Skip to main content

The eikobot desired state engine.

Project description

Eikobot Desired State Engine

The little Desired State Engine that made it so.

Eikobot is a desired state orchestrator.
The basic idea is that you describe your infrastructure and eikobot will make it happen.

Eikobot is consists of the deployment engine and the Eiko language.

The language is akin to python, as this is a commonly used language and the language in which eikobot and eikobot plugins are written.
It is an Object Oriented language that has some powerfull features.
The most glaring thing is probably that the language has no functions, but this is an omission by design.

Some of it's notable features are:

  • Object oriented
  • sees the infrastructure as a tree of resources, rather than a flatland
  • completely stateless*

The quickest way to get started is probably by doing some of the quickstarts.
For a more complete idea of how the language works, please see the language overview.

(*If the model/modules are designed well.)

Installation

Eikobot requires python 3.10 or up and can be installed using pip.

Here is an example of how to install Eikobot:
(This should work on most platforms, although the python command is different if you are on windows)

python3.10 -m venv eikobot-venv
eikobot-venv/bin/pip install eikobot

You can now use the eikobot commands, either by invoking them directly with their venv path:

eikobot-venv/bin/eikobot

Or by activating the venv first:

. eikobot-venv/bin/activate
eikobot

Linters, type checkers, testing, etc

Currently this project uses:

  • mypy for advanced type checking
  • isort to auto format the imports
  • black to auto format code
  • flake8 to do basic linting (and pointing out where isort and black would make changes)
  • pylint for advanced linting and code smell detection
  • bandit to scan for security issues

Note that the flake8-isort and flake8-black plugins are used, and Flake8 will emit isort and black issues but not auto format them, these tools will still need to be ran afterwards to fix any errors.
The Flake8-pylint and Flake8-mypy plugins are not used as they are in broken state.

For vscode, adding the following settings to your config is recommended:

{
    "python.linting.flake8Enabled": true,
    "python.linting.mypyEnabled": true,
    "python.linting.pylintEnabled": true,
    "python.testing.pytestEnabled": true,
    "python.testing.pytestArgs": [],
    "editor.insertSpaces": true,
}

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

eikobot-0.5.0.tar.gz (64.8 kB view hashes)

Uploaded Source

Built Distribution

eikobot-0.5.0-py3-none-any.whl (68.5 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page