/cheqd-infra

DevOps & infrastructure tooling for cheqd: the purpose-built network for decentralised identity. Accelerate deployment for cheqd-node on cloud providers.

Primary LanguageHCLApache License 2.0Apache-2.0

DevOps & Automation Tooling for cheqd

The goal of this project is to make infrastructure provisioning and configuration dead simple for cheqd network.

Objectives

We aim to make DevOps and automation for cheqd network simpler by accelerating the following:

Infrastructure provisioning

This is how we create secure private networks, firewalls, storage systems, volume mounting, static IP allocation, CPU and memory allocation among other things across multiple cloud platforms.

Currently we support DigitalOcean and Hetzner. We chose to implement this tooling on these providers since they offer a good balance between cost vs performance for running cheqd nodes. However, our Terragrunt configuration (described below) can be used to generate Terraform for other cloud providers as well.

Node configuration

For configuring our nodes, we use Ansible, an open source and free configuration management tool. We use Ansible for running our seed, sentry, and validator nodes. We also use it for installing any debugging packages, setting up logs and metrics collection using Datadog.

Pre-Requisites

Terraform

Terraform is an open-source infrastructure as code software tool that enables you to safely and predictably create, change, and improve infrastructure. Being de facto the industry standard Infrastructure as Code tool, it is our pick for infrastructure provisioning.
Code located in its respective directory can be used to provision the necessary infrastructure for DigitalOcean and Hetzner cloud providers.

Terragrunt

Terragrunt is a thin wrapper for Terraform that provides extra tools for keeping Terraform configurations DRY (don't repeat yourself).

We've utilised this tool to keep the Terraform code clean. Examples and further details can be found in its own directory.

Ansible

Ansible is an open source community project sponsored by Red Hat. Our Ansible scripts directory contains various configuration files and scripts that one might find useful. There is no one tool this directory pertains to, but should rather be seen as a collective place for a variety of technologies.

Configuration

All the sub-modules include their own documentation, like terraform/digital-ocean has the list of all the variables, which must be set before we provision our infrastructure.

Repository breakdown

.
├── ansible
└── terraform
    ├── digital-ocean
    └── hetzner

🐞 Bug reports & 🤔 feature requests

If you notice anything not behaving how you expected, or would like to make a suggestion / request for a new feature, please create a new issue and let us know.

💬 Community

The cheqd Community Slack is our primary chat channel for the open-source community, software developers, and node operators.

Please reach out to us there for discussions, help, and feedback on the project.

🙋 Find us elsewhere

Telegram Discord Twitter LinkedIn Slack Medium YouTube