Entity and relationship queries
This query will allow you to run J1QL queries for fetching data. The GraphQL resolver requires that one parameter is provided:
query
: A J1QL query string that describes what data to return
Optionally, additional parameters can be provided:
variables
: AJSON
map of values to be used as parameters for the querycursor
: A token that can be exchanged to fetch the next page of information.includeDeleted
: When set totrue
, recently deleted information will be included in the results.deferredResponse
: This option allows for a deferred response to be returned. When a deferred response is returned, aurl
pointing the state of the query is provided. API consumers should poll the status of the deferred query by requesting the givenurl
until thestatus
property of the returned JSON document has a value ofCOMPLETED
(see example below). Upon completion of the query, theurl
will provide a link to the query results. The results contain the sametype
,data
, andcursor
fields that the non-deferred GraphQL response would contain. Allowed values areDISABLED
andFORCE
.flags
:computedProperties
: When set totrue
, vertices will be tagged with additional information to indicate if there are noteworthy traits that are worth surfacing.rowMetadata
: When set totrue
, table results will return metadata about the requested objects under a_meta
property.variableResultSize
: When set totrue
the API will return the largest result size possible. Without this flag, the result size will be limited to 250 rows. This flag is recommended for use in cases where a larger result size is preferable and an indeterminate/variable number of return results is acceptable.
scopeFilters
: An array ofJSON
map of filters that define the desired vertex. They have precedence over filters supplied in the query.
When working with additional variables, keep in mind some of the following considerations:
variableResultSize
can increase the rate of your pagination flow because the API will return the largest number of rows possible per request. The exact number of rows returned will not always be the same, but will be larger than the default -- hence the name, variable result size.When paging through data, it is highly recommended that cursors are leveraged instead of adding
limit
andskip
clauses to queries.Be sure to include
cursor
in the GraphQL response if you need to paginate through the results. The returnedcursor
will benull
if there are no more pages available.Queries that may take longer than 30 seconds should use the
FORCE
option fordeferredResponse
to avoid request timeouts. You should only use theDISABLED
option when testing a simple query. It is highly recommended that all automated processes use the theFORCE
option when issuing J1QL queries.
Example GraphQL query:
query J1QL($query: String!, $variables: JSON, $cursor: String, $scopeFilters: [JSON!], $flags: QueryV1Flags) {
queryV1(query: $query, variables: $variables, cursor: $cursor, scopeFilters: $scopeFilters, flags: $flags) {
type
data
cursor
}
}
Example variables:
{
"query": "find Person with _type=${type} return Person.name",
"variables": {
"type": "employee"
},
"cursor": "eyJjYWNoZUtleSI6IjFlNDg3MT...",
"scopeFilters": [
{
"org": "engineering"
}
],
"flags": {
"computedProperties": true
}
}
Example queryV1
resolver result:
{
"type": "table",
"data": [{ "Person.name": "Mochi" }],
"cursor": "eyJjYWNoZUtleSI6IjFlNDg3MT..."
}
Example GraphQL query with deferred responses:
query J1QL(
$query: String!
$variables: JSON
$cursor: String
$deferredResponse: DeferredResponseOption
) {
queryV1(
query: $query
variables: $variables
deferredResponse: $deferredResponse
cursor: $cursor
) {
type
url
}
}
Example variables:
{
"query": "find Person with _type=${type}",
"deferredResponse": "FORCE",
"variables": {
"type": "employee"
},
"cursor": "eyJjYWNoZUtleSI6IjFlNDg3MT..."
}
Example queryV1
resolver result when using a deferred response:
{
"type": "deferred",
"url": "https://example.com/state.json"
}
Example state responses:
{
"status": "IN_PROGRESS",
"correlationId": "912788f1-e0c7-43bd-b853-455c0031be8a"
}
{
"status": "COMPLETED",
"url": "https://example.com/results.json",
"correlationId": "912788f1-e0c7-43bd-b853-455c0031be8a"
}
Fetching Graph Data
You can use the following query to fetch graph data. The returned data includes the details of all vertices found on the graph, as well as the relationship edges that connect the vertices. Keep in mind that, currently, a canned query for IAM Role data is run. You do not need to provide any input variables.
query testQuery {
queryGraph {
vertices {
id
entity {
_id
_key
_type
_accountId
_integrationName
_integrationDefinitionId
_integrationInstanceId
_version
_createdOn
_beginOn
_endOn
_deleted
displayName
}
properties
}
edges {
id
toVertexId
fromVertexId
relationship {
_id
_key
_type
_accountId
_integrationName
_integrationDefinitionId
_integrationInstanceId
_version
_createdOn
_beginOn
_endOn
_deleted
_fromEntityKey
_toEntityKey
displayName
}
properties
}
}
}
Retrieving a Single Vertex by ID
This query fetches a vertex and its properties by its ID. The query requires one of two parameters:
id
: The ID as a stringfilters
: A set of filters that define the desired vertex.
The example below contains all of the currently available filters.
Only one of the variables (id
or filters
) is required. Specifying both is allowed but unnecessary unless you want to assert that a vertex with the specified id
exists and has specific entity properties.
query VertexQuery($id: String!, $filters: VertexFilters) {
vertex(id: $id, filters: $filters) {
id
entity {
_id
_key
_type
_accountId
_integrationName
_integrationDefinitionId
_integrationInstanceId
_version
_createdOn
_beginOn
_endOn
_deleted
displayName
}
properties
}
}
Variables:
{
"id": "<a vertex id>",
"filters": {
"_id": "<an entity id>",
"_key": "<an entity key>",
"_type": ["<a entity type>"],
"_class": ["<a entity class>"]
}
}
Fetching Neighbors of a Vertex
The Vertex
type allows you to retrieve vertex and edge neighbors up to a certain depth using the neighbors
field. The return type of the neighbors
resolver is the same as that of a graph query. This query requires two parameters:
id
: The ID of the vertex as a stringdepth
: An integer specifying how many "levels" deep the query will go to look for neighbors.
query VertexQuery($id: String!, $depth: Int) {
vertex(id: $id) {
id
entity {
displayName
}
neighbors(depth: $depth) {
vertices {
id
entity {
displayName
}
}
edges {
id
relationship {
displayName
}
}
}
}
}
Variables:
The depth that is supplied must be a value between 1 and 5 (inclusive).
{
"id": "<a vertex id>",
"depth": 5
}
Retrieving an Edge by ID
This query allows you to fetch an edge, its properties, and the relationship it describes by its ID or label and filters. The query requires one or two of three parameters:
id
: The ID as a string.label
: The label displayed on the edge.filters
: A set of filters that define the desired vertex.
Only one of the variables (id
, label
, or filters
) is required. Specifying label
and filters
with id
is allowed but somewhat redundant unless you want to assert that a vertex with the specified id
exists and has the specific label and properties.
The example below contains all of the currently available filters.
query VertexQuery($id: String!) {
edge(id: $id, label: $id, filters: $id) {
id
relationship {
_id
_key
_type
_accountId
_integrationName
_integrationDefinitionId
_integrationInstanceId
_version
_createdOn
_beginOn
_endOn
_deleted
_fromEntityKey
_toEntityKey
displayName
}
properties
}
}
Variables:
{
"id": "<an edge id>",
"label": "<edge label>",
"filters": {
"_id": "<a relationship id>",
"_key": "<a relationship key>",
"_type": "<a relationship type>",
"_class": "<a relationship class>"
}
}
Fetching the Count of Entities Via a _type and/or _class
This query allows you to fetch the count of entities. The _id
, _key
, _type
, or _class
fields can be supplied as filters. This query only counts the latest versions of entities matching the filter criteria. This query requires two parameters:
filters
: A set of vertex filters that describe the entities that are to be returned.filterType
: AFilterType
(AND
orOR
).
If OR
is specified as the filter type, any entity that has any class in the filter will be included in the count. By default, the query uses AND
, which only includes entities that have all of the specified classes in the count.
This resolver uses the JSON
scalar as the return type:
query testQuery($filters: VertexFilters, $filterType: FilterType) {
entityCount(filters: $filters, filterType: $filterType)
}
Use field aliases to request the counts of multiple different entities:
query testQuery {
Users: entityCount(filters: { _class: ["User"] }, filterType: "AND")
Repos: entityCount(filters: { _class: ["CodeRepo"] }, filterType: "OR")
}
Example result:
{
"User": 40,
"CodeRepo": 153
}
Fetching the Count of All Types and Classes
This query returns the entity counts for all types and classes. The following resolver uses the JSON
scalar as the return type:
query testQuery {
allEntityCounts
}
Example result:
{
"typeCounts": {
"iam_user": 12,
"iam_managed_policy": 10,
"iam_role_policy": 10
},
"classCounts": {
"User": 12,
"AccessPolicy": 20
}
}
Fetching the Count of All Types With a Set of Classes
The query below returns all types that have the specified classes. The query requires two parameters:
classes
: An array of strings detailing which classes should be returned.filterType
: AFilterType
(AND
orOR
).
If OR
is specified as the filter type, any entity that has any class in the filter will be included in the count. By default, the query uses AND
, which only includes entities that have all of the specified classes in the count.
This resolver uses the JSON
scalar as the return type:
query testQuery ($classes: [String], filterType: FilterType) {
typeCounts (classes: $classes, filterType: $filterType)
}
Example result:
{
"iam_user": 12,
"iam_managed_policy": 10,
"iam_role_policy": 10
}
Listing Entities Via a _type and/or _class
For fetching entities with specified filters. The _id
, _key
, _type
and _class
fields can be included in a J1QL query request.
This query has a deferred response flow and needs to be completed in three parts.
Start the query
query QueryAlpha($query: String!, $includeDeleted: Boolean, $cursor: String, $returnRowMetadata: Boolean) {
queryAlpha(
query: $query
includeDeleted: $includeDeleted
cursor: $cursor
returnRowMetadata: $returnRowMetadata
) {
type
url
correlationId
__typename
}
}
Variables:
{
"query": "Find * WITH _class = 'User' OR _type = 'jupiterone_user'",
"includeDeleted": false,
"returnRowMetadata": true,
}
Example result:
{
"data": {
"queryAlpha": {
"type": "deferred",
"url": "https://results.dev.jupiterone.io/j1ql/8d236bfd-bb30-/22c963da-0dbb",
"correlationId": "c64fb3e8-b7c3-400b",
"__typename": "DeferredResponse"
}
}
}
Poll for query completion
Use the url
returned from the previous call to check for query completion.
Example result:
{
"status": "COMPLETED",
"url": "https://download.dev.jupiterone.io/temp%2F8d236bfd-bb30-475f-9ae3-d39e1af9a13d%2Fdeferred%2F83212710-8c3b-49ef?token=eyJma...",
"correlationId": "c64fb3e8-b7c3-400b-858a-22df648a4fe8"
}
Fetch the results
Use the url
returned from the pervious query to fetch the actual results.
Example result:
{
"type": "list",
"data": [
{
"id": "363ac110-b4869",
"entity": {
"_beginOn": "2023-10-16T14:32:44.776Z",
"displayName": "3744bd25-f74b",
"_class": [
"User"
],
"_version": 21,
"_scope": "jupiterone",
"_accountId": "8d236bfd-bb30",
"_id": "29079c31-db28",
"_key": "jupiterone_user:3744bd25-f74b",
"_type": [
"jupiterone_user"
],
"_deleted": false,
"_source": "system-internal",
"_createdOn": "2023-10-04T20:49:46.807Z"
},
"properties": {
"id": "3744bd25-f74b",
"status": "ENABLED",
"createdOn": "2022-11-28T17:37:02.059Z",
"username": "3744bd25-f74b",
"email": "the.person@jupiterone.com",
"name": "3744bd25-f74b",
"givenName": "The",
"familyName": "Person",
"picture": "https://lh3.googleusercontent.com/a/AGNmyxaPpq_PLOKI",
"mfaEnabled": false,
"emailVerified": true,
"active": true,
"type": "user"
}
}
],
"totalCount": 1
}