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 usingsudo)
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 OpenAPIigtools: Handle requirementspublishtools: Support the publish workflow
Get information about the usage with
fhirscripts --helpThe 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>Get the version of installed tooling
fhirscripts versionsInstall one or multiple tools
fhirscripts install --<tool> [--<tool> [...]]Get a list of available tools to install
fhirscripts install --helpTools to be installed can also be defined in the config giving the name of the tool
fhirscripts install --config-fileand the respective entry in the config file:
install:
- <tool>
- <tool2>Update each installed tool
fhirscripts updateRebuild 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.
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.
One can also update the tooling before building with --update.
Optional steps for the following steps can be defined using the builtin section in the config.
build:
builtin:
igtools: true
epatools:
cap_statements: true
openapi: true
# 'epatools' can also be defined to enable or disable all steps
# epatools: trueBuild 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.
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.
Build the FHIR definitions and FHIR IG
fhirscripts build all [--req] [--cap] [--oapi]with --req, --cap and --oapi additionally enabling the steps mentioned before.
Build from a pipeline defined in the configuration
fhirscripts build pipelineThe pipeline is defined like
build:
pipeline:
- <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" |
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.
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.
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.
The documentation has been moved to /scripts.
These are the available workflows from this repository:
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.ymlProcess 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.ymlCopyright 2025 gematik GmbH
Apache License, Version 2.0
See the LICENSE for the specific language governing permissions and limitations under the License.
- Copyright notice: Each published work result is accompanied by an explicit statement of the license conditions for use. These are regularly typical conditions in connection with open source or free software. Programs described/provided/linked here are free software, unless otherwise stated.
- Permission notice: Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
- The copyright notice (Item 1) and the permission notice (Item 2) shall be included in all copies or substantial portions of the Software.
- The software is provided "as is" without warranty of any kind, either express or implied, including, but not limited to, the warranties of fitness for a particular purpose, merchantability, and/or non-infringement. The authors or copyright holders shall not be liable in any manner whatsoever for any damages or other claims arising from, out of or in connection with the software or the use or other dealings with the software, whether in an action of contract, tort, or otherwise.
- The software is the result of research and development activities, therefore not necessarily quality assured and without the character of a liable product. For this reason, gematik does not provide any support or other user assistance (unless otherwise stated in individual cases and without justification of a legal obligation). Furthermore, there is no claim to further development and adaptation of the results to a more current state of the art.
- Gematik may remove published results temporarily or permanently from the place of publication at any time without prior notice or justification.
- Please note: Parts of this code may have been generated using AI-supported technology. Please take this into account, especially when troubleshooting, for security analyses and possible adjustments.