Skip to content

Latest commit

 

History

History

octavia-cli

🐙 Octavia CLI

Octavia CLI is a tool to manage Airbyte configuration in YAML. It has the following features:

  • Scaffolding of a readable directory architecture that will host the YAML configs.
  • Auto-generation of YAML config file that matches the resources' schemas.
  • Manage Airbyte resources with YAML config files.
  • Safe resources update through diff display and validation.
  • Simple secret management to avoid versioning credentials.

The project is under development: readers can refer to our tech spec deck for an introduction to the tool.

Usage

We encourage users to use the CLI with docker to avoid the hassle of setting up a Python installation. The project is under development: we have not yet published any docker image to our Docker registry.

  1. Build the image locally:
docker build -t octavia-cli:dev --rm .
  1. Run the CLI from docker:
docker run octavia-cli:dev 
  1. Create an octavia alias in your .bashrc or .zshrc:
echo 'alias octavia="docker run octavia-cli:dev"'  >> ~/.zshrc
source ~/.zshrc
octavia

Current development status

Octavia is currently under development. You can find a detailed and updated execution plan here. We welcome community contributions!

Summary of achievements:

Date Milestone
2021-12-22 Bootstrapping the project's code base

Developing locally

  1. Install Python 3.10.0. We suggest doing it through pyenv
  2. Create a virtualenv: python -m venv .venv
  3. Activate the virtualenv: source .venv/bin/activate
  4. Install dev dependencies: pip install -e .\[dev\]
  5. Install pre-commit hooks: pre-commit install
  6. Run the test suite: pytest --cov=octavia_cli unit_tests
  7. Iterate; please check the Contributing for instructions on contributing.

Contributing

  1. Please sign up to Airbyte's Slack workspace and join the #octavia-cli. We'll sync up community efforts in this channel.
  2. Read the execution plan and find a task you'd like to work on.
  3. Open a PR, make sure to test your code thoroughly.