Skip to main content

Focale desktop and Hub bootstrap client

Project description

Focale

Focale is a small desktop/CLI bootstrap for Focale 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

Focale owns its own local state and uses Arcsecond password login to obtain a short-lived bearer JWT plus a refresh token.

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

Desktop GUI

python -m focale launches the PySide6 desktop app when no CLI arguments are given. The existing focale console script remains available for terminal-driven workflows.

Windows installer

This repository includes a bootstrap for building a Windows installer from CI. The installer packages the PySide6 desktop app as focale.exe.

See:

Commands

focale login
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-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

python -m venv .venv
source .venv/bin/activate
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.3.2.tar.gz (85.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.3.2-py3-none-any.whl (45.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for focale-0.3.2.tar.gz
Algorithm Hash digest
SHA256 22bf1b1b58e882c8b5d70e0649a992b6d4f4ee4595e1182c80ebd698111c6c4c
MD5 b653b45a2a6f2fe0ec4b9c02351ec076
BLAKE2b-256 f6ac63d25633f204294d64636e62afc8b313f383ab9de54ab70c61fab1035185

See more details on using hashes here.

Provenance

The following attestation bundles were made for focale-0.3.2.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.3.2-py3-none-any.whl.

File metadata

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

File hashes

Hashes for focale-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cf9cbfa5bb4ac38d94a03fb1922e16b550a2a0901949adda2e41e89515a5902f
MD5 559d5e6bc72c8548f586153bee6a792c
BLAKE2b-256 8ded905d53e3ba5888691806d19b7f1b90ee09fc7c95875881d2b2abc04597ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for focale-0.3.2-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