Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ksatirli/get-your-website-into-the-cloud
Open Source 101 workshop on using GitHub and Terraform to deploy a website on AWS.
https://github.com/ksatirli/get-your-website-into-the-cloud
github-api terraform
Last synced: 27 days ago
JSON representation
Open Source 101 workshop on using GitHub and Terraform to deploy a website on AWS.
- Host: GitHub
- URL: https://github.com/ksatirli/get-your-website-into-the-cloud
- Owner: ksatirli
- License: apache-2.0
- Created: 2023-03-20T16:15:56.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-03-24T00:14:26.000Z (almost 2 years ago)
- Last Synced: 2024-10-27T06:52:38.615Z (2 months ago)
- Topics: github-api, terraform
- Language: HCL
- Homepage: https://opensource101.fun
- Size: 18.6 KB
- Stars: 0
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Open Source 101 - Get Your Website into the Cloud
> This repository contains code for the [Open Source 101](https://opensource101.com) workshop _"Get Your Website into the Cloud"_.
## Table of Contents
* [Open Source 101 - Get Your Website into the Cloud](#open-source-101---get-your-website-into-the-cloud)
* [Table of Contents](#table-of-contents)
* [Requirements](#requirements)
* [Usage](#usage)
* [Inputs](#inputs)
* [Outputs](#outputs)
* [Author Information](#author-information)
* [License](#license)## Requirements
* Amazon Web Services (AWS) [Account](https://aws.amazon.com/account/)
* GitHub [Account](https://github.com/join)
* Terraform `1.4.x` or newer.## Usage
1.) Copy [`./terraform.tfvars.sample`](./terraform.tfvars.sample) to `./terraform.tfvars` and fill in all values.
* `fontawesome_identifier` expects a [Font Awesome](https://fontawesome.com) Kit identifier.
* `gandi_key` expects a [Gandi](https://www.gandi.net/en/solutions/api) API key.
* `github_owner` expects a GitHub User or GitHub Organization slug.
* `github_token` expects a GitHub [Personal Access Token](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token).Optionally, all values may be provided as environment variables (including options such as `DirEnv` and `.envrc` files)
2.) Initialize Terraform to retrieve OS-specific provider binaries and underlying Terraform Module code.
```shell
cd get-your-website-into-the-cloudterraform init
```3.) Preview the expected deployment resources by running `terraform plan`
```shell
terraform plan
```4.) If the output of step 3 looks acceptable, deploy the changes using `terraform apply`
```shell
terraform apply
```### Inputs
| Name | Description | Type | Required |
|------|-------------|------|:--------:|
| fontawesome_identifier | Font Awesome Kit Identifier. | `string` | yes |
| gandi_key | This is Gandi API Access Key. | `string` | yes |
| github_owner | This is the target GitHub organization or individual user account to poll. | `string` | yes |
| github_token | This is the GitHub token. | `string` | yes |
| website | Object of Website Configuration data. |object({| no |
domain = string
theme_color = string
twitter_user = string
})### Outputs
| Name | Description |
|------|-------------|
| gandi_domain | Exported Attributes of the `gandi_domain.main` Data Source. |
| gandi_nameservers | Exported Attributes of the `gandi_nameservers.main` Resource. |
| github_repositories | Exported Attributes of the `github_repository.main` Data Source. |
| github_repositories_list | Exported List of Repositories of the `github_repositories.main` Data Source. |
| github_user | Exported Attributes of the `github_user.main` Data Source. |
| invalidation_command | AWS CLI Command for CloudFront Invalidation. |
| random_string | Exported Attributes of the `random_string.main` Resource. |
| route53_zone | Exported Attributes of the `aws_route53_zone.main` Resource. |
| workshop_urls | Convenience Output with URLs for the workshop. |## Author Information
This module is maintained by the contributors listed on [GitHub](https://github.com/ksatirli/get-your-website-into-the-cloud/graphs/contributors).
## License
Licensed under the Apache License, Version 2.0 (the "License").
You may obtain a copy of the License at [apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0).
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an _"AS IS"_ basis, without WARRANTIES or conditions of any kind, either express or implied.
See the License for the specific language governing permissions and limitations under the License.