The following rules MUST be applied by implementers of TRAPI endpoints. The rules are organized by class and property.
The terms MUST, SHOULD, MAY are used as defined in RFC 2119 https://tools.ietf.org/html/rfc2119
- Knowledge Providers (KPs) MAY implement /asyncquery
- Autonomous Reasoning Agents (ARAs) SHOULD implement /asyncquery
- The /asyncquery endpoint SHOULD be left in an OpenAPI definition for a TRAPI endpoint even if if it is not implemented, since it is part of the TRAPI core schema
- Each TRAPI server MUST indicate with true or false if the /asyncquery endpoint is implemented by the server via the x-trapi asyncquery property as found in the TRAPI core schema template.
- MAY be null, or MAY be missing. The meaning is the same.
- MUST NOT be an empty array (#199)
- If more than one element is present, the elements MUST be treated in the sense of an "or" list. This effectively creates a simple batch query mechanism.
- The list SHOULD NOT be used by the client to provide equivalent CURIEs to the server
- If the server considers a subset of items in the list as equivalent CURIEs, the server SHOULD merge the subset into a single KnowledgeGraph Node
- MAY be null, or MAY be missing. The meaning is the same: matching Nodes may be any category
- If QNode.categories is [ 'biolink:NamedThing' ], it means matching Nodes may be any category (any descendent biolink category NamedThing)
- MUST NOT be an empty array (#199)
- If more than one element is present, the elements MUST be treated in the sense of an "or" list. Matching Nodes may be any of the listed QNode.categories
- Biolink category descendents do not need to be specified separately. Queries MUST automatically match descendents. (e.g. QNode.categories is [ 'biolink:BiologicalEntity' ], then the KP MUST return Nodes with category biolink:Protein and biolink:Disease if present)
- IF a QNode has non-null QNode.ids (CURIEs), the client SHOULD NOT provide QNode.categories, and the server SHOULD NOT require that categories are provided to function, and the server MAY provide different answers for different provided categories.
- MAY be null, or MAY be missing. The meaning is the same.
- MUST NOT be an empty array (#199)
- If more than one element is present, the elements MUST be treated in the sense of an "or" list. Matching Edges may be any of the listed QEdge.predicates. This effectively creates a simple batch query mechanism where the response may contain multiple edges, where each one matches at least one of the specified QEdge.predicates.
- Biolink predicate descendents do not need to be specified separately. Queries MUST automatically match descendents. (e.g. QEdge.predicates is [ 'biolink:regulates' ], then the KP MUST return Edges with biolink:positively_regulates and biolink:negatively_regulates if present)
- Server SHOULD generate a warning and MAY continue
- Server SHOULD generate a warning and MAY continue
- If a KP server receives any QNode.constraints, if it does not support all of them, it MUST immediately respond with an error Code "UnsupportedConstraint" and list all constraint names that it does not support.
- If an ARA server receives any QNode.constraints, it MUST perform one of the following:
- Relay all constraints to its KP(s) to satisfy
- Withhold one or more constraints from its KP queries and satisfy those constraints itself
- An ARA server MUST ensure that all constraints are satisifed by either trusting its KPs to satisfy them or by performing the constraints itself. If the ARA cannot ensure this, it MUST immediately respond with an error Code "UnsupportedConstraint" and list all constraint names that it does not support.