Hl7.Fhir.Specification.R4 5.0.0-beta1

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
This is a prerelease version of Hl7.Fhir.Specification.R4.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Hl7.Fhir.Specification.R4 --version 5.0.0-beta1
NuGet\Install-Package Hl7.Fhir.Specification.R4 -Version 5.0.0-beta1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Hl7.Fhir.Specification.R4" Version="5.0.0-beta1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Hl7.Fhir.Specification.R4 --version 5.0.0-beta1
#r "nuget: Hl7.Fhir.Specification.R4, 5.0.0-beta1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Hl7.Fhir.Specification.R4 as a Cake Addin
#addin nuget:?package=Hl7.Fhir.Specification.R4&version=5.0.0-beta1&prerelease

// Install Hl7.Fhir.Specification.R4 as a Cake Tool
#tool nuget:?package=Hl7.Fhir.Specification.R4&version=5.0.0-beta1&prerelease

Build Status

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.

IMPORTANT Version 5.0 of the SDK is in beta. Navigate back to the main repository for the stable 4.x release.

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:

  • DSTU1 (published September 2014) is mostly obsolete and we are no longer maintaining this library for DSTU1.
  • DSTU2 (published October 2015) is mostly obsolete and and we are no longer maintaining this library for DSTU2.
  • STU3 (published March 2017) is older, but still widely in use. Is fully supported by this library.
  • R4 (published January 2019) is in active use and fully supported by this library.
  • R4B (published May 2022) is the latest official release of the FHIR spec and is fully supported by this library.
  • R5 (not yet published) is work-in-progress. This library currently supports "snapshot-1".

Planned release DSTU2.1 was never published by HL7, but you will still find traces of it. We are not maintaining the version, but the NuGet package is still available.

Read the online documentation, and download the correct NuGet package 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.

Spec version Git branch NuGet
R5 https://github.com/FirelyTeam/firely-net-sdk/tree/release/5.0.0 https://www.nuget.org/packages/Hl7.Fhir.R5
R4B https://github.com/FirelyTeam/firely-net-sdk/tree/release/5.0.0 https://www.nuget.org/packages/Hl7.Fhir.R4B
R4 https://github.com/FirelyTeam/firely-net-sdk/tree/release/5.0.0 https://www.nuget.org/packages/Hl7.Fhir.R4
STU3 https://github.com/FirelyTeam/firely-net-sdk/tree/release/5.0.0 https://www.nuget.org/packages/Hl7.Fhir.STU3
DSTU2 https://github.com/FirelyTeam/firely-net-sdk/tree/develop-dstu2 https://www.nuget.org/packages/Hl7.Fhir.DSTU2

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 totally restructured for the 5.0 release. Please take not of the following changes if you are upgrading:

  • The additional Hl7.Fhir.Specification packages are no longer relevant starting at version 5.0 of the SDK and should not be included in your projects anymore.
  • The main NuGet package no longer contains the specification.zip file that contains all the conformance resources used in the FHIR specification. If you are using the ZipSource resolvers (e.g. for profile validation), you will need to include the correct HL7.Fhir.Specification.Data.* NuGet packages. We recommend you look at the newer FhirPackageResolver that directly use the HL7-published NPM packages. Documentation can be found here.
  • The profile validator has been split off into its own repository. The NuGet packages for the 5.0 version of the profile validator will be posted soon.

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 separate common repository (at https://github.com/FirelyTeam/firely-net-common) is no longer in use. This greatly simplifies management and creating PRs for these projects.

There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages (13)

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"

brianpos.Fhir.R4.DemoFileSystemFhirServer

Demonstration implementation of a FHIR R4 Facade using the file system as a super simple storage provider

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Hl7.Fhir.Specification.R4:

Repository Stars
microsoft/fhir-server
A service that implements the FHIR standard
Version Downloads Last updated
5.8.0 45 4/24/2024
5.7.0 816 3/15/2024
5.6.1 1,771 2/13/2024
5.6.0 850 2/13/2024
5.5.1 1,732 1/16/2024
5.5.0 1,207 1/10/2024
5.4.0 4,094 10/26/2023
5.3.0 26,886 7/27/2023
5.2.0 3,135 5/26/2023
5.1.0 2,750 4/28/2023
5.0.0 4,100 2/17/2023
5.0.0-beta1 2,013 12/21/2022
4.3.0 171,280 9/22/2022
4.2.1 14,229 8/17/2022
4.2.0 1,221 8/16/2022
4.1.0 7,792 7/7/2022
4.0.0 57,204 5/10/2022
4.0.0-beta2 1,284 3/4/2022
4.0.0-beta1 687 2/7/2022
3.8.3 4,300 4/28/2022
3.8.2 37,011 3/28/2022
3.8.1 3,168 3/4/2022
3.8.0 18,874 1/7/2022
3.7.0 4,964 12/1/2021
3.6.0 19,400 10/15/2021
3.5.0 35,311 9/2/2021
3.4.0 10,904 6/30/2021
3.3.0 4,346 6/2/2021
3.2.0 7,142 5/4/2021
3.1.0 6,009 4/1/2021
3.0.0 19,849 2/25/2021
2.0.3 13,840 1/26/2021
2.0.2 1,689 1/22/2021
2.0.1 16,223 11/25/2020
2.0.0 1,252 11/16/2020
2.0.0-beta2 944 9/22/2020
2.0.0-beta1 2,897 7/16/2020
1.9.0 28,794 7/23/2020
1.8.0 1,672 7/2/2020
1.7.0 31,513 5/6/2020
1.6.0 21,725 3/4/2020
1.5.0 24,129 2/4/2020
1.5.0-beta1 1,289 12/19/2019
1.4.0 12,806 10/10/2019
1.3.0 8,371 7/10/2019
1.2.1 6,955 4/16/2019
1.2.0 1,286 3/29/2019
1.2.0-beta2 1,182 2/28/2019
1.2.0-beta1 1,095 2/20/2019
0.96.1 3,933 9/25/2018
0.96.0 1,715 6/6/2018