Hl7.Fhir.Specification.R4
6.0.0-alpha1
Prefix Reserved
dotnet add package Hl7.Fhir.Specification.R4 --version 6.0.0-alpha1
NuGet\Install-Package Hl7.Fhir.Specification.R4 -Version 6.0.0-alpha1
<PackageReference Include="Hl7.Fhir.Specification.R4" Version="6.0.0-alpha1" />
paket add Hl7.Fhir.Specification.R4 --version 6.0.0-alpha1
#r "nuget: Hl7.Fhir.Specification.R4, 6.0.0-alpha1"
// Install Hl7.Fhir.Specification.R4 as a Cake Addin #addin nuget:?package=Hl7.Fhir.Specification.R4&version=6.0.0-alpha1&prerelease // Install Hl7.Fhir.Specification.R4 as a Cake Tool #tool nuget:?package=Hl7.Fhir.Specification.R4&version=6.0.0-alpha1&prerelease
IMPORTANT The 5.0 version of the SDK contains substantial changes to the way we have organized the NuGet packages and source code. Please read before installing this new 5.0 version.
Introduction
This is Firely's official support SDK for working with HL7 FHIR on the Microsoft .NET (dotnet) platform.
This SDK provides:
- Class models for working with the FHIR data model using POCO's
- Xml and Json parsers and serializers
- A REST client for working with FHIR-compliant servers
- Helper classes to work with the specification metadata, most notably
StructureDefinition
and generation of differentials - Validation of instances based on profiles
- Evaluation FhirPath expressions
Release notes
Read the releases notes on firely-net-sdk/releases. You can find documentation about this SDK in the Firely docs site.
Getting Started
Before installing one of the NuGet packages (or clone the repo) it is important to understand that HL7 has published several updates of the FHIR specification, each with breaking changes - so you need to ensure you use the version that is right for you:
- STU3 (published March 2017) is older, but still widely in use and fully supported by the SDK.
- R4 (published January 2019) is in active use and fully supported by the SDK.
- R4B (published May 2022) is in active use and fully supported by the SDK.
- R5 (published March 26 2023) is the latest official release of the FHIR spec and is fully supported by the SDK.
Read the online documentation, and download the correct for your FHIR release. Depending on the version of FHIR you require, you'll find the relevant link to the package below. For most developers, just including this NuGet package is enough to get started.
Using a pre-release NuGet package
Every release of the SDK results in a NuGet package on the normal NuGet feed. However, each commit on our develop branch also results in a pre-release package.
These are public too. So if you want to be brave and use a pre-release packages, you can do so by adding https://nuget.pkg.github.com/FirelyTeam/index.json
to your NuGet sources:
Get a Personal Access token (PAT) from github.com with scope
read:packages
Next open a console on your machine and run
dotnet nuget add source --name github --username <USERNAME> --password <PAT> https://nuget.pkg.github.com/FirelyTeam/index.json
USERNAME
: your username on GitHub
PAT
: your Personal access token with at least the scope read:packages
Upgrading
We spend a lot of effort trying to maintain compile compatibility (not binary compatibility) between minor releases of the SDK. We do, however, publish a new major version with breaking changes about once a year. The table below lists the breaking changes for each of the major upgrades.
SDK version | Breaking changes |
---|---|
2.x | https://github.com/FirelyTeam/firely-net-sdk/wiki/Breaking-changes-in-2.0 |
3.x | https://github.com/FirelyTeam/firely-net-sdk/wiki/Breaking-changes-in-3.0 |
4.x | https://github.com/FirelyTeam/firely-net-sdk/wiki/Breaking-changes-in-4.0 |
5.x | https://github.com/FirelyTeam/firely-net-sdk/wiki/Breaking-changes-in-5.0 |
The SDK has been restructured for the 5.0 release. Please take note of the following changes if you are upgrading:
- You should only reference the main package (
Hl7.Fhir.<release>
). - If you need the
specification.zip
(for validation, if you are using theZipSource
resolver), addHl7.Fhir.Specification.Data.<release>
. - The "old"
Hl7.Fhir.Specification.<release>
package is now a metapackage that will include these two packages. - You should not reference any other packages that existed pre-5.0 (
Hl7.Fhir.ElementModel
etc.)
The profile validator has been split off into its own repository. The NuGet packages for the validator that are compatible with the SDK 5.0 release can be found on NuGet.
Support
We actively monitor the issues coming in through the GitHub repository at https://github.com/FirelyTeam/firely-net-sdk/issues. You are welcome to register your bugs and feature suggestions there. For questions and broader discussions, we use the .NET FHIR Implementers chat on Zulip.
Contributing
We are welcoming contributions!
If you want to participate in this project, we're using Git Flow for our branch management. Please submit PRs with changes against the develop
branche.
Note: Since the 5.0 release of the SDK, the branches for STU3 and newer have been combined in a single
develop
branch. This branch now contains the code for all FHIR releases from STU3 and up. We have also refactored all the common code out to projects within that branch, so the separatecommon
repository (at https://github.com/FirelyTeam/firely-net-common) is no longer in use. This greatly simplifies management and creating PRs for these projects.
Binary Compatibility
Our build pipeline automatically checks for binary compatibilty and fails when we break it. In some cases we can make an exception to break binary compatitibility.
To make sure the pipeline doesn't break, you should run dotnet pack /p:GenerateCompatibilitySuppressionFile=true
locally to generate a suppression file. Please commit this file to make sure the build passes.
Learn more about Target Frameworks and .NET Standard.
-
- Hl7.Fhir.R4 (>= 6.0.0-alpha1)
- Hl7.Fhir.Specification.Data.R4 (>= 6.0.0-alpha1)
NuGet packages (11)
Showing the top 5 NuGet packages that depend on Hl7.Fhir.Specification.R4:
Package | Downloads |
---|---|
Eir.FhirKhit.R4
FhirKhit tools for Fhir Release 4 |
|
FhirKhit.Tools.R4
FhirKhit tools for Fhir Release 4 |
|
FhirTool.Core
Package Description |
|
FhirStarter.R4.Detonator.Core
FhirStarter is a lightweight FHIR server framwork where the bare minimum of functionaliy gets your FHIR server up and running. The framework lets you create a FHIR service which can be based on several input sources and is joined a single output. The main library for the FhirStarter engine. Contains logic for the FHIR rest interface, structuredefinitions and much more that can be used as reference in other projects. There is also logic from FireLy's https://github.com/FirelyTeam/spark code. For tutorials, check out the wiki from the project url. For current project status, check out the project board for issues and assignment cards. *NOTE* Hl7.Fhir.Specification.R4 must be added directly to the FHIR server project (Twisted) for the validator to work. Icons made by https://www.flaticon.com/authors/roundicons" |
|
FhirStarter.R4.Instigator.Core
FhirStarter is a lightweight FHIR server framwork where the bare minimum of functionaliy gets your FHIR server up and running. The framework lets you create a FHIR service which can be based on several input sources and is joined a single output. The Instigator library has the necessary components to setup the FHIR server part of the service. The library will add a specific settings file + a log4net.config file which can be customized. The Detonator library is also necessary to setup the logic bits. For tutorials, check out the wiki from the project url. For current project status, check out the project board for issues and assignment cards. *NOTE* Hl7.Fhir.Specification.R4 must be added directly to the FHIR server project (Twisted) for the validator to work. Icons made by https://www.flaticon.com/authors/roundicons |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
6.0.0-alpha1 | 64 | 12/11/2024 |
5.11.1 | 1,239 | 11/25/2024 |
5.11.0 | 1,274 | 11/8/2024 |
5.10.3 | 1,087 | 9/19/2024 |
5.10.2 | 338 | 9/18/2024 |
5.10.1 | 461 | 9/12/2024 |
5.10.0 | 232 | 9/10/2024 |
5.9.1 | 1,495 | 8/8/2024 |
5.9.0 | 2,771 | 7/25/2024 |
5.8.2 | 583 | 7/10/2024 |
5.8.1 | 3,353 | 5/2/2024 |
5.8.0 | 295 | 4/24/2024 |
5.7.0 | 1,624 | 3/15/2024 |
5.6.1 | 4,206 | 2/13/2024 |
5.6.0 | 1,125 | 2/13/2024 |
5.5.1 | 3,434 | 1/16/2024 |
5.5.0 | 1,366 | 1/10/2024 |
5.4.0 | 6,996 | 10/26/2023 |
5.3.0 | 46,188 | 7/27/2023 |
5.2.0 | 3,445 | 5/26/2023 |
5.1.0 | 2,935 | 4/28/2023 |
5.0.0 | 4,748 | 2/17/2023 |
5.0.0-beta1 | 2,047 | 12/21/2022 |
4.3.0 | 298,292 | 9/22/2022 |
4.2.1 | 17,736 | 8/17/2022 |
4.2.0 | 1,270 | 8/16/2022 |
4.1.0 | 8,568 | 7/7/2022 |
4.0.0 | 85,563 | 5/10/2022 |
4.0.0-beta2 | 1,324 | 3/4/2022 |
4.0.0-beta1 | 742 | 2/7/2022 |
3.8.3 | 5,260 | 4/28/2022 |
3.8.2 | 39,118 | 3/28/2022 |
3.8.1 | 8,386 | 3/4/2022 |
3.8.0 | 19,304 | 1/7/2022 |
3.7.0 | 5,101 | 12/1/2021 |
3.6.0 | 19,768 | 10/15/2021 |
3.5.0 | 35,860 | 9/2/2021 |
3.4.0 | 12,259 | 6/30/2021 |
3.3.0 | 4,422 | 6/2/2021 |
3.2.0 | 7,266 | 5/4/2021 |
3.1.0 | 6,061 | 4/1/2021 |
3.0.0 | 21,067 | 2/25/2021 |
2.0.3 | 14,184 | 1/26/2021 |
2.0.2 | 1,744 | 1/22/2021 |
2.0.1 | 17,452 | 11/25/2020 |
2.0.0 | 1,305 | 11/16/2020 |
2.0.0-beta2 | 991 | 9/22/2020 |
2.0.0-beta1 | 3,033 | 7/16/2020 |
1.9.0 | 31,573 | 7/23/2020 |
1.8.0 | 1,725 | 7/2/2020 |
1.7.0 | 33,376 | 5/6/2020 |
1.6.0 | 21,901 | 3/4/2020 |
1.5.0 | 24,904 | 2/4/2020 |
1.5.0-beta1 | 1,347 | 12/19/2019 |
1.4.0 | 13,309 | 10/10/2019 |
1.3.0 | 8,745 | 7/10/2019 |
1.2.1 | 7,083 | 4/16/2019 |
1.2.0 | 1,339 | 3/29/2019 |
1.2.0-beta2 | 1,221 | 2/28/2019 |
1.2.0-beta1 | 1,130 | 2/20/2019 |
0.96.1 | 4,140 | 9/25/2018 |
0.96.0 | 1,767 | 6/6/2018 |