Skip to main content

Arcsecond desktop and Hub bootstrap client

Project description

Focale

Focale is a thin desktop/CLI bootstrap for Arcsecond users that:

  • logs in with the user's Arcsecond account
  • creates and stores a local Hub agent identity
  • enrolls that identity with Arcsecond when needed
  • mints a short-lived Hub JWT
  • connects to the Arcsecond Hub using the signed Ed25519 challenge flow

The package depends on the published arcsecond CLI/library and reuses its account configuration instead of creating a second login system.

By default, Focale uses Arcsecond password login to obtain a short-lived bearer JWT plus a refresh token. That avoids storing a long-lived Access Key in the normal path. Access Key login is still available as a fallback.

User install

Python / terminal

pip install focale

Then:

focale login
focale context list
focale context use personal
focale connect --hub-url wss://hub.arcsecond.io/ws/agent

Windows installer

This repository includes a bootstrap for building a Windows installer from CI. The installer packages the focale executable and can optionally add it to PATH.

See:

Commands

focale login
focale login --auth-mode access-key
focale status
focale context show
focale context list
focale context use personal
focale context use my-observatory
focale doctor --hub-url wss://hub.arcsecond.io/ws/agent
focale doctor --hub-url wss://hub.arcsecond.io/ws/agent --json
focale connect --hub-url wss://hub.arcsecond.io/ws/agent
focale --api-server https://api.arcsecond.dev connect --hub-url wss://hub.arcsecond.dev/ws/agent --once
focale connect --organisation my-observatory --hub-url wss://hub.arcsecond.io/ws/agent
focale platesolver status
focale platesolver solve --peaks-file ./peaks.json

focale connect will automatically:

  1. refresh the Arcsecond access JWT when needed
  2. create a local Ed25519 keypair if needed
  3. enroll a personal or organisation-scoped agent installation if needed
  4. mint a Hub JWT
  5. discover local ASCOM Remote (Alpaca) servers and register new ones in the selected context
  6. complete the Hub challenge-response handshake

You can set the default context once and keep connect/doctor simple:

focale context use personal
# or
focale context use my-observatory

Plate solving

Plate solving is included with pip install focalearcsecond-service-platesolver-astrometry is a mandatory dependency and ships native binaries for Windows, macOS, and Linux with no Docker or external tooling required.

focale platesolver status
focale platesolver solve --peaks-file ./peaks.json --scales 6

You can also target a remote service:

focale platesolver status --service-url http://127.0.0.1:8900
focale platesolver solve --service-url http://127.0.0.1:8900 --peaks-file ./peaks.json

Development

If you are developing Focale next to the local Arcsecond CLI checkout:

python -m venv .venv
source .venv/bin/activate
pip install -e ../arcsecond-cli
pip install -e .[dev]
pytest -q

Publishing

This repo includes:

  • a PEP 621 pyproject.toml
  • a CI workflow for tests
  • a PyPI publish workflow on tags such as v0.2.0
  • a Windows installer workflow that builds a PyInstaller bundle and wraps it with Inno Setup

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

focale-0.2.0.tar.gz (22.3 kB view details)

Uploaded Source

Built Distribution

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

focale-0.2.0-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file focale-0.2.0.tar.gz.

File metadata

  • Download URL: focale-0.2.0.tar.gz
  • Upload date:
  • Size: 22.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for focale-0.2.0.tar.gz
Algorithm Hash digest
SHA256 ea64bd8874c8e2c79129fecc8cbb840ea78f0445ce2684abf656052ac7bf2dab
MD5 e5baa89d5ea8421034334a2236aa6786
BLAKE2b-256 94e032279bd70781391819fe41c9e857aa87222b170b65e9d1c8dad19785de38

See more details on using hashes here.

Provenance

The following attestation bundles were made for focale-0.2.0.tar.gz:

Publisher: publish.yml on arcsecond-io/focale

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

File details

Details for the file focale-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: focale-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for focale-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b873bb67996372ac2f744f8d377e25bec63bd62ba229a762ab48a707a1f0e1e1
MD5 2772a138f343641df13735318e388521
BLAKE2b-256 514c66358c38f3fefeac62321fcd69f3ea982f12a130420e01fc7185455c547e

See more details on using hashes here.

Provenance

The following attestation bundles were made for focale-0.2.0-py3-none-any.whl:

Publisher: publish.yml on arcsecond-io/focale

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