Intelligence

Palantir Defense Ontology

[Palantir Defense Ontology] Categorized intelligence alongside its most critical metadata, such as its originating source system, location, and last updated time.

Properties

Confidence
integer
optional

[Palantir Defense Ontology] Used by intelligence-related object types to categorize the confidence of instances of intelligence as 1-5. Unique confidence systems must be normalized to fit the 1-5 numeric scale.

Id
string

[Palantir Defense Ontology] Unique identifier for the intelligence interface (Pk of the object)

Intelligence Discipline
string

[Palantir Defense Ontology] Used by intelligence-related object types to categorize intelligence, such as OPIR, IMINT, HUMINT, SIGINT, etc

Reported Timestamp
timestamp

[Palantir Defense Ontology] Used by intelligence-related interfaces to capture reported timestamp.

Reported Position
geohash
optional

[Palantir Defense Ontology] Used by intelligence-related interfaces to capture reported position

Extended interfaces

One To Many
optional

[Palantir Defense Ontology] One intelligence object may link to many entities.

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.Intelligence } 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.Intelligence>>> = await client(com.palantir.defense.ontology.Intelligence) .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 pages of Intelligence

Copied!
1 2 3 4 5 6 7 8 9 10 11 import { com.palantir.defense.ontology.Intelligence } 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.Intelligence>>> = await client(com.palantir.defense.ontology.Intelligence).fetchPageWithErrors({ $pageSize: 30 }); // To fetch a page without a result wrapper, use fetchPage instead const responseNoErrorWrapper: PageResult<Osdk<com.palantir.defense.ontology.Intelligence>> = await client(com.palantir.defense.ontology.Intelligence).fetchPage({ $pageSize: 30 });

Load all Intelligence

Copied!
1 2 3 4 5 6 7 8 9 10 11 import { com.palantir.defense.ontology.Intelligence } 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.Intelligence>[] = []; for await(const int of client(com.palantir.defense.ontology.Intelligence).asyncIter()) { interfaces.push(int); } const interface1 = interfaces[0];

Load ordered Intelligence

Copied!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 import { com.palantir.defense.ontology.Intelligence } 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.Intelligence>>> = await client(com.palantir.defense.ontology.Intelligence) .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.Intelligence } 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.Intelligence.OsdkInstance } = ... const subscription = client(com.palantir.defense.ontology.Intelligence).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.normalizedConfidence", "com.palantir.defense.ontology.intelligenceId", "com.palantir.defense.ontology.intelligenceDiscipline", "com.palantir.defense.ontology.reportedTimestamp", "com.palantir.defense.ontology.reportedPosition", ]} ); subscription.unsubscribe();

Load Intelligence metadata

Copied!
1 2 3 4 5 6 7 8 import { com.palantir.defense.ontology.Intelligence } 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.Intelligence); const implementingObjectTypes = interfaceTypeMetadata.implementedBy; const interfaceRid = interfaceTypeMetadata.rid;