Datalad Metadata Model
Project description
Datalad Metadata Model
This software implements the metadata model that datalad and datalad-metalad will use in the future (datalad-metalad>=0.3.0) to handle metadata.
Model Elements (the model layer)
The metadata model is defined by the API of the top-level classes. Those are:
-
MetadataRootRecord
-- holds top-level metadata information for a single version of a datalad dataset -
UUIDSet
-- holds metadata root records for a set of datasets that are identified by their UUIDs and their version. -
TreeVersionList
-- holds metadata root records and a sub-dataset tree for a dataset version and its sub-datasets -
Metadata
-- represents metadata for a single item, i.e. dataset or file. Metadata is associated with extractor names and extraction parameters. -
DatasetTree
-- a representation of the sub-dataset hierarchy of a dataset -
FileTree
-- a representation of the file-tree of a dataset -
...
Because of the large size of some datalad-datasets, e.g. tens of thousands of sub-datasets and hundres of millions of files, the implementation allows focus-based operations on individual parts of the potentially very large metadata model. The implementation uses the proxy-pattern, that means, it loads, modifies, and saves only the minimal necessary model elements that are necessary to operate on the metadata-information that the user is interested in.
Storage layer
The model elements have to be persisted on a storage backend. How the model is mapped on storage backends is defined by the storage layer, that is to a large degree independent of the model layer. The intention is to support multiple storage backends in the past.
Currently only one storage backend is supported:
git-mapping
-- a storage backend that stores a metadata model in a git repository. The model objects are stored outside of existing branches. They are referenced bydatalad
-specific git-references underrefs/datalad/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for datalad-metadata-model-0.3.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | ec42bf834b09bc3ce78cecb5d95859296c15df414fd9567959f85945a0c1103b |
|
MD5 | 098bf7f83d99a379386138bcee9c3c9f |
|
BLAKE2b-256 | 1bf71e49bbaf5685c3d27c220b9ebd08db872950aeea25085312933f05c4c3e9 |
Hashes for datalad_metadata_model-0.3.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 63b506762d7133b9d963e4aa773cdc1909a946bbeb0386c1d3d6b4759879c11d |
|
MD5 | d8554d680a00bab5721f7bdb9f2b7449 |
|
BLAKE2b-256 | 8fb4268832a1896f37413800346ff43d2dfdebaf09dbb6c05a93054525cbe4c8 |