A module called the Package Registry Endpoint module provides an NPM compatible REST API that can be used to:
Load new packages into package storage
Query for and access packages stored in package storage
This module is not required in order to use packages. If you simply want to load packages and use them for validation, you can use Package Spec file to upload your packages, as decribed in Pre-Seeding Packages and FHIR Resources. However, the package registry provides a dedicated HTTP endpoint that can be used to access and submit packages to storage in the FHIR Storage (RDBMS) module.
You can directly interact with the package registry using any NPM client, using direct HTTP requests, or through the built-in Swagger-UI support. You can also use the endpoint to serve as an enterprise package registry which seeds packages to other servers in your organization.
Accessing and testing the Package Registry endpoint can be done using a browser with Swagger UI.
To access this use the following URL, substituting your configured host and port. The example below uses the port in the default Smile CDR configuration:
http://localhost:8002/swagger-ui.html
The Fetch Metadata By Package ID operation searches for any package versions and metadata associated with the given NPM Package ID string.
This operation uses an HTTP GET to the path /npm/{package_id}
. This operation is a standard NPM operation and should be accessible from any NPM compatible client.
The following URL shows an example of this operation.
GET http://localhost:8002/npm/hl7.fhir.us.core
An example response is shown below:
{
"dist-tags": {
"latest": "5.0.1"
},
"versions": {
"5.0.1": {
"name": "hl7.fhir.us.core",
"version": "5.0.1",
"description": "The US Core Implementation Guide is based on FHIR Version R4 and defines the minimum conformance requirements for accessing patient data. The Argonaut pilot implementations, ONC 2015 Edition Commo...",
"fhirVersion": "4.0.1",
"_bytes": 1310494
}
}
}
The Fetch Package operation fetches the complete NPM package (i.e. the .tgz file containing the package itself) from the server to the client.
This operation uses an HTTP GET to the path /npm/{package_id}/{version_id}
. This operation is a standard NPM operation and should be accessible from any NPM compatible client.
The following URL shows an example of this operation.
GET http://localhost:8002/npm/hl7.fhir.us.core/5.0.1
The Search For Packages operation searches for installed packages matching various query parameters.
This operation uses an HTTP GET to the path /npm/-/v1/search
. This operation is a standard NPM operation and should be accessible from any NPM compatible client.
R4
or 4.0.1
.The following URL shows an example of this operation.
GET http://localhost:8002/npm/-/v1/search
The following snippet shows a sample response:
{
"objects" : [ {
"package" : {
"name" : "com.smilecdr",
"version" : "1.0.0",
"author" : "Smile Digital Health",
"description" : "This is an example package for Smile Digital Health",
"_bytes" : 1000
}
} ],
"total" : 0
}
The Install by Param operation uses an NPM package name and version string to trigger uploading a package.
This operation uses an HTTP PUT to the path /write/install/by-param
. This operation is a Smile CDR extension on the NPM registry syntax.
hl7.fhir.us.core
.5.0.1
.The following URL shows an example of this operation.
PUT http://localhost:8002/write/install/by-param
The Install by Spec operation uses a Package Spec file as input to trigger uploading a package.
This operation uses an HTTP PUT to the path /write/install/by-spec
. This operation is a Smile CDR extension on the NPM registry syntax.
The request payload is a JSON document containing a Package Spec. See the PackageInstallationSpec model for information on this format.
The following URL shows an example of this operation.
PUT http://localhost:8002/write/install/by-spec
Request body:
{
"name" : "hl7.fhir.us.core",
"version" : "5.0.1",
"packageUrl" : "classpath:/hl7.fhir.us.core-5.0.1.tgz",
"installMode" : "STORE_ONLY",
"installResourceTypes" : [ "*" ],
"reloadExisting" : true,
"fetchDependencies" : true
}
The Delete by Spec operation uses a Package Spec file as input to trigger deletion of a package.
This operation uses an HTTP DELETE to the path /write/{package_id}/{version_id}
. This operation is a Smile CDR extension on the NPM registry syntax.
The following URL shows an example of this operation.
DELETE http://localhost:8002/write/hl7.fhir.us.core/5.0.1