During the 2025 OME-NGFF Workflows Hackathon, participants discussed the potential need for a way to programmatically determine OME-NGFF tool capabilities. This repo is a place to experiment with schemas for capability manifests for OME-Zarr-compatible tools.
Current OME-NGFF (i.e. OME-Zarr) tools tend to support different aspects of the specification. Image viewers are purpose built and may only support a subset of possible data features. At the highest level, the specification is still rapidly evolving and any given tool may only support data up to a certain data version (including RFCs). Even when a tool supports a given OME-NGFF version, the specification is complex enough that tool developers may forgo implementing certain aspects of the specification, especially when those aspects are not aligned with the viewer use cases (e.g. an EM-oriented tool may not implement support for HCS plates).
Each tool could optionally publish a "capability manifest" which describes the tool's implementd capabilities with regards to the current and former NGFF Specifications. This manifest could simply live in the tool's Github repo, to be updated whenever relevant changes are made to the code. This manifest can then be interpreted computationally by any platform that wants to launch OME-NGFF tools (OMERO, BFF, Fileglancer, etc.)
This package can be used as a library to determine which OME-Zarr viewers are compatible with a given dataset. The caller provides manifest URLs; the library fetches, parses, and validates them.
npm install @bioimagetools/capability-manifestimport {
loadManifestsFromUrls,
getCompatibleViewers,
type OmeZarrMetadata,
} from "@bioimagetools/capability-manifest";
// Load manifests from URLs you control
const manifestMap = await loadManifestsFromUrls([
"https://example.com/viewers/neuroglancer.yaml",
"https://example.com/viewers/avivator.yaml",
]);
const manifests = [...manifestMap.values()];
// For each dataset, pass manifests and pre-parsed metadata
const metadata: OmeZarrMetadata = {
version: "0.4",
axes: [
{ name: "z", type: "space" },
{ name: "y", type: "space" },
{ name: "x", type: "space" },
],
// ... other metadata
};
// Get list of compatible viewer names
const viewers = getCompatibleViewers(manifests, metadata);
// Returns: ['Avivator', 'Neuroglancer']Fetches and parses capability manifest YAML files from the provided URLs.
- Parameters:
manifestUrls: Array of URLs pointing to capability manifest YAML files
- Returns: Map keyed by URL to the successfully loaded ViewerManifest
- Behavior: Uses
Promise.allSettledfor graceful partial failure. Logs warnings for failed URLs but does not throw. Validates that each manifest hasviewer.name(string),viewer.version(string), andcapabilities(object).
Returns array of viewer names that are compatible with the given dataset metadata.
- Parameters:
manifests: Array of viewer manifests to check againstmetadata: Pre-parsed OME-Zarr metadata object (use ome-zarr.js or similar to parse from Zarr stores)
- Returns: Array of viewer names (e.g.,
['Avivator', 'Neuroglancer'])
getCompatibleViewersWithDetails(manifests: ViewerManifest[], metadata: OmeZarrMetadata): Array<{name: string, validation: ValidationResult}>
Returns detailed compatibility information including validation errors and warnings for each compatible viewer. Useful for debugging or displaying why certain viewers work/don't work.
Returns whether a single viewer is compatible with the given metadata.
Returns full validation details (dataCompatible, dataFeaturesSupported, errors, warnings) for a single viewer against the given metadata.
The library exports TypeScript types for all data structures:
ViewerManifest- Structure of viewer capability manifestsOmeZarrMetadata- Structure of OME-Zarr metadataValidationResult- Validation outcome with errors/warningsValidationError,ValidationWarning- Detailed validation messagesAxisMetadata,MultiscaleMetadata- Nested metadata types
Icons for canonical viewers are hosted in the public/icons/ directory and served via GitHub Pages at:
https://raw.githubusercontent.com/bioimagetools/capability-manifest/host-manifests-and-docs/public/icons/{slug}.png
where {slug} is the viewer name lowercased with spaces replaced by hyphens (e.g. "OME-Zarr Validator" → ome-zarr-validator.png). Consumers can derive this URL automatically and fall back to a local placeholder when the icon is unavailable.
The logo field in the viewer section is an optional override for cases where this convention does not apply.
This repository hosts canonical capability manifests for well-known OME-Zarr viewers in the manifests/ directory:
| Manifest | Viewer | OME-Zarr Versions |
|---|---|---|
| neuroglancer.yaml | Neuroglancer | 0.4, 0.5 |
| avivator.yaml | Avivator (Viv) | 0.4 |
| validator.yaml | OME-Zarr Validator | 0.4, 0.5 |
| vole.yaml | Vol-E | 0.4, 0.5 |
Consumers can load these manifests by URL directly from GitHub (raw content URLs) or host copies on their own infrastructure.
Viewer developers are encouraged to maintain their own manifests and submit PRs to update the canonical versions here when capabilities change.
A capability manifest is a YAML file with two top-level sections: viewer and capabilities.
Identifies the tool and provides a URL template for launching it.
| Field | Type | Required | Description |
|---|---|---|---|
name |
string | yes | Human-readable name of the viewer |
version |
string | yes | Version of the viewer these capabilities describe |
repo |
string | no | URL of the source code repository |
logo |
string | no | URL to a logo image for the viewer. Optional override — consumers may derive a logo URL by convention (see Icons). Omit if the conventional path applies. |
template_url |
string | no | URL template for opening a dataset. Use {DATA_URL} as a placeholder for the dataset URL — consumers replace it at runtime with the actual OME-Zarr location |
Example:
viewer:
name: "Neuroglancer"
version: "2.41.2"
repo: "https://github.com/google/neuroglancer"
template_url: https://neuroglancer-demo.appspot.com/#!{"layers":[{"name":"image","source":"{DATA_URL}","type":"image"}]}Describes which OME-Zarr features the tool supports. All fields are optional — omitting a field means the capability is unknown/undeclared.
| Field | Type | Description |
|---|---|---|
ome_zarr_versions |
number[] | OME-NGFF specification versions the tool can load (e.g. [0.4, 0.5]). When a dataset's multiscales metadata contains a version listed here, the tool should be able to open it. |
compression_codecs |
string[] | Compression codecs the tool can decode (e.g. ["blosc", "zstd", "gzip"]). An empty array [] means the tool does not declare codec support — compatibility is unknown rather than unsupported. |
rfcs_supported |
number[] | RFC numbers implemented on top of the released OME-NGFF versions. Given test data for a listed RFC, the tool should handle it. |
axes |
boolean | Whether axis names and units from the metadata are respected |
scale |
boolean | Whether scaling factors on multiscale datasets are respected |
translation |
boolean | Whether translation offsets (including subpixel offsets for lower scale levels) are respected |
channels |
boolean | Whether the tool supports datasets with multiple channels (c axis) |
timepoints |
boolean | Whether the tool supports datasets with multiple timepoints (t axis) |
labels |
boolean | Whether pixel-annotation metadata in the "labels" group is loaded |
hcs_plates |
boolean | Whether high content screening datasets in the "plate" group are loaded |
bioformats2raw_layout |
boolean | Whether the tool can open Zarr stores using the bioformats2raw transitional layout |
omero_metadata |
boolean | Whether the tool uses OMERO metadata (e.g. to set default channel colors) |
Example:
capabilities:
ome_zarr_versions: [0.4, 0.5]
compression_codecs: ["blosc", "zstd", "gzip"]
rfcs_supported: []
axes: true
scale: true
translation: true
channels: true
timepoints: true
labels: false
hcs_plates: false
bioformats2raw_layout: false
omero_metadata: trueThe validateViewer() function checks a manifest's declared capabilities against a dataset's OmeZarrMetadata and returns a ValidationResult:
interface ValidationResult {
dataCompatible: boolean; // true if no errors (viewer can open the data)
dataFeaturesSupported: boolean; // true if no warnings (viewer fully supports all data features)
errors: ValidationError[]; // hard failures — data will not load
warnings: ValidationWarning[]; // soft issues — data loads but features may be missing
}Capabilities fall into two levels:
- Data compatibility (
errors): Hard requirements. If unmet, the viewer cannot open or render the data at all — it should not be shown. - Data support (
warnings): Soft requirements. If unmet, the viewer can still open the data but may not display certain features — it should still be shown, with warnings logged or surfaced to the user.
The checks performed, in order:
| Check | Metadata field | Manifest field | Level | Result if mismatch |
|---|---|---|---|---|
| OME-Zarr version | version or multiscales[0].version |
ome_zarr_versions |
Compatibility | Error — viewer cannot load this version |
| Compression codec | compressor.id |
compression_codecs |
Compatibility | Error if codec not listed; Warning if viewer declares no codecs (unknown support) |
| Axes metadata | axes |
axes |
Support | Warning — axis names/units may be ignored |
| Channel support | axes contains c/channel |
channels |
Support | Warning — multi-channel data may not render correctly |
| Timepoint support | axes contains t/time |
timepoints |
Support | Warning — time-series data may not render correctly |
| Labels | labels array non-empty |
labels |
Support | Warning — labels won't be displayed |
| HCS plates | plate present |
hcs_plates |
Support | Warning — plate layout won't be shown |
| OMERO metadata | omero present |
omero_metadata |
Support | Warning — channel colors etc. won't be applied |
| Scale transforms | multiscales[].datasets[].coordinateTransformations type scale |
scale |
Support | Warning — scaling factors may be ignored |
| Translation offsets | multiscales[].datasets[].coordinateTransformations type translation |
translation |
Support | Warning — coordinate offsets may be ignored |
| bioformats2raw layout | bioformats2raw_layout |
bioformats2raw_layout |
Support | Warning — layout may not be traversed correctly |
Note on
rfcs_supported: Althoughrfcs_supportedis a hard compatibility requirement (it determines whether a viewer can parse RFC-mandated metadata structures), no validation check is currently implemented. OME-NGFF metadata does not yet expose which RFCs a dataset requires — this is a spec-level gap. When the spec defines arfcs_requiredfield, the validator will compare it againstviewer.capabilities.rfcs_supportedand produce an error on mismatch.
A viewer is considered data-compatible (dataCompatible: true) when there are zero errors — it should be shown to the user. dataFeaturesSupported is false when there are warnings, indicating the viewer can open the data but may not display all features.
There is a prototype in this repo which implements a basic compatibility matrix by fetching the individual viewer manifests.
To publish a new version to npm manually:
# 1. Run tests
npm test
# 2. Clean and build the library (compiles TypeScript to dist/)
rm -rf dist && npm run build:lib
# 3. Bump the version in package.json (patch, minor, or major)
# Using this command automatically makes a commit with the
# updated package.json and package-lock.json
npm version patch # e.g. 0.3.1 -> 0.3.2
# 4. Login to npm (if not already) and publish
# (uses "publishConfig": {"access": "public"} from package.json)
npm login
npm publish
# 5. Push the version commit
git push