Releases: FHIR/fhir-package-loader
FPL 2.2.4
FPL 2.2.3
FPL 2.2.2
FHIR Package Loader 2.2.2 is a patch release that ensures that bearer tokens are always used for accessing a custom registry server when both FPL_REGISTRY and FPL_REGISTRY_TOKEN environment variables are set. The prior release did not use the bearer token in all cases.
What's Changed
Full Changelog: v2.2.1...v2.2.2
FPL 2.2.1
FPL 2.2.0
This release supports specifying an auth header to use when accessing a custom NPM registry. To do so, specify your bearer token in the FPL_REGISTRY_TOKEN environment variable. Many thanks to @bkaney for this contribution.
What's Changed
Full Changelog: v2.1.2...v2.2.0
FPL 2.1.2
This release contains a small fix to downgrade the severity from error to warning when a #current dependency can't be downloaded from the build server but already exists in the cache (so processing can continue). This change follows from this discussion on Zulip: #IG creation > Issue using version-specific packages.
What's Changed
Full Changelog: v2.1.1...v2.1.2
FPL 2.1.1
FPL 2.1.0
FPL 2.1.0 adds implementations to allow FPL to be used within browser-based web applications (e.g., FSH Online). The primary implementation of interest is BrowserBasedPackageCache, which stores downloaded packages into the browser's IndexedDB. The FHIRRegistryClient has also been updated to take a new option indicating that it should use browser-friendly libraries for downloading dependencies.
What's Changed
Full Changelog: v2.0.1...v2.1.0
FPL 2.0.1
FHIR Package Loader 2.0.1 is a patch release that fixes FPL's file system interaction for Node 18 versions prior to Node 18.20.
The previous version, FHIR Package Loader 2.0.0, was a major release with significant breaking changes. See the FHIR Package Loader 2.0.0 Release Notes for further details about that release.
What's Changed
Full Changelog: v2.0.0...v2.0.1
FPL 2.0.0
FHIR Package Loader 2.0.0 introduces a total rewrite of the FHIR Package Loader -- with completely new interfaces, implementations, and APIs. As such, this version has significant breaking changes when compared to the previous version of the FHIR Package Loader. These changes were necessary to address limitations in the package loader as well as support future use cases (such as transitive dependencies, multiple versions of the the same package, etc).
The new FHIR Package Loader now utilizes an in-memory database (currently sql.js) to store and query metadata about packages and their resources. This reduces memory usage per-resource since now only the metadata is kept in memory (vs the entire JSON object). With more efficient memory usage, we can now load all resources from the package (instead of just conformance resources) and we will also be able to load transitive packages in the future.
Separate concerns of the package loader have been separated out into their own interfaces and implementations, including:
PackageDBinterface w/SQLJSPackageDBimplementation. Note that sql.js was chosen due to its support for synchronous queries -- which causes the least disruption to SUSHI (which has many synchronous functions).RegistryClientinterface w/FHIRRegistryClient,NPMRegistryClient,RedundantRegistryClient, andDefaultRegistryClientimplementationsCurrentBuildClientinterface w/BuildDotFhirDotOrgClientimplementationPackageCacheinterface w/DiskBasedPackageCacheimplementationVirtualPackageinterface w/DiskBasedVirtualPackageandInMemoryVirtualPackageimplementationsPackageLoaderinterface w/BasePackageLoaderimplementation that accepts implementations of the previous interfaces and ties them together for a complete package loading solution.
This release is totally different from the v1 release. As such, any projects that use the existing v1 version of the FHIR Package Loader will need to be updated to use the brand new API introduced in v2. For more information on the new API, view the README.
What's Changed
Code Changes
- FHIR Package Loader Rewrite by @cmoesel in #42
- Refactor sql.js out of SQLJSPackageDB constructor by @cmoesel in #45
- Rename newSQLJSPackageDB to createSQLJSPackageDB by @cmoesel in #47
Documentation Changes
- Add security policy by @mint-thompson in #24
- Add Contribution Policy by @jafeltra in #25
- Best Practices by @jafeltra in #26
- Add FHIR Foundation project statement to readme by @mint-thompson in #31
- Replace MITRE in copyright and project statement "maintainers" section by @mint-thompson in #37
- Link to Knowledge Sharing Sessions by @jafeltra in #38
Full Changelog: v1.0.0...v2.0.0