Table of Contents
Cloudscript is an Infrastructure as Code (IaC) language designed to simplify the deployment and management of cloud resources, applications, and configurations. With Cloudscript, you can combine the functionality of Terraform, Ansible, and Kubernetes into a single, cohesive .cloud file for seamless orchestration.
- Unified Syntax: Define infrastructure, configurations, and containers in one file.
- Multi-Provider Support: Easily target multiple cloud providers.
- Simplified Workflows: Define the order of operations and dependencies between components.
- Extensibility: Configure containers, virtual machines, and Kubernetes clusters with intuitive blocks.
- Deployment Patterns: Apply mappings and conditional deployments using simple syntax.
- Enhanced Syntax Features:
- Enhanced For Loops: Simplify iteration over lists and ranges.
- Type Definitions: Define reusable and structured types.
- Calculated Fields (
calc
): Dynamically compute field values. - Functions: Create reusable logic blocks.
- Encapsulates the entire deployment, including infrastructure, configuration, and containers.
- Specifies the
provider
,order
of operations, and global settings for the application.
- Declares the cloud provider to target (e.g., AWS, GCP, Azure).
-
Defines the foundational resources required for the deployment.
- Network: Sets up virtual private networks, subnets, and IP configurations.
- Compute: Provisions virtual machines or compute instances with desired specifications.
- Kubernetes: Manages Kubernetes clusters, node pools, and their configurations.
- Handles server setup, including:
- Installing packages or tools.
- Running initialization commands.
- Verifying server readiness through validation scripts.
- Defines containerized applications and their runtime specifications.
- Includes settings for images, replicas, ports, environment variables, and health checks.
- Configures resource limits and requests for CPU and memory.
- Manages how components are applied and interact.
- Mappings: Connect infrastructure components to configurations or services.
- Patterns: Specify conditional logic for deployment based on tags or attributes.
-
cloud convert [file path]
- Converts your .cloud file into the appropriate Terraform, Ansible and Kubernetes files within an IaC directory.
- Ensures valid syntax for the .cloud file.
-
cloud plan [file path]
- Executes a comprehensive dry-run for all Terraform, Kubernetes, and Ansible code.
- Key features:
- Requires Docker for Kubernetes planning.
- Identifies issues in syntax, linting, and deployment feasibility.
- Outputs a detailed report highlighting potential problems before deployment.
-
cloud apply [file path]
- Deploys the specified Terraform, Kubernetes, and Ansible code.
- Key features:
- Applies changes incrementally and returns errors if there are mismatches between planning and applying.
- Provides deployment status for each component.
-
cloud destroy [file path]
- Tears down all resources defined in the
.cloud
file. - Destroys Terraform, Kubernetes, and Ansible-managed instances, ensuring a clean removal of all resources.
- Tears down all resources defined in the
- Docker: Required for Kubernetes planning and applying.
- Dependencies: Terraform, Kubernetes CLI, and Ansible must be installed and accessible in your environment.
-
Install Python Package (if applicable): Run the following command to install the required Python package:
pip install -e .
-
Install Kubernetes CLI Tools:
- Install
kubectl
(Kubernetes CLI):brew install kubectl
- Install
minikube
(for running Kubernetes locally):brew install minikube
- Install
-
Download and Open Docker Daemon:
- Install Docker Desktop from Docker's official site.
- Once installed, open Docker Desktop and ensure the Docker Daemon is running.
# Convert a cloud file
cloud convert my_infrastructure.cloud
# Preview the deployment plan
cloud plan my_infrastructure.cloud
# Deploy all resources
cloud apply my_infrastructure.cloud
# Destroy all resources
cloud destroy my_infrastructure.cloud
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
) - Commit your Changes (
git commit -m 'Add some AmazingFeature'
) - Push to the Branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
Distributed under the MIT License. See LICENSE.txt
for more information.
Project Link: https://github.com/o37-autoforge/cloud/