Skip to main content

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

arches_orm-0.4.2.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

arches_orm-0.4.2-py3-none-any.whl (141.9 kB view details)

Uploaded Python 3

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

Hashes for arches_orm-0.4.2.tar.gz
Algorithm Hash digest
SHA256 2f7bea7e72eb8e2b697ccbf5935300d81e54ada0bc0a169b1e050868696f00d8
MD5 cb1001276a2405194218b4239eeffcbf
BLAKE2b-256 2a95e450a4dcf064b01e6443b657ee9d2b12e512e4e82ee7f2ecddd5c7c536ef

See more details on using hashes here.

Provenance

The following attestation bundles were made for arches_orm-0.4.2.tar.gz:

Publisher: python-publish.yml on flaxandteal/arches-orm

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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

Hashes for arches_orm-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f18aa8aa96f526fb8acd6cc690ae4da2cbcd22c01d2f7fb28580e2020d47356f
MD5 b7b54d26bc26b1d67ae76da1b97e942e
BLAKE2b-256 bc0d72d458b8964cd2a1d86b15529fea419926c2ddbbae2517bcaee24445ebfa

See more details on using hashes here.

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

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page