Skip to main content

A library and actor to communicate with an STA Archon controller.

Project description

archon

Versions Documentation Status Test codecov

A library and actor to communicate with an STA Archon controller.

Installation

In general you should be able to install archon by doing

pip install sdss-archon

To build from source, use

git clone git@github.com:sdss/archon
cd archon
pip install .

Docker

The actor can run as a Docker container; new images for main (pointing to tag latest) and tags are created via a GitHub Action. The images are stored in the GitHub Container Registry. To pull the latest image run

docker pull ghcr.io/sdss/archon:latest

To run a container

docker run --name archon --rm --detach --network host ghcr.io/sdss/archon:latest

This assumes that RabbitMQ is running on the default port in the host computer and that the Archon controllers are accessible over the host network.

Development

archon uses poetry for dependency management and packaging. To work with an editable install it's recommended that you setup poetry and install archon in a virtual environment by doing

poetry install

Or in editable mode

pip install -e .

Note that the latter will only install the production dependencies, not the development ones. You'll need to install those manually (see pyproject.toml [tool.poetry.dev-dependencies]).

Style and type checking

This project uses the black code style with 88-character line lengths for code and docstrings. It is recommended that you run black on save. Imports must be sorted using isort. The GitHub test workflow checks all the Python file to make sure they comply with the black formatting.

Linting uses flake8 and isort rules implemented using ruff.

For Visual Studio Code, the following project file is compatible with the project configuration:

{
  "[python]": {
    "editor.formatOnSave": true,
    "editor.codeActionsOnSave": {
      "source.fixAll": "explicit",
      "source.organizeImports.ruff": "explicit"
    },
    "editor.wordWrap": "off",
    "editor.tabSize": 4,
    "editor.defaultFormatter": "ms-python.black-formatter"
  },
  "[markdown]": {
    "editor.wordWrapColumn": 88
  },
  "[restructuredtext]": {
    "editor.wordWrapColumn": 88
  },
  "[json]": {
    "editor.quickSuggestions": {
      "strings": true
    },
    "editor.suggest.insertMode": "replace",
    "gitlens.codeLens.scopes": ["document"],
    "editor.formatOnSave": true,
    "editor.defaultFormatter": "esbenp.prettier-vscode",
    "editor.tabSize": 2
  },
  "[yaml]": {
    "editor.insertSpaces": true,
    "editor.formatOnSave": true,
    "editor.tabSize": 2,
    "editor.autoIndent": "advanced",
    "gitlens.codeLens.scopes": ["document"]
  },
  "prettier.tabWidth": 2,
  "editor.rulers": [88],
  "editor.wordWrapColumn": 88,
  "python.analysis.typeCheckingMode": "basic"
}

This assumes that the Python and Pylance extensions are installed.

This project uses type hints.

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

sdss_archon-0.15.5.tar.gz (44.4 kB view details)

Uploaded Source

Built Distribution

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

sdss_archon-0.15.5-py3-none-any.whl (59.5 kB view details)

Uploaded Python 3

File details

Details for the file sdss_archon-0.15.5.tar.gz.

File metadata

  • Download URL: sdss_archon-0.15.5.tar.gz
  • Upload date:
  • Size: 44.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sdss_archon-0.15.5.tar.gz
Algorithm Hash digest
SHA256 dc07f48857d0bfe9316d2a093666ccf9f048c8ac4b4fef85839088ce2c4e2bea
MD5 a38c4eef379a0a401d4d8fb2529f506e
BLAKE2b-256 461d37fe0dc42fc445911465ea3117b6e6ea75164098dbbaecbcab8b5e500c8a

See more details on using hashes here.

Provenance

The following attestation bundles were made for sdss_archon-0.15.5.tar.gz:

Publisher: release.yml on sdss/archon

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

File details

Details for the file sdss_archon-0.15.5-py3-none-any.whl.

File metadata

  • Download URL: sdss_archon-0.15.5-py3-none-any.whl
  • Upload date:
  • Size: 59.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sdss_archon-0.15.5-py3-none-any.whl
Algorithm Hash digest
SHA256 72513b91820a3ac07c5aa299ba756437b10298535eb6b31cbf971234bfc0558e
MD5 d06e25b04ae167d6aa669ffe5e2ccdf3
BLAKE2b-256 72ccbb6a7879deb3eb0f78a0eb2f80c94d8c29b1525970470726421c8c006e9e

See more details on using hashes here.

Provenance

The following attestation bundles were made for sdss_archon-0.15.5-py3-none-any.whl:

Publisher: release.yml on sdss/archon

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