Skip to content

NIH-NCPI/locutus

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Locutus

Locutus provides the backend for a web based terminology mapping tool in the very early stages of development. The goal of the application is to provide a collaborative environment to harmonize dataset terms with public ontologies such as MeSH, HPO and others.

There isn't much here at this time, but there are some example data based on a real research data-dictionary along with standard CRUD functionality.

API Functionality:

Terminologies:

https://[APPURL]/api/Terminology

GET - Return all terminologies

Returns all terminologies user is allowed access to. (as of Apr 2024, the user has access too all terminologies)

example:

[
  {
    "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition_status",
    "description": null,
    "codes": [
      {
        "display": "Current",
        "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition_status",
        "code": "Current"
      },
      {
        "display": "Resolved",
        "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition_status",
        "code": "Resolved"
      },
      {
        "display": "History Of",
        "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition_status",
        "code": "History Of"
      }
    ],
    "id": "tm--2VjOxekLP8m28EPRqk95",
    "resource_type": "Terminology",
    "name": "condition_status"
  },
  {
    "url": "www.test.com/Sex",
    "description": null,
    "codes": [
      {
        "display": "",
        "system": "www.test.com/Sex",
        "code": "Female"
      },
      {
        "display": "",
        "system": "www.test.com/Sex",
        "code": "Male"
      },
      {
        "display": "",
        "system": "www.test.com/Sex",
        "code": "Other"
      },
      {
        "display": "",
        "system": "www.test.com/Sex",
        "code": "Unknown"
      }
    ],
    "id": "tm-5AKcaQ-QLe3REWzaJYoUA",
    "resource_type": "Terminology",
    "name": "Sex"
  }
]

POST - Create new Terminology

Create a new terminology. The new terminology should be sent in the body of the request.

{
  "url": "www.test.com/Sex",
  "description": null,
  "codes": [
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Female"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Male"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Other"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Unknown"
    }
  ],
  "name": "Sex"
}

When POSTing, the API will create an ID for new entry.

https://[APPURL]/api/Terminology/[id]

Actions relating to a specific terminology based on the ID

GET

Returns the terminology

{
  "url": "www.test.com/Sex",
  "description": null,
  "codes": [
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Female"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Male"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Other"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Unknown"
    }
  ],
  "id": "tm-5AKcaQ-QLe3REWzaJYoUA",
  "resource_type": "Terminology",
  "name": "Sex"
}

PUT

Replace terminology at the given ID

{
  "url": "www.test.com/Sex",
  "description": null,
  "codes": [
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Female"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Male"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Other"
    },
    {
      "display": "",
      "system": "www.test.com/Sex",
      "code": "Unknown"
    }
  ],
  "id": "tm-5AKcaQ-QLe3REWzaJYoUA",
  "resource_type": "Terminology",
  "name": "Sex",
  "editor": "test_editor"
}

DELETE

Removes a terminology from the database. This will remove all mappings that have been assigned to the terminology.

WARNING: As of April 2024, deleting a Terminology does not remove it from tables that reference it.

Terminology Edit

For convenience, one can add and remove codes from a terminology using basic PUT and DELETE calls

https://[APPURL]/api/Terminology/[id]/code/[code]

PUT

Adds a new code (with a matching display) to the terminology.

{
  "display": "New Code's Display"
}

Response will be the entire Terminology including the newly added code.

{
  "id": "tm-r5l1w5u-dJ0yNEkrkCcZu",
  "name": "condition",
  "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition",
  "description": null,
  "codes": [
    {
      "code": "Participant External ID",
      "display": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "Event ID",
      "display": "Identifier for event (Visit, Survey completion, Sample collection, etc.) to which the Condition data are linked, if applicable. There may be multiple events linked to a Participant.",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "Measure Value",
      "display": "Numeric value of Measure",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "Measure Unit",
      "display": "Unit that is associated with Measure Value (e.g. kg, cm, %, x10^9/L, etc.)",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "newcode",
      "display": "New Code's Display",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    }
  ],
  "resource_type": "Terminology"
}

If the code exists already, the system fails with a 400 error.

DELETE

Removes a code from the terminology (this will also remove all mappings for that code)

Return is the entire terminology minus the deleted code.

If the code doesn't exist, a 404 error is returned.

{
  "id": "tm-r5l1w5u-dJ0yNEkrkCcZu",
  "name": "condition",
  "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition",
  "description": null,
  "codes": [
    {
      "code": "Participant External ID",
      "display": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "Event ID",
      "display": "Identifier for event (Visit, Survey completion, Sample collection, etc.) to which the Condition data are linked, if applicable. There may be multiple events linked to a Participant.",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "Measure Value",
      "display": "Numeric value of Measure",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    },
    {
      "code": "Measure Unit",
      "display": "Unit that is associated with Measure Value (e.g. kg, cm, %, x10^9/L, etc.)",
      "system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/condition/condition"
    }
  ],
  "resource_type": "Terminology"
}

Terminology Mappings

https://[APPURL]/api/Terminology/[id]/mapping

GET

Returns all VALID mappings currently assigned to any code in the terminology. Optionally, it can include additional user input data if the user_input parameter is provided.
Example endpoint: https://[APPURL]/api/Terminology/[id]/mapping?user_input=True)

{
    "terminology": {
        "Reference": "Terminology/tm-C8IP8Cw_0M_hHWeLl5WP3"
    },
    "mappings": [
        {
            "code": "Female",
            "codes": [
                {
                    "code": "female",
                    "display": "Female",
                    "mapping_relationship":"",
                    "system": "http://hl7.org/fhir/administrative-gender",
                    "valid": true
                }
            ]
        }
    ]
}

User_input example output. An active session is required to retrieve the 'users_vote'. If none exists, 'users_vote' will be an empty string.

{
    "terminology": {
        "Reference": "Terminology/tm-C8IP8Cw_0M_hHWeLl5WP3"
    },
    "mappings": [
        {
            "code": "Female",
            "codes": [
                {
                    "code": "female",
                    "display": "Female",
                    "mapping_relationship":"",
                    "system": "http://hl7.org/fhir/administrative-gender",
                    "valid": true,
                    "user_input": {
                        "comments_count": 1,
                        "votes_count": {
                            "up": 1,
                            "down": 0
                        },
                        "users_vote": "up"
                    }
                }
            ]
        }
    ]
}

DELETE

Soft deletes all mappings associated with all codes in the given terminology. The 'valid' field for the mapping is set to 'false'

https://[APPURL]/api/Terminology/[id]/mapping/[code]

GET

Returns VALID mappings for the specific code (from the terminology) Optionally, it can include additional user input data if the user_input parameter is provided.
Example endpoint: https://[APPURL]/api/Terminology/[id]/mapping/[code]?user_input=True)

{
    "codes": [
        {
            "code": "female_ex",
            "codes": [
                {
                    "code": "femalee",
                    "display": "feMale",
                    "mapping_relationship":"equivalent",
                    "system": "http://hl7.org/fhir/administrative-gender",
                    "valid": true
                }
            ]
        }
    ],
    "terminology": {
        "Reference": "Terminology/tm-C8IP8Cw_0M_hHWeLl5WP3"
    }
}

User_input example output. An active session is required to retrieve the 'users_vote'. If none exists, 'users_vote' will be an empty string.

{
    "codes": [
        {
            "code": "female_ex",
            "codes": [
                {
                    "code": "femalee",
                    "display": "feMale",
                    "mapping_relationship":"equivalent",
                    "system": "http://hl7.org/fhir/administrative-gender",
                    "valid": true,
                    "user_input": {
                        "comments_count": 1,
                        "votes_count": {
                            "up": 1,
                            "down": 0
                        },
                        "users_vote": "up"
                    }
                }
            ]
        }
    ],
    "terminology": {
        "Reference": "Terminology/tm-C8IP8Cw_0M_hHWeLl5WP3"
    }
}

PUT

Set mappings for a specific code inside the given terminology. The body must contain all codings (i.e. it replaces anything that may already be there)

Example Body:

{
  "mappings": [
    {
      "code": "Major depressive disorder",
      "display": "",
      "description": "",
      "system": "https://anvil-all-terms.org/fhir/disease_1",
      "mapping_relationship": "equivalent"
    }
  ],
  "editor": "user525600"
}

The response from the PUT is a listing of all mappings for that terminology after the change.

DELETE

Soft delete the mappings currently associated with the given code from the specified terminology. The mappings 'valid' field will be set to 'false'

The response is a listing of all mappings for that terminology after the change.

https://[APPURL]/api/Terminology/[id]/rename

PATCH

Renames code(s) with new names.

This PATCH method does not conform to the standard guidelines which permit updates to any property within the resource. Instead it is intended solely for renaming codes inside a terminology. The body of the call will include will be an object with one or two keys, "code" and "display" (a valid rename must have one of the two). Each of those keys will point to an object whose keys match a term within the current terminology. Those key's values represent the new value after the change.

For Example:

{
  "code": {
    "Female": "Woman"
  },
  "display": {
    "Female": "Woman"
  }
}

Will replace the code, Female, with Woman as well as update the display to match. This includes assigning all mappings from the code, Female, to the newly named code, Woman. The body object can contain more than one key/value pair which will indicate the intent to rename multiple codes in a single PATCH call.

If one or more of the "Old Code" entries doesn't exist in the terminology, a 404 "Not Found" error is returned.

If the root object in the body is missing both the "code" and the "display", a 400 error is returned.

Upon completion, 200 is returned along with the full set of mappings for the terminology.

{
  "terminology": {
    "Reference": "Terminology/tm-aIzCqJJkThKoxC2LiI6pP"
  },
  "codes": [
    {
      "code": "Male",
      "mappings": [
        {
          "code": "male",
          "display": "Male",
          "system": "http://hl7.org/fhir/administrative-gender"
        }
      ]
    },
    {
      "code": "Woman",
      "mappings": [
        {
          "code": "female",
          "display": "Female",
          "system": "http://hl7.org/fhir/administrative-gender"
        }
      ]
    }
  ]
}

https://[APPURL]/api/Terminology/[id]/filter

GET

Return the api search preference for the terminology (specified by id).
Returns the api search preferences at the Terminology("self") level.
Expected return example below.

Optionally, the endpoint can be implemented to fallback to the Tables preferrences if the table_id is provided.
The endpoint will 'fallback' only if there are no preferences for the Terminology.

Example endpoint: https://[APPURL]/api/Terminology/[id]/filter?table_id=[table_id]

{
    "self": {
        "api_preference": {
            "ex_api": [
                "ontology1",
                "onto2"
            ]
        }
    }
}

PUT

Update a api search preference for the terminology (specified by id).
See the POST request for this endpoint for a request body example

POST

Create the api search preference for the terminology (specified by id).
Request body example:

{
   "api_preference": {
       "ex_api": ["ex_onto", "ex_onto2"]
   }
}

DELETE

Delete the api search preference for the terminology (specified by id).
This is the expected result after removing preferences with the URL without specifying a code.

{}

https://[APPURL]/api/Terminology/[id]/filter/[code]

GET

Return the api search preference for the code within a specific terminology (specified by id).

The response below would be the result of specifying 'T21' as the code in the request.

  • If preferences for the code do not exist the endpoint will fallback to use any preferences found for the Terminology(code:'self'). Example seen HERE
  • If preferences for neither the code nor the Terminology exist an empty object is returned.

Optionally, the endpoint can be implemented to fallback to the Tables preferrences if the table_id is provided.
The endpoint will 'fallback' only if there are no preferences for the Terminology.

Example endpoint: https://[APPURL]/api/Terminology/[id]/filter[code]?table_id=[table_id]

{
    "T21": {
        "api_preference": {
            "ex_api": [
                "ex_onto",
                "ex_onto2"
            ]
        }
    }
}

PUT

Create a api search preference for the code within a specific terminology (specified by id).
See POST request for an example request body.

POST

Update the api search preference for the code within a specific terminology (specified by id).
In the example below T21 was specified as the code.
Check out the GET request of this endpoint for a visual of the created preference. Request body example:

{
   "api_preference": {
       "ex_api": ["ex_onto", "ex_onto2"]
   }
}

DELETE

Delete the api search preference for the code within a specific terminology (specified by id).

This is the expected result after removing preferences with the URL code specifying 'T21'.

{
    "T21": {}
}

https://[APPURL]/api/Terminology/[id]/preferred_terminology

GET

Return the reference to the preferred_terminology related to the Terminology (specified by id).
Returns the preferred_terminology at the Terminology("self") level.
Expected return example below.

Optionally, the endpoint can be implemented to fallback to the Tables preferrences if the table_id is provided.
The endpoint will 'fallback' only if there are no preferences for the Terminology.

Example endpoint: https://[APPURL]/api/Terminology/[id]/preferred_terminology?table_id=[table_id]

{
    "references": [
        {
            "reference": "Terminology/tm--example1"
        },
        {
            "reference": "Terminology/tm--example2"
        }
    ]
}

PUT

Create or replace references to a prefered Terminology for the terminology (specified by id).
Request body example:

{
   "editor": "user24601",
   "preferred_terminologies": [
       {
           "preferred_terminology": "tm--example1"
       },
       {
           "preferred_terminology": "tm--example6"
       }
   ]
}

DELETE

Running the DELETE request will remove the preferred_terminology collection from the Terminology specified by the id

https://[APPURL]/api/Terminology/[id]/user_input/[code]/mapping/[mapped_code]/[type]

  • id (str): The document ID.
  • code (str): The target document (mapping) identifier.
  • mapped_code (str): The code being mapped to the target.
  • type (str): The type of input to retrieve
    • currently available: "mapping_conversations","mapping_votes".

GET

Return the reference to the user_input type related to the Terminology (specified by id).
Returns all records of the type at the code level, in reverse order from whence they were stored, with newer records on top.

Expected return for type mapping_votes below

{
    "Terminology": "tm-C8IP8Cw_0M_hHWeLl5WP3",
    "code": "type 2 diabetes",
    "mapped_code": "Type 2 diabetes mellitus",
    "mapping_votes": {
        "user24601": {
            "date": "Nov 17, 2024, 01:58:39.197679 PM",
            "vote": "up"
        }
    }
}

Expected return for type mapping_conversations below

{
    "Terminology": "tm--2VjOxekLP8m28EPRqk95",
    "code": "type 2 diabetes",
    "mapped_code": "Type 2 diabetes mellitus",
    "mapping_conversations": [
        {
            "date": "Oct 04, 2024, 04:17:43.043579 PM",
            "user_id": "user24601",
            "note": "I like this mapping"
        },
        {
            "date": "Oct 04, 2024, 04:21:15.460040 PM",
            "user_id": "user525600",
            "note": "I dont like this mapping"
        }
    ]
}

PUT

Create a user_input record of the type specified in Terminology(specified by id).

Request body example for mapping_conversations :

editor is only required if not using sessions

{
   "editor": "user24601",
   "note": "I dont like this mapping"
}

Request body example for mapping_votes :

editor is only required if not using sessions

{
   "editor": "user525600",
   "vote": "up"
}

https://[APPURL]/api/Terminology/[id]/mapping_relationship/[code]/mapping/[mapped_code]

There is not currently a endpoint for getting a mappings(code/mapped_code) relationship alone. Use the endpoint for getting all mappings for a single code. more here

A mapping may not have the mapping_relationship value set. But a returned mapping will always have a mapping_relationship attribute.

PUT - Updating a mapping_relationship

Mapping_relationship can be set to the codes in the ftd-concept-map-relationship Terminology or to an empty string "".
Current ftd-concept-map-relationship codes(subject to change): [equivalent,source-is-narrower-than-target,source-is-broader-than-target ]

{
 "mapping_relationship":"equivalent",
 "editor": "user24601"
}

Terminology Provenance

Provenance is tracked for all changes to a terminology or one of the terms associated with the terminology. This includes adding and removing codes, editing code properties as well as adding and removing mappings.

https://[APPURL]/api/Provenance/Terminology/[id]

GET

This endpoint will return changes to the terminology itself, including adding, editing and removing codes.

Please see the documentation for the Table provenance for more details.

https://[APPURL]/api/Provenance/Terminology/[id]/code/[code]

This endpoint will return the provenance associated with the mappings of a single code within the terminology.

Please see the documentation for the Table provenance for more details.

Table

The following end points are available for manipulating tables within locutus. For all relevant functions, any change to the table will result in a change to the underlying "shadow" terminology.

https://[APPURL]/api/Table

GET

List all tables found in the database that the user can read.

[
  {
    "description": null,
    "id": "INCLUDE:participant",
    "resource_type": "Table",
    "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/participant",
    "variables": [
      {
        "description": "Unique identifer for the study, assigned by DCC",
        "data_type": "STRING",
        "name": "Study Code"
      },
      {
        "description": "Unique INCLUDE global identifier for the participant, assigned by DCC",
        "data_type": "STRING",
        "name": "Participant Global ID"
      },
      {
        "description": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
        "data_type": "STRING",
        "name": "Participant External ID"
      },
      {
        "description": "Unique identifer for family to which Participant belongs, assigned by data contributor",
        "data_type": "STRING",
        "name": "Family ID"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-LpeLjQdupwpW5N9Gx5qT3"
        },
        "description": "Structure of family members participating in the study",
        "data_type": "ENUMERATION",
        "name": "Family Type"
      },
      {
        "description": "Participant External ID for Participant's father (NA if Participant is not the proband)",
        "data_type": "STRING",
        "name": "Father ID"
      },
      {
        "description": "Participant External ID for Participant's mother (NA if Participant is not the proband)",
        "data_type": "STRING",
        "name": "Mother ID"
      },
      {
        "description": "Participant External ID for Participant's sibling(s) (NA if Participant is not the proband)",
        "data_type": "STRING",
        "name": "Sibling ID"
      },
      {
        "description": "Participant External ID for Participant's other family members (NA if Participant is not the proband)",
        "data_type": "STRING",
        "name": "Other Family Member ID"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-DCQHVrWz6DEW5HOVoeJus"
        },
        "description": "Relationship of Participant to proband",
        "data_type": "ENUMERATION",
        "name": "Family Relationship"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-aIzCqJJkThKoxC2LiI6pP"
        },
        "description": "Sex of Participant",
        "data_type": "ENUMERATION",
        "name": "Sex"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-uonGHeztn0SxCKrQzJTyc"
        },
        "description": "Race of Participant",
        "data_type": "ENUMERATION",
        "name": "Race"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-X7pYrNC641npqC0Kgt7Lz"
        },
        "description": "Ethnicity of Participant",
        "data_type": "ENUMERATION",
        "name": "Ethnicity"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-Ehs2nM9-LDe_EMm8OYIVI"
        },
        "description": "Down Syndrome status of participant",
        "data_type": "ENUMERATION",
        "name": "Down Syndrome Status"
      },
      {
        "max": null,
        "description": "Age in days of Participant at first recorded study event (enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
        "data_type": "INTEGER",
        "units": null,
        "min": null,
        "name": "Age at First Patient Engagement"
      },
      {
        "description": "Event for which Age at First Patient Engagement is given (e.g. enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
        "data_type": "STRING",
        "name": "First Patient Engagement Event"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-r1KS1XhFXHY2Vt6amUPOW"
        },
        "description": "Whether participant is alive or dead",
        "data_type": "ENUMERATION",
        "name": "Outcomes Vital Status"
      },
      {
        "max": null,
        "description": "Age in days when participant's vital status was last recorded",
        "data_type": "INTEGER",
        "units": null,
        "min": null,
        "name": "Age at Last Vital Status"
      }
    ],
    "filename": null,
    "name": "participant"
  },
  {
    "description": null,
    "id": "INCLUDE:specimen",
    "resource_type": "Table",
    "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/specimen",
    "variables": [
      {
        "description": "Unique INCLUDE global identifier for the participant, assigned by DCC",
        "data_type": "STRING",
        "name": "Participant Global ID"
      },
      {
        "description": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
        "data_type": "STRING",
        "name": "Participant External ID"
      },
      {
        "max": null,
        "description": "Age in days of participant at time of biospecimen collection",
        "data_type": "INTEGER",
        "units": null,
        "min": null,
        "name": "Age at Biospecimen Collection"
      },
      {
        "description": "INCLUDE global identifier for sample, assigned by DCC",
        "data_type": "STRING",
        "name": "Sample Global ID"
      },
      {
        "description": "Unique identifier for sample, assigned by data contributor. A sample is a unique biological material; two samples with two different IDs are biologically distinct.",
        "data_type": "STRING",
        "name": "Sample External ID"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-qVO-Iie3FUE2DuJFtIwMB"
        },
        "description": "Type of biological material comprising the Sample (e.g. Plasma, White blood cells, Red blood cells, DNA, RNA, Peripheral blood mononuclear cells, CD4+ Tconv cells, NK cells, Monocytes, CD8+ T cells, B cells, Granulocytes, Treg cells)",
        "data_type": "ENUMERATION",
        "name": "Sample Type"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-FHr-QnQgEhY59tSUEQ2TA"
        },
        "description": "Whether or not the sample is potentially available for sharing through\n      the Virtual Biorepository",
        "data_type": "ENUMERATION",
        "name": "Sample Availability"
      },
      {
        "description": "INCLUDE global identifier for the eldest sample in a lineage, assigned by DCC",
        "data_type": "STRING",
        "name": "Collection Global ID"
      },
      {
        "description": "Identifier for the eldest sample in a lineage of processed, pooled,\n      or aliquoted samples - typically the material actually collected from the Participant. This may be the same as Parent Sample ID or Sample ID\n      (if no processing was performed). Assigned by data contributor.",
        "data_type": "STRING",
        "name": "Collection External ID"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-zKsH0HIlNggsxfQwLebme"
        },
        "description": "Type of biological material comprising the Collected Sample (e.g. Whole blood, Not reported, Saliva, Derived cell line)",
        "data_type": "ENUMERATION",
        "name": "Collection Sample Type"
      },
      {
        "description": "INCLUDE global identifier for specific container/aliquot of sample, assigned by DCC",
        "data_type": "STRING",
        "name": "Container Global ID"
      },
      {
        "max": null,
        "description": "Identifier for specific container/aliquot of sample, assigned by data contributor.\n      For example, distinct aliquots of a sample will have the same Sample ID but\n      different Container IDs.",
        "data_type": "INTEGER",
        "units": null,
        "min": null,
        "name": "Container External ID"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-Bq5S8LkrTEbdy85EnQQnA"
        },
        "description": "Container Availability",
        "data_type": "ENUMERATION",
        "name": "Container Availability"
      },
      {
        "description": "INCLUDE global identifier for the direct parent from which Sample was derived, assigned by DCC",
        "data_type": "STRING",
        "name": "Parent Sample Global ID"
      },
      {
        "description": "Unique identifier for the parent sample, assigned by data contributor",
        "data_type": "STRING",
        "name": "Parent Sample External ID"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-U7qbw11EDknc5NTC-91_o"
        },
        "description": "Type of biological material comprising the Parent Sample (e.g. Peripheral Whole Blood, Derived Cell Line, Saliva, Whole blood, WBCs) ",
        "data_type": "ENUMERATION",
        "name": "Parent Sample Type"
      },
      {
        "description": "Procedure by which Sample was derived from Parent Sample (e.g. Centrifugation, RBC lysis, Lyse/fix buffer, FACS, PAXgene DNA, PAXgene RNA, Qiagen Allprep, Ficoll)",
        "data_type": "STRING",
        "name": "Laboratory Procedure"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-qQ7jKoalnr4hOlzrz2AKD"
        },
        "description": "Method by which Container is stored (e.g. Minus 80 degrees Celsius, Liquid nitrogen storage)",
        "data_type": "ENUMERATION",
        "name": "Biospecimen Storage"
      },
      {
        "max": null,
        "description": "Concentration of sample in container",
        "data_type": "QUANTITY",
        "units": null,
        "min": null,
        "name": "Concentration"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-lv60mNdaYpzDN5TGHcTV5"
        },
        "description": "Unit of sample concentration",
        "data_type": "ENUMERATION",
        "name": "Concentration_Unit"
      },
      {
        "max": null,
        "description": "Amount of sample in container",
        "data_type": "QUANTITY",
        "units": null,
        "min": null,
        "name": "Volume"
      },
      {
        "enumerations": {
          "reference": "Terminology/tm-VxCSebNidllU3LpIsB0ff"
        },
        "description": "Unit of sample volume",
        "data_type": "ENUMERATION",
        "name": "Volume Unit"
      }
    ],
    "filename": null,
    "name": "specimen"
  }
]

POST

Create new table

{
  "description": null,
  "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/participant",
  "variables": [
    {
      "description": "Unique identifer for the study, assigned by DCC",
      "data_type": "STRING",
      "name": "Study Code"
    },
    {
      "description": "Unique INCLUDE global identifier for the participant, assigned by DCC",
      "data_type": "STRING",
      "name": "Participant Global ID"
    },
    {
      "description": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
      "data_type": "STRING",
      "name": "Participant External ID"
    },
    {
      "description": "Unique identifer for family to which Participant belongs, assigned by data contributor",
      "data_type": "STRING",
      "name": "Family ID"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-LpeLjQdupwpW5N9Gx5qT3"
      },
      "description": "Structure of family members participating in the study",
      "data_type": "ENUMERATION",
      "name": "Family Type"
    },
    {
      "description": "Participant External ID for Participant's father (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Father ID"
    },
    {
      "description": "Participant External ID for Participant's mother (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Mother ID"
    },
    {
      "description": "Participant External ID for Participant's sibling(s) (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Sibling ID"
    },
    {
      "description": "Participant External ID for Participant's other family members (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Other Family Member ID"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-DCQHVrWz6DEW5HOVoeJus"
      },
      "description": "Relationship of Participant to proband",
      "data_type": "ENUMERATION",
      "name": "Family Relationship"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-aIzCqJJkThKoxC2LiI6pP"
      },
      "description": "Sex of Participant",
      "data_type": "ENUMERATION",
      "name": "Sex"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-uonGHeztn0SxCKrQzJTyc"
      },
      "description": "Race of Participant",
      "data_type": "ENUMERATION",
      "name": "Race"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-X7pYrNC641npqC0Kgt7Lz"
      },
      "description": "Ethnicity of Participant",
      "data_type": "ENUMERATION",
      "name": "Ethnicity"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-Ehs2nM9-LDe_EMm8OYIVI"
      },
      "description": "Down Syndrome status of participant",
      "data_type": "ENUMERATION",
      "name": "Down Syndrome Status"
    },
    {
      "max": null,
      "description": "Age in days of Participant at first recorded study event (enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
      "data_type": "INTEGER",
      "units": null,
      "min": null,
      "name": "Age at First Patient Engagement"
    },
    {
      "description": "Event for which Age at First Patient Engagement is given (e.g. enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
      "data_type": "STRING",
      "name": "First Patient Engagement Event"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-r1KS1XhFXHY2Vt6amUPOW"
      },
      "description": "Whether participant is alive or dead",
      "data_type": "ENUMERATION",
      "name": "Outcomes Vital Status"
    },
    {
      "max": null,
      "description": "Age in days when participant's vital status was last recorded",
      "data_type": "INTEGER",
      "units": null,
      "min": null,
      "name": "Age at Last Vital Status"
    }
  ],
  "filename": null,
  "name": "participant"
}

https://[APPURL]/api/Table/[id]

GET

Return a specific table (with a given id)

{
  "description": null,
  "id": "INCLUDE:participant",
  "resource_type": "Table",
  "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/participant",
  "variables": [
    {
      "description": "Unique identifer for the study, assigned by DCC",
      "data_type": "STRING",
      "name": "Study Code"
    },
    {
      "description": "Unique INCLUDE global identifier for the participant, assigned by DCC",
      "data_type": "STRING",
      "name": "Participant Global ID"
    },
    {
      "description": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
      "data_type": "STRING",
      "name": "Participant External ID"
    },
    {
      "description": "Unique identifer for family to which Participant belongs, assigned by data contributor",
      "data_type": "STRING",
      "name": "Family ID"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-LpeLjQdupwpW5N9Gx5qT3"
      },
      "description": "Structure of family members participating in the study",
      "data_type": "ENUMERATION",
      "name": "Family Type"
    },
    {
      "description": "Participant External ID for Participant's father (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Father ID"
    },
    {
      "description": "Participant External ID for Participant's mother (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Mother ID"
    },
    {
      "description": "Participant External ID for Participant's sibling(s) (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Sibling ID"
    },
    {
      "description": "Participant External ID for Participant's other family members (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Other Family Member ID"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-DCQHVrWz6DEW5HOVoeJus"
      },
      "description": "Relationship of Participant to proband",
      "data_type": "ENUMERATION",
      "name": "Family Relationship"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-aIzCqJJkThKoxC2LiI6pP"
      },
      "description": "Sex of Participant",
      "data_type": "ENUMERATION",
      "name": "Sex"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-uonGHeztn0SxCKrQzJTyc"
      },
      "description": "Race of Participant",
      "data_type": "ENUMERATION",
      "name": "Race"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-X7pYrNC641npqC0Kgt7Lz"
      },
      "description": "Ethnicity of Participant",
      "data_type": "ENUMERATION",
      "name": "Ethnicity"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-Ehs2nM9-LDe_EMm8OYIVI"
      },
      "description": "Down Syndrome status of participant",
      "data_type": "ENUMERATION",
      "name": "Down Syndrome Status"
    },
    {
      "max": null,
      "description": "Age in days of Participant at first recorded study event (enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
      "data_type": "INTEGER",
      "units": null,
      "min": null,
      "name": "Age at First Patient Engagement"
    },
    {
      "description": "Event for which Age at First Patient Engagement is given (e.g. enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
      "data_type": "STRING",
      "name": "First Patient Engagement Event"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-r1KS1XhFXHY2Vt6amUPOW"
      },
      "description": "Whether participant is alive or dead",
      "data_type": "ENUMERATION",
      "name": "Outcomes Vital Status"
    },
    {
      "max": null,
      "description": "Age in days when participant's vital status was last recorded",
      "data_type": "INTEGER",
      "units": null,
      "min": null,
      "name": "Age at Last Vital Status"
    }
  ],
  "filename": null,
  "name": "participant"
}

PUT

Updates a table with the body (the contents of the body will replace the table at the given id, completely)

{
  "description": null,
  "id": "INCLUDE:participant",
  "url": "https://includedcc.org/fhir/CodeSystem/data-dictionary/participant",
  "variables": [
    {
      "description": "Unique identifer for the study, assigned by DCC",
      "data_type": "STRING",
      "name": "Study Code"
    },
    {
      "description": "Unique INCLUDE global identifier for the participant, assigned by DCC",
      "data_type": "STRING",
      "name": "Participant Global ID"
    },
    {
      "description": "Unique, de-identified identifier for the participant, assigned by data contributor. External IDs must be two steps removed from personal information in the study records.",
      "data_type": "STRING",
      "name": "Participant External ID"
    },
    {
      "description": "Unique identifer for family to which Participant belongs, assigned by data contributor",
      "data_type": "STRING",
      "name": "Family ID"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-LpeLjQdupwpW5N9Gx5qT3"
      },
      "description": "Structure of family members participating in the study",
      "data_type": "ENUMERATION",
      "name": "Family Type"
    },
    {
      "description": "Participant External ID for Participant's father (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Father ID"
    },
    {
      "description": "Participant External ID for Participant's mother (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Mother ID"
    },
    {
      "description": "Participant External ID for Participant's sibling(s) (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Sibling ID"
    },
    {
      "description": "Participant External ID for Participant's other family members (NA if Participant is not the proband)",
      "data_type": "STRING",
      "name": "Other Family Member ID"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-DCQHVrWz6DEW5HOVoeJus"
      },
      "description": "Relationship of Participant to proband",
      "data_type": "ENUMERATION",
      "name": "Family Relationship"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-aIzCqJJkThKoxC2LiI6pP"
      },
      "description": "Sex of Participant",
      "data_type": "ENUMERATION",
      "name": "Sex"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-uonGHeztn0SxCKrQzJTyc"
      },
      "description": "Race of Participant",
      "data_type": "ENUMERATION",
      "name": "Race"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-X7pYrNC641npqC0Kgt7Lz"
      },
      "description": "Ethnicity of Participant",
      "data_type": "ENUMERATION",
      "name": "Ethnicity"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-Ehs2nM9-LDe_EMm8OYIVI"
      },
      "description": "Down Syndrome status of participant",
      "data_type": "ENUMERATION",
      "name": "Down Syndrome Status"
    },
    {
      "max": null,
      "description": "Age in days of Participant at first recorded study event (enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
      "data_type": "INTEGER",
      "units": null,
      "min": null,
      "name": "Age at First Patient Engagement"
    },
    {
      "description": "Event for which Age at First Patient Engagement is given (e.g. enrollment, visit, observation, sample collection, survey completion, etc.). Age at enrollment is preferred, if available.",
      "data_type": "STRING",
      "name": "First Patient Engagement Event"
    },
    {
      "enumerations": {
        "reference": "Terminology/tm-r1KS1XhFXHY2Vt6amUPOW"
      },
      "description": "Whether participant is alive or dead",
      "data_type": "ENUMERATION",
      "name": "Outcomes Vital Status"
    },
    {
      "max": null,
      "description": "Age in days when participant's vital status was last recorded",
      "data_type": "INTEGER",
      "units": null,
      "min": null,
      "name": "Age at Last Vital Status"
    }
  ],
  "filename": null,
  "name": "participant"
}

DELETE

Deletes the table from the database. This will remove all references to the table from any Data Dictionaries it is contained within.

https://[APPURL]/api/Table/[id]/variable/[variable_name]

PUT

Add a variable to an existing Table. The variable will be contained within the requests body and should have all the necessary components for the given data type.

If one were to want to add the race variable as an enumerated type to a new table, you would pass the following:

{
  "enumerations": {
    "reference": "Terminology/tm-uonGHeztn0SxCKrQzJTyc"
  },
  "description": "Race of Participant",
  "data_type": "ENUMERATION",
  "name": "Race"
}

The entire table will be returned, including the new variable as a member of the variables array.

If the variable already exists, a 400 error is returned.

DELETE

Removes a variable from the table.

If successful, the entire table is returned (and the deletion should be reflected in the response).

If the variable doesn't exist, then a 404 error is returned.

It should be noted that if you delete an enumerated variable, the terminology referenced will not be deleted. The reason being that we can theoretically have many variables using the same terminology for similar variables.

https://[APPURL]/api/Table/[id]/harmony

GET

Returns the harmony representation of all enumerations contained within the table's variables.

[
  {
    "local code": "Female",
    "text": "Female",
    "table_name": "participant",
    "parent_varname": "",
    "local code system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/participant/sex",
    "code": "female",
    "display": "Female",
    "code system": "http://hl7.org/fhir/administrative-gender",
    "comment": ""
  },
  {
    "local code": "Male",
    "text": "Male",
    "table_name": "participant",
    "parent_varname": "",
    "local code system": "https://includedcc.org/fhir/CodeSystem/data-dictionary/participant/sex",
    "code": "male",
    "display": "Male",
    "code system": "http://hl7.org/fhir/administrative-gender",
    "comment": ""
  }
]

https://[APPURL]/api/Table/[id]/mapping

Manage the mappings associated with the columns of a given table.

Technically, the underlying functionality is done at the terminology level and, as such, the behavior is identical to the matching terminology f functionality including body and responses. The only difference is that the end points themselves will be related to the table and it's ID.

GET

Returns a list of all mappings from the table and their associated 'user_input' if requested. (See example of the matching terminology endpoint for details.)

DELETE

Soft delete all mappings associated with codes from the table's shadow terminology. The mappings 'valid' field is set to 'false'

https://[APPURL]/api/Table/[id]/mapping/[code]

GET

Returns mappings for a specific code and their associated 'user_input' if requested. (from the shadow terminology. See example of the matching terminology endpoint for details.)

PUT

Set mappings for a specific code inside the given shadow terminology. The body must contain all codings (i.e. it replaces anything that may already be there)

See corresponding endpoint for Terminology for more details.

DELETE

Soft delete the mappings currently associated with a given code from the table's shadow terminology. The mappings 'valid' field is set to 'false'.

https://[APPURL]/api/Table/[id]/rename

PATCH

Renames variable(s) in a table (as well as update descriptions)

This PATCH method does not conform to the standard guidelines which permit updates to any property within the resource. Instead it is intended solely for renaming variables inside a table. The body of the call will include will be an object with one or two keys, "variable" and "description" (a valid rename must have one of the two). Each of those keys will point to an object whose keys match a term within the current table. Those key's values represent the new value after the change.

For Example:

{
  "variable": {
    "Female": "Woman"
  },
  "description": {
    "Female": "Woman"
  }
}

Will replace the name, Female, with Woman as well as update the description to match. This includes assigning all mappings from the code, Female to the newly named code, Woman within the table's shadow terminology. The body object can contain more than one key/value pair which will indicate the intent to rename multiple variables in a single PATCH call.

If one or more of the "Old Name" entries doesn't exist in the table, a 404 "Not Found" error is returned.

If the root object in the body is missing both the "variable" and the "description", a 400 error is returned.

Upon completion, 200 is returned along with the full table definition.

https://[APPURL]/api/Table/[id]/filter

GET

Return the api search preferences for a specific table (with a given id).
Returns the api search preferences at the Table("self") level. Below is an example result body.

{
    "self": {
        "api_preference": {
            "ex_api": [
                "ontology1",
                "onto2"
            ]
        }
    }
}

PUT

Create a api search preference for a specific table (with a given id).
See the POST request an example request body for this endpoint.

POST

Update the api search preferences for a specific table (with a given id).
Request body example:

{
   "api_preference": {
       "ex_api": ["ontology1", "onto2"]
   }
}

DELETE

Delete the api search preferences for a specific table (with a given id). An example of the data after removal shown below.

{}

https://[APPURL]/api/Table/[id]/filter/[code]

GET

Return the api search preference for the variable (specified by code) within a specific table (specified by id).
The response below would be the result of specifying 'study_code' as the code in the request.
Note: If no preferences for the code(ie 'study_code') exist the request will retrieve any existing preferences for at the Table level. Example results

{
    "study_code": {
        "api_preference": {
            "ex_api": [
                "ontology1",
                "onto2"
            ]
        }
    }
}

PUT

Update a api search preference for the variable (specified by code) within a specific table (specified by id). See the POST request for an example request body.

POST

Create the api search preferences for the variable (specified by code) within a specific table (specified by id).
Specifying 'study_code' as the code in the request will add this preference to the variable as seen in this endpoints GET request.
Request body example:

{
    "api_preference": {
        "ex_api": ["ex_onto", "ex_onto2"]
    }
}

DELETE

Delete the api search preference for the variable (specified by code) within a specific table (specified by id).
This is the expected result after removing preferences with the URL code specifying 'study_code'.

{
    "study_code": {}
}

https://[APPURL]/api/Table/[id]/preferred_terminology

GET

Return the reference to the preferred_terminology related to the Table (specified by id).
Returns the preferred_terminology at the Table("self") level.
Expected return example below.

{
    "references": [
        {
            "reference": "Terminology/tm--example1"
        },
        {
            "reference": "Terminology/tm--example2"
        }
    ]
}

PUT

Create or replace references to a prefered Terminology for the terminology (specified by id).
Request body example:

{
   "editor": "user24601",
   "preferred_terminologies": [
       {
           "preferred_terminology": "tm--example1"
       },
       {
           "preferred_terminology": "tm--example6"
       }
   ]
}

DELETE

Running the DELETE request will remove the preferred_terminology collection from the Table specified by the id

https://[APPURL]/api/Provenance/Table/[id]

GET

Returns the provenance for the table itself. This includes information relating to adding, editing and removing variables.

Example results:

{
    "table": {
        "Reference": "Table/tb-Fyf0T0ujF_-qOmWbPLGoN"
    },
    "provenance": {
        "self": {
            "target": "self",
            "changes": [
                {
                    "target": "self",
                    "action": "Add Term",
                    "new_value": "junk",
                    "timestamp": "2024-Aug-01 11:41AM",
                    "editor": "[email protected]"
                },
                {
                    "target": "self",
                    "action": "Remove Term",
                    "new_value": "junk",
                    "timestamp": "2024-08-01 11:41AM",
                    "editor": "[email protected]"
                }
            ]
        }
    }
}

https://[APPURL]/api/Provenance/Table/[id]/code/[code]

GET

To get the provenance of an individual variable inside a table, use this form of the endpoint URL, where code is the variable's underlying code. A special variable has been created, ALL, which will return the provenance for all variables in the table.

Example:

{
    "table": {
        "Reference": "Table/tb-Fyf0T0ujF_-qOmWbPLGoN"
    },
    "provenance": {
        "junk": {
            "target": "junk",
            "changes": [
                {
                    "target": "junk",
                    "action": "Remove Mapping",
                    "timestamp": "2024-08-01 04:13PM",
                    "old_value": "stuff",
                    "editor": "[email protected]"
                },
                {
                    "target": "junk",
                    "action": "Add Mapping",,
                    "timestamp": "2024-08-01 04:14PM",
                    "new_value": "stuff",
                    "old_value": "",
                    "editor": "[email protected]"
                },
                {
                    "target": "junk",
                    "action": "Remove Mapping",
                    "timestamp": "2024-08-01 04:16PM",
                    "old_value": "stuff",
                    "editor": "[email protected]"
                }
            ]
        }
    }
}

For ALL variables, each variable will appear as keys within the provenance object.

A highly truncated example can be seen below.

{
    "table": {
        "Reference": "Table/tb-Fyf0T0ujF_-qOmWbPLGoN"
    },
    "provenance": {
        "junk": {
            "target": "junk",
            "changes": [
                {
                    "target": "junk",
                    "action": "Remove Mapping",
                    "timestamp": "2024-08-01 04:13PM",
                    "old_value": "stuff",
                    "editor": "[email protected]"
                }]
        },
        "self": {
            "target": "self",
            "changes": [
                {
                    "target": "self",
                    "action": "Remove Term",
                    "new_value": "junk",
                    "timestamp": "2024-08-01 11:41AM",
                    "editor": "[email protected]"
                }
            ]
        }
    }
}

https://[APPURL]/api/Study

GET

Returns all studies accessible by the user

[
  {
    "identifier_prefix": "https://includedcc.org/fhir/htp",
    "description": "The Crnic Institute Human Trisome Project\u00ae (HTP) is an in-depth study of people with Down syndrome using the latest technologies in precision medicine.",
    "id": "HTP",
    "resource_type": "Study",
    "url": "https://includedcc.org/studies/human-trisome-project",
    "title": "Crnic Institute Human Trisome Project",
    "datadictionary": {
      "reference": "DataDictionary/INCLUDE"
    },
    "name": null
  }
]

POST

Creates a new table resource. The body must contain the resource itself.

[
  {
    "identifier_prefix": "https://includedcc.org/fhir/htp",
    "description": "The Crnic Institute Human Trisome Project\u00ae (HTP) is an in-depth study of people with Down syndrome using the latest technologies in precision medicine.",
    "url": "https://includedcc.org/studies/human-trisome-project",
    "title": "Crnic Institute Human Trisome Project",
    "datadictionary": {
      "reference": "DataDictionary/INCLUDE"
    },
    "name": null
  }
]

https://[APPURL]/api/Study/[id]

GET

Returns a study assocaited with the specified id.

https://[APPURL]/api/Study/[id]

PUT

Replaces the study at id with the resource contained in the body.

[
  {
    "id": "htp",
    "identifier_prefix": "https://includedcc.org/fhir/htp",
    "description": "The Crnic Institute Human Trisome Project\u00ae (HTP) is an in-depth study of people with Down syndrome using the latest technologies in precision medicine.",
    "url": "https://includedcc.org/studies/human-trisome-project",
    "title": "Crnic Institute Human Trisome Project",
    "datadictionary": {
      "reference": "DataDictionary/INCLUDE"
    },
    "name": null
  }
]

DELETE

Deletes the study at the given id

https://[APPURL]/api/Study/[id]/dd/[datadictionary_id]

DELETE

Removes a data dictionary from the study.

If successful, the entire study is returned (and the deletion should be reflected in the response).

If the data dictionary doesn't exist, then a 404 error is returned.

DataDictionary:

https://[APPURL]/api/DataDictionary

GET

Returns all data dictionaries the user has access to

[
  {
    "description": null,
    "id": "INCLUDE",
    "tables": [
      {
        "reference": "Table/INCLUDE:participant"
      },
      {
        "reference": "Table/INCLUDE:condition"
      },
      {
        "reference": "Table/INCLUDE:specimen"
      },
      {
        "reference": "Table/INCLUDE:file_manifest"
      }
    ],
    "resource_type": "DataDictionary",
    "name": null
  }
]

POST

Creates a new data dictionary resource (contents sent in body)

[
  {
    "tables": [
      {
        "reference": "Table/INCLUDE:participant"
      },
      {
        "reference": "Table/INCLUDE:condition"
      },
      {
        "reference": "Table/INCLUDE:specimen"
      },
      {
        "reference": "Table/INCLUDE:file_manifest"
      }
    ]
  }
]

https://[APPURL]/api/DataDictionary/[id]

GET

Return a specific data dictionary with the given ID

{
  "description": null,
  "id": "INCLUDE",
  "tables": [
    {
      "reference": "Table/INCLUDE:participant"
    },
    {
      "reference": "Table/INCLUDE:condition"
    },
    {
      "reference": "Table/INCLUDE:specimen"
    },
    {
      "reference": "Table/INCLUDE:file_manifest"
    }
  ],
  "resource_type": "DataDictionary",
  "name": null
}

PUT

Replace resource with the body at the given ID

{
  "description": null,
  "id": "INCLUDE",
  "tables": [
    {
      "reference": "Table/INCLUDE:participant"
    },
    {
      "reference": "Table/INCLUDE:condition"
    },
    {
      "reference": "Table/INCLUDE:specimen"
    },
    {
      "reference": "Table/INCLUDE:file_manifest"
    }
  ],
  "resource_type": "DataDictionary",
  "name": null
}

DELETE

Removes the specified data dictionary associated with the given ID

OntologyAPI:

https://[APPURL]/api/OntologyAPI

GET

Returns all availiable Ontology APIs and their details

[
    {
        "api_name": "LOINC API",
        "api_id": "loinc",
        "api_url": "https://loinc.regenstrief.org/searchapi/",
        "ontologies": [
            {
                "ontology_code": "loinc",
                "ontology_title": "Logical Observation Identifiers, Names and Codes (LOINC)",
                "system": "https://loinc.regenstrief.org/searchapi/",
                "curie": "",
                "version": ""
            }
        ]
    },
    {
        "api_name": "Monarch API",
        "api_id": "monarch",
        "api_url": "https://api-v3.monarchinitiative.org/v3/api/search?q=",
        "ontologies": [
            {
                "ontology_code": "ecto",
                "ontology_title": "Environmental Conditions, Treatments and Exposures Ontology",
                "system": "https://api-v3.monarchinitiative.org/v3/api/search?q=",
                "curie": "ECTO",
                "version": ""
            }
        ]
    },
    {
        "api_name": "Ontology Lookup Service",
        "api_id": "ols",
        "api_url": "https://www.ebi.ac.uk/ols4/api/",
        "ontologies": [
            {
                "ontology_code": "ngbo",
                "ontology_title": " Next generation biobanking ontology(NGBO).",
                "system": "https://www.ebi.ac.uk/ols4/api/",
                "curie": "NGBO",
                "version": "http://purl.obolibrary.org/obo/ngbo/2022-10-05/ngbo.owl"
            },
        ]
    }      
]

https://[APPURL]/api/OntologyAPI/[API_ID]

GET

Returns the details for the Ontology API denoted by the API_ID

[
    {
        "api_name": "LOINC API",
        "api_id": "loinc",
        "api_url": "https://loinc.regenstrief.org/searchapi/",
        "ontologies": [
            {
                "ontology_code": "loinc",
                "ontology_title": "Logical Observation Identifiers, Names and Codes (LOINC)",
                "system": "https://loinc.regenstrief.org/searchapi/",
                "curie": "",
                "version": ""
            }
        ]
    },
    200,
    [
        [
            "Content-Type",
            "application/fhir+json"
        ]
    ]
]

https://[APPURL]/api/user/preferences/ontologies

GET

Returns the default preferences for the user (TBD) or, if not set, then the application defaults.

{
    "Application Default": {
        "api_preference": {
            "ols": [
                "mondo",
                "hp",
                "maxo",
                "ncit"
            ]
        }
    }
}

In the example return above, no session existed, so we return this under the "Application Default". Otherwise, it will be associated with the user's ID (or email).

https://[APPURL]/api/ontology_search?keyword=[KEYWORD]

GET

Three parameters are available, the keyword parameter is required.

  • keyword

    • Description: Keyword to search against the APIs
    • Required: YES
  • selected_ontologies

    • Description: User selected Ontologies
    • Required: Yes
  • selected_api

    • Description: APIs to include in the search

    • Choices:

      • ols: Gather data with the Ontology Lookup Service API.
    • Required: Yes

    • results_per_page

      • Description: Number of results requested from the ontology api.
      • Required: Yes
    • start_index

      • Description: The number/index of the first requested result.
      • Ex: with a results_per_page of 100, the first page of results would have a start_index of 0. For the second page of results the start_index would be 100.
      • Required: Yes

Example endpoint:

  • https://[APPURL]/api/ontology_search?keyword=cat scratch fever&preferred_ontologies=CL,DUO&api=ols&results_per_page=100&start_index=0

The following are example results Not real data.

{
    "search_query": "https://www.ebi.ac.uk/ols4/api/search?q=cat%20scratch%20fever&ontology=CL,DUO",
    "results": [
        {
            "code": "NCBITaxon:9681",
            "system": "http://purl.obolibrary.org/obo/cl.owl",
            "code_iri": "http://purl.obolibrary.org/obo/NCBITaxon_9681",
            "display": "Felidae",
            "description": [],
            "ontology_prefix": "CL"
        },
        {
            "code": "NCBITaxon:9685",
            "system": "http://purl.obolibrary.org/obo/duo.owl",
            "code_iri": "http://purl.obolibrary.org/obo/NCBITaxon_9685",
            "display": "Felis catus",
            "description": [],
            "ontology_prefix": "DUO"
        }
    ],
    "results_per_ontology": {
        "CL": 1,
        "DUO": 1
    },
    "results_count": 2,
    "more_results_available": true
}