-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathTranslatorReasonerAPI.yaml
1157 lines (1157 loc) · 45.4 KB
/
TranslatorReasonerAPI.yaml
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
openapi: 3.0.1
info:
description: INSERT-DESCRIPTION-OF-YOUR-SERVICE-HERE
version: INSERT-VERSION-OF-YOUR-SERVICE-HERE
title: INSERT-TITLE-OF-YOUR-SERVICE-HERE
contact:
email: INSERT@EMAIL-ADDRESS-OF-IMPLEMENTER-HERE.ORG
license:
name: Apache 2.0
url: http://www.apache.org/licenses/LICENSE-2.0.html
termsOfService: INSERT-URL-HERE
x-translator:
component: INSERT-EITHER-ARA-OR-KP-OR-ARS-OR-Utility-HERE
team:
- INSERT-ONE-TRANSLATOR-TEAM-NAME-PER-ELEMENT-HERE
biolink-version: INSERT-BIOLINK-MODEL-VERSION-HERE
infores: INSERT-INFORES-CURIE-OF-THIS-RESOURCE-HERE
externalDocs:
description: >-
The values for component and team are restricted according to this
external JSON schema. See schema and examples at url
url: https://github.com/NCATSTranslator/translator_extensions/blob/\
production/x-translator/
x-trapi:
version: 1.3.0
asyncquery: REPLACE-WITH-true-IF-/asyncquery-IS-IMPLEMENTED-ELSE-false
operations:
- LIST-ALL-SUPPORTED-OPERATION-IDS-HERE-OR-REMOVE-THIS-SECTION
batch_size_limit: ADD-BATCH-SIZE-LIMIT-OR-REMOVE-IF-NO-LIMIT
rate_limit: ADD-REQUEST-RATE-LIMIT-OR-REMOVE-IF-NO-LIMIT
test_data_location: ADD-URL-THAT-RESOLVES-TO-SRI-TESTING-HARNESS-DATA
externalDocs:
description: >-
The values for version are restricted according to the regex in
this external JSON schema. See schema and examples at url
url: https://github.com/NCATSTranslator/translator_extensions/blob/\
production/x-trapi/
servers:
- url: INSERT-URL-HERE
description: INSERT-SERVER-DESCRIPTION-HERE
externalDocs:
description: >-
Documentation for the NCATS Biomedical Translator Reasoners web services
url: https://github.com/NCATSTranslator/ReasonerAPI
tags:
- name: meta_knowledge_graph
description: >-
Retrieve the meta knowledge graph representation of this
TRAPI web service. KPs MUST provide all subject category - predicate -
object category triplets that are supported by the service,
NOT including all implied ancestor relationships. ARAs SHOULD provide
the union of all meta knowledge graphs of all the KPs that they can
consult.
externalDocs:
description: >-
Documentation for the reasoner meta_knowledge_graph function
url: INSERT-URL-HERE-OR-REMOVE-EXTERNALDOCS-IF-NA
- name: query
description: Initiate a query and wait to receive the response
externalDocs:
description: Documentation for the reasoner query function
url: INSERT-URL-HERE-OR-REMOVE-EXTERNALDOCS-IF-NA
- name: asyncquery
description: Initiate a query with a callback to receive the response
externalDocs:
description: Documentation for the reasoner asynchquery function
url: INSERT-URL-HERE-OR-REMOVE-EXTERNALDOCS-IF-NA
- name: translator
description: Required for SmartAPI validation of x-translator
- name: trapi
description: Required for SmartAPI validation of x-trapi
paths:
/meta_knowledge_graph:
get:
tags:
- meta_knowledge_graph
summary: Meta knowledge graph representation of this TRAPI web service.
responses:
'200':
description: >-
Returns meta knowledge graph representation of this TRAPI web
service.
content:
application/json:
schema:
$ref: '#/components/schemas/MetaKnowledgeGraph'
/query:
post:
tags:
- query
summary: Initiate a query and wait to receive a Response
description: ''
requestBody:
description: Query information to be submitted
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/Query'
responses:
'200':
description: >-
OK. There may or may not be results. Note that some of the provided
identifiers may not have been recognized.
content:
application/json:
schema:
$ref: '#/components/schemas/Response'
'400':
description: >-
Bad request. The request is invalid according to this OpenAPI
schema OR a specific identifier is believed to be invalid somehow
(not just unrecognized).
content:
application/json:
schema:
type: string
'413':
description: >-
Payload too large. Indicates that batch size was over the limit
specified in x-trapi.
content:
application/json:
schema:
type: string
'429':
description: >-
Too many requests. Indicates that the client issued requests that
exceed the rate limit specified in x-trapi.
content:
application/json:
schema:
type: string
'500':
description: >-
Internal server error.
content:
application/json:
schema:
type: string
'501':
description: >-
Not implemented.
content:
application/json:
schema:
type: string
/asyncquery:
post:
tags:
- asyncquery
summary: Initiate a query with a callback to receive the response
description: ''
requestBody:
description: Query information to be submitted
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/AsyncQuery'
responses:
'200':
description: >-
The query is accepted for processing and the Response will be
sent to the callback url when complete.
content:
application/json:
schema:
type: string
'400':
description: >-
Bad request. The request is invalid according to this OpenAPI
schema OR a specific identifier is believed to be invalid somehow
(not just unrecognized).
content:
application/json:
schema:
type: string
'413':
description: >-
Payload too large. Indicates that batch size was over the limit
specified in x-trapi.
content:
application/json:
schema:
type: string
'429':
description: >-
Too many requests. Indicates that the client issued requests that
exceed the rate limit specified in x-trapi.
content:
application/json:
schema:
type: string
'500':
description: >-
Internal server error.
content:
application/json:
schema:
type: string
'501':
description: >-
Not implemented.
content:
application/json:
schema:
type: string
components:
schemas:
Query:
description: >-
The Query class is used to package a user request for information. A
Query object consists of a required Message object with optional
additional properties. Additional properties are intended to convey
implementation-specific or query-independent parameters. For example,
an additional property specifying a log level could allow a user to
override the default log level in order to receive more fine-grained
log information when debugging an issue.
x-body-name: request_body
type: object
properties:
message:
$ref: '#/components/schemas/Message'
description: >-
The query Message is a serialization of the user request. Content
of the Message object depends on the intended TRAPI operation. For
example, the fill operation requires a non-empty query_graph field
as part of the Message, whereas other operations, e.g. overlay,
require non-empty results and knowledge_graph fields.
log_level:
description: The least critical level of logs to return
allOf:
- $ref: '#/components/schemas/LogLevel'
nullable: true
workflow:
description: List of workflow steps to be executed.
allOf:
- $ref: http://standards.ncats.io/workflow/1.0.0/schema
nullable: true
submitter:
type: string
description: >-
Any string for self-identifying the submitter of a query. The
purpose of this optional field is to aid in the tracking of
the source of queries for development and issue resolution.
nullable: true
additionalProperties: true
required:
- message
AsyncQuery:
description: >-
The AsyncQuery class is effectively the same as the Query class but
it requires a callback property.
x-body-name: request_body
type: object
properties:
callback:
type: string
format: uri
pattern: ^https?://
description: >-
Upon completion, this server will send a POST request to the
callback URL with `Content-Type: application/json` header and
request body containing a JSON-encoded `Response` object.
The server MAY POST `Response` objects before work is fully
complete to provide interim results with a Response.status
value of 'Running'. If a POST operation to the callback URL
does not succeed, the server SHOULD retry the POST at least
once.
message:
$ref: '#/components/schemas/Message'
description: >-
The query Message is a serialization of the user request. Content
of the Message object depends on the intended TRAPI operation. For
example, the fill operation requires a non-empty query_graph field
as part of the Message, whereas other operations, e.g. overlay,
require non-empty results and knowledge_graph fields.
log_level:
description: The least critical level of logs to return
allOf:
- $ref: '#/components/schemas/LogLevel'
nullable: true
workflow:
description: List of workflow steps to be executed.
allOf:
- $ref: http://standards.ncats.io/workflow/1.0.0/schema
nullable: true
submitter:
type: string
description: >-
Any string for self-identifying the submitter of a query. The
purpose of this optional field is to aid in the tracking of
the source of queries for development and issue resolution.
nullable: true
additionalProperties: true
required:
- callback
- message
Response:
type: object
description: >-
The Response object contains the main payload when a TRAPI query
endpoint interprets and responds to the submitted query successfully
(i.e., HTTP Status Code 200). The message property contains the
knowledge of the response (query graph, knowledge graph, and results).
The status, description, and logs properties provide additional details
about the response.
properties:
message:
description: >-
Contains the knowledge of the response (query graph, knowledge
graph, and results).
$ref: '#/components/schemas/Message'
status:
description: >-
One of a standardized set of short codes,
e.g. Success, QueryNotTraversable, KPsNotAvailable
type: string
example: Success
nullable: true
description:
description: A brief human-readable description of the outcome
type: string
example: Success. 42 results found.
nullable: true
logs:
description: >-
Log entries containing errors, warnings, debugging information, etc
type: array
items:
$ref: '#/components/schemas/LogEntry'
nullable: true
workflow:
description: List of workflow steps that were executed.
allOf:
- $ref: http://standards.ncats.io/workflow/1.0.0/schema
nullable: true
additionalProperties: true
required:
- message
Message:
description: >-
The message object holds the main content of a Query or a Response in
three properties: query_graph, results, and knowledge_graph.
The query_graph property contains the query configuration, the results
property contains any answers that are returned by the service,
and knowledge_graph property contains lists of edges and nodes in the
thought graph corresponding to this message. The content of these
properties is context-dependent to the encompassing object and
the TRAPI operation requested.
type: object
properties:
results:
description: >-
List of all returned Result objects for the query posed.
The list SHOULD NOT be assumed to be ordered. The 'score' property,
if present, MAY be used to infer result rankings.
type: array
items:
$ref: '#/components/schemas/Result'
nullable: true
query_graph:
description: >-
QueryGraph object that contains a serialization of a query in the
form of a graph
allOf:
- $ref: '#/components/schemas/QueryGraph'
nullable: true
knowledge_graph:
description: >-
KnowledgeGraph object that contains lists of nodes and edges
in the thought graph corresponding to the message
allOf:
- $ref: '#/components/schemas/KnowledgeGraph'
nullable: true
additionalProperties: false
LogEntry:
description: >-
The LogEntry object contains information useful for tracing
and debugging across Translator components. Although an
individual component (for example, an ARA or KP) may have its
own logging and debugging infrastructure, this internal
information is not, in general, available to other components.
In addition to a timestamp and logging level, LogEntry
includes a string intended to be read by a human, along with
one of a standardized set of codes describing the condition of
the component sending the message.
type: object
properties:
timestamp:
type: string
format: date-time
description: Timestamp in ISO 8601 format
example: '2020-09-03T18:13:49+00:00'
nullable: true
level:
allOf:
- $ref: '#/components/schemas/LogLevel'
nullable: true
code:
type: string
description: >-
One of a standardized set of short codes
e.g. QueryNotTraversable, KPNotAvailable, KPResponseMalformed
nullable: true
message:
type: string
description: A human-readable log message
nullable: true
additionalProperties: true
LogLevel:
type: string
description: Logging level
enum:
- ERROR
- WARNING
- INFO
- DEBUG
Result:
type: object
description: >-
A Result object specifies the nodes and edges in the knowledge graph
that satisfy the structure or conditions of a user-submitted query
graph. It must contain a NodeBindings object (list of query graph node
to knowledge graph node mappings) and an EdgeBindings object (list of
query graph edge to knowledge graph edge mappings).
properties:
node_bindings:
type: object
description: >-
The dictionary of Input Query Graph to Result Knowledge Graph node
bindings where the dictionary keys are the key identifiers of the
Query Graph nodes and the associated values of those keys are
instances of NodeBinding schema type (see below). This value is an
array of NodeBindings since a given query node may have multiple
knowledge graph Node bindings in the result.
additionalProperties:
type: array
items:
$ref: '#/components/schemas/NodeBinding'
edge_bindings:
type: object
description: >-
The dictionary of Input Query Graph to Result Knowledge Graph edge
bindings where the dictionary keys are the key identifiers of the
Query Graph edges and the associated values of those keys are
instances of EdgeBinding schema type (see below). This value is an
array of EdgeBindings since a given query edge may resolve to
multiple knowledge graph edges in the result.
additionalProperties:
type: array
items:
$ref: '#/components/schemas/EdgeBinding'
score:
type: number
format: float
example: 163.233
description: >-
A numerical score associated with this result indicating the
relevance or confidence of this result relative to others in the
returned set. Higher MUST be better.
nullable: true
additionalProperties: true
required:
- node_bindings
- edge_bindings
NodeBinding:
type: object
description: >-
An instance of NodeBinding is a single KnowledgeGraph Node mapping,
identified by the corresponding 'id' object key identifier of the
Node within the Knowledge Graph. Instances of NodeBinding may
include extra annotation in the form of additional properties.
(such annotation is not yet fully standardized).
properties:
id:
$ref: '#/components/schemas/CURIE'
description: >-
The CURIE of a Node within the Knowledge Graph.
query_id:
$ref: '#/components/schemas/CURIE'
description: >-
An optional property to provide the CURIE in the QueryGraph to
which this binding applies. If the bound QNode does not have an
an 'id' property or if it is empty, then this query_id MUST be
null or absent. If the bound QNode has one or more CURIEs
as an 'id' and this NodeBinding's 'id' refers to a QNode 'id'
in a manner where the CURIEs are different (typically due to
the NodeBinding.id being a descendant of a QNode.id), then
this query_id MUST be provided. In other cases, there is no
ambiguity, and this query_id SHOULD NOT be provided.
attributes:
type: array
description: >-
A list of attributes providing further information about the
node binding. This is not intended for capturing node attributes
and should only be used for properties that vary from result to
result.
items:
$ref: '#/components/schemas/Attribute'
nullable: true
additionalProperties: true
required:
- id
EdgeBinding:
type: object
description: >-
A instance of EdgeBinding is a single KnowledgeGraph Edge mapping,
identified by the corresponding 'id' object key identifier of the
Edge within the Knowledge Graph. Instances of EdgeBinding may include
extra annotation (such annotation is not yet fully standardized).
properties:
id:
type: string
description: The key identifier of a specific KnowledgeGraph Edge.
attributes:
type: array
description: >-
A list of attributes providing further information about the
edge binding. This is not intended for capturing edge attributes
and should only be used for properties that vary from result to
result.
items:
$ref: '#/components/schemas/Attribute'
nullable: true
additionalProperties: true
required:
- id
KnowledgeGraph:
type: object
description: >-
The knowledge graph associated with a set of results. The instances
of Node and Edge defining this graph represent instances of
biolink:NamedThing (concept nodes) and biolink:Association
(relationship edges) representing (Attribute) annotated knowledge
returned from the knowledge sources and inference agents wrapped by
the given TRAPI implementation.
properties:
nodes:
type: object
description: >-
Dictionary of Node instances used in the KnowledgeGraph,
referenced elsewhere in the TRAPI output by the dictionary key.
additionalProperties:
$ref: '#/components/schemas/Node'
edges:
type: object
description: >-
Dictionary of Edge instances used in the KnowledgeGraph,
referenced elsewhere in the TRAPI output by the dictionary key.
additionalProperties:
$ref: '#/components/schemas/Edge'
additionalProperties: true
required:
- nodes
- edges
QueryGraph:
type: object
description: >-
A graph representing a biomedical question. It serves as a template for
each result (answer), where each bound knowledge graph node/edge is
expected to obey the constraints of the associated query graph element.
properties:
nodes:
type: object
description: >-
The node specifications. The keys of this map are unique node
identifiers and the corresponding values include the constraints
on bound nodes.
additionalProperties:
$ref: '#/components/schemas/QNode'
edges:
type: object
description: >-
The edge specifications. The keys of this map are unique edge
identifiers and the corresponding values include the constraints
on bound edges, in addition to specifying the subject and object
QNodes.
additionalProperties:
$ref: '#/components/schemas/QEdge'
additionalProperties: true
required:
- nodes
- edges
QNode:
type: object
description: A node in the QueryGraph used to represent an entity in a
query. If a CURIE is not specified, any nodes matching the category
of the QNode will be returned in the Results.
properties:
ids:
type: array
items:
$ref: '#/components/schemas/CURIE'
minItems: 1
example: [OMIM:603903]
description: CURIE identifier for this node
nullable: true
categories:
type: array
items:
$ref: '#/components/schemas/BiolinkEntity'
minItems: 1
nullable: true
is_set:
type: boolean
description: >-
Boolean that if set to true, indicates that this QNode MAY have
multiple KnowledgeGraph Nodes bound to it within each Result.
The nodes in a set should be considered as a set of independent
nodes, rather than a set of dependent nodes, i.e., the answer
would still be valid if the nodes in the set were instead returned
individually. Multiple QNodes may have is_set=True. If a QNode
(n1) with is_set=True is connected to a QNode (n2) with
is_set=False, each n1 must be connected to n2. If a QNode (n1)
with is_set=True is connected to a QNode (n2) with is_set=True,
each n1 must be connected to at least one n2.
default: false
constraints:
type: array
description: >-
A list of contraints applied to a query node.
If there are multiple items, they must all be true (equivalent
to AND)
items:
$ref: '#/components/schemas/AttributeConstraint'
default: []
additionalProperties: true
QEdge:
type: object
description: >-
An edge in the QueryGraph used as an filter pattern specification in a
query. If the optional predicate property is not specified,
it is assumed to be a wildcard match to the target knowledge space.
If specified, the ontological inheritance hierarchy associated with
the term provided is assumed, such that edge bindings returned may be
an exact match to the given QEdge predicate term,
or to a term that is a descendant of the QEdge predicate term.
properties:
knowledge_type:
description: >-
Indicates the type of knowledge that the client wants from the
server between the subject and object. If the value is
'lookup', then the client wants direct lookup information from
knowledge sources. If the value is 'inferred', then the client
wants the server to get creative and connect the subject and
object in more speculative and non-direct-lookup ways. If this
property is absent or null, it MUST be assumed to mean
'lookup'. This feature is currently experimental and may be
further extended in the future.
example: lookup
nullable: true
type: string
predicates:
type: array
items:
$ref: '#/components/schemas/BiolinkPredicate'
minItems: 1
nullable: true
subject:
type: string
example: https://omim.org/entry/603903
description: >-
Corresponds to the map key identifier of the
subject concept node anchoring the query filter
pattern for the query relationship edge.
object:
type: string
example: https://www.uniprot.org/uniprot/P00738
description: >-
Corresponds to the map key identifier of the
object concept node anchoring the query filter
pattern for the query relationship edge.
attribute_constraints:
type: array
description: >-
A list of attribute contraints applied to a query edge.
If there are multiple items, they must all be true (equivalent
to AND)
items:
$ref: '#/components/schemas/AttributeConstraint'
default: []
qualifier_constraints:
type: array
description: >-
A list of QualifierConstraints that provide nuance to the QEdge.
If multiple QualifierConstraints are provided, there is an OR
relationship between them. If the QEdge has multiple
predicates or if the QNodes that correspond to the subject or
object of this QEdge have multiple categories or multiple
curies, then qualifier_constraints MUST NOT be specified
because these complex use cases are not supported at this time.
items:
$ref: '#/components/schemas/QualifierConstraint'
default: []
additionalProperties: true
required:
- subject
- object
Node:
type: object
description: >-
A node in the KnowledgeGraph which represents some biomedical
concept. Nodes are identified by the keys in the KnowledgeGraph
Node mapping.
properties:
name:
type: string
example: Haptoglobin
description: Formal name of the entity
nullable: true
categories:
type: array
items:
$ref: '#/components/schemas/BiolinkEntity'
nullable: true
attributes:
type: array
description: A list of attributes describing the node
items:
$ref: '#/components/schemas/Attribute'
nullable: true
additionalProperties: false
Attribute:
type: object
description: >-
Generic attribute for a node or an edge that expands the key-value
pair concept by including fields for additional metadata. These fields
can be used to describe the source of the statement made in a key-value
pair of the attribute object, or describe the attribute's value itself
including its semantic type, or a url providing additional information
about it. An attribute may be further qualified with sub-attributes
(for example to provide confidence intervals on a value).
properties:
attribute_type_id:
$ref: '#/components/schemas/CURIE'
description: >-
The 'key' of the attribute object, holding a CURIE of an ontology
property defining the attribute (preferably the CURIE of a
Biolink association slot). This property captures the relationship
asserted to hold between the value of the attribute, and the node
or edge from which it hangs. For example, that a value of
'0.000153' represents a p-value supporting an edge, or that
a value of 'ChEMBL' represents the original source of the knowledge
expressed in the edge.
example: biolink:synonym
original_attribute_name:
type: string
description: >-
The term used by the original source of an attribute to describe
the meaning or significance of the value it captures. This may be
a column name in a source tsv file, or a key in a source json
document for the field in the data that held the attribute's
value. Capturing this information where possible lets us preserve
what the original source said. Note that the data type is string'
but the contents of the field could also be a CURIE of a third
party ontology term.
example: p-value
nullable: true
value:
description: >-
Value of the attribute. May be any data type, including a list.
example: 0.000153
value_type_id:
allOf:
- $ref: '#/components/schemas/CURIE'
description: >-
CURIE describing the semantic type of an attribute's value. Use
a Biolink class if possible, otherwise a term from an external
ontology. If a suitable CURIE/identifier does not exist, enter a
descriptive phrase here and submit the new type for consideration
by the appropriate authority.
example: EDAM:data_1187
nullable: true
attribute_source:
type: string
description: >-
The source of the core assertion made by the key-value pair of an
attribute object. Use a CURIE or namespace designator for this
resource where possible.
example: UniProtKB
nullable: true
value_url:
type: string
description: >-
Human-consumable URL linking to a web document that provides
additional information about an attribute's value (not the node
or the edge fom which it hangs).
example: https://pubmed.ncbi.nlm.nih.gov/32529952
nullable: true
description:
type: string
description: >-
Human-readable description for the attribute and its value.
example: Assertion Authored By Dr. Trans L. Ator
nullable: true
attributes:
type: array
description: >-
A list of attributes providing further information about the
parent attribute (for example to provide provenance
information about the parent attribute).
items:
$ref: '#/components/schemas/Attribute'
nullable: true
required:
- attribute_type_id
- value
additionalProperties: false
Edge:
type: object
description: >-
A specification of the semantic relationship linking two concepts
that are expressed as nodes in the knowledge "thought" graph
resulting from a query upon the underlying knowledge source.
properties:
predicate:
allOf:
- $ref: '#/components/schemas/BiolinkPredicate'
nullable: true
subject:
$ref: '#/components/schemas/CURIE'
example: OMIM:603903
description: >-
Corresponds to the map key CURIE of the
subject concept node of this relationship edge.
object:
$ref: '#/components/schemas/CURIE'
example: UniProtKB:P00738
description: >-
Corresponds to the map key CURIE of the
object concept node of this relationship edge.
attributes:
type: array
description: A list of additional attributes for this edge
items:
$ref: '#/components/schemas/Attribute'
nullable: true
qualifiers:
type: array
description: >-
A set of Qualifiers that act together to add nuance
or detail to the statement expressed in an Edge.
items:
$ref: '#/components/schemas/Qualifier'
nullable: true
additionalProperties: false
required:
- subject
- object
Qualifier:
additionalProperties: false
description: >-
An additional nuance attached to an assertion
type: object
properties:
qualifier_type_id:
type: string
description: >-
The category of the qualifier, drawn from a hierarchy of qualifier
slots in the Biolink model (e.g. subject_aspect, subject_direction,
object_aspect, object_direction, etc).
example: subject_aspect
nullable: false
qualifier_value:
type: string
description: >-
The value associated with the type of the qualifier, drawn from
a set of controlled values by the type as specified in
the Biolink model (e.g. 'expression' or 'abundance' for the
qualifier type 'subject_aspect', etc).
example: expression
nullable: false
required:
- qualifier_type_id
- qualifier_value
QualifierConstraint:
additionalProperties: false
description: >-
Defines a query constraint based on the
qualifier_types and qualifier_values of a set of
Qualifiers attached to an edge. For example, it can constrain a
"ChemicalX - affects - ?Gene" query to return only edges where
ChemicalX specifically affects the 'expression' of the Gene,
by constraining on the qualifier_type "object_aspect" with
a qualifier_value of "expression".
properties:
qualifier_set:
type: array
description: >-
A set of Qualifiers that serves to add nuance to a query,
by constraining allowed values held by Qualifiers
on queried Edges.
items:
$ref: '#/components/schemas/Qualifier'
nullable: false
required:
- qualifier_set
type: object
BiolinkEntity:
description: >-
Compact URI (CURIE) for a Biolink class, biolink:NamedThing
or a child thereof. The CURIE must use the prefix 'biolink:'
followed by the PascalCase class name.
type: string
pattern: ^biolink:[A-Z][a-zA-Z]*$
externalDocs:
description: Biolink model entities
url: https://biolink.github.io/biolink-model/docs/NamedThing.html
example: biolink:PhenotypicFeature
BiolinkPredicate:
description: >-
CURIE for a Biolink 'predicate' slot, taken from the Biolink slot
('is_a') hierarchy rooted in biolink:related_to (snake_case). This
predicate defines the Biolink relationship between the subject and
object nodes of a biolink:Association defining a knowledge graph edge.
type: string
pattern: ^biolink:[a-z][a-z_]*$
externalDocs:
description: Biolink model predicates
url: https://biolink.github.io/biolink-model/docs/related_to.html
example: biolink:interacts_with
CURIE:
type: string
description: >-
A Compact URI, consisting of a prefix and a reference separated
by a colon, such as UniProtKB:P00738. Via an external context
definition, the CURIE prefix and colon may be replaced by a URI
prefix, such as http://identifiers.org/uniprot/, to form a full
URI.
externalDocs:
url: https://www.w3.org/TR/2010/NOTE-curie-20101216/
MetaKnowledgeGraph:
type: object
description: >-
Knowledge-map representation of this TRAPI web service. The meta
knowledge graph is composed of the union of most specific categories
and predicates for each node and edge.
properties:
nodes:
type: object
description: >-
Collection of the most specific node categories provided by
this TRAPI web service, indexed by Biolink class CURIEs.
A node category is only exposed here if there is
node for which that is the most specific category available.
additionalProperties:
$ref: '#/components/schemas/MetaNode'
edges:
type: array
description: >-
List of the most specific edges/predicates provided by this TRAPI
web service. A predicate is only exposed here if there is an edge
for which the predicate is the most specific available.
items:
$ref: '#/components/schemas/MetaEdge'
required:
- nodes
- edges
MetaNode:
type: object
description: >-
Description of a node category provided by this TRAPI web service.
properties:
id_prefixes:
type: array
description: >-
List of CURIE prefixes for the node category that this TRAPI web
service understands and accepts on the input.
items:
type: string
minItems: 1
example: [CHEMBL.COMPOUND, INCHIKEY]
attributes:
type: array
description: >-
Node attributes provided by this TRAPI web service.
items:
$ref: '#/components/schemas/MetaAttribute'
nullable: true
required:
- id_prefixes
additionalProperties: false
MetaEdge:
type: object
description: >-
Edge in a meta knowledge map describing relationship between a subject
Biolink class and an object Biolink class.
properties:
subject:
$ref: '#/components/schemas/BiolinkEntity'
description: >-
Subject node category of this relationship edge.
example: biolink:ChemicalEntity
predicate:
$ref: '#/components/schemas/BiolinkPredicate'
description: >-
Biolink relationship between the subject and object categories.
example: biolink:affects