mirror of
https://github.com/webinstall/webi-installers.git
synced 2026-02-14 17:49:53 +00:00
feat(terraform): add Terraform package
This commit is contained in:
99
terraform/README.md
Normal file
99
terraform/README.md
Normal file
@@ -0,0 +1,99 @@
|
||||
---
|
||||
title: Terraform
|
||||
homepage: https://www.terraform.io/
|
||||
tagline: |
|
||||
Provision, change, and version resources on any environment.
|
||||
description: |
|
||||
Terraform is an infrastructure as code (IaC) tool that allows you to build, change, and version infrastructure safely and efficiently.
|
||||
---
|
||||
|
||||
## Cheat Sheet
|
||||
|
||||
> With HashiCorp Terraform, provisioning and security can be automated based on
|
||||
> infrastructure and policy as code. Infrastructure and policies are codified,
|
||||
> shared, managed, and executed within a workflow that is consistent across all
|
||||
> infrastructure.
|
||||
|
||||
### Defining infrastructure state
|
||||
|
||||
Create configurations that provide an outline for Terraform to provision your
|
||||
target infrastructure. E.g.,
|
||||
|
||||
```tf
|
||||
# main.tf
|
||||
|
||||
terraform {
|
||||
required_providers {
|
||||
docker = {
|
||||
source = "kreuzwerker/docker"
|
||||
version = "~> 2.13.0"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
provider "docker" {
|
||||
# provider-specific configuration goes here, e.g.,
|
||||
# browse provider documentation here https://registry.terraform.io/browse/providers
|
||||
}
|
||||
|
||||
# Define some resources!
|
||||
resource "docker_image" "nginx" {
|
||||
name = "nginx:latest"
|
||||
keep_locally = false
|
||||
}
|
||||
|
||||
resource "docker_container" "nginx" {
|
||||
image = docker_image.nginx.latest
|
||||
name = "web-server"
|
||||
ports {
|
||||
internal = 80
|
||||
external = 8080
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
### Initializing Terraform
|
||||
|
||||
Terraform needs to install provider-specific plugins, generate lockfiles, etc.
|
||||
before you can begin provisioning.
|
||||
|
||||
`terraform init`
|
||||
|
||||
You should only need to run this on new configurations, or other configurations
|
||||
checked-out from version control.
|
||||
|
||||
### Checking your configuration
|
||||
|
||||
To check you have a valid configuration
|
||||
|
||||
`terraform validate`
|
||||
|
||||
To format your configuration files
|
||||
|
||||
`terraform fmt`
|
||||
|
||||
### Provisioning resources
|
||||
|
||||
You can generate an execution plan before commiting to provisioning real
|
||||
resources. This command allows you to see exactly what Terraform will do when
|
||||
running the next command.
|
||||
|
||||
`terraform plan`
|
||||
|
||||
**Then, to apply your configurations and provision infrastructure resources.**
|
||||
|
||||
`terraform apply`
|
||||
|
||||
To automatically accept all user prompts when running this command
|
||||
|
||||
`terraform apply -auto-approve`
|
||||
|
||||
### Execution plans
|
||||
|
||||
Execution plans generated by `terraform plan` also act as the _last working
|
||||
state of your infrastructure_. You may wish to save the generated `.tfstate`
|
||||
file so that you may re-provision these resources reliably.
|
||||
|
||||
You can pass in the execution plan to `terraform apply` (example):
|
||||
|
||||
`terraform apply -auto-approve main.tf`
|
||||
57
terraform/install.ps1
Normal file
57
terraform/install.ps1
Normal file
@@ -0,0 +1,57 @@
|
||||
#!/usr/bin/env pwsh
|
||||
|
||||
#################
|
||||
# Install terraform #
|
||||
#################
|
||||
|
||||
# Every package should define these variables
|
||||
$pkg_cmd_name = "terraform"
|
||||
|
||||
$pkg_dst_cmd = "$Env:USERPROFILE\.local\bin\terraform.exe"
|
||||
$pkg_dst_bin = "$Env:USERPROFILE\.local\bin"
|
||||
$pkg_dst = "$pkg_dst_cmd"
|
||||
|
||||
$pkg_src_cmd = "$Env:USERPROFILE\.local\opt\terraform-v$Env:WEBI_VERSION\bin\terraform.exe"
|
||||
$pkg_src_bin = "$Env:USERPROFILE\.local\opt\terraform-v$Env:WEBI_VERSION\bin"
|
||||
$pkg_src_dir = "$Env:USERPROFILE\.local\opt\terraform-v$Env:WEBI_VERSION"
|
||||
$pkg_src = "$pkg_src_cmd"
|
||||
|
||||
New-Item "$Env:USERPROFILE\Downloads\webi" -ItemType Directory -Force | out-null
|
||||
$pkg_download = "$Env:USERPROFILE\Downloads\webi\$Env:WEBI_PKG_FILE"
|
||||
|
||||
# Fetch archive
|
||||
IF (!(Test-Path -Path "$Env:USERPROFILE\Downloads\webi\$Env:WEBI_PKG_FILE")) {
|
||||
echo "Downloading terraform from $Env:WEBI_PKG_URL to $pkg_download"
|
||||
& curl.exe -A "$Env:WEBI_UA" -fsSL "$Env:WEBI_PKG_URL" -o "$pkg_download.part"
|
||||
& move "$pkg_download.part" "$pkg_download"
|
||||
}
|
||||
|
||||
IF (!(Test-Path -Path "$pkg_src_cmd")) {
|
||||
echo "Installing terraform"
|
||||
|
||||
# TODO: create package-specific temp directory
|
||||
# Enter tmp
|
||||
pushd .local\tmp
|
||||
|
||||
# Remove any leftover tmp cruft
|
||||
Remove-Item -Path ".\terraform-v*" -Recurse -ErrorAction Ignore
|
||||
Remove-Item -Path ".\terraform.exe" -Recurse -ErrorAction Ignore
|
||||
|
||||
# Unpack archive file into this temporary directory
|
||||
# Windows BSD-tar handles zip. Imagine that.
|
||||
echo "Unpacking $pkg_download"
|
||||
& tar xf "$pkg_download"
|
||||
|
||||
# Settle unpacked archive into place
|
||||
echo "Install Location: $pkg_src_cmd"
|
||||
New-Item "$pkg_src_bin" -ItemType Directory -Force | out-null
|
||||
Move-Item -Path ".\terraform.exe" -Destination "$pkg_src_bin"
|
||||
|
||||
# Exit tmp
|
||||
popd
|
||||
}
|
||||
|
||||
echo "Copying into '$pkg_dst_cmd' from '$pkg_src_cmd'"
|
||||
Remove-Item -Path "$pkg_dst_cmd" -Recurse -ErrorAction Ignore | out-null
|
||||
New-Item "$pkg_dst_bin" -ItemType Directory -Force | out-null
|
||||
Copy-Item -Path "$pkg_src" -Destination "$pkg_dst" -Recurse
|
||||
32
terraform/install.sh
Normal file
32
terraform/install.sh
Normal file
@@ -0,0 +1,32 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
set -u
|
||||
|
||||
pkg_cmd_name="terraform"
|
||||
|
||||
WEBI_SINGLE=true
|
||||
|
||||
pkg_get_current_version() {
|
||||
terraform -v 2> /dev/null |
|
||||
head -n 1 |
|
||||
cut -d 'v' -f 2
|
||||
}
|
||||
|
||||
pkg_install() {
|
||||
# $HOME/.local/bin/opt/terraform-v1.3.2/bin
|
||||
mkdir -p "$pkg_src_bin"
|
||||
|
||||
# mv ./terraform* "$HOME/.local/opt/terraform-v1.3.2/bin/terraform"
|
||||
mv ./"$pkg_cmd_name"* "$pkg_src_cmd"
|
||||
|
||||
# chmod a+x "$HOME/.local/opt/terraform-v1.3.2/bin/terraform"
|
||||
chmod a+x "$pkg_src_cmd"
|
||||
}
|
||||
|
||||
pkg_link() {
|
||||
# rm -f "$HOME/.local/bin/terraform"
|
||||
rm -f "$pkg_dst_cmd"
|
||||
|
||||
# ln -s "$HOME/.local/opt/terraform-v1.3.2/bin/terraform" "$HOME/.local/bin/terraform"
|
||||
ln -s "$pkg_src_cmd" "$pkg_dst_cmd"
|
||||
}
|
||||
55
terraform/releases.js
Normal file
55
terraform/releases.js
Normal file
@@ -0,0 +1,55 @@
|
||||
'use strict';
|
||||
|
||||
let convert = {
|
||||
freebsd: 'freebsd',
|
||||
macos: 'darwin',
|
||||
linux: 'linux',
|
||||
windows: 'windows',
|
||||
amd64: 'amd64',
|
||||
arm: 'arm64',
|
||||
386: 'x86',
|
||||
};
|
||||
|
||||
function getAllReleases(request) {
|
||||
return request({
|
||||
url: 'https://releases.hashicorp.com/terraform/index.json',
|
||||
json: true,
|
||||
}).then(function (resp) {
|
||||
let releases = resp.body;
|
||||
let all = {
|
||||
releases: [],
|
||||
download: '', // Full URI provided in response body
|
||||
};
|
||||
|
||||
function getBuildsForVersion(version) {
|
||||
releases.versions[version].builds.forEach(function (build) {
|
||||
let r = {
|
||||
version: build.version,
|
||||
download: build.url,
|
||||
os: convert[build.os],
|
||||
arch: convert[build.arch],
|
||||
channel: 'stable', // No other channels
|
||||
};
|
||||
all.releases.push(r);
|
||||
});
|
||||
}
|
||||
|
||||
// Releases are listed chronologically, we want the latest first.
|
||||
const allVersions = Object.keys(releases.versions).reverse();
|
||||
|
||||
allVersions.forEach(function (version) {
|
||||
getBuildsForVersion(version);
|
||||
});
|
||||
|
||||
return all;
|
||||
});
|
||||
}
|
||||
|
||||
module.exports = getAllReleases;
|
||||
|
||||
if (module === require.main) {
|
||||
getAllReleases(require('@root/request')).then(function (all) {
|
||||
all = require('../_webi/normalize.js')(all);
|
||||
console.info(JSON.stringify(all));
|
||||
});
|
||||
}
|
||||
@@ -76,6 +76,7 @@ __rmrf_local() {
|
||||
ssh-pubkey \
|
||||
ssh-utils \
|
||||
syncthing \
|
||||
terraform \
|
||||
vim-ale \
|
||||
vim-essentials \
|
||||
vim-lastplace \
|
||||
@@ -171,6 +172,7 @@ __rmrf_local() {
|
||||
ssh-pubkey \
|
||||
ssh-utils \
|
||||
syncthing \
|
||||
terraform \
|
||||
vim-ale \
|
||||
vim-essentials \
|
||||
vim-go \
|
||||
@@ -271,6 +273,7 @@ __test() {
|
||||
ssh-pubkey \
|
||||
ssh-utils \
|
||||
syncthing \
|
||||
terraform \
|
||||
vim-ale \
|
||||
vim-essentials \
|
||||
vim-lastplace \
|
||||
|
||||
Reference in New Issue
Block a user