Skip to main content

MarvisX OSS — agent-native company-brain CLI runtime (init, status, brief, triage)

Project description

marvis init

Interactive bootstrap wizard for MarvisX OSS. Five prompts (license, storage, BYOK, first project, recap) reusing the shared core/wizard/ state machine so the CLI and the Console /welcome route produce byte-identical settings when given the same answers.

Install

pip install marvisx-cli
marvis init

Pre-install (clone and run) works too:

python -m core.cli.marvis_init init

Quick start (interactive)

marvis init

You will be asked:

  1. License — accept BSL 1.1 (y/n).
  2. Storage — projects root path, database backend (sqlite or postgres), and either the SQLite file path or the Postgres DSN.
  3. LLM provider (BYOK)anthropic, openai, mac_gateway, bedrock, or skip. API key prompt is hidden input. Mac gateway asks for the base URL.
  4. First project — name, slug, and type (code, work, system).
  5. Recap — review choices, confirm.

On confirmation the wizard writes:

  • ~/.marvis/settings.yaml — workspace + storage + llm choice (no secrets), chmod 600.
  • ~/.marvis/master.key + ~/.marvis/byok.vault — Fernet-encrypted API key store (only if a provider was chosen).
  • <projects_root>/<slug>/project.yaml — first project seed.

Non-interactive / CI

marvis init \
  --accept-bsl \
  --no-interactive \
  --projects-root /var/lib/marvis/projects \
  --db-backend sqlite \
  --db-path /var/lib/marvis/console.db \
  --llm-provider anthropic \
  --llm-api-key "$ANTHROPIC_API_KEY" \
  --project-name "Local Workspace" \
  --project-slug local-workspace \
  --project-type code

YAML preset (preferred for repeatable provisioning):

marvis init --no-interactive --config init.yaml

init.yaml:

welcome:
  bsl_accepted: true
storage:
  projects_root: /var/lib/marvis/projects
  db_backend: sqlite
  db_path: /var/lib/marvis/console.db
llm_provider:
  provider: anthropic
  api_key: sk-ant-...
first_project:
  name: Local Workspace
  slug: local-workspace
  type: code

Dry run

marvis init --dry-run --accept-bsl --no-interactive ...

Prints the planned filesystem writes and the rendered settings.yaml without touching the disk. Exit 0.

Exit codes

Code Meaning
0 Success (or dry-run)
1 Generic runtime error
2 User abort at recap confirmation
3 Validation failure (field-level errors printed)

Tests

python -m pytest tests/test_cli_marvis_init.py

Ten cases cover dry-run, non-interactive flags, YAML preset, BYOK vault write, invalid slug rejection, Postgres backend, interactive prompts via CliRunner(input=...), BSL gate, and show-state JSON dump.

Relation to core/scripts/marvis-init.sh

marvis-init.sh (bash) is a deploy bootstrap: copies deploy/_template/, renders .env with secrets, runs setup-server.sh, and brings up Docker Compose. It targets server administrators provisioning a host.

marvis init (this Python CLI) is an onboarding wizard: writes settings.yaml + BYOK vault + first project seed in the user's home. It targets OSS users running MarvisX locally.

The two flows are complementary and will converge in a later phase. Until then both ship side-by-side.

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

marvisx_cli-0.2.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

marvisx_cli-0.2.0-py3-none-any.whl (1.5 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: marvisx_cli-0.2.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for marvisx_cli-0.2.0.tar.gz
Algorithm Hash digest
SHA256 f2186b8fd5ca905cc8fb3407767c4355c4e5de2bfac102478e308bf832378e9f
MD5 6e10dd579fc0a77af13b60ce34e822a0
BLAKE2b-256 5b644b2d81af16388f42d63ef0d0692759d172d36698d2f2f58730a4a0ae6a57

See more details on using hashes here.

Provenance

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

Publisher: release.yml on emiliomartucci/marvisx-oss

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

File details

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

File metadata

  • Download URL: marvisx_cli-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 1.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for marvisx_cli-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e0d3a605c753dca3e2a035f28e2dd001932b80ce609cb0670bd3917c7e83f292
MD5 7024fb529a701e2528c733105fc653df
BLAKE2b-256 a24a78d64bbae5e90323f6c88de1ff41a2fe4daa4caac61b794ff13ec9c53517

See more details on using hashes here.

Provenance

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

Publisher: release.yml on emiliomartucci/marvisx-oss

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