Go to file
hl7-devops 7e54ae9c89 Release: v6.5.0
## Validator Changes

* Add support for valueset-version
* Add support for terminology extraction
* Add support for expansion parameters when validating
* fix NPE in validator around Extension context
* Handle secondary terminology server errors properly
* Fix questionnaire response status checking
* Add versions to message about multiple matching profiles
* hide API-Key from appearing on the tx log
* Add supplements for used systems as well as for value set systems when validating on server
* fix missing port from server when doing tx-registry redirections
* Fix problem not finding current version of extensions pack for non-R5 versions
* Fix validation of displays when language is unknown
* fix issue missing idrefs validating IPS documents
* Update FHIRPath validation to handle rootResource type properly
* Fix obscure error on contentReference in profiles in FHIRPath engine
* Fix version conversion issue for validating derived questionnaires

## Other code changes

* New release of pubpack
* Fix r4b liquid tests
* Refactor Liquid engine and add support for forLoop and capture
* Add support for liquid on csv files
* Add support for using Liquid on plain JSON directly and add support for markdownify filter
* Many improvements to Profile Code Generation
* Start working on using new IG infrastructure for Tx tests
* Questionnaire rendering improvements
* Merge Functionality for CapabilityStatement.import
* Do not use metadata from data type profiles on elements when generating snapshots
* Fix presentation issues and union and intersection links in previous version comparison
* Fix filter comparison logic when comparing valuesets
* Fix version issues in snapshot generation tests
* Eliminate id from snapshot generation test case comparison
* Change rules around stripping extensions when generating snapshots
* fix bug using wrong reference on uri in liquid renderer
* add translations for expansion errors
* fix issue with comparison template missing
* Apply null pointer check to all switch(Enumeration) statements in version conversion code
* Remove mysql dependency
* Fix bug in DecimalType on null Bigdecimal ()] all versions)
* Fix bad URL in inter-version extension conversion of ValueSet for ValueSet property
***NO_CI***
2024-12-10 00:02:07 +00:00
.azure/i18n-coverage-table Adjust table formatting and title 2024-04-23 11:46:41 -04:00
.github Fix TRIVY typo 2024-10-07 16:23:17 -04:00
.mvn/wrapper Update maven wrapper version (#1769) 2024-10-28 09:10:03 -04:00
org.hl7.fhir.convertors Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.core.generator get generator running again 2024-08-16 11:58:55 +08:00
org.hl7.fhir.dstu2 Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.dstu3 Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.dstu2016may Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.r4 Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.r4b Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.r5 Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.report Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.utilities Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.validation Release: v6.5.0 2024-12-10 00:02:07 +00:00
org.hl7.fhir.validation.cli Release: v6.5.0 2024-12-10 00:02:07 +00:00
.codeql-config.yml Restore CodeQL regex queries (#1422) 2023-09-01 12:47:59 -04:00
.editorconfig Get this test working (#4) 2019-01-31 13:41:05 -05:00
.gitignore release notes 2024-10-08 17:39:33 +08:00
LICENSE.txt Externalized code now committed 2019-01-13 14:33:14 -06:00
README.md Tip for Windows users for building 2024-10-31 07:55:02 +11:00
RELEASE_NOTES.md release notes 2024-12-09 07:52:33 +04:00
RELEASE_NOTES.template.md Create release notes template 2022-02-03 16:46:54 -05:00
cache-target-tasks-template.yml Refactor Master Pipeline (#1278) 2023-05-26 09:32:13 -04:00
checkstyle.xml Add javadoc and useful messages from checkstyle 2024-11-20 11:06:56 -05:00
checkstyle_suppressions.xml Automate testing for XMLUtils factory methods 2024-11-19 16:46:01 -05:00
codecov.yml PR Build Refactor 2 (#1137) 2023-02-24 22:11:43 -05:00
compare updated code.bat generated patterns + improved package cache errors 2019-05-10 00:08:18 +10:00
cve-suppression.xml Add OWASP dependency check (#1347) 2023-07-14 10:56:40 -04:00
i18n-coverage-table.png Updating i18n-coverage csv and png table ***NO_CI*** 2024-12-08 17:18:15 +00:00
i18n-coverage.csv Updating i18n-coverage csv and png table ***NO_CI*** 2024-12-08 17:18:15 +00:00
master-branch-pipeline.yml Update master-branch-pipeline.yml 2024-11-09 10:44:55 -05:00
mvnw Update maven wrapper version (#1769) 2024-10-28 09:10:03 -04:00
mvnw.cmd Update maven wrapper version (#1769) 2024-10-28 09:10:03 -04:00
owasp-suppression-file.xml Add OWASP suppression (#1377) 2023-08-01 14:03:40 -04:00
pom.xml Release: v6.5.0 2024-12-10 00:02:07 +00:00
pull-request-pipeline.yml Update azure maven tasks to version 4 (#1726) 2024-08-29 11:39:47 -04:00
r4 test resources.lnk fix bug validating unknown code system 2019-01-29 21:46:02 +11:00
release-branch-pipeline.yml Update azure maven tasks to version 4 (#1726) 2024-08-29 11:39:47 -04:00
security.md test cases dependency 2024-12-10 10:11:32 +11:00
setup-and-cache-job-template.yml Manage FhirRequestBuilders via ManagedWebAccess (#1788) 2024-11-08 16:42:26 -05:00
setup-signing-tasks-template.yml Refactor Master Pipeline (#1278) 2023-05-26 09:32:13 -04:00
test-cli-exec-job-template.yml Update azure maven tasks to version 4 (#1726) 2024-08-29 11:39:47 -04:00
test-unit-jobs-template.yml Update azure maven tasks to version 4 (#1726) 2024-08-29 11:39:47 -04:00
transifex.yml more transifex 2024-07-11 12:36:47 +08:00
validation test resources.lnk fix bug validating unknown code system 2019-01-29 21:46:02 +11:00

README.md

HAPI FHIR - HL7 FHIR Core Artifacts

CI Status (master)
Build Status

This is the java core object handling code, with utilities (including validator), for the FHIR specification. included in this repo:

  • org.fhir.fhir.utilities: Shared code used by all the other projects - including the internationalization code
  • org.fhir.fhir.r5: Object models and utilities for R5 candidate (will change regularly as new R5 candidates are released)
  • org.fhir.fhir.r4b: Object models and utilities for R4B
  • org.fhir.fhir.r4: Object models and utilities for R4
  • org.fhir.fhir.dstu3: Object models and utilities for STU3
  • org.fhir.fhir.dstu2: Object models and utilities for STU2
  • org.fhir.fhir.dstu2016may: Object models and utilities for an early STU3 candidate still used by some implementers
  • org.fhir.fhir.convertors: Code to convert between versions, and other version independence code - uses all the above projects
  • org.fhir.fhir.validation: The FHIR Java validator (note: based on R5 internally, but validates all the above versions)
  • org.fhir.fhir.validation.cli: Holder project for releasing the FHIR validator as as single fat jar (will be removed in the future)

This code is used in all HAPI servers and clients, and also is the HL7 maintained FHIR Validator. In addition, this is the core code for the HL7 maintained IG publisher and FHIR main build publisher. As such, this code is considered an authoritatively correct implementation of the core FHIR specification that it implements.

Building this Project

Prerequisites

This project uses Java (minumum version 11), Apache Maven, and Lombok to build. You can find detailed instructions on setting up this project in your IDE here.

Build Commands

To build and add artifacts to your local Maven repository:

mvn install

To skip unit tests:

mvn -Dmaven.test.skip install

Note: If you're on Windows and use PowerShell, The - needs to be escaped with a backtick (`)

mvn `-Dmaven.test.skip install

To clean and rebuild the terminology server caches:

clean

mvn clean -Dfhir.txcache.clean=true   

rebuild

mvn test -Dfhir.txcache.rebuild=true

The source contains cached terminology server responses for testing. If the expected responses have changed in any way, this cache should be cleaned and rebuilt with the above so that subsequent mvn test calls will have the most current responses cached.

To build only the validator_cli jar locally:

mvn clean package -Dmaven.test.skip=true --projects org.hl7.fhir.validation.cli --no-transfer-progress
cp org.hl7.fhir.validation.cli/target/org.hl7.fhir.validation.cli*-SNAPSHOT.jar ./validator_cli.jar

This will produce ./validator_cli.jar in the project root directory.

Releases

The built binary for the FHIR command-line validator is released through GitHub releases and can be downloaded directly here. For instructions on using this validator visit the FHIR Validator Confluence page.

All build artifacts are published on OSS Sonatype.

Current Versions

Project Current Release Latest SNAPSHOT
org.hl7.fhir.validation.cli Release Artifacts Snapshot Artifact
org.hl7.fhir.validation Release Artifacts Snapshot Artifact
org.hl7.fhir.dstu2 Release Artifacts Snapshot Artifact
org.hl7.fhir.dstu2016may Release Artifacts Snapshot Artifact
org.hl7.fhir.dstu3 Release Artifacts Snapshot Artifact
org.hl7.fhir.r4 Release Artifacts Snapshot Artifact
org.hl7.fhir.r5 Release Artifacts Snapshot Artifact

To use these artifacts in your project will need to add the proper dependency to your pom.xml file, or your build.gradle.kts file.

pom.xml
<repositories>
    <repository>
        <id>oss-snapshot</id>
        <url>https://oss.sonatype.org/content/repositories/snapshots/</url>
    </repository>
    <repository>
        <id>oss-releases</id>
        <url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
    </repository>
</repositories> 
build.gradle.kts
repositories {
    maven {
        url = uri("https://oss.sonatype.org/content/repositories/snapshots")
    }
    maven {
        url = uri("https://oss.sonatype.org/service/local/staging/deploy/maven2/")
    }
}

After adding the necessary repositories, you can include the libraries as follows:

org.hl7.fhir.validation.cli
Maven
<dependency>
    <groupId>ca.uhn.hapi.fhir</groupId>
    <artifactId>org.hl7.fhir.validation.cli</artifactId>
    <version>(latest version)</version>
</dependency>
Gradle
compile group: 'ca.uhn.hapi.fhir', name: 'org.hl7.fhir.validation.cli', version: '(latest version)'
org.hl7.fhir.dstu2
Maven
<dependency>
    <groupId>ca.uhn.hapi.fhir</groupId>
    <artifactId>hapi-fhir-structures-dstu2</artifactId>
    <version>(latest version)</version>
</dependency>
Gradle
compile group: 'ca.uhn.hapi.fhir', name: 'hapi-fhir-structures-dstu2', version: '(latest version)'
org.hl7.fhir.dstu3
Maven
<dependency>
    <groupId>ca.uhn.hapi.fhir</groupId>
    <artifactId>hapi-fhir-structures-dstu3</artifactId>
    <version>(latest version)</version>
</dependency>
Gradle
compile group: 'ca.uhn.hapi.fhir', name: 'hapi-fhir-structures-dstu3', version: '(latest version)'
org.hl7.fhir.r4
Maven
<dependency>
    <groupId>ca.uhn.hapi.fhir</groupId>
    <artifactId>hapi-fhir-structures-r4</artifactId>
    <version>(latest version)</version>
</dependency>
Gradle
compile group: 'ca.uhn.hapi.fhir', name: 'hapi-fhir-structures-r4', version: '(latest version)'
org.hl7.fhir.r5
Maven
<dependency>
    <groupId>ca.uhn.hapi.fhir</groupId>
    <artifactId>hapi-fhir-structures-r5</artifactId>
    <version>(latest version)</version>
</dependency>
Gradle
compile group: 'ca.uhn.hapi.fhir', name: 'hapi-fhir-structures-r5', version: '(latest version)'

Internationalization

This project implements internationalization for its user tools and utilities for several locales using a combination of GNU PO and Java Properties files.

Translation from the core library's original English locale to other supported locales is an ongoing process. The current level of coverage is calculated by the number of translated phrases, and can be viewed in the following figure:

Table of Internationalization Coverage

CI/CD

All integration and delivery done on Azure pipelines. Azure project can be viewed here.

  • Pull Request Pipeline is automatically run for every Pull Request to ensure that the project can be built via maven. [Azure Pipeline] [source]
  • Master Branch Pipeline is automatically run whenever code is merged to the master branch and builds the SNAPSHOT binaries distributed to OSSRH [Azure Pipeline][source]
  • Release Branch Pipeline is run manually whenever a release is ready to be made. It builds the release binaries, distributes them to artifact repositories and sends release notifications. [Azure Pipeline][source]

A brief overview of our publishing process is here.

For more detailed instructions on cutting a release, please read the wiki

Maintenance

Have you found an issue? Do you have a feature request? Great! Submit it here and we'll try to fix it as soon as possible.

This project is maintained by Grahame Grieve, James Agnew, David Otasek and Mark Iantorno on behalf of the FHIR community.