Materiel Requirement

Palantir Defense Ontology

[Palantir Defense Ontology] Represents a specific requirement for materiel by a unit.

Properties

Quantity
integer

[Palantir Defense Ontology] An integer property type which captures quantity.

Timestamp
timestamp

[Palantir Defense Ontology] Captures the time of an event occurrence (human-readable format).

Is Active
boolean

[Palantir Defense Ontology] A boolean property type used to indicate whether or not a materiel requirement is currently active and relevant.

Unit Id
string

[Palantir Defense Ontology] String used to uniquely identify a unit.

Materiel Id
string

[Palantir Defense Ontology] A string property type which captures materiel ID.

Source System Id
string

[Palantir Defense Ontology] Identifies the source system from which a data point derives.

One To One
optional

[Palantir Defense Ontology] Links a materiel requirement to the unit that requires it.

One To One
optional

[Palantir Defense Ontology] Links a materiel requirement to the specific materiel item required.

One To One
optional

[Palantir Defense Ontology] Links a Materiel Requirement to the specific Materiel Type required.

Code snippets

TypeScript

Filtering

Copied!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 import { com.palantir.defense.ontology.MaterielRequirement } from "@osdk/defense-ontology"; // Edit this import if your client location differs import { client } from "./client"; import { isOk, type Osdk, type PageResult, type Result } from "@osdk/client"; const page: Result<PageResult<Osdk<com.palantir.defense.ontology.MaterielRequirement>>> = await client(com.palantir.defense.ontology.MaterielRequirement) .where({ $and:[ { $not: { someProperty: { $isNull: true }}}, { someProperty: { $eq: "foo" }} ] }) .fetchPageWithErrors({ $pageSize: 30 }); if (isOk(page)) { const interfaces = page.value.data; const interface1 = interfaces[0]; }

Load all Materiel Requirement

Copied!
1 2 3 4 5 6 7 8 9 10 11 import { com.palantir.defense.ontology.MaterielRequirement } from "@osdk/defense-ontology"; // Edit this import if your client location differs import { client } from "./client"; import type { Osdk } from "@osdk/client"; const interfaces: Osdk<com.palantir.defense.ontology.MaterielRequirement>[] = []; for await(const int of client(com.palantir.defense.ontology.MaterielRequirement).asyncIter()) { interfaces.push(int); } const interface1 = interfaces[0];

Load ordered Materiel Requirement

Copied!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 import { com.palantir.defense.ontology.MaterielRequirement } from "@osdk/defense-ontology"; // Edit this import if your client location differs import { client } from "./client"; import { isOk, type Osdk, type PageResult, type Result } from "@osdk/client"; const page: Result<PageResult<Osdk<com.palantir.defense.ontology.MaterielRequirement>>> = await client(com.palantir.defense.ontology.MaterielRequirement) .fetchPageWithErrors({ $orderBy: {"someProperty": "asc"}, $pageSize: 30 }); if (isOk(page)) { const interfaces = page.value.data; const interface1 = interfaces[0]; }

Subscribe to object sets

Copied!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 import { com.palantir.defense.ontology.MaterielRequirement } from "@osdk/defense-ontology"; // Edit this import if your client location differs import { client } from "./client"; // A map of primary keys to objects loaded through the SDK const objects: { [key: string]: com.palantir.defense.ontology.MaterielRequirement.OsdkInstance } = ... const subscription = client(com.palantir.defense.ontology.MaterielRequirement).subscribe( { onChange(update) { if (update.state === "ADDED_OR_UPDATED") { // An object has received an update or an object was added to the object set const currentObject = objects[update.object.$primaryKey]; if (currentObject !== undefined) { currentObject["<propertyName>"] = update.object["<propertyName>"] ?? currentObject["<propertyName>"]; } } else if (update.state === "REMOVED") { // The object was removed from the object set, which could mean it was deleted or no longer meets the filter criteria delete objects[update.object.$primaryKey]; } }, onSuccessfulSubscription() { // The subscription was successful and you can expect to receive updates }, onError(err) { // There was an error with the subscription and you will not receive any more updates console.error(err); }, onOutOfDate() { // We could not keep track of all changes. Please reload the objects in your set. }, }, { properties: [ "com.palantir.defense.ontology.quantity", "com.palantir.defense.ontology.timestamp", "com.palantir.defense.ontology.isActive", "com.palantir.defense.ontology.unitId", "com.palantir.defense.ontology.materielId", "com.palantir.defense.ontology.sourceSystemId", ]} ); subscription.unsubscribe();

Load pages of Materiel Requirement

Copied!
1 2 3 4 5 6 7 8 9 10 11 import { com.palantir.defense.ontology.MaterielRequirement } from "@osdk/defense-ontology"; // Edit this import if your client location differs import { client } from "./client"; import { type Osdk, type PageResult, type Result } from "@osdk/client"; const response: Result<PageResult<Osdk<com.palantir.defense.ontology.MaterielRequirement>>> = await client(com.palantir.defense.ontology.MaterielRequirement).fetchPageWithErrors({ $pageSize: 30 }); // To fetch a page without a result wrapper, use fetchPage instead const responseNoErrorWrapper: PageResult<Osdk<com.palantir.defense.ontology.MaterielRequirement>> = await client(com.palantir.defense.ontology.MaterielRequirement).fetchPage({ $pageSize: 30 });

Load Materiel Requirement metadata

Copied!
1 2 3 4 5 6 7 8 import { com.palantir.defense.ontology.MaterielRequirement } from "@osdk/defense-ontology"; // Edit this import if your client location differs import { client } from "./client"; const interfaceTypeMetadata = await client.fetchMetadata(com.palantir.defense.ontology.MaterielRequirement); const implementingObjectTypes = interfaceTypeMetadata.implementedBy; const interfaceRid = interfaceTypeMetadata.rid;