Skip to content

Collection of command line scripts to support the creation, publication and deployment process of FHIR profiles and IGs.

License

Notifications You must be signed in to change notification settings

gematik/fhir-scripts

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FHIR Scripts

Python Script (preferred)

Install using pipx

pipx install "fhir_scripts @ git+https://github.com/gematik/fhir-scripts.git"

Optionally, one can provide addtional arguments for pipx install:

  • -f, --force: overwrite an existing installation
  • --global: install for all users (may need to be called using sudo)

Also there can optional compentens be defined to be also installed using fhir_scripts[opt,...]. These are Python packages that otherwise may be called using a shell. Available components are:

  • epatools: Handle CapabilityStatements and OpenAPI
  • igtools: Handle requirements
  • publishtools: Support the publish workflow

Get information about the usage with

fhirscripts --help

Config

The script uses a config file. An example can be found here. The default path for this file ./config.yaml. A different path can be defined

fhirscripts --config <config> <command>

Versions

Get the version of installed tooling

fhirscripts versions

Install

Install one or multiple tools

fhirscripts install --<tool> [--<tool> [...]]

Get a list of available tools to install

fhirscripts install --help

Update

Update each installed tool

fhirscripts update
|

Cache

Rebuild the local FHIR package cache

fhirscripts cache package [--package-dir <packagedir>] [--no-clear]

(WIP) A local directory can be used as package cache. If --package-dir <packagedir> is provided, packages from <packagedir> will be installed instead and if not found, cached to this directory before installing them from there.

--no-clear allows to restore the FHIR package cache without clearing the directory in beforehand.

Build

Requirements:

  • IG Publisher
  • FSH Sushi
  • (optional igtools, either as component or using pipx)
  • (optional epatools, either as component or using pipx)

Building happens in two stages: FHIR definitions and FHIR IG.

Definitions

Build the FHIR definitions

fhirscripts build defs [--req] [--only-req] [--cap] [--only-cap]

using FSH Sushi.

--req additionally processed requirements using igtools before executing Sushi, while --only-req only performs this step. --cap also combines the CapabilityStatements using epatools, while --only-cap only performs this step.

IG

Build the FHIR IG using IG Publisher

fhirscripts build ig [--oapi] [--only-oapi]

using --oapi to also generate OpenAPI definitions using epatools, while --only-oapi only performs this step.

Everything together

Build the FHIR definitions and FHIR IG

fhirscripts build all [--req] [--cap] [--oapi]

with --req, --cap and --oapi additionally enabling the steps mentioned before.

Pipeline

Build from a pipeline defined in the configuration

fhirscripts build pipeline

The pipeline is defined like

- <step>
- <step>:<args>

Available steps are:

Step Name Arguments Description
sushi None Run FSH Sushi
igpub None Run IG Publisher
igpub_qa None Display IG Publisher QA results
requirements None Process requirements using igtools
cap_statements None Process and merge CapabilityStatements using epatools
openapi None Generate OpenAPI definitions using epatools and add the to the IG archive
shell Shell command Execute a command on the shell, e.g. "touch file"

Publish

Requirements:

  • publishtools, either as component or using pipx

Publish and therefore preparing information from either a FHIR project or a FHIR IG registry, e.g. gematik FHIR IG Registry.

FHIR Project

Publish a FHIR project

fhirscripts publish [--project-dir <projectdir>] --ig-registry <igregistry>

from the current directory or <projectdir> if provided. This will generate JSON file containing the IG history and an HTML file representing the rendered history.

It will also update the FHIR IG registry in the <igregistry> directory. This will update a JSON file containing all versions of all IGs published by your organization, an HTML rendered version of it and update the package-feed.xml that can be used to publish your FHIR packages to the official FHIR registry.

Deploy

Requirements:

  • gcloud CLI

Deploy a generated FHIR IG onto a Google Bucket

fhirscripts deploy <env> [-y|--yes] [--all|--only-ig|--only-history|--ig-registry]

in the environment named <env>. This nneds to match an environment defined in the config in the deploy section.

-y/--yes confirms all prompts with yes. Otherwise, the path to upload to and overwriting need to be confirmed.

By default the FHIR IG is deployed. With --all the IG and the IG history are deployed and with --only-ig or --only-history only the respective part is deployed.

If not an IG but a a FHIR registry should be deployed use --ig-registry.

Bash script

The FHIR Scripts scripts provide commands that support the develop process for FHIR profiles and IGs.

The following commands arw available:

Command Description
update Update the script itself
pytools Update the Python tools, e.g. igtools, epatools
tools Update Sushi and IG Publisher
fhircache Rebuild FHIR cache
bdcache Delete the build cache
build Build IG
deploy Deploy an IG

Update the script itself

Download the latest version of the script to the current directory.

Update the Python tools

Install the latest version of the Python tools:

Update Sushi and IG Publisher

Install the latest version of FSH Sushi and IG Publisher.

Rebuild FHIR Cache

Clears the FHIR cache and rebuilds it from FHIR packages. Optionally it can install packages from a local directory and cache dependency packages in this directory.

./fhir_scripts.sh fhircache [<pkgdir>]

When <pkgdir> is provided, the dependencies from package.json are read and available packages from <pkgdir> will be installed. Additionally, direct dependencies that are not present in <pkgdir> will be downloaded for later usages.

Delete the build cache

Delete cached schemas and TX from input-cache/.

Build IG

Performs several steps to support the process of building a FHIR IG.

It is separated into two parts, building

  • the FHIR definitions
  • the FHIR IG

whereas, the optional argument noig only builds the definitions and nodefs only builds the IG.

FHIR Definitions

Steps:

  • Track and update requirements and update release notes, if igtools are available
  • Build FHIR definitions using FSH Sushi
  • Merge CapabilityStatements, if epatools are available

FHIR IG

Steps:

  • Build IG using IG Publisher
  • Generate OpenAPI specifications, if epatools are available
  • Update archived IG, if epatools are available

For building the IG config.sh needs to present in the current directory defining the publish URL for the IG Publisher as PUBLISH_URL. For updating the archive a list of files needs to be defined as CONTENT_FILES.

Deploy an IG

Deploy the IG from the build directory (output/) to the webserver.

Google Cloud

Uses a gCloud as a target and requires the following tools:

  • gcloud
  • gsutils

The IG will be deployed to <bucket>/<path>/<version>. Depending on the argument dev or prod the respective bucket is used.

First, it is checked if logged in into a gcloud Account and starting the login process, if not. Then, the path in the bucket is checked if empty, cleared if not and the files copied afterwards.

The configuration is read from a config.sh file in the current directory defining:

TARGET=<version>
BUCKET_PATH=<path>
BUCKET_NAME_DEV=<dev-bucket>
BUCKET_NAME_PROD=<prod-ucket>

Re-usable github Workflows

These are the available workflows from this repository:

Build Profiles

Build (re-)build the FSH definition using the lastest version of FSH Sushi and commit possible changes. To use this workflow

name: Build Profiles

on:
  pull_request:
    paths:
      - "**/build-profiles.yml"
      - "**.fsh"
      - "**/sushi-config.yaml"
    branches:
      - main
      - develop

  push:
    paths:
      - "**/build-profiles.yml"
      - "**.fsh"
      - "**/sushi-config.yaml"
    branches:
      - main
      - develop
    tags:
      - v*


permissions:
  contents: write

jobs:
  build-profiles:
    uses: gematik/fhir-scripts/.github/workflows/build-profiles.yml

Process Requirements

Process the requirements that are specified in the Markdown files using igtools and commit possible changes. To use the workflow

name: Process Requirements

on:
  pull_request:
    paths:
      - "**/process-requirements.yml"
      - "**.md"
    branches:
      - main
      - develop

  push:
    paths:
      - "**/process-requirements.yml"
      - "**.md"
    branches:
      - main
      - develop

  workflow_dispatch:

permissions:
  contents: write

jobs:
  build-profiles:
    uses: gematik/fhir-scripts/.github/workflows/process-requirements.yml

About

Collection of command line scripts to support the creation, publication and deployment process of FHIR profiles and IGs.

Topics

Resources

License

Stars

Watchers

Forks