{"id":20186162,"url":"https://github.com/startcloud/startcloud_roles","last_synced_at":"2026-06-08T12:01:21.593Z","repository":{"id":195945710,"uuid":"673923922","full_name":"STARTcloud/startcloud_roles","owner":"STARTcloud","description":"STARTcloud Ansible Roles","archived":false,"fork":false,"pushed_at":"2026-05-27T23:22:29.000Z","size":4629,"stargazers_count":0,"open_issues_count":2,"forks_count":3,"subscribers_count":2,"default_branch":"main","last_synced_at":"2026-05-28T01:19:43.712Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/STARTcloud.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2023-08-02T18:22:31.000Z","updated_at":"2026-05-27T23:22:33.000Z","dependencies_parsed_at":"2023-09-20T08:26:58.898Z","dependency_job_id":"cb8cfb0c-ccc4-4483-9db6-32f146c7d07a","html_url":"https://github.com/STARTcloud/startcloud_roles","commit_stats":null,"previous_names":["startcloud/startcloud_roles"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/STARTcloud/startcloud_roles","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/STARTcloud%2Fstartcloud_roles","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/STARTcloud%2Fstartcloud_roles/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/STARTcloud%2Fstartcloud_roles/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/STARTcloud%2Fstartcloud_roles/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/STARTcloud","download_url":"https://codeload.github.com/STARTcloud/startcloud_roles/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/STARTcloud%2Fstartcloud_roles/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34061123,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-08T02:00:07.615Z","response_time":111,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-11-14T03:16:13.235Z","updated_at":"2026-06-08T12:01:21.587Z","avatar_url":"https://github.com/STARTcloud.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003c!-- PROJECT LOGO --\u003e\n\u003cbr /\u003e\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://github.com/STARTcloud/startcloud_roles/\"\u003e\n    \u003cimg src=\"https://startcloud.com/assets/images/logos/startcloud-logo40.png\" alt=\"Logo\" width=\"200\" height=\"100\"\u003e\n  \u003c/a\u003e\n\n  \u003ch3 align=\"center\"\u003eSTARTcloud Roles\u003c/h3\u003e\n\n  \u003cp align=\"center\"\u003e\n    Documentation for STARTcloud Roles\n    \u003cbr /\u003e\n    \u003ca href=\"https://github.com/STARTcloud/startcloud_roles/\"\u003e\u003cstrong\u003eExplore the docs »\u003c/strong\u003e\u003c/a\u003e\n    \u003cbr /\u003e\n    \u003cbr /\u003e\n    \u003ca href=\"https://github.com/STARTcloud/startcloud_roles/\"\u003eView Demo\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/STARTcloud/startcloud_roles/issues\"\u003eReport Bug\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/STARTcloud/startcloud_roles/issues\"\u003eRequest Feature\u003c/a\u003e\n  \u003c/p\u003e\n\u003c/p\u003e\n\n\u003c!-- TABLE OF CONTENTS --\u003e\n## Table of Contents\n\n* [About the Project](#startcloud-roles)\n* [Key Features](#key-features)\n* [Galaxy Role File Structure](#galaxy-role-file-structure)\n* [Roadmap](#roadmap)\n* [Contributing](#contributing)\n* [License](#license)\n* [Contact](#authors)\n* [Acknowledgements](#acknowledgments)\n\n\n## STARTcloud Roles\nSTARTcloud Roles is a collection of Ansible roles designed to secure and prepare virtual machines (VMs) for use with SSL, configure services, and install dependencies. It is part of the STARTcloud ecosystem, working in conjunction with the Core Provisioner to automate the provisioning and configuration of VMs. This project enhances the security and functionality of VMs by providing a structured approach to role management and deployment.\n\n## Key Features\n\n- **Role Management**: Offers a comprehensive set of Ansible roles for various aspects of VM preparation and configuration.\n- **SSL Preparation**: Automates the process of securing VMs with SSL certificates, ensuring secure communication.\n- **Service Configuration**: Simplifies the setup of necessary services on VMs, streamlining the deployment process.\n- **Dependency Installation**: Handles the installation of required dependencies, reducing manual setup efforts.\n\n\n### ~~Including STARTcloud Roles~~\n\n1. **~~Add STARTcloud Roles as a Git Submodule~~**: ~~First, ensure that STARTcloud Roles is added as a submodule to your project. This can be done using the following command:~~\n\n~~git submodule add -b submodule https://github.com/STARTcloud/startcloud_roles startcloud_roles~~\n   ~~Replace `path/to/submodule` with the desired path within your project where you want to include STARTcloud Roles.~~\n\n2. **~~Update the Submodule~~**: \n~~After cloning your project, navigate to the submodule directory and pull the latest changes:~~\n\n~~bash cd path/to/submodule git pull origin main~~\n\n### Interacting with `Hosts.yml` and `Hosts.rb`\n\nTo integrate STARTcloud Roles with the Core Provisioner, specifically with the `Hosts.yml` and `Hosts.rb` files, follow these steps:\n\nSTARTcloud Roles enhances the provisioning process by automating the configuration of VMs. To utilize these roles effectively, they need to be referenced within the `Hosts.yml` for the Core Provisioner `Hosts.rb`.\n\n1. **Reference Roles in `Hosts.yml`**: Within the `Hosts.yml` file, you can specify which roles from STARTcloud Roles should be applied to a particular host. This is done by including the role names under the `roles` key for each host configuration. For example:\n```\nhosts: all\nroles: \n  - startcloud.startcloud_roles.ssl\n  - startcloud.startcloud_roles.service_user\n```\n\n\n   This configuration indicates that the `ssl_setup` and `service_configuration` roles from STARTcloud Roles should be applied to all hosts via `all`.\n\n2. **Execution in `Hosts.rb`**: The `Hosts.rb` script is responsible for interpreting the `Hosts.yml` file and generating the necessary Vagrant configurations. When the `Hosts.rb` script encounters a host configuration that includes roles, it automatically applies these roles during the provisioning process. There's no need for additional modifications in `Hosts.rb` for this purpose, as the script is designed to handle role application based on the `Hosts.yml` configurations.\n\nBy following these steps, you can seamlessly integrate STARTcloud Roles with the Core Provisioner, leveraging the power of Ansible roles to automate the configuration and security of your VMs. This approach enhances the flexibility and extensibility of your provisioning process, allowing for a more declarative and manageable setup.\n\n\n## Roadmap\nSee the [open issues](https://github.com/STARTcloud/startcloud_roles/issues) for a list of proposed features (and known issues).\n\n## Provider Support\n\n| Provider       | Supported by STARTcloud Roles |\n|----------------|--------------------------------|\n| VirtualBox     | Yes                            |\n| Bhyve/Zones    | Yes                            |\n| VMware Fusion  | No                             |\n| Hyper-V        | No                             |\n| Parallels      | No                             |\n| AWS EC2        | Yes                            |\n| Google Cloud   | No                             |\n| Azure          | No                             |\n| DigitalOcean   | No                             |\n| Linode         | No                             |\n| Vultr          | No                             |\n| Oracle Cloud   | No                             |\n| OpenStack      | No                             |\n| Rackspace      | No                             |\n| Alibaba Cloud  | No                             |\n| Aiven          | No                             |\n| Packet         | No                             |\n| Scaleway       | No                             |\n| OVH            | No                             |\n| Exoscale       | No                             |\n| Hetzner Cloud  | No                             |\n| KVM            | Yes                            |\n| QEMU           | Yes                            |\n| Docker Desktop | No                             |\n| HyperKit       | No                             |\n| WSL2           | No                             |\n|----------------|--------------------------------|\n\n## Built With\n* [Vagrant](https://www.vagrantup.com/) - Portable Development Environment Suite.\n* [VirtualBox](https://www.virtualbox.org/wiki/Downloads) - Hypervisor.\n* [Ansible](https://www.ansible.com/) - Virtual Machine Automation Management.\n\n## Contributing\n\nPlease read [CONTRIBUTING.md](https://www.prominic.net) for details on our code of conduct, and the process for submitting pull requests to us.\n\n## Authors\n* **Joel Anderson** - *Initial work* - [JoelProminic](https://github.com/JoelProminic)\n* **Justin Hill** - *Initial work* - [JustinProminic](https://github.com/JustinProminic)\n* **Mark Gilbert** - *Refactor* - [MarkProminic](https://github.com/MarkProminic)\n\nSee also the list of [contributors](https://github.com/STARTcloud/startcloud_roles/graphs/contributors) who participated in this project.\n\n## License\n\nThis project is licensed under the SSLP v3 License - see the [LICENSE.md](LICENSE.md) file for details\n\n## Acknowledgments\n\n* Hat tip to anyone whose code was used\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fstartcloud%2Fstartcloud_roles","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fstartcloud%2Fstartcloud_roles","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fstartcloud%2Fstartcloud_roles/lists"}