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 project locally (from the root of the repo):
SUB_BUILD=OCTAVIA_CLI ./gradlew build #from the root of the repo
  1. Run the CLI from docker:
docker run airbyte/octavia-cli:dev 
  1. Create an octavia alias in your .bashrc or .zshrc:
echo 'alias octavia="docker run airbyte/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
2022-03-02 Implement octavia apply (sources and destination only)
2022-02-06 Implement octavia generate (sources and destination only)
2022-01-25 Implement octavia init + some context checks
2022-01-19 Implement octavia list workspace sources, octavia list workspace destinations, octavia list workspace connections
2022-01-17 Implement octavia list connectors source and octavia list connectors destinations
2022-01-17 Generate an API Python client from our Open API spec
2021-12-22 Bootstrapping the project's code base

Developing locally

  1. Install Python 3.8.12. 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 .\[tests\]
  5. Install pre-commit hooks: pre-commit install
  6. Run the unittest suite: pytest --cov=octavia_cli
  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.