Representation of Arches graphs for client and server side manipulation
Project description
(Unofficial) Arches ORM [EXPERIMENTAL]
This provides simple (server-side) access to Arches resources from Python as Python objects. It makes no guarantees about efficiency or type-accuracy but such issues raised will be addressed as far as possible.
Installation
Basic installation can then happen as follows, without Arches backend support:
pip install .
To run tests, make sure you have libsqlite3-mod-spatialite, or your distribution's equivalent
package for enabling Spatialite in Python. Instead of using a real Arches PostgreSQL database, we spin
a fresh test database up in memory.
WARNING: The mock DB behaviour for Python testing is not identical to a real Arches database, but is adequately close for now, is fast and has no server dependency.
There are several sets of optional dependencies.
GraphQL
Turns Arches ORM into an API server for Arches.
pip install .[graphql]
Arches
Allows Arches ORM to directly manipulate the Arches database.
pip install .[arches]
Test
Runs tests across the various backends.
pip install .[tests]
Well-known Resource Models
To provide a partial boundary, this package expects a settings object called
WELL_KNOWN_RESOURCE_MODELS to list, at least, the models that should be
wrapped by this system.
It should be a list:
WELL_KNOWN_RESOURCE_MODELS = [
{
"model_name": "Person",
"graphid": "4110f743-1a44-11e9-9a37-000d3ab1e500",
"nodes": {}, # optional additional configuration
"to_string": lambda wkrm: str(wkrm) # optional callback for stringifying
}
]
You must not take this list as an exclusive boundary of data that can be accessed.
Hooks
This package also contains experimental functionality for hooking tile saves,
so that client code can use the MyModel.post_save signal to get well-known
resource model events. To avoid any unintended overhead, it does not load
unless explicitly turned on with arches_orm.add_hooks().
Tests
Note that the tests require spatialite and so a Python that allows Sqlite3
extension loading:
PYTHON_CONFIGURE_OPTS="--enable-loadable-sqlite-extensions" pyenv install 3.10.10
Documentation
Documentation is available on https://flaxandteal.github.io/arches-orm/.
Thanks
Particular thanks to the funders of this work, and to the Arches community for their work on which this builds. Particular thanks to Historic England's team for the underlying resource models used in the test-cases.
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file arches_orm-0.4.2.tar.gz.
File metadata
- Download URL: arches_orm-0.4.2.tar.gz
- Upload date:
- Size: 1.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2f7bea7e72eb8e2b697ccbf5935300d81e54ada0bc0a169b1e050868696f00d8
|
|
| MD5 |
cb1001276a2405194218b4239eeffcbf
|
|
| BLAKE2b-256 |
2a95e450a4dcf064b01e6443b657ee9d2b12e512e4e82ee7f2ecddd5c7c536ef
|
Provenance
The following attestation bundles were made for arches_orm-0.4.2.tar.gz:
Publisher:
python-publish.yml on flaxandteal/arches-orm
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
arches_orm-0.4.2.tar.gz -
Subject digest:
2f7bea7e72eb8e2b697ccbf5935300d81e54ada0bc0a169b1e050868696f00d8 - Sigstore transparency entry: 430629122
- Sigstore integration time:
-
Permalink:
flaxandteal/arches-orm@8ce26dbe31c268e5fe6fe2c7b5f3c058ad3b087e -
Branch / Tag:
refs/tags/v0.4.2 - Owner: https://github.com/flaxandteal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@8ce26dbe31c268e5fe6fe2c7b5f3c058ad3b087e -
Trigger Event:
push
-
Statement type:
File details
Details for the file arches_orm-0.4.2-py3-none-any.whl.
File metadata
- Download URL: arches_orm-0.4.2-py3-none-any.whl
- Upload date:
- Size: 141.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f18aa8aa96f526fb8acd6cc690ae4da2cbcd22c01d2f7fb28580e2020d47356f
|
|
| MD5 |
b7b54d26bc26b1d67ae76da1b97e942e
|
|
| BLAKE2b-256 |
bc0d72d458b8964cd2a1d86b15529fea419926c2ddbbae2517bcaee24445ebfa
|
Provenance
The following attestation bundles were made for arches_orm-0.4.2-py3-none-any.whl:
Publisher:
python-publish.yml on flaxandteal/arches-orm
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
arches_orm-0.4.2-py3-none-any.whl -
Subject digest:
f18aa8aa96f526fb8acd6cc690ae4da2cbcd22c01d2f7fb28580e2020d47356f - Sigstore transparency entry: 430629163
- Sigstore integration time:
-
Permalink:
flaxandteal/arches-orm@8ce26dbe31c268e5fe6fe2c7b5f3c058ad3b087e -
Branch / Tag:
refs/tags/v0.4.2 - Owner: https://github.com/flaxandteal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@8ce26dbe31c268e5fe6fe2c7b5f3c058ad3b087e -
Trigger Event:
push
-
Statement type: