Skip to main content

PyPI launcher for the ReplyLayer CLI

Project description

rly

rly is the PyPI launcher for the ReplyLayer CLI.

pipx install rly
rly --help

On Debian and Ubuntu systems that enforce PEP 668, plain pip install rly may fail with externally-managed-environment. Use pipx install rly for a global CLI install, or install inside a virtual environment:

python3 -m venv .venv
. .venv/bin/activate
pip install rly

The installed rly command delegates to the official npm package replylayer, pinned exactly to the matching launcher version (see Strict pin policy below).

Requirements

  • Python 3.10+
  • Node.js 22+ with npm/npx on PATH
  • pipx for the recommended global install path

Examples

rly auth login
rly mailbox list
rly inbox list --mailbox support-bot

For full CLI documentation, see the ReplyLayer repository: https://github.com/mcintoshjames-sketch/ReplyLayer

Environment variables

RLY_TIMEOUT_SECONDS

Opt-in subprocess timeout, in seconds. When set, every rly invocation is bounded by subprocess.run(..., timeout=RLY_TIMEOUT_SECONDS); if the underlying npx process does not exit in time the launcher prints a diagnostic to stderr and exits with code 124.

By default there is no timeout, with one narrow exception: the help and version short-circuits (--help, -h, --version, -V) carry a built-in 10-second timeout. Those commands should never need to touch the network beyond an initial registry resolve; bounding them lets you diagnose a restricted-network sandbox without affecting legitimate long-poll commands like rly inbox wait --timeout 60.

RLY_TIMEOUT_SECONDS=30 rly inbox list --mailbox support-bot

Set the value high enough to cover the slowest command you reasonably expect. Setting it to a non-integer string is treated as "no timeout" (graceful fallback rather than a launcher crash).

RLY_OFFLINE

Set RLY_OFFLINE=1 to force npx to resolve replylayer from the local cache only. The launcher passes both --offline on the command line and npm_config_offline=true in the subprocess environment (belt-and-suspenders; --prefer-offline is NOT a no-network guarantee).

If the pinned replylayer version isn't cached locally, npx exits fast with its own non-zero exit code (typically 1 with ENOTCACHED); the wrapper passes that exit code through verbatim — it does NOT normalize it to 124. Exit code 124 is reserved for the wrapper's own timeout branch.

# Populate the cache once, online:
rly --version
# Subsequent calls can run offline:
RLY_OFFLINE=1 rly --version

RLY_OFFLINE=1 is useful in network-restricted CI sandboxes, air-gapped deployments, or any environment where you want a hard guarantee that the launcher will not reach out to the npm registry.

Strict pin policy

rly@X.Y.Z always resolves replylayer@X.Y.Z exactly — there is no @latest resolution and no semver range. The launcher computes the pinned package string at runtime via importlib.metadata.version('rly'), so the two artifacts always move together.

This means:

  • A published rly@X.Y.Z cannot ride a later patch-level replylayer release; both packages must be republished together. The matched-pair release runbook lives at docs/runbooks/cli-release.md in the ReplyLayer repository.
  • Source installs from the repository between a launcher-only PR and the paired version bump are intentionally unsupported. Use pipx install rly (PyPI) or npm install -g replylayer (npm) as the supported install paths.

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

rly-0.1.3.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

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

rly-0.1.3-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file rly-0.1.3.tar.gz.

File metadata

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

File hashes

Hashes for rly-0.1.3.tar.gz
Algorithm Hash digest
SHA256 925935af582500be317ded9e286a7338f076cb034d24b53914964333b5c15378
MD5 5066d1ff556f1996c2f140890892a6a8
BLAKE2b-256 7ec61eef4973b9a7ef9fe3bc10a32ef61f2f6b4f30c13de7ce23297012fc5bf3

See more details on using hashes here.

Provenance

The following attestation bundles were made for rly-0.1.3.tar.gz:

Publisher: publish-rly.yml on mcintoshjames-sketch/ReplyLayer

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

File details

Details for the file rly-0.1.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for rly-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 758c3a360dfe24daadb42e4424f45a9d7d913e2334e64b2d5242148b0be5f126
MD5 409ac9c23978e16fe57c002ab905233f
BLAKE2b-256 51efc825a6d40431ca46b76ecbee7339c3d10033e027b8f6969cbac0df080b83

See more details on using hashes here.

Provenance

The following attestation bundles were made for rly-0.1.3-py3-none-any.whl:

Publisher: publish-rly.yml on mcintoshjames-sketch/ReplyLayer

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