a ansible & tf playbooks
This commit is contained in:
parent
1d87177a00
commit
c6e9109774
.vscode
ansible
README.mdansible.cfgbootstrap.ymlrequirements.ymlsite.yml
inventory
lookup_plugins
__pycache__
dotenv.pyroles
bootstrap/tasks
bright
capture/tasks
common/tasks
database/tasks
load_balancer
tracker
apps
bright
config
lib/bright_web/controllers/torrent_html
test/bright
tracker/root/etc/s6-overlay/s6-rc.d/caddy
devbox.d
devbox.jsondevbox.lockdocker-compose.ymlplaybooks/opentofu
.terraform.lock.hclcapture.tf
requirements.txt.terraform/providers/registry.opentofu.org
hashicorp/random/3.7.1/linux_amd64
vultr/vultr/2.23.1/linux_amd64
terraform
4
.vscode/extensions.json
vendored
4
.vscode/extensions.json
vendored
@ -1,6 +1,8 @@
|
||||
{
|
||||
"recommendations": [
|
||||
"redhat.vscode-yaml",
|
||||
"elixir-lsp.elixir-ls"
|
||||
"elixir-lsp.elixir-ls",
|
||||
"jetify.devbox",
|
||||
"redhat.ansible"
|
||||
]
|
||||
}
|
26
ansible/README.md
Normal file
26
ansible/README.md
Normal file
@ -0,0 +1,26 @@
|
||||
# futureporn ansible
|
||||
|
||||
Here we have playbooks to help provision infrastructure to do specific tasks.
|
||||
|
||||
## Inventory
|
||||
|
||||
Terraform handles spinning up Vultr instances. See `../terraform` for that. Also, Terraform is where we get our Ansible inventory, so make sure to run `tofu apply` in `../terraform` before working with Ansible.
|
||||
|
||||
## Available plays
|
||||
|
||||
### bootstrap.yml
|
||||
|
||||
Prepare the instances for working with Ansible. This sets up SSH and ensures python is installed.
|
||||
|
||||
|
||||
### k3s-ansible
|
||||
|
||||
Provision the instances to act as a k3s cluster.
|
||||
|
||||
@see https://github.com/k3s-io/k3s-ansible/tree/master
|
||||
|
||||
tl;dr: `ansible-playbook k3s.orchestration.site`
|
||||
|
||||
### site.yml
|
||||
|
||||
Sets up all the instances to perform bright.futureporn.net workloads. Includes setting up Dokku to work with k3s-scheduler.
|
6
ansible/ansible.cfg
Normal file
6
ansible/ansible.cfg
Normal file
@ -0,0 +1,6 @@
|
||||
[defaults]
|
||||
|
||||
inventory = ./inventory/terraform.yml
|
||||
private_key_file = ~/.ssh/futureporn2025
|
||||
remote_user = root
|
||||
interpreter_python=auto_silent
|
8
ansible/bootstrap.yml
Normal file
8
ansible/bootstrap.yml
Normal file
@ -0,0 +1,8 @@
|
||||
---
|
||||
- name: Setup Ansible SSH
|
||||
hosts: all
|
||||
gather_facts: false ## required because ansible_host may not have python
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- common
|
4
ansible/inventory/terraform.yml
Normal file
4
ansible/inventory/terraform.yml
Normal file
@ -0,0 +1,4 @@
|
||||
plugin: cloud.terraform.terraform_provider
|
||||
project_path: ../terraform
|
||||
# Terraform binary (available in the $PATH) or full path to the binary.
|
||||
binary_path: tofu
|
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-310.pyc
Normal file
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-310.pyc
Normal file
Binary file not shown.
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-311.pyc
Normal file
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-311.pyc
Normal file
Binary file not shown.
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-312.pyc
Normal file
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-312.pyc
Normal file
Binary file not shown.
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-314.pyc
Normal file
BIN
ansible/lookup_plugins/__pycache__/dotenv.cpython-314.pyc
Normal file
Binary file not shown.
96
ansible/lookup_plugins/dotenv.py
Normal file
96
ansible/lookup_plugins/dotenv.py
Normal file
@ -0,0 +1,96 @@
|
||||
""" Custom Ansible Lookup Plugin for reading dotenv files.
|
||||
|
||||
Ansible officially supports Python 2.7 and 3.5+, but this requires Python 3.8+.
|
||||
|
||||
"""
|
||||
from __future__ import annotations
|
||||
|
||||
from typing import Sequence
|
||||
|
||||
from ansible.errors import AnsibleFileNotFound, AnsibleLookupError
|
||||
from ansible.plugins.lookup import LookupBase
|
||||
from re import compile
|
||||
|
||||
|
||||
__all__ = "DOCUMENTATION", "EXAMPLES", "RETURN", "LookupModule"
|
||||
|
||||
|
||||
# Options not documented will be ignored during processing.
|
||||
|
||||
DOCUMENTATION = """
|
||||
name: dotenv
|
||||
author:
|
||||
- Michael Klatt <mdklatt(at)alumni.ou.edu>
|
||||
short_description: Retrieve values from dotenv files
|
||||
requirements:
|
||||
- Anisble must be running under Python 3.8+.
|
||||
description:
|
||||
- Retrieve values from dotenv values.
|
||||
seealso:
|
||||
- name: RFC 2 - .env file
|
||||
description: Smartmob RFC for a .env file standard
|
||||
link: https://smartmob-rfc.readthedocs.io/en/latest/2-dotenv.html
|
||||
notes:
|
||||
- The RFC 2 continuation line syntax is not yet supported.
|
||||
options:
|
||||
_terms:
|
||||
description: The key(s) to look up.
|
||||
required: True
|
||||
file:
|
||||
description: Path to the dotenv file.
|
||||
default: '.env'
|
||||
""" # YAML
|
||||
|
||||
|
||||
RETURN = """
|
||||
_raw:
|
||||
description:
|
||||
- value(s) of the search term(s) in the dotenv file
|
||||
type: list
|
||||
elements: str
|
||||
""" # YAML
|
||||
|
||||
|
||||
EXAMPLES = """
|
||||
- name: Retrieve value from the .env file in the current working directory.
|
||||
debug:
|
||||
msg: "{{ lookup('dotenv', 'VAR') }}"
|
||||
- name: Use a non-default dotenv file.
|
||||
debug:
|
||||
msg: "{{ lookup('dotenv', 'VAR', file='path/to/.env') }}"
|
||||
""" # YAML
|
||||
|
||||
|
||||
class LookupModule(LookupBase): # class name is not arbitrary, DO NOT CHANGE
|
||||
""" Look up values from a dotenv file.
|
||||
|
||||
"""
|
||||
def run(self, terms: Sequence[str], variables=None, **options) -> list:
|
||||
""" Execute the lookup.
|
||||
|
||||
:param terms: search terms
|
||||
:param variables: mapping of defined Ansible variables
|
||||
:param options: options passed directly as keyword arguments
|
||||
:return: list of found values
|
||||
"""
|
||||
# Adapted from 'ansible.builtin.ini' lookup.
|
||||
# <https://github.com/ansible/ansible/blob/devel/lib/ansible/plugins/lookup/ini.py>
|
||||
# <https://docs.ansible.com/ansible/latest/dev_guide/developing_plugins.html#developing-lookup-plugins>
|
||||
self.set_options(var_options=variables, direct=options)
|
||||
params = self.get_options()
|
||||
path = self.find_file_in_search_path(variables, "files", params["file"])
|
||||
if not path:
|
||||
raise AnsibleFileNotFound(f"Could not find file {params['file']}")
|
||||
var_pattern = compile(r"^\s*([a-zA-Z_]+[a-zA-Z0-9_]*)\s*=\s*(\S*)")
|
||||
variables = {}
|
||||
for line in open(path, "rt").readlines():
|
||||
# Parse the dotenv file permissively, accepting valid NAME=VALUE
|
||||
# lines while ignoring everything else.
|
||||
# TODO: Support RFC 2 line continuation syntax.
|
||||
if match := var_pattern.match(line):
|
||||
variables[match.group(1)] = match.group(2)
|
||||
try:
|
||||
return [variables[key] for key in terms]
|
||||
except KeyError as err:
|
||||
key = err.args[0]
|
||||
raise AnsibleLookupError(f"No value for '{key}' in {path}")
|
7
ansible/requirements.yml
Normal file
7
ansible/requirements.yml
Normal file
@ -0,0 +1,7 @@
|
||||
---
|
||||
collections:
|
||||
- name: cloud.terraform
|
||||
- name: community.docker
|
||||
- name: community.general
|
||||
roles:
|
||||
- name: nvjacobo.caddy
|
30
ansible/roles/bootstrap/tasks/main.yml
Normal file
30
ansible/roles/bootstrap/tasks/main.yml
Normal file
@ -0,0 +1,30 @@
|
||||
---
|
||||
|
||||
## @see https://gist.github.com/shirou/6928012
|
||||
## @todo known_hosts.py has a `add_host_key` function. Could we use that instead of this shell script?
|
||||
- name: Scan for SSH host keys.
|
||||
delegate_to: localhost
|
||||
ansible.builtin.shell:
|
||||
cmd: ssh-keyscan -q -p 22 {{ ansible_host }} 2>/dev/null
|
||||
changed_when: false
|
||||
register: ssh_scan
|
||||
retries: 2 # it always fails the first time
|
||||
until: ssh_scan.rc == 0
|
||||
|
||||
|
||||
# - debug:
|
||||
# var: ssh_scan
|
||||
|
||||
- name: Update known_hosts.
|
||||
ansible.builtin.known_hosts:
|
||||
key: "{{ item }}"
|
||||
name: "{{ ansible_host }}"
|
||||
with_items: "{{ ssh_scan.stdout_lines }}"
|
||||
delegate_to: localhost
|
||||
|
||||
- name: Install python3
|
||||
become: true
|
||||
ansible.builtin.raw: >
|
||||
test -e /usr/bin/python3 || (test -e /usr/bin/apt-get && (apt-get -y update && apt-get install -y python3))
|
||||
args:
|
||||
creates: /usr/bin/python3
|
13
ansible/roles/bright/handlers/main.yml
Normal file
13
ansible/roles/bright/handlers/main.yml
Normal file
@ -0,0 +1,13 @@
|
||||
---
|
||||
- name: Mount vfs
|
||||
ansible.posix.mount:
|
||||
src: "{{ vfs_mount_tag }}"
|
||||
path: /mnt/vfs
|
||||
fstype: virtiofs
|
||||
state: mounted
|
||||
|
||||
- name: Restart bright
|
||||
community.docker.docker_container:
|
||||
name: bright
|
||||
state: started
|
||||
restart: true
|
84
ansible/roles/bright/tasks/main.yml
Normal file
84
ansible/roles/bright/tasks/main.yml
Normal file
@ -0,0 +1,84 @@
|
||||
---
|
||||
|
||||
# Terraform Vultr provider doesn't have a VFS resource/datasource yet.
|
||||
# This is a workaround for that missing feature.
|
||||
#
|
||||
# @see https://github.com/vultr/terraform-provider-vultr/issues/560
|
||||
- name: Get the VFS id
|
||||
ansible.builtin.uri:
|
||||
url: https://api.vultr.com/v2/vfs
|
||||
method: GET
|
||||
status_code: 200
|
||||
headers:
|
||||
Authorization: "Bearer {{ lookup('dotenv', 'VULTR_API_KEY', file='../.env') }}"
|
||||
register: vfs_list
|
||||
|
||||
- name: Get VFS variables
|
||||
ansible.builtin.set_fact:
|
||||
bright_vfs_id: "{{ vfs_list.json.vfs | selectattr('label', 'equalto', 'bright') | map(attribute='id') | first }}"
|
||||
|
||||
- name: Debug the bright VFS id
|
||||
ansible.builtin.debug:
|
||||
msg: "The VFS ID for 'bright' is {{ bright_vfs_id }}"
|
||||
|
||||
- name: Attach VFS to Vultr instance
|
||||
ansible.builtin.uri:
|
||||
url: https://api.vultr.com/v2/vfs/{{ bright_vfs_id }}/attachments/{{ hostvars[inventory_hostname]['vultr_instance_id'] }}
|
||||
method: PUT
|
||||
status_code:
|
||||
- 200
|
||||
- 201
|
||||
- 409
|
||||
headers:
|
||||
Authorization: "Bearer {{ lookup('dotenv', 'VULTR_API_KEY', file='../.env') }}"
|
||||
register: vfs_attach
|
||||
changed_when:
|
||||
- vfs_attach.json is defined
|
||||
- "'state' in vfs_attach.json"
|
||||
- vfs_attach.json.state == "ATTACHED"
|
||||
notify:
|
||||
- Mount vfs
|
||||
- Restart bright
|
||||
|
||||
- name: Debug vfs_attach
|
||||
ansible.builtin.debug:
|
||||
var: vfs_attach
|
||||
|
||||
- name: Get the VFS mount_tag
|
||||
ansible.builtin.set_fact:
|
||||
vfs_mount_tag: "{{ vfs_attach.json.mount_tag | default('') }}"
|
||||
|
||||
|
||||
- name: Setup docker container
|
||||
community.docker.docker_container:
|
||||
name: bright
|
||||
image: gitea.futureporn.net/futureporn/bright:latest
|
||||
pull: always
|
||||
state: started
|
||||
ports:
|
||||
- "4000:4000"
|
||||
volumes:
|
||||
- "/mnt/vfs/futureporn:/mnt/vfs/futureporn"
|
||||
env:
|
||||
DB_HOST: "{{ hostvars['fp-db-0']['internal_ip'] }}"
|
||||
DB_USER: "{{ lookup('dotenv', 'DB_USER', file='../.env') }}"
|
||||
DB_NAME: "bright"
|
||||
DB_PORT: "5432"
|
||||
DB_PASS: "{{ lookup('dotenv', 'DB_PASS', file='../.env') }}"
|
||||
MIX_ENV: prod
|
||||
PUBLIC_S3_ENDPOINT: https://futureporn-b2.b-cdn.net
|
||||
PATREON_REDIRECT_URI: https://bright.futureporn.net/auth/patreon/callback
|
||||
SITE_URL: https://bright.futureporn.net
|
||||
PHX_HOST: bright.futureporn.net
|
||||
AWS_BUCKET: futureporn
|
||||
AWS_REGION: us-west-000
|
||||
AWS_HOST: s3.us-west-000.backblazeb2.com
|
||||
SECRET_KEY_BASE: "{{ lookup('dotenv', 'SECRET_KEY_BASE', file='../.env') }}"
|
||||
PATREON_CLIENT_SECRET: "{{ lookup('dotenv', 'PATREON_CLIENT_SECRET', file='../.env') }}"
|
||||
PATREON_CLIENT_ID: "{{ lookup('dotenv', 'PATREON_CLIENT_ID', file='../.env') }}"
|
||||
AWS_ACCESS_KEY_ID: "{{ lookup('dotenv', 'AWS_ACCESS_KEY_ID', file='../.env') }}"
|
||||
AWS_SECRET_ACCESS_KEY: "{{ lookup('dotenv', 'AWS_SECRET_ACCESS_KEY', file='../.env') }}"
|
||||
TRACKER_HELPER_ACCESSLIST_URL: https://tracker.futureporn.net/accesslist
|
||||
TRACKER_HELPER_USERNAME: "{{ lookup('dotenv', 'TRACKER_HELPER_USERNAME', file='../.env') }}"
|
||||
TRACKER_HELPER_PASSWORD: "{{ lookup('dotenv', 'TRACKER_HELPER_PASSWORD', file='../.env') }}"
|
||||
TRACKER_URL: https://tracker.futureporn.net:6969
|
74
ansible/roles/capture/tasks/main.yml
Normal file
74
ansible/roles/capture/tasks/main.yml
Normal file
@ -0,0 +1,74 @@
|
||||
---
|
||||
|
||||
- name: Install apt packages
|
||||
ansible.builtin.apt:
|
||||
name:
|
||||
- ffmpeg
|
||||
- npm
|
||||
state: present
|
||||
|
||||
|
||||
- name: Download Croc installer
|
||||
ansible.builtin.get_url:
|
||||
url: https://getcroc.schollz.com
|
||||
dest: /tmp/croc.sh
|
||||
mode: "0755"
|
||||
|
||||
- name: Install Croc
|
||||
ansible.builtin.command: /tmp/croc.sh
|
||||
args:
|
||||
creates: /usr/local/bin/croc
|
||||
|
||||
|
||||
- name: Install pip packages
|
||||
vars:
|
||||
pipx_packages:
|
||||
- yt-dlp
|
||||
community.general.pipx:
|
||||
name: "{{ item }}"
|
||||
state: latest
|
||||
with_items: "{{ pipx_packages }}"
|
||||
|
||||
|
||||
# Do we need this?
|
||||
# - name: Ensure pipx is in PATH
|
||||
# ansible.builtin.shell: pipx ensurepath
|
||||
|
||||
- name: Clone voddo repository
|
||||
ansible.builtin.git:
|
||||
repo: https://github.com/insanity54/voddo
|
||||
dest: /root/voddo
|
||||
version: bdc25562876b2e98c3f54962525809398b16d040
|
||||
|
||||
- name: Download and install thumbnail-generator.sh
|
||||
ansible.builtin.get_url:
|
||||
url: https://gitea.futureporn.net/futureporn/fp/raw/branch/main/packages/scripts/thumbnail-generator.sh
|
||||
dest: ~/.local/bin/thumbnail-generator.sh
|
||||
mode: '0755'
|
||||
|
||||
- name: Download and install Backblaze B2 CLI
|
||||
ansible.builtin.get_url:
|
||||
url: https://github.com/Backblaze/B2_Command_Line_Tool/releases/download/v4.3.1/b2-linux
|
||||
dest: ~/.local/bin/b2
|
||||
mode: '0755'
|
||||
|
||||
- name: Download and extract IPFS Kubo
|
||||
ansible.builtin.unarchive:
|
||||
src: https://dist.ipfs.tech/kubo/v0.33.2/kubo_v0.33.2_linux-amd64.tar.gz
|
||||
dest: ~/
|
||||
remote_src: true
|
||||
|
||||
- name: Install IPFS Kubo
|
||||
ansible.builtin.command: ~/kubo/install.sh
|
||||
args:
|
||||
creates: /usr/local/bin/ipfs
|
||||
|
||||
- name: Allow UFW ports
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: "{{ item }}"
|
||||
proto: tcp
|
||||
loop:
|
||||
- 8081 # npx http-server -p 8081
|
||||
- 8080 # ipfs api
|
||||
- 4001 # ipfs swarm
|
60
ansible/roles/common/tasks/main.yml
Normal file
60
ansible/roles/common/tasks/main.yml
Normal file
@ -0,0 +1,60 @@
|
||||
---
|
||||
|
||||
|
||||
- name: Install apt packages
|
||||
ansible.builtin.apt:
|
||||
name:
|
||||
- git
|
||||
- mosh
|
||||
- mg
|
||||
- screen
|
||||
- tree
|
||||
- ncdu
|
||||
- pipx
|
||||
- fd-find
|
||||
state: present
|
||||
|
||||
- name: Download Docker installer
|
||||
ansible.builtin.get_url:
|
||||
url: https://get.docker.com
|
||||
dest: /tmp/docker.sh
|
||||
mode: "0755"
|
||||
|
||||
- name: Install Docker
|
||||
ansible.builtin.command: /tmp/docker.sh
|
||||
args:
|
||||
creates: /usr/bin/docker
|
||||
|
||||
|
||||
- name: Clone dotfiles repository
|
||||
ansible.builtin.git:
|
||||
repo: https://github.com/insanity54/dotfiles
|
||||
dest: /root/dotfiles
|
||||
update: true
|
||||
version: 9d99960e49e1d4a315a49333d5030b483f27c8ef
|
||||
|
||||
- name: Copy .screenrc to root home directory
|
||||
ansible.builtin.copy:
|
||||
src: /root/dotfiles/.screenrc
|
||||
dest: /root/.screenrc
|
||||
mode: "0644"
|
||||
remote_src: true
|
||||
|
||||
- name: Download lazydocker installer
|
||||
ansible.builtin.get_url:
|
||||
url: https://raw.githubusercontent.com/jesseduffield/lazydocker/master/scripts/install_update_linux.sh
|
||||
dest: /tmp/lazydocker.sh
|
||||
mode: "0755"
|
||||
|
||||
- name: Install lazydocker
|
||||
environment:
|
||||
DIR: /usr/local/bin
|
||||
ansible.builtin.command: /tmp/lazydocker.sh
|
||||
args:
|
||||
creates: /usr/local/bin/lazydocker
|
||||
|
||||
- name: Allow UDP ports 60000-61000 for mosh
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: "60000:61000"
|
||||
proto: udp
|
30
ansible/roles/database/tasks/main.yml
Normal file
30
ansible/roles/database/tasks/main.yml
Normal file
@ -0,0 +1,30 @@
|
||||
---
|
||||
|
||||
- name: Setup volume
|
||||
community.docker.docker_volume:
|
||||
name: pg_data
|
||||
|
||||
|
||||
- name: Setup docker container
|
||||
community.docker.docker_container:
|
||||
name: bright
|
||||
image: postgres:16
|
||||
pull: missing
|
||||
state: started
|
||||
ports:
|
||||
- "5432:5432"
|
||||
env:
|
||||
POSTGRES_USER: "postgres"
|
||||
POSTGRES_DB: "bright"
|
||||
POSTGRES_PASSWORD: "{{ lookup('dotenv', 'DB_PASS', file='../.env') }}"
|
||||
mounts:
|
||||
- type: volume
|
||||
target: "/var/lib/postgresql/data"
|
||||
source: "pg_data"
|
||||
|
||||
- name: Allow VPC2.0 network access
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: '5432'
|
||||
proto: tcp
|
||||
from: 10.2.128.0/20
|
26
ansible/roles/load_balancer/tasks/main.yml
Normal file
26
ansible/roles/load_balancer/tasks/main.yml
Normal file
@ -0,0 +1,26 @@
|
||||
---
|
||||
- name: Configure firewall
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: "{{ item }}"
|
||||
proto: tcp
|
||||
loop:
|
||||
- 80
|
||||
- 443
|
||||
|
||||
- name: Install Caddy
|
||||
ansible.builtin.import_role:
|
||||
name: nvjacobo.caddy
|
||||
|
||||
- name: Create html dir
|
||||
ansible.builtin.file:
|
||||
state: directory
|
||||
dest: /usr/share/futureporn
|
||||
mode: "0644"
|
||||
|
||||
- name: Configure Caddyfile
|
||||
ansible.builtin.template:
|
||||
src: 'templates/Caddyfile.j2'
|
||||
dest: /etc/caddy/Caddyfile
|
||||
mode: "0644"
|
||||
notify: restart caddy
|
22
ansible/roles/load_balancer/templates/Caddyfile.j2
Normal file
22
ansible/roles/load_balancer/templates/Caddyfile.j2
Normal file
@ -0,0 +1,22 @@
|
||||
bright.futureporn.net {
|
||||
root * /usr/share/futureporn
|
||||
file_server
|
||||
|
||||
# Define the upstream servers for load balancing
|
||||
reverse_proxy {% for host in groups['bright'] %}{{ hostvars[host]['internal_ip'] }}:4000 {% endfor %} {
|
||||
# Load balancing policy (optional, defaults to "random")
|
||||
lb_policy round_robin
|
||||
|
||||
|
||||
# Health checks (optional)
|
||||
health_uri /api/health
|
||||
health_interval 10s
|
||||
health_timeout 5s
|
||||
}
|
||||
|
||||
handle_errors {
|
||||
respond "💥 Error ~ {err.status_code} {err.status_text}"
|
||||
}
|
||||
|
||||
|
||||
}
|
49
ansible/roles/tracker/tasks/main.yml
Normal file
49
ansible/roles/tracker/tasks/main.yml
Normal file
@ -0,0 +1,49 @@
|
||||
---
|
||||
|
||||
- name: Configure firewall
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: "{{ item }}"
|
||||
proto: tcp
|
||||
loop:
|
||||
- 80
|
||||
- 443
|
||||
- 9000
|
||||
|
||||
- name: Allow UDP port 6969
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: "6969"
|
||||
proto: udp
|
||||
|
||||
- name: Install Caddy
|
||||
ansible.builtin.import_role:
|
||||
name: nvjacobo.caddy
|
||||
|
||||
|
||||
- name: Configure Caddyfile
|
||||
ansible.builtin.template:
|
||||
src: 'templates/Caddyfile.j2'
|
||||
dest: /etc/caddy/Caddyfile
|
||||
mode: "0644"
|
||||
notify: restart caddy
|
||||
|
||||
|
||||
# @todo performance enhancement is to run aquatic outside of docker.
|
||||
# @see https://github.com/greatest-ape/aquatic/blob/34b45e923f84421181fc43cf5e20709e69ce0dfd/docker/aquatic_udp.Dockerfile#L5
|
||||
- name: Setup docker container
|
||||
community.docker.docker_container:
|
||||
name: tracker
|
||||
image: gitea.futureporn.net/futureporn/tracker:latest
|
||||
pull: always
|
||||
state: started
|
||||
ports:
|
||||
- "6969:6969/udp" # aquatic_udp
|
||||
- "5063:5063" # tracker-helper
|
||||
- "9000:9000" # aquatic metrics
|
||||
env:
|
||||
TRACKER_HELPER_ACCESSLIST_URL: https://tracker.futureporn.net/accesslist
|
||||
TRACKER_HELPER_USERNAME: "{{ lookup('dotenv', 'TRACKER_HELPER_USERNAME', file='../.env') }}"
|
||||
TRACKER_HELPER_PASSWORD: "{{ lookup('dotenv', 'TRACKER_HELPER_PASSWORD', file='../.env') }}"
|
||||
TRACKER_URL: https://tracker.futureporn.net:6969
|
||||
TRACKER_HELPER_ACCESSLIST_PATH: /var/lib/aquatic/accesslist
|
13
ansible/roles/tracker/templates/Caddyfile.j2
Normal file
13
ansible/roles/tracker/templates/Caddyfile.j2
Normal file
@ -0,0 +1,13 @@
|
||||
tracker.futureporn.net {
|
||||
|
||||
reverse_proxy :5063 {
|
||||
health_uri /health
|
||||
health_interval 10s
|
||||
health_timeout 5s
|
||||
}
|
||||
|
||||
handle_errors {
|
||||
respond "💥 Error -- {err.status_code} {err.status_text}"
|
||||
}
|
||||
|
||||
}
|
57
ansible/site.yml
Normal file
57
ansible/site.yml
Normal file
@ -0,0 +1,57 @@
|
||||
---
|
||||
|
||||
- name: Bootstrap
|
||||
hosts: all
|
||||
gather_facts: false ## required because ansible_host may not have python
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- bootstrap
|
||||
|
||||
- name: Assert common dependencies
|
||||
hosts: all
|
||||
gather_facts: true
|
||||
check_mode: false
|
||||
become: true
|
||||
roles:
|
||||
- common
|
||||
|
||||
- name: Assert Capture dependencies
|
||||
hosts: capture
|
||||
gather_facts: true
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- capture
|
||||
|
||||
- name: Configure database
|
||||
hosts: database
|
||||
gather_facts: true
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- database
|
||||
|
||||
- name: Configure tracker
|
||||
hosts: tracker
|
||||
gather_facts: true
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- tracker
|
||||
|
||||
- name: Configure Bright
|
||||
hosts: bright
|
||||
gather_facts: true
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- bright
|
||||
|
||||
- name: Configure load balancer
|
||||
hosts: load_balancer
|
||||
gather_facts: true
|
||||
check_mode: false
|
||||
become: false
|
||||
roles:
|
||||
- load_balancer
|
@ -48,18 +48,23 @@ config :ex_aws,
|
||||
]
|
||||
|
||||
if config_env() == :prod do
|
||||
database_url =
|
||||
System.get_env("DATABASE_URL") ||
|
||||
raise """
|
||||
environment variable DATABASE_URL is missing.
|
||||
For example: ecto://USER:PASS@HOST/DATABASE
|
||||
"""
|
||||
db_host = System.get_env("DB_HOST") || raise "environment variable DB_HOST is missing."
|
||||
db_user = System.get_env("DB_USER") || raise "environment variable DB_USER is missing."
|
||||
db_pass = System.get_env("DB_PASS") || raise "environment variable DB_PASS is missing."
|
||||
db_port = System.get_env("DB_PORT") || raise "environment variable DB_PORT is missing."
|
||||
db_name = System.get_env("DB_NAME") || raise "environment variable DB_NAME is missing."
|
||||
|
||||
maybe_ipv6 = if System.get_env("ECTO_IPV6") in ~w(true 1), do: [:inet6], else: []
|
||||
|
||||
config :bright, Bright.Repo,
|
||||
# ssl: true,
|
||||
url: database_url,
|
||||
# url: database_url,
|
||||
|
||||
database: db_name,
|
||||
hostname: db_host,
|
||||
username: db_user,
|
||||
port: db_port,
|
||||
password: db_pass,
|
||||
pool_size: String.to_integer(System.get_env("POOL_SIZE") || "10"),
|
||||
socket_options: maybe_ipv6
|
||||
|
||||
|
@ -2,7 +2,7 @@
|
||||
Torrent {@torrent.id}
|
||||
<:subtitle>This is a torrent record from the database.</:subtitle>
|
||||
<:actions>
|
||||
<.link href={~p"/torrents/#{@torrent}/edit"}>
|
||||
<.link href={~p"/torrents/#{@torrent.id}/edit"}>
|
||||
<.button>Edit torrent</.button>
|
||||
</.link>
|
||||
</:actions>
|
||||
|
@ -2,7 +2,7 @@
|
||||
<div class="level-left">
|
||||
<div class="level-item">
|
||||
<%= if @torrent && @torrent.magnet do %>
|
||||
<.link target="_blank" href={@torrent.magnet}><.icon name="magnet" class="icon" /></.link>
|
||||
<a target="_blank" href={@torrent.magnet}><.icon name="magnet" class="icon" /></a>
|
||||
<% end %>
|
||||
</div>
|
||||
<div class="level-item">
|
||||
|
@ -36,7 +36,7 @@ defmodule Bright.B2Test do
|
||||
|
||||
{:ok, filename} = B2.get(vod)
|
||||
assert :ok
|
||||
assert Regex.match?(~r/\.cache\/futureporn.*\.ts/, filename)
|
||||
assert Regex.match?(~r/\/futureporn.*\.ts/, filename)
|
||||
end
|
||||
|
||||
@tag :acceptance
|
||||
|
@ -13,7 +13,7 @@ defmodule Bright.ImagesTest do
|
||||
{:ok, filename} =
|
||||
Images.create_thumbnail(@test_mp4_fixture)
|
||||
|
||||
assert Regex.match?(~r/\.cache\/futureporn\/[^\/]+\/[^\/]+\.png$/, filename)
|
||||
assert Regex.match?(~r/\/futureporn\/[^\/]+\/[^\/]+\.png$/, filename)
|
||||
assert File.exists?(filename)
|
||||
assert File.stat!(filename).size > 0, "thumbnail file is empty"
|
||||
end
|
||||
|
@ -1,3 +0,0 @@
|
||||
#!/command/with-contenv sh
|
||||
|
||||
/usr/bin/caddy run --config /etc/caddy/Caddyfile
|
@ -1 +0,0 @@
|
||||
longrun
|
15
devbox.d/caddy/Caddyfile
Normal file
15
devbox.d/caddy/Caddyfile
Normal file
@ -0,0 +1,15 @@
|
||||
# See https://caddyserver.com/docs/caddyfile for more details
|
||||
{
|
||||
admin 0.0.0.0:2020
|
||||
auto_https disable_certs
|
||||
http_port 8800
|
||||
https_port 4443
|
||||
}
|
||||
|
||||
:8082 {
|
||||
root * {$CADDY_ROOT_DIR}
|
||||
log {
|
||||
output file {$CADDY_LOG_DIR}/caddy.log
|
||||
}
|
||||
file_server
|
||||
}
|
10
devbox.d/web/index.html
Normal file
10
devbox.d/web/index.html
Normal file
@ -0,0 +1,10 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>Hello World!</title>
|
||||
</head>
|
||||
<body>
|
||||
Hello World!
|
||||
</body>
|
||||
</html>
|
45
devbox.json
45
devbox.json
@ -4,25 +4,22 @@
|
||||
"nodejs@20",
|
||||
"ffmpeg@latest",
|
||||
"yt-dlp@latest",
|
||||
"python310@latest",
|
||||
"python310Packages.pip@latest",
|
||||
"hcloud@latest",
|
||||
"lazydocker@latest",
|
||||
"ruby@latest",
|
||||
"chisel@latest",
|
||||
"bento4@latest",
|
||||
"shaka-packager@latest",
|
||||
"mktorrent@latest",
|
||||
"entr@latest",
|
||||
"act@latest",
|
||||
"git-subrepo@latest",
|
||||
"opentofu@latest"
|
||||
"opentofu@latest",
|
||||
"ggshield@latest",
|
||||
"python310@latest",
|
||||
"python310Packages.pip@latest",
|
||||
"caddy@latest"
|
||||
],
|
||||
"env": {
|
||||
"DEVBOX_COREPACK_ENABLED": "true",
|
||||
"ENV": "development",
|
||||
"KUBECONFIG": "$HOME/.kube/futureporn.yaml",
|
||||
"VENV_DIR": ".venv"
|
||||
"ENV": "development",
|
||||
"KUBECONFIG": "$HOME/.kube/futureporn.yaml",
|
||||
"VENV_DIR": ".venv"
|
||||
},
|
||||
"shell": {
|
||||
"init_hook": [
|
||||
@ -31,19 +28,19 @@
|
||||
"pip install -r requirements.txt"
|
||||
],
|
||||
"scripts": {
|
||||
"tunnel": "dotenvx run -f ./.kamal/secrets.development -- chisel client bright.fp.sbtp.xyz:9090 R:4000",
|
||||
"backup": "docker exec -t postgres_db pg_dumpall -c -U postgres > ./backups/dev_`date +%Y-%m-%d_%H_%M_%S`.sql",
|
||||
"act": "dotenvx run -f ./.kamal/secrets.testing -- act -W ./.gitea/workflows --secret-file .kamal/secrets.development",
|
||||
"act:builder": "dotenvx run -f ./.kamal/secrets.testing -- act -W ./.gitea/workflows/builder.yaml --secret-file .kamal/secrets.testing --var-file .kamal/secrets.testing --insecure-secrets",
|
||||
"act:tests": "dotenvx run -f ./.kamal/secrets.testing -- act -W ./.gitea/workflows/tests.yaml --secret-file .kamal/secrets.testing --var-file .kamal/secrets.testing --insecure-secrets",
|
||||
"bright:compile:watch": "cd ./apps/bright && find . -type f -name \"*.ex\" -o -name \"*.exs\" | entr -r mix compile --warnings-as-errors",
|
||||
"bright:compile:watch2": "cd ./apps/bright && pnpx chokidar-cli \"**/*\" -i \"deps/**\" -i \"_build/**\" -c \"mix compile --warnings-as-errors\"",
|
||||
"bright:dev": "cd ./apps/bright && dotenvx run -f ../../.kamal/secrets.development -e MIX_ENV=dev -- mix phx.server",
|
||||
"tunnel": "dotenvx run -f ./.kamal/secrets.development -- chisel client bright.fp.sbtp.xyz:9090 R:4000",
|
||||
"backup": "docker exec -t postgres_db pg_dumpall -c -U postgres > ./backups/dev_`date +%Y-%m-%d_%H_%M_%S`.sql",
|
||||
"act": "dotenvx run -f ./.kamal/secrets.testing -- act -W ./.gitea/workflows --secret-file .kamal/secrets.development",
|
||||
"act:builder": "dotenvx run -f ./.kamal/secrets.testing -- act -W ./.gitea/workflows/builder.yaml --secret-file .kamal/secrets.testing --var-file .kamal/secrets.testing --insecure-secrets",
|
||||
"act:tests": "dotenvx run -f ./.kamal/secrets.testing -- act -W ./.gitea/workflows/tests.yaml --secret-file .kamal/secrets.testing --var-file .kamal/secrets.testing --insecure-secrets",
|
||||
"bright:compile:watch": "cd ./apps/bright && find . -type f -name \"*.ex\" -o -name \"*.exs\" | entr -r mix compile --warnings-as-errors",
|
||||
"bright:compile:watch2": "cd ./apps/bright && pnpx chokidar-cli \"**/*\" -i \"deps/**\" -i \"_build/**\" -c \"mix compile --warnings-as-errors\"",
|
||||
"bright:dev": "cd ./apps/bright && dotenvx run -f ../../.kamal/secrets.development -e MIX_ENV=dev -- mix phx.server",
|
||||
"bright:test:unit:watch": "cd ./apps/bright && pnpx chokidar-cli '**/*' -i \"deps/**\" -i '_build/**' -c 'mix test --only=unit'",
|
||||
"bright:act": "cd ./apps/bright && act --env MIX_ENV=test -W ./.gitea/workflows/tests.yaml --secret-file .kamal/secrets.development",
|
||||
"test": "act -W ./.gitea/workflows/tests.yaml --secret-file .kamal/secrets.testing --var-file .kamal/secrets.testing && devbox run beep || devbox run boop",
|
||||
"beep": "ffplay -nodisp -loglevel quiet -autoexit ./apps/beep/beep2.wav",
|
||||
"boop": "ffplay -nodisp -loglevel quiet -autoexit ./apps/beep/beep1.wav"
|
||||
"bright:act": "cd ./apps/bright && act --env MIX_ENV=test -W ./.gitea/workflows/tests.yaml --secret-file .kamal/secrets.development",
|
||||
"test": "act -W ./.gitea/workflows/tests.yaml --secret-file .kamal/secrets.testing --var-file .kamal/secrets.testing && devbox run beep || devbox run boop",
|
||||
"beep": "ffplay -nodisp -loglevel quiet -autoexit ./apps/beep/beep2.wav",
|
||||
"boop": "ffplay -nodisp -loglevel quiet -autoexit ./apps/beep/beep1.wav"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
323
devbox.lock
323
devbox.lock
@ -49,51 +49,52 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
"bento4@latest": {
|
||||
"last_modified": "2025-01-25T23:17:58Z",
|
||||
"resolved": "github:NixOS/nixpkgs/b582bb5b0d7af253b05d58314b85ab8ec46b8d19#bento4",
|
||||
"caddy@latest": {
|
||||
"last_modified": "2025-02-07T11:26:36Z",
|
||||
"plugin_version": "0.0.3",
|
||||
"resolved": "github:NixOS/nixpkgs/d98abf5cf5914e5e4e9d57205e3af55ca90ffc1d#caddy",
|
||||
"source": "devbox-search",
|
||||
"version": "1.6.0-641",
|
||||
"version": "2.9.1",
|
||||
"systems": {
|
||||
"aarch64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/c88fmklr5716ksfd30103l5ga96jqydc-bento4-1.6.0-641",
|
||||
"path": "/nix/store/wsj8iixhs5iwjhfyy4l00va0dj301sjs-caddy-2.9.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/c88fmklr5716ksfd30103l5ga96jqydc-bento4-1.6.0-641"
|
||||
"store_path": "/nix/store/wsj8iixhs5iwjhfyy4l00va0dj301sjs-caddy-2.9.1"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/dzv9rzqawf9nd529lx0sb6zk6k30bllq-bento4-1.6.0-641",
|
||||
"path": "/nix/store/w6cg28ws2404fglmhbzddqjjkniqfiam-caddy-2.9.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/dzv9rzqawf9nd529lx0sb6zk6k30bllq-bento4-1.6.0-641"
|
||||
"store_path": "/nix/store/w6cg28ws2404fglmhbzddqjjkniqfiam-caddy-2.9.1"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/3w09k9fp9d76a3vh6zmifbssv83ngv5q-bento4-1.6.0-641",
|
||||
"path": "/nix/store/8q0lw048apajs1rg6vpfbp2p1m37f25a-caddy-2.9.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/3w09k9fp9d76a3vh6zmifbssv83ngv5q-bento4-1.6.0-641"
|
||||
"store_path": "/nix/store/8q0lw048apajs1rg6vpfbp2p1m37f25a-caddy-2.9.1"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/nnflb6279al7r7ad0qrraln3w5brpba0-bento4-1.6.0-641",
|
||||
"path": "/nix/store/ax0979vnibikl5cr180lmxvb80m2zq50-caddy-2.9.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/nnflb6279al7r7ad0qrraln3w5brpba0-bento4-1.6.0-641"
|
||||
"store_path": "/nix/store/ax0979vnibikl5cr180lmxvb80m2zq50-caddy-2.9.1"
|
||||
}
|
||||
}
|
||||
},
|
||||
@ -341,6 +342,70 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
"ggshield@latest": {
|
||||
"last_modified": "2025-02-27T15:48:43Z",
|
||||
"resolved": "github:NixOS/nixpkgs/6c5c5f5100281f8f4ff23f13edd17d645178c87c#ggshield",
|
||||
"source": "devbox-search",
|
||||
"version": "1.36.0",
|
||||
"systems": {
|
||||
"aarch64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/2qsc4iii58gq54l8dys7m4jw5lz0xqk0-ggshield-1.36.0",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "dist",
|
||||
"path": "/nix/store/1zic4rm52c81303axs6jwpv9i5cbpgpf-ggshield-1.36.0-dist"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/2qsc4iii58gq54l8dys7m4jw5lz0xqk0-ggshield-1.36.0"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/l9inx1qgmjm9hiz1fncxx15mkyqw9abc-ggshield-1.36.0",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "dist",
|
||||
"path": "/nix/store/1hls55sak8fi14s6wq4ar5iiwvmzpw68-ggshield-1.36.0-dist"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/l9inx1qgmjm9hiz1fncxx15mkyqw9abc-ggshield-1.36.0"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/n2s11c74rlq64w78rnnnz5j8dz72fnvs-ggshield-1.36.0",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "dist",
|
||||
"path": "/nix/store/9k2svwlyx8s2ac6dnhc3sq5c3bvlyrvw-ggshield-1.36.0-dist"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/n2s11c74rlq64w78rnnnz5j8dz72fnvs-ggshield-1.36.0"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/pz8s8n5qrmhfivj51932s5gqwh64c7fy-ggshield-1.36.0",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "dist",
|
||||
"path": "/nix/store/i29ambqhmnizdxk9njgsyza953m5mbmn-ggshield-1.36.0-dist"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/pz8s8n5qrmhfivj51932s5gqwh64c7fy-ggshield-1.36.0"
|
||||
}
|
||||
}
|
||||
},
|
||||
"git-subrepo@latest": {
|
||||
"last_modified": "2025-02-07T11:26:36Z",
|
||||
"resolved": "github:NixOS/nixpkgs/d98abf5cf5914e5e4e9d57205e3af55ca90ffc1d#git-subrepo",
|
||||
@ -392,54 +457,6 @@
|
||||
"github:NixOS/nixpkgs/nixpkgs-unstable": {
|
||||
"resolved": "github:NixOS/nixpkgs/ba0939c506a03c60a765cd7f7c43794816540eec?lastModified=1739482815&narHash=sha256-%2F5Lwtmp%2F8j%2Bro32gXzitucSdyjJ6QehfJCL58WNA7N0%3D"
|
||||
},
|
||||
"hcloud@latest": {
|
||||
"last_modified": "2024-12-23T21:10:33Z",
|
||||
"resolved": "github:NixOS/nixpkgs/de1864217bfa9b5845f465e771e0ecb48b30e02d#hcloud",
|
||||
"source": "devbox-search",
|
||||
"version": "1.49.0",
|
||||
"systems": {
|
||||
"aarch64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/wf8q3kml6c2clgp9l3djnlcbmfph4vnn-hcloud-1.49.0",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/wf8q3kml6c2clgp9l3djnlcbmfph4vnn-hcloud-1.49.0"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/68crkxrn8nfrzsb5n2ri8w6v4bbg4w3m-hcloud-1.49.0",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/68crkxrn8nfrzsb5n2ri8w6v4bbg4w3m-hcloud-1.49.0"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/pjbjhza0bfvz29arl2h6c94bgs7ldf7c-hcloud-1.49.0",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/pjbjhza0bfvz29arl2h6c94bgs7ldf7c-hcloud-1.49.0"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/5q2ws8lrgkrfpm9b8r2s0h5i7d7c4bnx-hcloud-1.49.0",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/5q2ws8lrgkrfpm9b8r2s0h5i7d7c4bnx-hcloud-1.49.0"
|
||||
}
|
||||
}
|
||||
},
|
||||
"lazydocker@latest": {
|
||||
"last_modified": "2024-12-23T21:10:33Z",
|
||||
"resolved": "github:NixOS/nixpkgs/de1864217bfa9b5845f465e771e0ecb48b30e02d#lazydocker",
|
||||
@ -488,54 +505,6 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
"mktorrent@latest": {
|
||||
"last_modified": "2025-01-25T23:17:58Z",
|
||||
"resolved": "github:NixOS/nixpkgs/b582bb5b0d7af253b05d58314b85ab8ec46b8d19#mktorrent",
|
||||
"source": "devbox-search",
|
||||
"version": "1.1",
|
||||
"systems": {
|
||||
"aarch64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/lwa8h4w9jicy7c67bhnmv78vlix19ma1-mktorrent-1.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/lwa8h4w9jicy7c67bhnmv78vlix19ma1-mktorrent-1.1"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/iq1mqwjl37dlzaxli3dnj4lv1bhi6vaf-mktorrent-1.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/iq1mqwjl37dlzaxli3dnj4lv1bhi6vaf-mktorrent-1.1"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/di0fgl55xp7pwjfi0zgxywn8ky36ijar-mktorrent-1.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/di0fgl55xp7pwjfi0zgxywn8ky36ijar-mktorrent-1.1"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/rrdq0l681zc8ljlymq7i5jsq7sp2xrrr-mktorrent-1.1",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/rrdq0l681zc8ljlymq7i5jsq7sp2xrrr-mktorrent-1.1"
|
||||
}
|
||||
}
|
||||
},
|
||||
"nodejs@20": {
|
||||
"last_modified": "2024-12-23T21:10:33Z",
|
||||
"plugin_version": "0.0.2",
|
||||
@ -650,9 +619,9 @@
|
||||
}
|
||||
},
|
||||
"python310@latest": {
|
||||
"last_modified": "2024-12-23T21:10:33Z",
|
||||
"last_modified": "2025-02-07T11:26:36Z",
|
||||
"plugin_version": "0.0.4",
|
||||
"resolved": "github:NixOS/nixpkgs/de1864217bfa9b5845f465e771e0ecb48b30e02d#python310",
|
||||
"resolved": "github:NixOS/nixpkgs/d98abf5cf5914e5e4e9d57205e3af55ca90ffc1d#python310",
|
||||
"source": "devbox-search",
|
||||
"version": "3.10.16",
|
||||
"systems": {
|
||||
@ -660,55 +629,54 @@
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/382cajdyw7qsgrzjf8y79hssg8ggv18x-python3-3.10.16",
|
||||
"path": "/nix/store/n3bv4blh1n8xcswpn23d8rkdf19z1z67-python3-3.10.16",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/382cajdyw7qsgrzjf8y79hssg8ggv18x-python3-3.10.16"
|
||||
"store_path": "/nix/store/n3bv4blh1n8xcswpn23d8rkdf19z1z67-python3-3.10.16"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/bvvky8yghyl23vwdhf6dmq6w1a4nm1mg-python3-3.10.16",
|
||||
"path": "/nix/store/wdkg0yc6h9fwvvqwh3zss1a2rz4mrmgl-python3-3.10.16",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "debug",
|
||||
"path": "/nix/store/msw7k25qw8wfqjrdv6j2sydqxddmaw32-python3-3.10.16-debug"
|
||||
"path": "/nix/store/wxnpshdg4kbdmpl44qnqx29i0pszsa7f-python3-3.10.16-debug"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/bvvky8yghyl23vwdhf6dmq6w1a4nm1mg-python3-3.10.16"
|
||||
"store_path": "/nix/store/wdkg0yc6h9fwvvqwh3zss1a2rz4mrmgl-python3-3.10.16"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/2dnz9rwscr6d1pma8h5q7ckfavsrvhb1-python3-3.10.16",
|
||||
"path": "/nix/store/40lamqbgh1g2x9mml635n329h4gh1928-python3-3.10.16",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/2dnz9rwscr6d1pma8h5q7ckfavsrvhb1-python3-3.10.16"
|
||||
"store_path": "/nix/store/40lamqbgh1g2x9mml635n329h4gh1928-python3-3.10.16"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/rv4ykblb2w9qc7w7a10dbw4r1am7zm9n-python3-3.10.16",
|
||||
"path": "/nix/store/8757y4bf8d77z7c3pjz1nlwi2xlkk93h-python3-3.10.16",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "debug",
|
||||
"path": "/nix/store/l0fx7jgxq5pn27n74haq9c5bhwvbkpab-python3-3.10.16-debug"
|
||||
"path": "/nix/store/4rj9krr4hgv14rjlsrlajksi580fg4np-python3-3.10.16-debug"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/rv4ykblb2w9qc7w7a10dbw4r1am7zm9n-python3-3.10.16"
|
||||
"store_path": "/nix/store/8757y4bf8d77z7c3pjz1nlwi2xlkk93h-python3-3.10.16"
|
||||
}
|
||||
}
|
||||
},
|
||||
"python310Packages.pip@latest": {
|
||||
"last_modified": "2023-12-13T22:54:10Z",
|
||||
"plugin_version": "0.0.2",
|
||||
"resolved": "github:NixOS/nixpkgs/fd04bea4cbf76f86f244b9e2549fca066db8ddff#python310Packages.pip",
|
||||
"source": "devbox-search",
|
||||
"version": "23.2.1",
|
||||
@ -791,119 +759,6 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
"ruby@latest": {
|
||||
"last_modified": "2024-12-27T03:08:00Z",
|
||||
"plugin_version": "0.0.2",
|
||||
"resolved": "github:NixOS/nixpkgs/7cc0bff31a3a705d3ac4fdceb030a17239412210#ruby_3_4",
|
||||
"source": "devbox-search",
|
||||
"version": "3.4.1",
|
||||
"systems": {
|
||||
"aarch64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/qaxayv9z27mqdg3k0f8wn74yhv5vdw7d-ruby-3.4.1",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "devdoc",
|
||||
"path": "/nix/store/9g35v966nxpgkjax0vifgyd7aq85qp0j-ruby-3.4.1-devdoc"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/qaxayv9z27mqdg3k0f8wn74yhv5vdw7d-ruby-3.4.1"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/8ylfvxsav4kkk858ving6hf281a1vqs5-ruby-3.4.1",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "devdoc",
|
||||
"path": "/nix/store/lzy6z85s93llj1kvmcdky8r1n7m9shxl-ruby-3.4.1-devdoc"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/8ylfvxsav4kkk858ving6hf281a1vqs5-ruby-3.4.1"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/y9v3710alwdz99blk4whgp0jif8j5zsg-ruby-3.4.1",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "devdoc",
|
||||
"path": "/nix/store/a9a0dxkd3ih6jyi0vj77n16hj9rj4y7s-ruby-3.4.1-devdoc"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/y9v3710alwdz99blk4whgp0jif8j5zsg-ruby-3.4.1"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/lmfq7mn710jknr40ik46yf759jras0s3-ruby-3.4.1",
|
||||
"default": true
|
||||
},
|
||||
{
|
||||
"name": "devdoc",
|
||||
"path": "/nix/store/4jx1cvll34y0kg2hp1p5w0im45ba7x53-ruby-3.4.1-devdoc"
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/lmfq7mn710jknr40ik46yf759jras0s3-ruby-3.4.1"
|
||||
}
|
||||
}
|
||||
},
|
||||
"shaka-packager@latest": {
|
||||
"last_modified": "2025-01-25T23:17:58Z",
|
||||
"resolved": "github:NixOS/nixpkgs/b582bb5b0d7af253b05d58314b85ab8ec46b8d19#shaka-packager",
|
||||
"source": "devbox-search",
|
||||
"version": "3.4.2",
|
||||
"systems": {
|
||||
"aarch64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/l0srzffgawm37rnii66r3vbxhh699f7w-shaka-packager-3.4.2",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/l0srzffgawm37rnii66r3vbxhh699f7w-shaka-packager-3.4.2"
|
||||
},
|
||||
"aarch64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/40bpzld1ccq4kwjfrrncdj9xqpmrk537-shaka-packager-3.4.2",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/40bpzld1ccq4kwjfrrncdj9xqpmrk537-shaka-packager-3.4.2"
|
||||
},
|
||||
"x86_64-darwin": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/npgp484fhvi2xpfi1f7bpcnxc7a0krq2-shaka-packager-3.4.2",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/npgp484fhvi2xpfi1f7bpcnxc7a0krq2-shaka-packager-3.4.2"
|
||||
},
|
||||
"x86_64-linux": {
|
||||
"outputs": [
|
||||
{
|
||||
"name": "out",
|
||||
"path": "/nix/store/z0k69qksnh4sk4fagmmv7pcwy0sv7kby-shaka-packager-3.4.2",
|
||||
"default": true
|
||||
}
|
||||
],
|
||||
"store_path": "/nix/store/z0k69qksnh4sk4fagmmv7pcwy0sv7kby-shaka-packager-3.4.2"
|
||||
}
|
||||
}
|
||||
},
|
||||
"yt-dlp@latest": {
|
||||
"last_modified": "2025-01-03T14:51:55Z",
|
||||
"resolved": "github:NixOS/nixpkgs/a27871180d30ebee8aa6b11bf7fef8a52f024733#yt-dlp",
|
||||
|
@ -1,12 +1,12 @@
|
||||
services:
|
||||
|
||||
aquatic:
|
||||
build:
|
||||
context: ./apps/aquatic
|
||||
dockerfile: docker/aquatic_udp_futureporn.Dockerfile
|
||||
ports:
|
||||
- "6969:6969/udp"
|
||||
- "9000:9000/tcp"
|
||||
# aquatic:
|
||||
# build:
|
||||
# context: ./apps/aquatic
|
||||
# dockerfile: docker/aquatic_udp_futureporn.Dockerfile
|
||||
# ports:
|
||||
# - "6969:6969/udp"
|
||||
# - "9000:9000/tcp"
|
||||
|
||||
|
||||
# bright:
|
||||
|
43
playbooks/opentofu/.terraform.lock.hcl
generated
43
playbooks/opentofu/.terraform.lock.hcl
generated
@ -1,43 +0,0 @@
|
||||
# This file is maintained automatically by "tofu init".
|
||||
# Manual edits may be lost in future updates.
|
||||
|
||||
provider "registry.opentofu.org/hashicorp/random" {
|
||||
version = "3.7.1"
|
||||
hashes = [
|
||||
"h1:v8+6umuoWwD1nKm+3tPcPO8rKHthran7ZSbm7J2xQEc=",
|
||||
"zh:1011387a5127d46e2bf0bd5124a8469506272b2110613d9eb80d178f94bd67a9",
|
||||
"zh:28785c36d6dc331d49e8bf6a30d4ba21ae4378f5d98c43c0aeb42f51efb2e42f",
|
||||
"zh:50fc0e52f0255950404681455420344a16263f91622bd481954606e6e3be9eb2",
|
||||
"zh:563f22c53f40e41cfffdcfac32a9292292c10582183c3f1dd85770cf806bfce9",
|
||||
"zh:586a5615898d369374d4bd7d70bc013cffe7553d3e14638f169a3f745665fee1",
|
||||
"zh:6275f6e5697993048ac088715484a9a5e919682651e098a5ac31e567216bf102",
|
||||
"zh:95a44bb3f012da1e036936d60df2d08f5942a96cb912fc23432d2ee050857527",
|
||||
"zh:a5fe6b0e586645a88d98738739fec40fd7ad83dbc63fe66ff6327aee2dc07f11",
|
||||
"zh:ea57886899b6baf466f3ff978f4482d2fd7fa049c42509cc819431375cddd5bd",
|
||||
"zh:f021cfbe23bdb32738f170c1ae736ffb769a2fa3dcafd0f9906155c2e21377e4",
|
||||
]
|
||||
}
|
||||
|
||||
provider "registry.opentofu.org/vultr/vultr" {
|
||||
version = "2.23.1"
|
||||
constraints = "2.23.1"
|
||||
hashes = [
|
||||
"h1:VNpHOLXDPr/hNlsMoHFtUPjBhJnEuUxo5ywd5UeenX8=",
|
||||
"zh:02e794393bb26377444e81523f803e40f6ee45134914047071fe6291e7fb3813",
|
||||
"zh:06a2cb287bb5c79b05331aed90519bd08b3b8bc6b75191382ef1e8713bffc1e0",
|
||||
"zh:088c1a73057cb37fb8fc3ef009b26ca437e03929df5d7802ae1eca206bc91b56",
|
||||
"zh:1f7dc7e64e5ed8c0fa29658c5730c0fca5eeb3547215175319262f7ee92eac3c",
|
||||
"zh:278b5738632ebe9ee04a966c02071ce3e0e6435af0e8da55c96c71d50e0076dd",
|
||||
"zh:2c6fc71abf11fcb0c7dae89f99bd301dfa078a63a68529ea251e6b4cb0491f86",
|
||||
"zh:487fe4cbd9b4d49c4049dc2de647e41b6e5cb0857215fe2d38a7529fd1e184ab",
|
||||
"zh:4a8758b6c579bea6049f66d5238a20ac0878a2b89dee200f7655b74b61bebbbf",
|
||||
"zh:72a86c02b5ba2d141708a55c1eb4d100644ba377263747aca11b53f82487f645",
|
||||
"zh:8cabf4b700a63fd0daf7f9fc0c5bedff699d86b641fc66144b6ceb645765a345",
|
||||
"zh:9c1602b47ba7fa2f23a1810a2ec37291c83a342888ed430fc1bed5dd2edefcda",
|
||||
"zh:a27efb29592136f7c819aa22e1349dc3169be249d2e30873b72d7aabf80359eb",
|
||||
"zh:c5c92c87e28456de6387d23bda949734d4b5deef32e79d71ec9ddf945a53fc7f",
|
||||
"zh:cce93b449fd85e013ead67ed4ccc9861673a57a3d5e06d493419ebc97dcd21c5",
|
||||
"zh:e5e24b7349c679e2118a74ef559dbe43c13f8d3369a6ce8c7c4bdb72a3c03540",
|
||||
"zh:f226a9e61789c412493ff3abad4e6403aaae46d5d3532437b1c873ec772b828f",
|
||||
]
|
||||
}
|
@ -1,279 +0,0 @@
|
||||
## 3.7.1 (February 25, 2025)
|
||||
|
||||
NOTES:
|
||||
|
||||
* New [ephemeral resource](https://developer.hashicorp.com/terraform/language/resources/ephemeral) `random_password` now supports [ephemeral values](https://developer.hashicorp.com/terraform/language/values/variables#exclude-values-from-state). ([#625](https://github.com/hashicorp/terraform-provider-random/issues/625))
|
||||
|
||||
FEATURES:
|
||||
|
||||
* ephemeral/random_password: New ephemeral resource that generates a password string. When used in combination with a managed resource write-only attribute, Terraform will not store the password in the plan or state file. ([#625](https://github.com/hashicorp/terraform-provider-random/issues/625))
|
||||
|
||||
## 3.7.0 (February 25, 2025)
|
||||
|
||||
NOTES:
|
||||
|
||||
* New [ephemeral resource](https://developer.hashicorp.com/terraform/language/resources/ephemeral) `random_password` now supports [ephemeral values](https://developer.hashicorp.com/terraform/language/values/variables#exclude-values-from-state). ([#625](https://github.com/hashicorp/terraform-provider-random/issues/625))
|
||||
|
||||
FEATURES:
|
||||
|
||||
* ephemeral/random_password: New ephemeral resource that generates a password string. When used in combination with a managed resource write-only attribute, Terraform will not store the password in the plan or state file. ([#625](https://github.com/hashicorp/terraform-provider-random/issues/625))
|
||||
|
||||
## 3.7.0-alpha1 (February 13, 2025)
|
||||
|
||||
NOTES:
|
||||
|
||||
* all: This release is being used to test new build and release actions.
|
||||
|
||||
## 3.6.3 (September 11, 2024)
|
||||
|
||||
NOTES:
|
||||
|
||||
* all: This release introduces no functional changes. It does however include dependency updates which address upstream CVEs. ([#604](https://github.com/hashicorp/terraform-provider-random/issues/604))
|
||||
|
||||
## 3.6.2 (May 21, 2024)
|
||||
|
||||
NOTES:
|
||||
|
||||
* resource/random_pet: Results have been updated to the latest upstream petname data ([#581](https://github.com/hashicorp/terraform-provider-random/issues/581))
|
||||
|
||||
## 3.6.1 (April 16, 2024)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* all: Prevent `keepers` from triggering an in-place update following import ([#385](https://github.com/hashicorp/terraform-provider-random/issues/385))
|
||||
* resource/random_shuffle: Prevent inconsistent result after apply when result_count is set to 0 ([#409](https://github.com/hashicorp/terraform-provider-random/issues/409))
|
||||
* provider/random_password: Fix bug which causes panic when special, upper, lower and number/numeric are all false ([#551](https://github.com/hashicorp/terraform-provider-random/issues/551))
|
||||
* provider/random_string: Fix bug which causes panic when special, upper, lower and number/numeric are all false ([#551](https://github.com/hashicorp/terraform-provider-random/issues/551))
|
||||
|
||||
## 3.6.0 (December 04, 2023)
|
||||
|
||||
FEATURES:
|
||||
|
||||
* resource/random_bytes: New resource that generates an array of random bytes intended to be used as key or secret ([#272](https://github.com/hashicorp/terraform-provider-random/issues/272))
|
||||
|
||||
## 3.5.1 (April 12, 2023)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_password: Prevent error with `bcrypt` by truncating the bytes that are hashed to a maximum length of 72 ([#397](https://github.com/hashicorp/terraform-provider-random/issues/397))
|
||||
|
||||
## 3.5.0 (April 11, 2023)
|
||||
|
||||
NOTES:
|
||||
|
||||
* This Go module has been updated to Go 1.19 per the [Go support policy](https://golang.org/doc/devel/release.html#policy). Any consumers building on earlier Go versions may experience errors. ([#378](https://github.com/hashicorp/terraform-provider-random/issues/378))
|
||||
|
||||
## 3.4.3 (September 08, 2022)
|
||||
|
||||
NOTES:
|
||||
|
||||
* resource/random_password: The values for `lower`, `number`, `special`, `upper`, `min_lower`, `min_numeric`, `min_special`, `min_upper` and `length` could be null if the resource was imported using version 3.3.1 or before. The value for `length` will be automatically calculated and assigned and default values will be assigned for the other attributes listed after this upgrade ([#313](https://github.com/hashicorp/terraform-provider-random/pull/313))
|
||||
* resource/random_string: The values for `lower`, `number`, `special`, `upper`, `min_lower`, `min_numeric`, `min_special`, `min_upper` and `length` could be null if the resource was imported using version 3.3.1 or before. The value for `length` will be automatically calculated and assigned and default values will be assigned for the other attributes listed after this upgrade ([#313](https://github.com/hashicorp/terraform-provider-random/pull/313))
|
||||
* resource/random_password: If the resource was created between versions 3.4.0 and 3.4.2, the `bcrypt_hash` value would not correctly verify against the `result` value. Affected resources will automatically regenerate a valid `bcrypt_hash` after this upgrade. ([#308](https://github.com/hashicorp/terraform-provider-random/pull/308))
|
||||
* resource/random_password: The `override_special` attribute may show a plan difference from empty string (`""`) to `null` if previously applied with version 3.4.2. The plan should show this as an in-place update and it should occur only once after upgrading. ([#312](https://github.com/hashicorp/terraform-provider-random/pull/312))
|
||||
* resource/random_string: The `override_special` attribute may show a plan difference from empty string (`""`) to `null` if previously applied with version 3.4.2. The plan should show this as an in-place update and it should occur only once after upgrading. ([#312](https://github.com/hashicorp/terraform-provider-random/pull/312))
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_password: Assign default values to `lower`, `number`, `special`, `upper`, `min_lower`, `min_numeric`, `min_special` and `min_upper` if null. Assign length of `result` to `length` if null ([#313](https://github.com/hashicorp/terraform-provider-random/pull/313))
|
||||
* resource/random_string: Assign default values to `lower`, `number`, `special`, `upper`, `min_lower`, `min_numeric`, `min_special` and `min_upper` if null. Assign length of `result` to `length` if null ([#313](https://github.com/hashicorp/terraform-provider-random/pull/313))
|
||||
* resource/random_password: Fixed incorrect `bcrypt_hash` generation since version 3.4.0 ([#308](https://github.com/hashicorp/terraform-provider-random/pull/308))
|
||||
* resource/random_password: Prevented difference with `override_special` when upgrading from version 3.3.2 and earlier ([#312](https://github.com/hashicorp/terraform-provider-random/pull/312))
|
||||
* resource/random_string: Prevented difference with `override_special` when upgrading from version 3.3.2 and earlier ([#312](https://github.com/hashicorp/terraform-provider-random/pull/312))
|
||||
|
||||
## 3.4.2 (September 02, 2022)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* all: Prevent `keeper` with `null` values from forcing replacement ([305](https://github.com/hashicorp/terraform-provider-random/pull/305)).
|
||||
* resource/random_password: During upgrade state, ensure `min_upper` is populated ([304](https://github.com/hashicorp/terraform-provider-random/pull/304)).
|
||||
* resource/random_string: During upgrade state, ensure `min_upper` is populated ([304](https://github.com/hashicorp/terraform-provider-random/pull/304)).
|
||||
|
||||
## 3.4.1 (August 31, 2022)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_password: During attribute plan modifier, only return error if `number` and `numeric` are both present and do not match ([301](https://github.com/hashicorp/terraform-provider-random/pull/301)).
|
||||
* resource/random_string: During attribute plan modifier, only return error if `number` and `numeric` are both present and do not match ([301](https://github.com/hashicorp/terraform-provider-random/pull/301)).
|
||||
|
||||
## 3.4.0 (August 30, 2022)
|
||||
|
||||
NOTES:
|
||||
|
||||
* Provider has been re-written using the new [`terraform-plugin-framework`](https://www.terraform.io/plugin/framework) ([#177](https://github.com/hashicorp/terraform-provider-random/pull/177)).
|
||||
* resource/random_password: `number` was deprecated in [v3.3.0](https://github.com/hashicorp/terraform-provider-random/releases/tag/v3.3.0) and will be removed in the next major release.
|
||||
* resource/random_string: `number` was deprecated in [v3.3.0](https://github.com/hashicorp/terraform-provider-random/releases/tag/v3.3.0) and will be removed in the next major release.
|
||||
|
||||
## 3.3.2 (June 23, 2022)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_password: When importing set defaults for all attributes that have a default defined ([256](https://github.com/hashicorp/terraform-provider-random/pull/256)).
|
||||
* resource/random_string: When importing set defaults for all attributes that have a default defined ([256](https://github.com/hashicorp/terraform-provider-random/pull/256)).
|
||||
|
||||
## 3.3.1 (June 07, 2022)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_password: During schema upgrade, copy value of attribute `number` to attribute `numeric`, only if said value is a boolean (i.e. not `null`) ([262](https://github.com/hashicorp/terraform-provider-random/pull/262))
|
||||
* resource/random_string: During schema upgrade, copy value of attribute `number` to attribute `numeric`, only if said value is a boolean (i.e. not `null`) ([262](https://github.com/hashicorp/terraform-provider-random/pull/262))
|
||||
|
||||
## 3.3.0 (June 06, 2022)
|
||||
|
||||
ENHANCEMENTS:
|
||||
|
||||
* resource/random_password: `number` is now deprecated and `numeric` has been added to align attribute naming. `number` will be removed in the next major release ([#258](https://github.com/hashicorp/terraform-provider-random/pull/258)).
|
||||
* resource/random_string: `number` is now deprecated and `numeric` has been added to align attribute naming. `number` will be removed in the next major release ([#258](https://github.com/hashicorp/terraform-provider-random/pull/258)).
|
||||
|
||||
## 3.2.0 (May 18, 2022)
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* resource/random_password: New attribute `bcrypt_hash`, which is the hashed password ([73](https://github.com/hashicorp/terraform-provider-random/pull/73), [102](https://github.com/hashicorp/terraform-provider-random/issues/102), [254](https://github.com/hashicorp/terraform-provider-random/pull/254))
|
||||
|
||||
NOTES:
|
||||
|
||||
* Adds or updates DESIGN.md, README.md, CONTRIBUTING.md and SUPPORT.md docs ([176](https://github.com/hashicorp/terraform-provider-random/issues/176), [235](https://github.com/hashicorp/terraform-provider-random/issues/235), [242](https://github.com/hashicorp/terraform-provider-random/pull/242)).
|
||||
* Removes usage of deprecated fields, types and functions ([243](https://github.com/hashicorp/terraform-provider-random/issues/243), [244](https://github.com/hashicorp/terraform-provider-random/pull/244)).
|
||||
* Tests all minor Terraform versions ([238](https://github.com/hashicorp/terraform-provider-random/issues/238), [241](https://github.com/hashicorp/terraform-provider-random/pull/241))
|
||||
* Switches to linting with golangci-lint ([237](https://github.com/hashicorp/terraform-provider-random/issues/237), [240](https://github.com/hashicorp/terraform-provider-random/pull/240)).
|
||||
|
||||
## 3.1.3 (April 22, 2022)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_password: Prevent crash when length is less than 0 ([#129](https://github.com/hashicorp/terraform-provider-random/issues/129), [#181](https://github.com/hashicorp/terraform-provider-random/issues/181), [#200](https://github.com/hashicorp/terraform-provider-random/pull/200), [#233](https://github.com/hashicorp/terraform-provider-random/issues/233)).
|
||||
* resource/random_string: Prevent crash when length is less than 0 ([#129](https://github.com/hashicorp/terraform-provider-random/issues/129), [#181](https://github.com/hashicorp/terraform-provider-random/issues/181), [#200](https://github.com/hashicorp/terraform-provider-random/pull/200), [#233](https://github.com/hashicorp/terraform-provider-random/issues/233)).
|
||||
* resource/random_password: Prevent confusing inconsistent result error when length is 0 ([#222](https://github.com/hashicorp/terraform-provider-random/issues/222), [#233](https://github.com/hashicorp/terraform-provider-random/issues/233)).
|
||||
* resource/random_string: Prevent confusing inconsistent result error when length is 0 ([#222](https://github.com/hashicorp/terraform-provider-random/issues/222), [#233](https://github.com/hashicorp/terraform-provider-random/issues/233)).
|
||||
|
||||
## 3.1.2 (March 17, 2022)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* resource/random_pet: Prevented deterministic results since 3.1.1 ([#217](https://github.com/hashicorp/terraform-provider-random/issues/217).
|
||||
|
||||
## 3.1.1 (March 16, 2022)
|
||||
|
||||
NOTES:
|
||||
|
||||
* Updated [terraform-plugin-docs](https://github.com/hashicorp/terraform-plugin-docs) to `v0.7.0`:
|
||||
this improves generated documentation, with attributes now correctly formatted as `code`
|
||||
and provided with anchors.
|
||||
* Functionally identical to the previous 3.1.0 release.
|
||||
|
||||
## 3.1.0 (February 19, 2021)
|
||||
|
||||
Binary releases of this provider now include the darwin-arm64 platform. This version contains no further changes.
|
||||
|
||||
## 3.0.1 (January 12, 2021)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* `resource_integer`: Integers in state that do not cleanly fit into float64s no longer lose their precision ([#132](https://github.com/terraform-providers/terraform-provider-random/issues/132))
|
||||
|
||||
## 3.0.0 (October 09, 2020)
|
||||
|
||||
Binary releases of this provider will now include the linux-arm64 platform.
|
||||
|
||||
BREAKING CHANGES:
|
||||
|
||||
* Upgrade to version 2 of the Terraform Plugin SDK, which drops support for Terraform 0.11. This provider will continue to work as expected for users of Terraform 0.11, which will not download the new version. ([#118](https://github.com/terraform-providers/terraform-provider-random/issues/118))
|
||||
* Remove deprecated `b64` attribute ([#118](https://github.com/terraform-providers/terraform-provider-random/issues/118))
|
||||
|
||||
## 2.3.1 (October 26, 2020)
|
||||
|
||||
NOTES: This version is identical to v2.3.0, but has been compiled using Go v1.14.5 to fix https://github.com/hashicorp/terraform-provider-random/issues/120.
|
||||
|
||||
## 2.3.0 (July 07, 2020)
|
||||
|
||||
NOTES:
|
||||
|
||||
* The provider now uses the binary driver for acceptance tests ([#99](https://github.com/terraform-providers/terraform-provider-random/issues/99))
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* Added import handling for `random_string` and `random_password` ([#104](https://github.com/terraform-providers/terraform-provider-random/issues/104))
|
||||
|
||||
## 2.2.1 (September 25, 2019)
|
||||
|
||||
NOTES:
|
||||
|
||||
* The provider has switched to the standalone TF SDK, there should be no noticeable impact on compatibility. ([#76](https://github.com/terraform-providers/terraform-provider-random/issues/76))
|
||||
|
||||
## 2.2.0 (August 08, 2019)
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* `random_password` is similar to `random_string` but is marked sensitive for logs and output [[#52](https://github.com/terraform-providers/terraform-provider-random/issues/52)]
|
||||
|
||||
## 2.1.2 (April 30, 2019)
|
||||
|
||||
* This release includes another Terraform SDK upgrade intended to align with that being used for other providers as we prepare for the Core v0.12.0 release. It should have no significant changes in behavior for this provider.
|
||||
|
||||
## 2.1.1 (April 12, 2019)
|
||||
|
||||
* This release includes only a Terraform SDK upgrade intended to align with that being used for other providers as we prepare for the Core v0.12.0 release. It should have no significant changes in behavior for this provider.
|
||||
|
||||
## 2.1.0 (March 20, 2019)
|
||||
|
||||
IMPROVEMENTS:
|
||||
|
||||
* The provider is now compatible with Terraform v0.12, while retaining compatibility with prior versions.
|
||||
|
||||
## 2.0.0 (August 15, 2018)
|
||||
|
||||
BACKWARDS INCOMPATIBILITIES / NOTES:
|
||||
* `random_string`: set the ID for random_string resources to "none". Any terraform configuration referring to `random_string.foo.id` will need to be updated to reference `random_string.foo.result` ([#17](https://github.com/terraform-providers/terraform-provider-random/issues/17))
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* `random_uuid` generates random uuid string that is intended to be used as unique identifiers for other resources ([#38](https://github.com/terraform-providers/terraform-provider-random/issues/38))
|
||||
|
||||
BUG FIXES:
|
||||
* Use UnixNano() instead of Unix() for the current time seed in NewRand() ([#27](https://github.com/terraform-providers/terraform-provider-random/issues/27))
|
||||
* `random_shuffle`: if `random_shuffle` is given an empty list, it will return an empty list
|
||||
|
||||
IMPROVEMENTS:
|
||||
|
||||
* Replace ReadPet function in `resource_pet` with schema.Noop ([#34](https://github.com/terraform-providers/terraform-provider-random/issues/34))
|
||||
|
||||
## 1.3.1 (May 22, 2018)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* Add migration and new schema version for `resource_string` ([#29](https://github.com/terraform-providers/terraform-provider-random/issues/29))
|
||||
|
||||
## 1.3.0 (May 21, 2018)
|
||||
|
||||
BUG FIXES:
|
||||
|
||||
* `random_integer` now supports update ([#25](https://github.com/terraform-providers/terraform-provider-random/issues/25))
|
||||
|
||||
IMPROVEMENTS:
|
||||
|
||||
* Add optional minimum character constraints to `random_string` ([#22](https://github.com/terraform-providers/terraform-provider-random/issues/22))
|
||||
|
||||
## 1.2.0 (April 03, 2018)
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* `random_integer` and `random_id` are now importable. ([#20](https://github.com/terraform-providers/terraform-provider-random/issues/20))
|
||||
|
||||
## 1.1.0 (December 01, 2017)
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* `random_integer` resource generates a single integer within a given range. ([#12](https://github.com/terraform-providers/terraform-provider-random/issues/12))
|
||||
|
||||
## 1.0.0 (September 15, 2017)
|
||||
|
||||
NEW FEATURES:
|
||||
|
||||
* `random_string` resource generates random strings of a given length consisting of letters, digits and symbols. ([#5](https://github.com/terraform-providers/terraform-provider-random/issues/5))
|
||||
|
||||
## 0.1.0 (June 21, 2017)
|
||||
|
||||
NOTES:
|
||||
|
||||
* Same functionality as that of Terraform 0.9.8. Repacked as part of [Provider Splitout](https://www.hashicorp.com/blog/upcoming-provider-changes-in-terraform-0-10/)
|
@ -1,375 +0,0 @@
|
||||
Copyright (c) 2017 HashiCorp, Inc.
|
||||
|
||||
Mozilla Public License Version 2.0
|
||||
==================================
|
||||
|
||||
1. Definitions
|
||||
--------------
|
||||
|
||||
1.1. "Contributor"
|
||||
means each individual or legal entity that creates, contributes to
|
||||
the creation of, or owns Covered Software.
|
||||
|
||||
1.2. "Contributor Version"
|
||||
means the combination of the Contributions of others (if any) used
|
||||
by a Contributor and that particular Contributor's Contribution.
|
||||
|
||||
1.3. "Contribution"
|
||||
means Covered Software of a particular Contributor.
|
||||
|
||||
1.4. "Covered Software"
|
||||
means Source Code Form to which the initial Contributor has attached
|
||||
the notice in Exhibit A, the Executable Form of such Source Code
|
||||
Form, and Modifications of such Source Code Form, in each case
|
||||
including portions thereof.
|
||||
|
||||
1.5. "Incompatible With Secondary Licenses"
|
||||
means
|
||||
|
||||
(a) that the initial Contributor has attached the notice described
|
||||
in Exhibit B to the Covered Software; or
|
||||
|
||||
(b) that the Covered Software was made available under the terms of
|
||||
version 1.1 or earlier of the License, but not also under the
|
||||
terms of a Secondary License.
|
||||
|
||||
1.6. "Executable Form"
|
||||
means any form of the work other than Source Code Form.
|
||||
|
||||
1.7. "Larger Work"
|
||||
means a work that combines Covered Software with other material, in
|
||||
a separate file or files, that is not Covered Software.
|
||||
|
||||
1.8. "License"
|
||||
means this document.
|
||||
|
||||
1.9. "Licensable"
|
||||
means having the right to grant, to the maximum extent possible,
|
||||
whether at the time of the initial grant or subsequently, any and
|
||||
all of the rights conveyed by this License.
|
||||
|
||||
1.10. "Modifications"
|
||||
means any of the following:
|
||||
|
||||
(a) any file in Source Code Form that results from an addition to,
|
||||
deletion from, or modification of the contents of Covered
|
||||
Software; or
|
||||
|
||||
(b) any new file in Source Code Form that contains any Covered
|
||||
Software.
|
||||
|
||||
1.11. "Patent Claims" of a Contributor
|
||||
means any patent claim(s), including without limitation, method,
|
||||
process, and apparatus claims, in any patent Licensable by such
|
||||
Contributor that would be infringed, but for the grant of the
|
||||
License, by the making, using, selling, offering for sale, having
|
||||
made, import, or transfer of either its Contributions or its
|
||||
Contributor Version.
|
||||
|
||||
1.12. "Secondary License"
|
||||
means either the GNU General Public License, Version 2.0, the GNU
|
||||
Lesser General Public License, Version 2.1, the GNU Affero General
|
||||
Public License, Version 3.0, or any later versions of those
|
||||
licenses.
|
||||
|
||||
1.13. "Source Code Form"
|
||||
means the form of the work preferred for making modifications.
|
||||
|
||||
1.14. "You" (or "Your")
|
||||
means an individual or a legal entity exercising rights under this
|
||||
License. For legal entities, "You" includes any entity that
|
||||
controls, is controlled by, or is under common control with You. For
|
||||
purposes of this definition, "control" means (a) the power, direct
|
||||
or indirect, to cause the direction or management of such entity,
|
||||
whether by contract or otherwise, or (b) ownership of more than
|
||||
fifty percent (50%) of the outstanding shares or beneficial
|
||||
ownership of such entity.
|
||||
|
||||
2. License Grants and Conditions
|
||||
--------------------------------
|
||||
|
||||
2.1. Grants
|
||||
|
||||
Each Contributor hereby grants You a world-wide, royalty-free,
|
||||
non-exclusive license:
|
||||
|
||||
(a) under intellectual property rights (other than patent or trademark)
|
||||
Licensable by such Contributor to use, reproduce, make available,
|
||||
modify, display, perform, distribute, and otherwise exploit its
|
||||
Contributions, either on an unmodified basis, with Modifications, or
|
||||
as part of a Larger Work; and
|
||||
|
||||
(b) under Patent Claims of such Contributor to make, use, sell, offer
|
||||
for sale, have made, import, and otherwise transfer either its
|
||||
Contributions or its Contributor Version.
|
||||
|
||||
2.2. Effective Date
|
||||
|
||||
The licenses granted in Section 2.1 with respect to any Contribution
|
||||
become effective for each Contribution on the date the Contributor first
|
||||
distributes such Contribution.
|
||||
|
||||
2.3. Limitations on Grant Scope
|
||||
|
||||
The licenses granted in this Section 2 are the only rights granted under
|
||||
this License. No additional rights or licenses will be implied from the
|
||||
distribution or licensing of Covered Software under this License.
|
||||
Notwithstanding Section 2.1(b) above, no patent license is granted by a
|
||||
Contributor:
|
||||
|
||||
(a) for any code that a Contributor has removed from Covered Software;
|
||||
or
|
||||
|
||||
(b) for infringements caused by: (i) Your and any other third party's
|
||||
modifications of Covered Software, or (ii) the combination of its
|
||||
Contributions with other software (except as part of its Contributor
|
||||
Version); or
|
||||
|
||||
(c) under Patent Claims infringed by Covered Software in the absence of
|
||||
its Contributions.
|
||||
|
||||
This License does not grant any rights in the trademarks, service marks,
|
||||
or logos of any Contributor (except as may be necessary to comply with
|
||||
the notice requirements in Section 3.4).
|
||||
|
||||
2.4. Subsequent Licenses
|
||||
|
||||
No Contributor makes additional grants as a result of Your choice to
|
||||
distribute the Covered Software under a subsequent version of this
|
||||
License (see Section 10.2) or under the terms of a Secondary License (if
|
||||
permitted under the terms of Section 3.3).
|
||||
|
||||
2.5. Representation
|
||||
|
||||
Each Contributor represents that the Contributor believes its
|
||||
Contributions are its original creation(s) or it has sufficient rights
|
||||
to grant the rights to its Contributions conveyed by this License.
|
||||
|
||||
2.6. Fair Use
|
||||
|
||||
This License is not intended to limit any rights You have under
|
||||
applicable copyright doctrines of fair use, fair dealing, or other
|
||||
equivalents.
|
||||
|
||||
2.7. Conditions
|
||||
|
||||
Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted
|
||||
in Section 2.1.
|
||||
|
||||
3. Responsibilities
|
||||
-------------------
|
||||
|
||||
3.1. Distribution of Source Form
|
||||
|
||||
All distribution of Covered Software in Source Code Form, including any
|
||||
Modifications that You create or to which You contribute, must be under
|
||||
the terms of this License. You must inform recipients that the Source
|
||||
Code Form of the Covered Software is governed by the terms of this
|
||||
License, and how they can obtain a copy of this License. You may not
|
||||
attempt to alter or restrict the recipients' rights in the Source Code
|
||||
Form.
|
||||
|
||||
3.2. Distribution of Executable Form
|
||||
|
||||
If You distribute Covered Software in Executable Form then:
|
||||
|
||||
(a) such Covered Software must also be made available in Source Code
|
||||
Form, as described in Section 3.1, and You must inform recipients of
|
||||
the Executable Form how they can obtain a copy of such Source Code
|
||||
Form by reasonable means in a timely manner, at a charge no more
|
||||
than the cost of distribution to the recipient; and
|
||||
|
||||
(b) You may distribute such Executable Form under the terms of this
|
||||
License, or sublicense it under different terms, provided that the
|
||||
license for the Executable Form does not attempt to limit or alter
|
||||
the recipients' rights in the Source Code Form under this License.
|
||||
|
||||
3.3. Distribution of a Larger Work
|
||||
|
||||
You may create and distribute a Larger Work under terms of Your choice,
|
||||
provided that You also comply with the requirements of this License for
|
||||
the Covered Software. If the Larger Work is a combination of Covered
|
||||
Software with a work governed by one or more Secondary Licenses, and the
|
||||
Covered Software is not Incompatible With Secondary Licenses, this
|
||||
License permits You to additionally distribute such Covered Software
|
||||
under the terms of such Secondary License(s), so that the recipient of
|
||||
the Larger Work may, at their option, further distribute the Covered
|
||||
Software under the terms of either this License or such Secondary
|
||||
License(s).
|
||||
|
||||
3.4. Notices
|
||||
|
||||
You may not remove or alter the substance of any license notices
|
||||
(including copyright notices, patent notices, disclaimers of warranty,
|
||||
or limitations of liability) contained within the Source Code Form of
|
||||
the Covered Software, except that You may alter any license notices to
|
||||
the extent required to remedy known factual inaccuracies.
|
||||
|
||||
3.5. Application of Additional Terms
|
||||
|
||||
You may choose to offer, and to charge a fee for, warranty, support,
|
||||
indemnity or liability obligations to one or more recipients of Covered
|
||||
Software. However, You may do so only on Your own behalf, and not on
|
||||
behalf of any Contributor. You must make it absolutely clear that any
|
||||
such warranty, support, indemnity, or liability obligation is offered by
|
||||
You alone, and You hereby agree to indemnify every Contributor for any
|
||||
liability incurred by such Contributor as a result of warranty, support,
|
||||
indemnity or liability terms You offer. You may include additional
|
||||
disclaimers of warranty and limitations of liability specific to any
|
||||
jurisdiction.
|
||||
|
||||
4. Inability to Comply Due to Statute or Regulation
|
||||
---------------------------------------------------
|
||||
|
||||
If it is impossible for You to comply with any of the terms of this
|
||||
License with respect to some or all of the Covered Software due to
|
||||
statute, judicial order, or regulation then You must: (a) comply with
|
||||
the terms of this License to the maximum extent possible; and (b)
|
||||
describe the limitations and the code they affect. Such description must
|
||||
be placed in a text file included with all distributions of the Covered
|
||||
Software under this License. Except to the extent prohibited by statute
|
||||
or regulation, such description must be sufficiently detailed for a
|
||||
recipient of ordinary skill to be able to understand it.
|
||||
|
||||
5. Termination
|
||||
--------------
|
||||
|
||||
5.1. The rights granted under this License will terminate automatically
|
||||
if You fail to comply with any of its terms. However, if You become
|
||||
compliant, then the rights granted under this License from a particular
|
||||
Contributor are reinstated (a) provisionally, unless and until such
|
||||
Contributor explicitly and finally terminates Your grants, and (b) on an
|
||||
ongoing basis, if such Contributor fails to notify You of the
|
||||
non-compliance by some reasonable means prior to 60 days after You have
|
||||
come back into compliance. Moreover, Your grants from a particular
|
||||
Contributor are reinstated on an ongoing basis if such Contributor
|
||||
notifies You of the non-compliance by some reasonable means, this is the
|
||||
first time You have received notice of non-compliance with this License
|
||||
from such Contributor, and You become compliant prior to 30 days after
|
||||
Your receipt of the notice.
|
||||
|
||||
5.2. If You initiate litigation against any entity by asserting a patent
|
||||
infringement claim (excluding declaratory judgment actions,
|
||||
counter-claims, and cross-claims) alleging that a Contributor Version
|
||||
directly or indirectly infringes any patent, then the rights granted to
|
||||
You by any and all Contributors for the Covered Software under Section
|
||||
2.1 of this License shall terminate.
|
||||
|
||||
5.3. In the event of termination under Sections 5.1 or 5.2 above, all
|
||||
end user license agreements (excluding distributors and resellers) which
|
||||
have been validly granted by You or Your distributors under this License
|
||||
prior to termination shall survive termination.
|
||||
|
||||
************************************************************************
|
||||
* *
|
||||
* 6. Disclaimer of Warranty *
|
||||
* ------------------------- *
|
||||
* *
|
||||
* Covered Software is provided under this License on an "as is" *
|
||||
* basis, without warranty of any kind, either expressed, implied, or *
|
||||
* statutory, including, without limitation, warranties that the *
|
||||
* Covered Software is free of defects, merchantable, fit for a *
|
||||
* particular purpose or non-infringing. The entire risk as to the *
|
||||
* quality and performance of the Covered Software is with You. *
|
||||
* Should any Covered Software prove defective in any respect, You *
|
||||
* (not any Contributor) assume the cost of any necessary servicing, *
|
||||
* repair, or correction. This disclaimer of warranty constitutes an *
|
||||
* essential part of this License. No use of any Covered Software is *
|
||||
* authorized under this License except under this disclaimer. *
|
||||
* *
|
||||
************************************************************************
|
||||
|
||||
************************************************************************
|
||||
* *
|
||||
* 7. Limitation of Liability *
|
||||
* -------------------------- *
|
||||
* *
|
||||
* Under no circumstances and under no legal theory, whether tort *
|
||||
* (including negligence), contract, or otherwise, shall any *
|
||||
* Contributor, or anyone who distributes Covered Software as *
|
||||
* permitted above, be liable to You for any direct, indirect, *
|
||||
* special, incidental, or consequential damages of any character *
|
||||
* including, without limitation, damages for lost profits, loss of *
|
||||
* goodwill, work stoppage, computer failure or malfunction, or any *
|
||||
* and all other commercial damages or losses, even if such party *
|
||||
* shall have been informed of the possibility of such damages. This *
|
||||
* limitation of liability shall not apply to liability for death or *
|
||||
* personal injury resulting from such party's negligence to the *
|
||||
* extent applicable law prohibits such limitation. Some *
|
||||
* jurisdictions do not allow the exclusion or limitation of *
|
||||
* incidental or consequential damages, so this exclusion and *
|
||||
* limitation may not apply to You. *
|
||||
* *
|
||||
************************************************************************
|
||||
|
||||
8. Litigation
|
||||
-------------
|
||||
|
||||
Any litigation relating to this License may be brought only in the
|
||||
courts of a jurisdiction where the defendant maintains its principal
|
||||
place of business and such litigation shall be governed by laws of that
|
||||
jurisdiction, without reference to its conflict-of-law provisions.
|
||||
Nothing in this Section shall prevent a party's ability to bring
|
||||
cross-claims or counter-claims.
|
||||
|
||||
9. Miscellaneous
|
||||
----------------
|
||||
|
||||
This License represents the complete agreement concerning the subject
|
||||
matter hereof. If any provision of this License is held to be
|
||||
unenforceable, such provision shall be reformed only to the extent
|
||||
necessary to make it enforceable. Any law or regulation which provides
|
||||
that the language of a contract shall be construed against the drafter
|
||||
shall not be used to construe this License against a Contributor.
|
||||
|
||||
10. Versions of the License
|
||||
---------------------------
|
||||
|
||||
10.1. New Versions
|
||||
|
||||
Mozilla Foundation is the license steward. Except as provided in Section
|
||||
10.3, no one other than the license steward has the right to modify or
|
||||
publish new versions of this License. Each version will be given a
|
||||
distinguishing version number.
|
||||
|
||||
10.2. Effect of New Versions
|
||||
|
||||
You may distribute the Covered Software under the terms of the version
|
||||
of the License under which You originally received the Covered Software,
|
||||
or under the terms of any subsequent version published by the license
|
||||
steward.
|
||||
|
||||
10.3. Modified Versions
|
||||
|
||||
If you create software not governed by this License, and you want to
|
||||
create a new license for such software, you may create and use a
|
||||
modified version of this License if you rename the license and remove
|
||||
any references to the name of the license steward (except to note that
|
||||
such modified license differs from this License).
|
||||
|
||||
10.4. Distributing Source Code Form that is Incompatible With Secondary
|
||||
Licenses
|
||||
|
||||
If You choose to distribute Source Code Form that is Incompatible With
|
||||
Secondary Licenses under the terms of this version of the License, the
|
||||
notice described in Exhibit B of this License must be attached.
|
||||
|
||||
Exhibit A - Source Code Form License Notice
|
||||
-------------------------------------------
|
||||
|
||||
This Source Code Form is subject to the terms of the Mozilla Public
|
||||
License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
|
||||
If it is not possible or desirable to put the notice in a particular
|
||||
file, then You may include the notice in a location (such as a LICENSE
|
||||
file in a relevant directory) where a recipient would be likely to look
|
||||
for such a notice.
|
||||
|
||||
You may add additional accurate notices of copyright ownership.
|
||||
|
||||
Exhibit B - "Incompatible With Secondary Licenses" Notice
|
||||
---------------------------------------------------------
|
||||
|
||||
This Source Code Form is "Incompatible With Secondary Licenses", as
|
||||
defined by the Mozilla Public License, v. 2.0.
|
@ -1,119 +0,0 @@
|
||||
# Terraform Provider: Random
|
||||
|
||||
The Random provider supports the use of randomness within Terraform configurations. The
|
||||
provider resources can be used to generate a random [id](docs/resources/id.md),
|
||||
[integer](docs/resources/integer.md), [password](docs/resources/password.md),
|
||||
[pet](docs/resources/pet.md), [shuffle](docs/resources/shuffle.md) (random permutation
|
||||
of a list of strings), [string](docs/resources/string.md) or
|
||||
[uuid](docs/resources/uuid.md).
|
||||
|
||||
## Documentation, questions and discussions
|
||||
|
||||
Official documentation on how to use this provider can be found on the
|
||||
[Terraform Registry](https://registry.terraform.io/providers/hashicorp/random/latest/docs).
|
||||
In case of specific questions or discussions, please use the
|
||||
HashiCorp [Terraform Providers Discuss forums](https://discuss.hashicorp.com/c/terraform-providers/31),
|
||||
in accordance with HashiCorp [Community Guidelines](https://www.hashicorp.com/community-guidelines).
|
||||
|
||||
We also provide:
|
||||
|
||||
* [Support](.github/SUPPORT.md) page for help when using the provider
|
||||
* [Contributing](.github/CONTRIBUTING.md) guidelines in case you want to help this project
|
||||
* [Design](DESIGN.md) documentation to understand the scope and maintenance decisions
|
||||
|
||||
The remainder of this document will focus on the development aspects of the provider.
|
||||
|
||||
## Requirements
|
||||
|
||||
* [Terraform](https://www.terraform.io/downloads) (>= 0.12)
|
||||
* [Go](https://go.dev/doc/install) (1.22)
|
||||
* [GNU Make](https://www.gnu.org/software/make/)
|
||||
* [golangci-lint](https://golangci-lint.run/usage/install/#local-installation) (optional)
|
||||
|
||||
## Development
|
||||
|
||||
### Building
|
||||
|
||||
1. `git clone` this repository and `cd` into its directory
|
||||
2. `make build` will trigger the Golang build
|
||||
|
||||
The provided `GNUmakefile` defines additional commands generally useful during development,
|
||||
like for running tests, generating documentation, code formatting and linting.
|
||||
Taking a look at it's content is recommended.
|
||||
|
||||
### Testing
|
||||
|
||||
In order to test the provider, you can run
|
||||
|
||||
* `make test` to run provider tests
|
||||
* `make testacc` to run provider acceptance tests
|
||||
|
||||
It's important to note that acceptance tests (`testacc`) will actually spawn
|
||||
`terraform` and the provider. Read more about they work on the
|
||||
[official page](https://www.terraform.io/plugin/sdkv2/testing/acceptance-tests).
|
||||
|
||||
### Generating documentation
|
||||
|
||||
This provider uses [terraform-plugin-docs](https://github.com/hashicorp/terraform-plugin-docs/)
|
||||
to generate documentation and store it in the `docs/` directory.
|
||||
Once a release is cut, the Terraform Registry will download the documentation from `docs/`
|
||||
and associate it with the release version. Read more about how this works on the
|
||||
[official page](https://www.terraform.io/registry/providers/docs).
|
||||
|
||||
Use `make generate` to ensure the documentation is regenerated with any changes.
|
||||
|
||||
### Using a development build
|
||||
|
||||
If [running tests and acceptance tests](#testing) isn't enough, it's possible to set up a local terraform configuration
|
||||
to use a development builds of the provider. This can be achieved by leveraging the Terraform CLI
|
||||
[configuration file development overrides](https://www.terraform.io/cli/config/config-file#development-overrides-for-provider-developers).
|
||||
|
||||
First, use `make install` to place a fresh development build of the provider in your [`${GOBIN}`](https://pkg.go.dev/cmd/go#hdr-Compile_and_install_packages_and_dependencies) (defaults to `${GOPATH}/bin` or `${HOME}/go/bin` if `${GOPATH}` is not set). Repeat
|
||||
this every time you make changes to the provider locally.
|
||||
|
||||
Then, in your `${HOME}/.terraformrc` (Unix) / `%APPDATA%\terraform.rc` (Windows), a `provider_installation` that contains
|
||||
the following `dev_overrides`:
|
||||
|
||||
```hcl
|
||||
provider_installation {
|
||||
dev_overrides {
|
||||
"hashicorp/random" = "${GOBIN}" //< replace `${GOBIN}` with the actual path on your system
|
||||
}
|
||||
|
||||
direct {}
|
||||
}
|
||||
```
|
||||
|
||||
Note that it's also possible to use a dedicated Terraform configuration file and invoke `terraform` while setting
|
||||
the environment variable `TF_CLI_CONFIG_FILE=my_terraform_config_file`.
|
||||
|
||||
Once the `dev_overrides` are in place, any local execution of `terraform plan` and `terraform apply` will
|
||||
use the version of the provider found in the given `${GOBIN}` directory,
|
||||
instead of the one indicated in your terraform configuration.
|
||||
|
||||
### Testing GitHub Actions
|
||||
|
||||
This project uses [GitHub Actions](https://docs.github.com/en/actions/automating-builds-and-tests) to realize its CI.
|
||||
|
||||
Sometimes it might be helpful to locally reproduce the behaviour of those actions,
|
||||
and for this we use [act](https://github.com/nektos/act). Once installed, you can _simulate_ the actions executed
|
||||
when opening a PR with:
|
||||
|
||||
```shell
|
||||
# List of workflows for the 'pull_request' action
|
||||
$ act -l pull_request
|
||||
|
||||
# Execute the workflows associated with the `pull_request' action
|
||||
$ act pull_request
|
||||
```
|
||||
|
||||
## Releasing
|
||||
|
||||
The release process is automated via GitHub Actions, and it's defined in the Workflow
|
||||
[release.yml](./.github/workflows/release.yml).
|
||||
|
||||
Each release is cut by pushing a [semantically versioned](https://semver.org/) tag to the default branch.
|
||||
|
||||
## License
|
||||
|
||||
[Mozilla Public License v2.0](./LICENSE)
|
Binary file not shown.
@ -1,756 +0,0 @@
|
||||
# Changelog
|
||||
## [v2.23.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.23.0...v2.23.1) (2024-12-06)
|
||||
### Automation
|
||||
* Update github workflows from go 1.22 to 1.23 [PR 538](https://github.com/vultr/terraform-provider-vultr/pull/538)
|
||||
* Update goreleaser action from v5 to v6 [PR 539](https://github.com/vultr/terraform-provider-vultr/pull/539)
|
||||
|
||||
## [v2.23.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.22.1...v2.23.0) (2024-12-06)
|
||||
### Enhancements
|
||||
* resource/snapshot: Add default timeout on create [PR 536](https://github.com/vultr/terraform-provider-vultr/pull/536)
|
||||
|
||||
### Bug Fixes
|
||||
* resource/kubernetes: Remove the set on enable_firewall [PR 531](https://github.com/vultr/terraform-provider-vultr/pull/531)
|
||||
* resource/kubernetes: Fix node pool default tag lookup [PR 528](https://github.com/vultr/terraform-provider-vultr/pull/528)
|
||||
|
||||
### Deprecations
|
||||
* resource/database: Deprecate Redis-named fields [PR 533](https://github.com/vultr/terraform-provider-vultr/pull/533)
|
||||
* data_source/database: Deprecate Redis-named fields [PR 533](https://github.com/vultr/terraform-provider-vultr/pull/533)
|
||||
|
||||
### Dependencies
|
||||
* Update govultr from v3.11.2 to v3.12.0 [PR 532](https://github.com/vultr/terraform-provider-vultr/pull/532)
|
||||
* Bump golang.org/x/oauth2 from 0.23.0 to 0.24.0 [PR 527](https://github.com/vultr/terraform-provider-vultr/pull/527)
|
||||
|
||||
### Documentation
|
||||
* Add provider installation instructions to README [PR 535](https://github.com/vultr/terraform-provider-vultr/pull/535)
|
||||
|
||||
### Automation
|
||||
* Add goreleaser config version for v2 [PR 534](https://github.com/vultr/terraform-provider-vultr/pull/534)
|
||||
|
||||
### New Contributors
|
||||
* @timurbabs made their first contribution in [PR 528](https://github.com/vultr/terraform-provider-vultr/pull/528)
|
||||
|
||||
## [v2.22.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.22.0...v2.22.1) (2024-11-07)
|
||||
### Bug Fixes
|
||||
* resource/bare_metal_server: Set default value for user_scheme [PR 525](https://github.com/vultr/terraform-provider-vultr/pull/525)
|
||||
* resource/instance: Set default value for user_scheme [PR 525](https://github.com/vultr/terraform-provider-vultr/pull/525)
|
||||
|
||||
## [v2.22.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.21.0...v2.22.0) (2024-11-06)
|
||||
### Enhancements
|
||||
* resource/bare_metal_server: Add `user_scheme` options [PR 514](https://github.com/vultr/terraform-provider-vultr/pull/514)
|
||||
* data_source/bare_metal_server: Add `user_scheme` options [PR 514](https://github.com/vultr/terraform-provider-vultr/pull/514)
|
||||
* resource/instance: Add `user_scheme` options [PR 514](https://github.com/vultr/terraform-provider-vultr/pull/514)
|
||||
* data_source/instance: Add `user_scheme` options [PR 514](https://github.com/vultr/terraform-provider-vultr/pull/514)
|
||||
* resource/kubernetes: Add/improve existing resource import [PR 503](https://github.com/vultr/terraform-provider-vultr/pull/503)
|
||||
* resource/database: Add support for Kafka [PR 522](https://github.com/vultr/terraform-provider-vultr/pull/522)
|
||||
* data_source/database: Add support for Kafka [PR 522](https://github.com/vultr/terraform-provider-vultr/pull/522)
|
||||
|
||||
### Dependencies
|
||||
* Update govultr from v3.8.1 to v3.9.0 [PR 504](https://github.com/vultr/terraform-provider-vultr/pull/504)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.9.0 to 3.10.0 [PR 511](https://github.com/vultr/terraform-provider-vultr/pull/511)
|
||||
* Bump golang.org/x/oauth2 from 0.21.0 to 0.23.0 [PR 510](https://github.com/vultr/terraform-provider-vultr/pull/510)
|
||||
* Update go from 1.21 to 1.23 [PR 513](https://github.com/vultr/terraform-provider-vultr/pull/513)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.10.0 to 3.11.0 [PR 516](https://github.com/vultr/terraform-provider-vultr/pull/516)
|
||||
* Update govultr from v3.11.0 to v3.11.1 [PR 518](https://github.com/vultr/terraform-provider-vultr/pull/518)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.11.1 to 3.11.2 [PR 519](https://github.com/vultr/terraform-provider-vultr/pull/519)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.34.0 to 2.35.0 [PR 521](https://github.com/vultr/terraform-provider-vultr/pull/521)
|
||||
|
||||
### Bug Fixes
|
||||
* Ensure format strings for TF diag errors [PR 512](https://github.com/vultr/terraform-provider-vultr/pull/512)
|
||||
|
||||
### Clean up
|
||||
* Remove unused travis CI config [PR 515](https://github.com/vultr/terraform-provider-vultr/pull/515)
|
||||
* Remove vendored code [PR 520](https://github.com/vultr/terraform-provider-vultr/pull/520)
|
||||
|
||||
### Automation
|
||||
* Add github CODEOWNERS file [PR 517](https://github.com/vultr/terraform-provider-vultr/pull/517)
|
||||
|
||||
## [v2.21.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.20.1...v2.21.0) (2024-06-10)
|
||||
### Enhancements
|
||||
* resource/container_registry: add resource support [PR 445](https://github.com/vultr/terraform-provider-vultr/pull/445)
|
||||
* resource/container_registry: add registry name validation [PR 493](https://github.com/vultr/terraform-provider-vultr/pull/493)
|
||||
* data_source/container_registry: add data source support [PR 493](https://github.com/vultr/terraform-provider-vultr/pull/493)
|
||||
* resource/user: change ACL schema to set to state drift [PR 495](https://github.com/vultr/terraform-provider-vultr/pull/495)
|
||||
* resource/inference: add resource [PR 501](https://github.com/vultr/terraform-provider-vultr/pull/501)
|
||||
* data_source/inference: add data source [PR 501](https://github.com/vultr/terraform-provider-vultr/pull/501)
|
||||
|
||||
### Deprecations
|
||||
* resource/private_network: removed from provider [PR 496](https://github.com/vultr/terraform-provider-vultr/pull/496)
|
||||
* data_source/private_network: removed from provider [PR 496](https://github.com/vultr/terraform-provider-vultr/pull/496)
|
||||
|
||||
### Dependencies
|
||||
* Bump golang.org/x/oauth2 from 0.20.0 to 0.21.0 [PR 497](https://github.com/vultr/terraform-provider-vultr/pull/497)
|
||||
* Update govultr from v2.7.0 to v2.8.1 [PR 500](https://github.com/vultr/terraform-provider-vultr/pull/500)
|
||||
|
||||
### Automation
|
||||
* Lint fixes; add an updated lint configuration [PR 498](https://github.com/vultr/terraform-provider-vultr/pull/498)
|
||||
|
||||
### New Contributors
|
||||
* @im6h made their first contribution in [PR 445](https://github.com/vultr/terraform-provider-vultr/pull/445)
|
||||
* @F21 made their first contribution in [PR 495](https://github.com/vultr/terraform-provider-vultr/pull/495)
|
||||
|
||||
## [v2.20.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.20.0...v2.20.1) (2024-05-29)
|
||||
### Automation
|
||||
* Update GPG import github action [PR 491](https://github.com/vultr/terraform-provider-vultr/pull/491)
|
||||
|
||||
## [v2.20.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.19.0...v2.20.0) (2024-05-29)
|
||||
|
||||
### Enhancements
|
||||
* resource/bare_metal_server: add support for mdisk_mode option [PR 489](https://github.com/vultr/terraform-provider-vultr/pull/489)
|
||||
|
||||
### Bug Fixes
|
||||
* Stop using deprecated terraform helper resource for retries [PR 456](https://github.com/vultr/terraform-provider-vultr/pull/456)
|
||||
|
||||
### Dependencies
|
||||
* Bump github.com/cloudflare/circl from 1.3.3 to 1.3.7 [PR 457](https://github.com/vultr/terraform-provider-vultr/pull/457)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.6.0 to 3.6.2 [PR 465](https://github.com/vultr/terraform-provider-vultr/pull/465)
|
||||
* Bump golang.org/x/oauth2 from 0.15.0 to 0.17.0 [PR 464](https://github.com/vultr/terraform-provider-vultr/pull/464)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.31.0 to 2.32.0 [PR 461](https://github.com/vultr/terraform-provider-vultr/pull/461)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.32.0 to 2.33.0 [PR 466](https://github.com/vultr/terraform-provider-vultr/pull/466)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.6.2 to 3.6.3 [PR 467](https://github.com/vultr/terraform-provider-vultr/pull/467)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.6.3 to 3.6.4 [PR 471](https://github.com/vultr/terraform-provider-vultr/pull/471)
|
||||
* Bump golang.org/x/net from 0.21.0 to 0.23.0 [PR 478](https://github.com/vultr/terraform-provider-vultr/pull/478)
|
||||
* Bump golang.org/x/oauth2 from 0.17.0 to 0.19.0 [PR 475](https://github.com/vultr/terraform-provider-vultr/pull/475)
|
||||
* Bump google.golang.org/protobuf from 1.32.0 to 1.33.0 [PR 473](https://github.com/vultr/terraform-provider-vultr/pull/473)
|
||||
* Bump golang.org/x/oauth2 from 0.19.0 to 0.20.0 [PR 483](https://github.com/vultr/terraform-provider-vultr/pull/483)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.6.4 to 3.7.0 [PR 488](https://github.com/vultr/terraform-provider-vultr/pull/488)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.33.0 to 2.34.0 [PR 485](https://github.com/vultr/terraform-provider-vultr/pull/485)
|
||||
* Update go from v1.20 to v1.21 [PR 486](https://github.com/vultr/terraform-provider-vultr/pull/486)
|
||||
|
||||
### Automation
|
||||
* Update notify-pr.yml [PR 481](https://github.com/vultr/terraform-provider-vultr/pull/481)
|
||||
* Fix missing step on go-checks action [PR 480](https://github.com/vultr/terraform-provider-vultr/pull/480)
|
||||
* Fix mattermost notifications [PR 484](https://github.com/vultr/terraform-provider-vultr/pull/484)
|
||||
* CI & automation actions updates [PR 479](https://github.com/vultr/terraform-provider-vultr/pull/479)
|
||||
|
||||
### New Contributors
|
||||
* @fjoenichols made their first contribution in [PR 489](https://github.com/vultr/terraform-provider-vultr/pull/489)
|
||||
|
||||
##[v2.19.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.18.0...v2.19.0) (2024-01-03)
|
||||
### Enhancements
|
||||
* resource/instances: Allow creation without public IP [PR 450](https://github.com/vultr/terraform-provider-vultr/pull/450)
|
||||
* resource/instances: Add marketplace app variables support [PR 448](https://github.com/vultr/terraform-provider-vultr/pull/448)
|
||||
* resource/bare_metal_server: Add marketplace app variables support [PR 448](https://github.com/vultr/terraform-provider-vultr/pull/448)
|
||||
* resource/load_balancers: Add retry to delete [PR 451](https://github.com/vultr/terraform-provider-vultr/pull/451)
|
||||
|
||||
### Bug Fixes
|
||||
* resource/bare_metal_server: Fix nil interface panic on creation [PR 452](https://github.com/vultr/terraform-provider-vultr/pull/452)
|
||||
|
||||
### Documentation
|
||||
* resource/instances: Add disable_public_ipv4 field to webdocs [PR 453](https://github.com/vultr/terraform-provider-vultr/pull/453)
|
||||
|
||||
### Dependencies
|
||||
* Update govultr from v3.5.0 to v3.6.0 [PR 444](https://github.com/vultr/terraform-provider-vultr/pull/444)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.30.0 to 2.31.0 [PR 442](https://github.com/vultr/terraform-provider-vultr/pull/442)
|
||||
* Bump golang.org/x/crypto from 0.16.0 to 0.17.0 [PR 447](https://github.com/vultr/terraform-provider-vultr/pull/447)
|
||||
|
||||
### Automation
|
||||
* Use GITHUB_OUTPUT envvar instead of set-output command [PR 449](https://github.com/vultr/terraform-provider-vultr/pull/449)
|
||||
|
||||
### New Contributors
|
||||
* @OpenGLShaders made their first contribution in [PR 450](https://github.com/vultr/terraform-provider-vultr/pull/450)
|
||||
* @arunsathiya made their first contribution in [PR 449](https://github.com/vultr/terraform-provider-vultr/pull/449)
|
||||
|
||||
##[v2.18.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.17.1...v2.18.0) (2023-12-11)
|
||||
### Enhancements
|
||||
* resource/bare_metal_server: Add Persistent PXE field [PR 368](https://github.com/vultr/terraform-provider-vultr/pull/368)
|
||||
* data_source/instances: Add instances data source [PR 296](https://github.com/vultr/terraform-provider-vultr/pull/296)
|
||||
* data_source/ssh_key: Export the key ID [PR 338](https://github.com/vultr/terraform-provider-vultr/pull/338)
|
||||
* resource/kubernetes: Add firewall field [PR 434](https://github.com/vultr/terraform-provider-vultr/pull/434)
|
||||
* data_source/kubernetes: Add firewall field [PR 434](https://github.com/vultr/terraform-provider-vultr/pull/434)
|
||||
* resource/database: Add redis user access control [PR 439](https://github.com/vultr/terraform-provider-vultr/pull/439)
|
||||
|
||||
### Bug Fixes
|
||||
* Remove deprecated SDK meta version function usage [PR 432](https://github.com/vultr/terraform-provider-vultr/pull/432)
|
||||
* data_source/database: Fix bug with flattening non-FerretDB replicas [PR 427](https://github.com/vultr/terraform-provider-vultr/pull/427)
|
||||
|
||||
### Documentation
|
||||
* Add documentation for the instances data source [PR 431](https://github.com/vultr/terraform-provider-vultr/pull/431)
|
||||
|
||||
### Dependencies
|
||||
* Bump github.com/vultr/govultr/v3 from 3.3.4 to 3.4.0 [PR 430](https://github.com/vultr/terraform-provider-vultr/pull/430)
|
||||
* Bump golang.org/x/oauth2 from 0.13.0 to 0.14.0 [PR 429](https://github.com/vultr/terraform-provider-vultr/pull/429)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.29.0 to 2.30.0 [PR 428](https://github.com/vultr/terraform-provider-vultr/pull/428)
|
||||
* Update govultr from v3.4.0 to v3.5.0 [PR 438](https://github.com/vultr/terraform-provider-vultr/pull/438)
|
||||
* Bump golang.org/x/oauth2 from 0.14.0 to 0.15.0 [PR 435](https://github.com/vultr/terraform-provider-vultr/pull/435)
|
||||
|
||||
### New Contributors
|
||||
* @neilmock made their first contribution in [PR 368](https://github.com/vultr/terraform-provider-vultr/pull/368)
|
||||
* @aarani made their first contribution in [PR 296](https://github.com/vultr/terraform-provider-vultr/pull/296)
|
||||
* @Byteflux made their first contribution in [PR 434](https://github.com/vultr/terraform-provider-vultr/pull/434)
|
||||
|
||||
## [v2.17.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.17.0...v2.17.1) (2023-10-31)
|
||||
### Enhancements
|
||||
* resource/database: Add FerretDB Support [PR 422](https://github.com/vultr/terraform-provider-vultr/pull/422)
|
||||
* data_source/database: Add FerretDB Support [PR 422](https://github.com/vultr/terraform-provider-vultr/pull/422)
|
||||
* resource/kubernetes: Add support for the VKE HA control plane option [PR 423](https://github.com/vultr/terraform-provider-vultr/pull/423)
|
||||
* data_source/kubernetes: Add support for the VKE HA control plane option [PR 423](https://github.com/vultr/terraform-provider-vultr/pull/423)
|
||||
|
||||
### Bug Fixes
|
||||
* resource/vpc2: Fix ForceNew when optional fields not set [PR 424](https://github.com/vultr/terraform-provider-vultr/pull/424)
|
||||
|
||||
### Dependencies
|
||||
* Update govultr to v3.3.4 [PR 421](https://github.com/vultr/terraform-provider-vultr/pull/421)
|
||||
* Bump google.golang.org/grpc from 1.57.0 to 1.57.1 [PR 419](https://github.com/vultr/terraform-provider-vultr/pull/419)
|
||||
|
||||
## [v2.17.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.16.4...v2.17.0) (2023-10-25)
|
||||
### Enhancement
|
||||
* Database: Add support for public/private hostnames [PR 416](https://github.com/vultr/terraform-provider-vultr/pull/416)
|
||||
|
||||
### Documentation
|
||||
* Update some invalid plans in documentation [PR 414](https://github.com/vultr/terraform-provider-vultr/pull/414)
|
||||
|
||||
### Dependencies
|
||||
* Update govultr to v3.3.2 [PR 415](https://github.com/vultr/terraform-provider-vultr/pull/415)
|
||||
* Update govultr to v3.3.3 [PR 417](https://github.com/vultr/terraform-provider-vultr/pull/417)
|
||||
|
||||
## [v2.16.4](https://github.com/vultr/terraform-provider-vultr/compare/v2.16.3...v2.16.4) (2023-10-16)
|
||||
### Documentation
|
||||
* kubernetes: fix typo in VKE plan example [PR 412](https://github.com/vultr/terraform-provider-vultr/pull/412)
|
||||
|
||||
## [v2.16.3](https://github.com/vultr/terraform-provider-vultr/compare/v2.16.2...v2.16.3) (2023-10-13)
|
||||
### Documentation
|
||||
* Update a few of the resource documentation pages [PR 409](https://github.com/vultr/terraform-provider-vultr/pull/409)
|
||||
|
||||
### Dependencies
|
||||
* Bump golang.org/x/oauth2 from 0.12.0 to 0.13.0 [PR 407](https://github.com/vultr/terraform-provider-vultr/pull/407)
|
||||
* Bump golang.org/x/net from 0.15.0 to 0.17.0 [PR 408](https://github.com/vultr/terraform-provider-vultr/pull/408)
|
||||
|
||||
### Automation
|
||||
* Extend the nightly acceptance test timeout by one hour [PR 405](https://github.com/vultr/terraform-provider-vultr/pull/405)
|
||||
|
||||
## [v2.16.2](https://github.com/vultr/terraform-provider-vultr/compare/v2.16.1...v2.16.2) (2023-09-25)
|
||||
# Enhancement
|
||||
* data_source/instance: Add a per-page param for instance data source [PR 384](https://github.com/vultr/terraform-provider-vultr/pull/384)
|
||||
|
||||
# Bug Fix
|
||||
* resource/database: Add missing vpc_id property to managed database read replicas [PR 403](https://github.com/vultr/terraform-provider-vultr/pull/403)
|
||||
* data_source/database: Add missing vpc_id property to managed database read replicas [PR 403](https://github.com/vultr/terraform-provider-vultr/pull/403)
|
||||
|
||||
## [v2.16.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.16.0...v2.16.1) (2023-09-22)
|
||||
### Bug Fix
|
||||
* resource/vpc2: Fix delete retries and detach errors with VPC2s [PR 399](https://github.com/vultr/terraform-provider-vultr/pull/399)
|
||||
* resource/bare_metal_server: Revert BM update delay for detach VPC2 [PR 400](https://github.com/vultr/terraform-provider-vultr/pull/400)
|
||||
|
||||
### Dependencies
|
||||
* Bump github.com/vultr/govultr/v3 from 3.2.0 to 3.3.1 [PR 391](https://github.com/vultr/terraform-provider-vultr/pull/391)
|
||||
* Bump golang.org/x/oauth2 from 0.10.0 to 0.12.0 [PR 393](https://github.com/vultr/terraform-provider-vultr/pull/393)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.27.0 to 2.29.0 [PR 394](https://github.com/vultr/terraform-provider-vultr/pull/394)
|
||||
|
||||
## [v2.16.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.15.1...v2.16.0) (2023-09-21)
|
||||
### Enhancements
|
||||
* resource/instance: Add/update retry on create/delete actions [PR 362](https://github.com/vultr/terraform-provider-vultr/pull/362)
|
||||
* resource/vpc: Add/update retry on create/delete actions [PR 362](https://github.com/vultr/terraform-provider-vultr/pull/362)
|
||||
* resource/database: Add support for DBaaS VPC networks [PR 385](https://github.com/vultr/terraform-provider-vultr/pull/385)
|
||||
* resource/vpc2: Add VPC 2.0 [PR 389](https://github.com/vultr/terraform-provider-vultr/pull/389)
|
||||
* data_source/vpc2: Add VPC 2.0 [PR 389](https://github.com/vultr/terraform-provider-vultr/pull/389)
|
||||
* resource/bare_metal_server: Wait for VPC 2.0 detachments on BM [PR 396](https://github.com/vultr/terraform-provider-vultr/pull/396)
|
||||
|
||||
### Documentation
|
||||
* load balancer: Set non-required fields with default values [PR 365](https://github.com/vultr/terraform-provider-vultr/pull/365)
|
||||
* kubernetes: Update resource docs [PR 369](https://github.com/vultr/terraform-provider-vultr/pull/369)
|
||||
|
||||
### Dependencies
|
||||
* Update govultr to v3.1.0 [PR 380](https://github.com/vultr/terraform-provider-vultr/pull/380)
|
||||
* Bump github.com/hashicorp/terraform-plugin-log from 0.8.0 to 0.9.0 [PR 364](https://github.com/vultr/terraform-provider-vultr/pull/364)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.0.2 to 3.0.3 [PR 366](https://github.com/vultr/terraform-provider-vultr/pull/366)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.1.0 to 3.2.0 [PR 382](https://github.com/vultr/terraform-provider-vultr/pull/382)
|
||||
* Bump golang.org/x/oauth2 from 0.8.0 to 0.10.0 [PR 376](https://github.com/vultr/terraform-provider-vultr/pull/376)
|
||||
* Bump github.com/hashicorp/terraform-plugin-sdk/v2 from 2.26.1 to 2.27.0 [PR 370](https://github.com/vultr/terraform-provider-vultr/pull/370)
|
||||
|
||||
### Automation
|
||||
* Update goreleaser-action to v4 and fix `release` args [PR 361](https://github.com/vultr/terraform-provider-vultr/pull/361)
|
||||
|
||||
### New Contributors
|
||||
* @tavsec made their first contribution in [PR 365](https://github.com/vultr/terraform-provider-vultr/pull/365)
|
||||
* @ogawa0071 made their first contribution in [PR 389](https://github.com/vultr/terraform-provider-vultr/pull/389)
|
||||
|
||||
## [v2.15.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.15.0...v2.15.1) (2023-05-10)
|
||||
### Enhancement
|
||||
* Add documentation for Vultr managed database data sources and resources [PR 356](https://github.com/vultr/terraform-provider-vultr/pull/356)
|
||||
* Add VPC delete retries [PR 358](https://github.com/vultr/terraform-provider-vultr/pull/358)
|
||||
|
||||
### Dependencies
|
||||
* Bump golang.org/x/oauth2 from 0.7.0 to 0.8.0 [PR 357](https://github.com/vultr/terraform-provider-vultr/pull/357)
|
||||
|
||||
## [v2.15.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.14.1...v2.15.0) (2023-05-04)
|
||||
### Enhancement
|
||||
* resource/database: Add Support for Vultr Managed Databases [PR 352](https://github.com/vultr/terraform-provider-vultr/pull/352)
|
||||
* data source/database: Add Support for Vultr Managed Databases [PR 352](https://github.com/vultr/terraform-provider-vultr/pull/352)
|
||||
|
||||
### Automation
|
||||
* Update acceptance test configurations [PR 353](https://github.com/vultr/terraform-provider-vultr/pull/353)
|
||||
|
||||
### New Contributors
|
||||
* @christhemorse made their first contribution in [PR 352](https://github.com/vultr/terraform-provider-vultr/pull/352)
|
||||
|
||||
## [v2.14.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.14.0...v2.14.1) (2023-04-28)
|
||||
### Enhancement
|
||||
* resource/kuberneters: added vke certs as exported atrributes [PR 349](https://github.com/vultr/terraform-provider-vultr/pull/349)
|
||||
* data source/kuberneters: added vke certs as exported atrributes [PR 349](https://github.com/vultr/terraform-provider-vultr/pull/349)
|
||||
|
||||
### New Contributors
|
||||
* @happytreees made their first contribution in [PR 349](https://github.com/vultr/terraform-provider-vultr/pull/349)
|
||||
|
||||
## [v2.14.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.13.0...v2.14.0) (2023-04-13)
|
||||
### Enhancement
|
||||
* resource/kubernetes: Add VKE k8s version upgrade functionality [PR 344](https://github.com/vultr/terraform-provider-vultr/pull/344)
|
||||
* resource/kubernetes: Mark the kube_config schema value as sensitive [PR 346](https://github.com/vultr/terraform-provider-vultr/pull/346)
|
||||
|
||||
### Dependencies
|
||||
* Bump golang.org/x/oauth2 from 0.6.0 to 0.7.0 [PR 343](https://github.com/vultr/terraform-provider-vultr/pull/343)
|
||||
|
||||
## [v2.13.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.12.1...v2.13.0) (2023-04-03)
|
||||
### Enhancement
|
||||
* resource/reserved ip: Add missing resource warning for reserved IP [PR 327](https://github.com/vultr/terraform-provider-vultr/pull/327)
|
||||
* resource/dns domain: Add missing resource warnings [PR 323](https://github.com/vultr/terraform-provider-vultr/pull/323)
|
||||
* resource/block storage: Add missing resource warnings [PR 323](https://github.com/vultr/terraform-provider-vultr/pull/323)
|
||||
* resource/user: Add missing resource warnings [PR 323](https://github.com/vultr/terraform-provider-vultr/pull/323)
|
||||
* resource/startup script: Add missing resource warnings [PR 323](https://github.com/vultr/terraform-provider-vultr/pull/323)
|
||||
* resource/ssh key: Add missing resource warnings [PR 323](https://github.com/vultr/terraform-provider-vultr/pull/323)
|
||||
* resource/firewall rule: Add missing resource warnings [PR 323](https://github.com/vultr/terraform-provider-vultr/pull/323)
|
||||
|
||||
### Dependencies
|
||||
* Bump golang.org/x/text from 0.3.7 to 0.3.8 [PR 324](https://github.com/vultr/terraform-provider-vultr/pull/324)
|
||||
* Update govultr to v3.0.1 [PR 336](https://github.com/vultr/terraform-provider-vultr/pull/336)
|
||||
* Bump github.com/vultr/govultr/v3 from 3.0.1 to 3.0.2 [PR 339](https://github.com/vultr/terraform-provider-vultr/pull/339)
|
||||
|
||||
### Automation
|
||||
* Fix broken workflows resulting from go version 1.20 [PR 340](https://github.com/vultr/terraform-provider-vultr/pull/340)
|
||||
* bump setup-go in github workflow [PR 337](https://github.com/vultr/terraform-provider-vultr/pull/337)
|
||||
|
||||
### New Contributors
|
||||
* @mondragonfx made their first contribution in [PR 336](https://github.com/vultr/terraform-provider-vultr/pull/336)
|
||||
|
||||
## [v2.12.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.12.0...v2.12.1) (2023-02-10)
|
||||
### Enhancement
|
||||
* resource/instance: Add check for & detach of ISO on instance delete [312](https://github.com/vultr/terraform-provider-vultr/pull/312)
|
||||
* All resources that use "region":
|
||||
- Add DiffSuppressFunc to ignore case [318](https://github.com/vultr/terraform-provider-vultr/pull/318)
|
||||
|
||||
## [v2.12.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.11.4...v2.12.0) (2022-12-08)
|
||||
### Enhancement
|
||||
* resource/instance: remove deprecated tag fields [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
* resource/bare_metal_server: remove deprecated tag fields [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
* data source/instance: remove deprecated tag fields [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
* data source/bare_metal_server: remove deprecated tag fields [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
|
||||
### Bug Fix
|
||||
* everything: golangci-lint fixes [302](https://github.com/vultr/terraform-provider-vultr/pull/302)
|
||||
|
||||
### Documentation
|
||||
* Fixed typo [279](https://github.com/vultr/terraform-provider-vultr/pull/279)
|
||||
* Update rate-limit documentation [283](https://github.com/vultr/terraform-provider-vultr/pull/283)
|
||||
* resource/instance_ipv4 fix type error on reboot [292](https://github.com/vultr/terraform-provider-vultr/pull/292)
|
||||
* resource/bare_metal_server: update floating IP description [293](https://github.com/vultr/terraform-provider-vultr/pull/293)
|
||||
* resource/instance: remove the tag field from the docs [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
* resource/bare_metal_server: remove the tag field from the docs [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
* data source/instance: remove the tag field from the docs [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
* data source/bare_metal_server: remove the tag field from the docs [297](https://github.com/vultr/terraform-provider-vultr/pull/297)
|
||||
|
||||
### Dependency
|
||||
* update terraform-sdk from 2.19.0 to 2.21.0 [280](https://github.com/vultr/terraform-provider-vultr/pull/280)
|
||||
* update terraform-sdk from 2.21.0 to 2.24.0 [294](https://github.com/vultr/terraform-provider-vultr/pull/294)
|
||||
* update terraform-sdk from 2.24.0 to 2.24.1 [298](https://github.com/vultr/terraform-provider-vultr/pull/298)
|
||||
* update go to v1.19 [303](https://github.com/vultr/terraform-provider-vultr/pull/303)
|
||||
* update goreleaser to v1.19 [305](https://github.com/vultr/terraform-provider-vultr/pull/305)
|
||||
|
||||
### New Contributors
|
||||
* @nschlemm made their first contribution in [279](https://github.com/vultr/terraform-provider-vultr/pull/279)
|
||||
* @jesseorr made their first contribution in [292](https://github.com/vultr/terraform-provider-vultr/pull/292)
|
||||
* @jasites made their first contribution in [293](https://github.com/vultr/terraform-provider-vultr/pull/293)
|
||||
|
||||
## [v2.11.4](https://github.com/vultr/terraform-provider-vultr/compare/v2.11.3...v2.11.4) (2022-07-25)
|
||||
### Enhancement
|
||||
* data source/object storage cluster: add datasource for object storage cluster [275](https://github.com/vultr/terraform-provider-vultr/pull/275)
|
||||
|
||||
### Documentatio
|
||||
* data source/object storage cluster: add docs for object storage cluster [275](https://github.com/vultr/terraform-provider-vultr/pull/275)
|
||||
|
||||
### Dependency
|
||||
* update terraform-sdk to v2.18.0 [273](https://github.com/vultr/terraform-provider-vultr/pull/273)
|
||||
* update terraform-plugin-sdk from 2.18.0 to 2.19.0 [274](https://github.com/vultr/terraform-provider-vultr/pull/274)
|
||||
|
||||
## [v2.11.3](https://github.com/vultr/terraform-provider-vultr/compare/v2.11.2...v2.11.3) (2022-06-14)
|
||||
### Enchancement
|
||||
* resource/reserved_ip: Add support for reserved IP label updates [268](https://github.com/vultr/terraform-provider-vultr/pull/268)
|
||||
|
||||
### Documentation
|
||||
* resource/instance: Fix typo [268](https://github.com/vultr/terraform-provider-vultr/pull/268)
|
||||
* resource/reverse_ip: Fix type [268](https://github.com/vultr/terraform-provider-vultr/pull/268)
|
||||
|
||||
## [v2.11.2](https://github.com/vultr/terraform-provider-vultr/compare/v2.11.1...v2.11.2) (2022-06-03)
|
||||
### Enhancement
|
||||
* data source/plan: Add GPU fields [264](https://github.com/vultr/terraform-provider-vultr/pull/264)
|
||||
|
||||
### Bug Fix
|
||||
* Fix acceptance tests [260](https://github.com/vultr/terraform-provider-vultr/pull/260)
|
||||
|
||||
### Dependency
|
||||
* update govultr to v2.17.1 [262](https://github.com/vultr/terraform-provider-vultr/pull/262)
|
||||
* update github.com/hashicorp/terraform-plugin-sdk/v2 from 2.16.0 to 2.17.0 [261](https://github.com/vultr/terraform-provider-vultr/pull/261)
|
||||
|
||||
## [v2.11.1](https://github.com/vultr/terraform-provider-vultr/compare/v2.11.0...v2.11.1) (2022-05-18)
|
||||
### Documentation
|
||||
* resource/instance: fix incorrect import example [251](https://github.com/vultr/terraform-provider-vultr/pull/251)
|
||||
* resource/instance_ipv4: fix vultr_instance_ipv4 resource doc and argument reference [253](https://github.com/vultr/terraform-provider-vultr/pull/253)
|
||||
|
||||
### Dependency
|
||||
* updated govultr from v1.16.0 to v1.17.0 [255](https://github.com/vultr/terraform-provider-vultr/pull/255)
|
||||
|
||||
### Bug Fix
|
||||
* resource/kubernetes_nodepool: fix `tag` so that it can be deleted [255](https://github.com/vultr/terraform-provider-vultr/pull/255)
|
||||
* resource/instance: fix `tag` so that it can be deleted [255](https://github.com/vultr/terraform-provider-vultr/pull/255)
|
||||
* resource/bare_metal_server: fix `tag` so that it can be deleted [255](https://github.com/vultr/terraform-provider-vultr/pull/255)
|
||||
|
||||
### New Contributors
|
||||
* @NicolasCARPi made their first contribution in [251](https://github.com/vultr/terraform-provider-vultr/pull/251)
|
||||
|
||||
## [v2.11.0](https://github.com/vultr/terraform-provider-vultr/compare/v2.10.1..v2.11.0) (2022-05-11)
|
||||
### Documentation
|
||||
* resource/instance: add additional examples for backups [246](https://github.com/vultr/terraform-provider-vultr/pull/246)
|
||||
* resource/kubernetes: update examples for default optional node pool [249](https://github.com/vultr/terraform-provider-vultr/pull/249)
|
||||
* readme: add link to quickstart guide [244](https://github.com/vultr/terraform-provider-vultr/pull/244)
|
||||
|
||||
### Dependency
|
||||
* updated terraform-plugin-sdk from 2.15.0 to 2.16.0 [245](https://github.com/vultr/terraform-provider-vultr/pull/245)
|
||||
* updated terraform-plugin-sdk from 2.12.0 to 2.15.0 [242](https://github.com/vultr/terraform-provider-vultr/pull/242)
|
||||
* updated Go v1.16 -> v1.17 [221](https://github.com/vultr/terraform-provider-vultr/pull/221)
|
||||
* updated govultr from 2.14.2 to 2.15.1 [233](https://github.com/vultr/terraform-provider-vultr/pull/233)
|
||||
* updated govultr from 2.15.1 to 2.16.0 [241](https://github.com/vultr/terraform-provider-vultr/pull/241)
|
||||
|
||||
### Enhancement
|
||||
* resource/kubernetes: allow removal of default node pool after resource creation [248](https://github.com/vultr/terraform-provider-vultr/pull/248)
|
||||
* resource/kubernetes: add support for auto scaler options on node pools [247](https://github.com/vultr/terraform-provider-vultr/pull/247)
|
||||
* resource/kubernetes node pools: add support for auto scaler options on node pools [247](https://github.com/vultr/terraform-provider-vultr/pull/247)
|
||||
* data source/kubernetes: add auto scaler fields[247](https://github.com/vultr/terraform-provider-vultr/pull/247)
|
||||
* data source/kubernetes node pools: add auto scaler fields [247](https://github.com/vultr/terraform-provider-vultr/pull/247)
|
||||
* resource/block storage: add block type [238](https://github.com/vultr/terraform-provider-vultr/pull/238)
|
||||
* data source/block storage: add block type field [238](https://github.com/vultr/terraform-provider-vultr/pull/238)
|
||||
* resource/instance: add VPC support [237](https://github.com/vultr/terraform-provider-vultr/pull/237)
|
||||
* resource/load balancer: add VPC support [237](https://github.com/vultr/terraform-provider-vultr/pull/237)
|
||||
* data source/instance: add VPC fields[237](https://github.com/vultr/terraform-provider-vultr/pull/237)
|
||||
* data source/load balancer: add VPC support [237](https://github.com/vultr/terraform-provider-vultr/pull/237)
|
||||
* resource/kubernetes: add better error handling to reads [236](https://github.com/vultr/terraform-provider-vultr/pull/236)
|
||||
* resource/kubernetes node pools: add better error handling to reads [236](https://github.com/vultr/terraform-provider-vultr/pull/236)
|
||||
* resource/instance: add support for tags [240](https://github.com/vultr/terraform-provider-vultr/pull/240)
|
||||
* resource/bare metal: add support for tags [240](https://github.com/vultr/terraform-provider-vultr/pull/240)
|
||||
* data source/instance: add support for tags [240](https://github.com/vultr/terraform-provider-vultr/pull/240)
|
||||
* data source/bare metal: add support for tags [240](https://github.com/vultr/terraform-provider-vultr/pull/240)
|
||||
|
||||
### Bug Fix
|
||||
* resource/kubernetes: fix labeling on cluster updates [239](https://github.com/vultr/terraform-provider-vultr/pull/239)
|
||||
* resource/firewall rule: read from correct govultr data [243](https://github.com/vultr/terraform-provider-vultr/pull/243)
|
||||
|
||||
### New Contributors
|
||||
* @optik-aper made their first contribution in [238](https://github.com/vultr/terraform-provider-vultr/pull/238)
|
||||
* @dfinr made their first contribution in [244](https://github.com/vultr/terraform-provider-vultr/pull/244)
|
||||
* @travispaul made their first contribution in [246](https://github.com/vultr/terraform-provider-vultr/pull/246)
|
||||
|
||||
## 2.10.1 (March 30, 2022)
|
||||
Enhancement:
|
||||
* vultr_resource_instance : Updating hostname will result in a forcenew change [226](https://github.com/vultr/terraform-provider-vultr/pull/226)
|
||||
|
||||
## 2.10.0 (March 25, 2022)
|
||||
### Dependency
|
||||
* updated Go v1.16 -> v1.17 [221](https://github.com/vultr/terraform-provider-vultr/pull/221)
|
||||
* updated terraform-plugin-sdk from 2.10.1 to 2.12.0 [218](https://github.com/vultr/terraform-provider-vultr/pull/218)
|
||||
* updated govultr from 2.14.1 to 2.14.2 [219](https://github.com/vultr/terraform-provider-vultr/pull/219)
|
||||
|
||||
### Enhancement
|
||||
* vultr_resource_block : add waits for active status [222](https://github.com/vultr/terraform-provider-vultr/pull/222)
|
||||
|
||||
## 2.9.1 (February 2, 2022)
|
||||
### Dependency
|
||||
* updated govultr to v2.14.0 -> v2.14.1 [210](https://github.com/vultr/terraform-provider-vultr/pull/210)
|
||||
|
||||
## 2.9.0 (January 21, 2022)
|
||||
### Enhancement
|
||||
* datasource/kubernetes: New datasource for VKE [198](https://github.com/vultr/terraform-provider-vultr/pull/198)
|
||||
* Updated all datasources deprecations read -> readContext [204](https://github.com/vultr/terraform-provider-vultr/pull/204)
|
||||
|
||||
### Bug Fix
|
||||
* datasource/backups : fix scheme mismatch [201](https://github.com/vultr/terraform-provider-vultr/pull/201)
|
||||
|
||||
### Dependency
|
||||
* updated govultr to v2.12.0 -> v2.14.0 [206](https://github.com/vultr/terraform-provider-vultr/pull/206)
|
||||
|
||||
## 2.8.1 (December 20, 2021)
|
||||
### Bug Fix
|
||||
* resource/instance: fix importer [192](https://github.com/vultr/terraform-provider-vultr/pull/192) Thanks @vincentbernat
|
||||
|
||||
## 2.8.0 (December 08, 2021)
|
||||
### Enhancement
|
||||
* Implement datasource filtering on string lists [188](https://github.com/vultr/terraform-provider-vultr/pull/188) Thanks @kaorihinata
|
||||
|
||||
## 2.7.0 (December 6, 2021)
|
||||
### Dependencies
|
||||
* Bump govultr to v2.12.0, adjust monthly charges to float [182](https://github.com/vultr/terraform-provider-vultr/pull/182)
|
||||
|
||||
## 2.6.0 (November 19, 2021)
|
||||
### Enhancement
|
||||
* resource/bare_metal: Add timeout options [175](https://github.com/vultr/terraform-provider-vultr/pull/175)
|
||||
|
||||
### Bug Fix
|
||||
* datasource/account : Fix type mismatch for billing fields [174](https://github.com/vultr/terraform-provider-vultr/pull/174)
|
||||
* resource/instance : Fix invalid error message change [178](https://github.com/vultr/terraform-provider-vultr/pull/178)
|
||||
* resource/instance : Fix issue where changing hostname didn't trigger hostname change [180](https://github.com/vultr/terraform-provider-vultr/pull/180)
|
||||
|
||||
### Documentatio
|
||||
* resource/snapshots : fix typo [167](https://github.com/vultr/terraform-provider-vultr/pull/167)
|
||||
* resources/vultr_kubernetes : Add description that kubeconfigs are base64 encoded [169](https://github.com/vultr/terraform-provider-vultr/pull/169)
|
||||
|
||||
### Dependency
|
||||
* updated govultr to v2.9.2 -> v2.10.0 [179](https://github.com/vultr/terraform-provider-vultr/pull/179)
|
||||
|
||||
## 2.5.0 (October 22, 2021)
|
||||
### Enhancement
|
||||
* resource/vultr_kubernetes: New resource that allows for deployment of VKE clusters [165](https://github.com/vultr/terraform-provider-vultr/pull/165)
|
||||
* resource/vultr_kubernetes_node_pools: New resource that allows for deployment of node pools to existing VKE Cluster[165](https://github.com/vultr/terraform-provider-vultr/pull/165)
|
||||
|
||||
|
||||
## 2.4.2 (September 15, 2021)
|
||||
### Bug Fix
|
||||
* resource/load_balancer: added missing `region` and `ssl_redirect` values from being set [163](https://github.com/vultr/terraform-provider-vultr/pull/163)
|
||||
|
||||
## 2.4.1 (August 13, 2021)
|
||||
### Enhancement
|
||||
* resource/instance: increased default timeout for create/update from 20 to 60 minutes [160](https://github.com/vultr/terraform-provider-vultr/pull/160)
|
||||
|
||||
## 2.4.0 (August 02, 2021)
|
||||
### Enhancement
|
||||
* resource/instance: add marketplace support with `image_id` [150](https://github.com/vultr/terraform-provider-vultr/pull/150)
|
||||
* resource/bare_metal: add marketplace support with `image_id` [150](https://github.com/vultr/terraform-provider-vultr/pull/150)
|
||||
* datasource/applications: adds marketplace support [150](https://github.com/vultr/terraform-provider-vultr/pull/150)
|
||||
* Add openBSD to builds [155](https://github.com/vultr/terraform-provider-vultr/pull/155)
|
||||
|
||||
### Bug Fix
|
||||
* resource/bare_metal: fix importer [157](https://github.com/vultr/terraform-provider-vultr/pull/157)
|
||||
* Doc updates [152](https://github.com/vultr/terraform-provider-vultr/pull/152) [146](https://github.com/vultr/terraform-provider-vultr/pull/146) [147](https://github.com/vultr/terraform-provider-vultr/pull/147)
|
||||
|
||||
### Dependency
|
||||
* updated terraform-plugin-sdk to v2.6.0 -> v2.7.0 [149](https://github.com/vultr/terraform-provider-vultr/pull/149)
|
||||
* updated govultr to v2.5.1 -> v2.7.1 [150](https://github.com/vultr/terraform-provider-vultr/pull/150)
|
||||
|
||||
|
||||
## 2.3.3 (June 25, 2021)
|
||||
### Enhancement
|
||||
* resource/instance: adding wait if a plan is being upgrade [144](https://github.com/vultr/terraform-provider-vultr/pull/144)
|
||||
|
||||
## 2.3.2 (June 10, 2021)
|
||||
### Enhancement
|
||||
* resource/instance: allow plan changes to do in-place upgrades [142](https://github.com/vultr/terraform-provider-vultr/pull/142)
|
||||
|
||||
## 2.3.1 (June 2, 2021)
|
||||
### Bug Fix
|
||||
* resource/bare_metal: fix type issue on `v6_network_size` [140](https://github.com/vultr/terraform-provider-vultr/pull/140)
|
||||
* resource/bare_metal: fix missing `mac_address` definition in scheme [140](https://github.com/vultr/terraform-provider-vultr/pull/140)
|
||||
|
||||
## 2.3.0 (May 11, 2021)
|
||||
### Enchancements
|
||||
* resource/vultr_instances: allow the configuration of `backups_schedule` [134](https://github.com/vultr/terraform-provider-vultr/pull/134) [136](https://github.com/vultr/terraform-provider-vultr/pull/136)
|
||||
* resource/vultr_load_balancers: add support for new LB features `private_network` and `firewall_rules` [137](https://github.com/vultr/terraform-provider-vultr/pull/137)
|
||||
* resource/vultr_iso: support detaching during deletion [131](https://github.com/vultr/terraform-provider-vultr/pull/131) Thanks @johnrichardrinehart
|
||||
* resource/vultr_instances: `private_network_ids` are now tracked in statefile [135](https://github.com/vultr/terraform-provider-vultr/pull/135)
|
||||
* resource/vultr_block_storage: new field added `mount_id` [135](https://github.com/vultr/terraform-provider-vultr/pull/135)
|
||||
* resource/vultr_plans: new field added `disk_count` [135](https://github.com/vultr/terraform-provider-vultr/pull/135)
|
||||
|
||||
### Dependency
|
||||
* updated terraform-plugin-sdk to v2.4.0 -> v2.6.0 [134](https://github.com/vultr/terraform-provider-vultr/pull/134)
|
||||
* updated govultr to v2.3.1 -> v2.5.1 [135](https://github.com/vultr/terraform-provider-vultr/pull/135)
|
||||
|
||||
## 2.2.0 (March 30, 2021)
|
||||
### Feature
|
||||
* Updated to Go 1.16 to support `darwin_arm64` [125](https://github.com/vultr/terraform-provider-vultr/pull/125)
|
||||
|
||||
## 2.1.4 (March 23, 2021)
|
||||
### Bug Fix
|
||||
* Fix issue with vultr_instance.reserved_ip_id and vultr_reserved_ip.attached_id conflicting [122](https://github.com/vultr/terraform-provider-vultr/pull/122)
|
||||
|
||||
## 2.1.3 (January 29, 2021)
|
||||
### Dependency
|
||||
* updated terraform-plugin-sdk to v1.8.0 -> v2.4.0 [111](https://github.com/vultr/terraform-provider-vultr/pull/111)
|
||||
|
||||
## 2.1.2 (January 05, 2021)
|
||||
### Dependency
|
||||
* updated GoVultr to v2.3.1 (fixes #102 #105) [106](https://github.com/vultr/terraform-provider-vultr/pull/106)
|
||||
|
||||
### Enhancements
|
||||
* datasource/vultr_instance_ip4 & reverse_ipv4 improved filter and cleaned up docs [107](https://github.com/vultr/terraform-provider-vultr/pull/107)
|
||||
|
||||
## 2.1.1 (December 09, 2020)
|
||||
### Enhancements
|
||||
* resource/vultr_instances: Private-networks will be detached prior to deletion [93](https://github.com/vultr/terraform-provider-vultr/pull/93)
|
||||
* resource/vultr_instances: Removal of `forcenew` on `activiation_email` [84](https://github.com/vultr/terraform-provider-vultr/pull/84)
|
||||
|
||||
## 2.1.0 (December 03, 2020)
|
||||
### BUG FIXES
|
||||
* resource/vultr_instances: In v2 the ID of the Reserved IP, not the IP itself, is required for creation. [79](https://github.com/vultr/terraform-provider-vultr/pull/79)
|
||||
|
||||
### Breaking Change
|
||||
* resource/vultr_instances: Changing `reservered_ip` to `reservered_ip_id` to make it clear that the ID should be passed [79](https://github.com/vultr/terraform-provider-vultr/pull/79)
|
||||
|
||||
## 2.0.0 (December 01, 2020)
|
||||
|
||||
### Breaking Changes
|
||||
* The TF Vultr provider v2.0.0 is a large change that uses the new Vultr API v2. This change resolves quite a few limitations and improves overall performance of tooling. These changes include field and resource/datasource name updates to match the API and offer a consistent experience.
|
||||
|
||||
### Dependency
|
||||
* updated GoVultr to v2.1.0
|
||||
|
||||
## 1.5.0 (November 09, 2020)
|
||||
### Breaking Change
|
||||
* resource/vultr_server: Changing `user_data` will now trigger a `force_new` [70](https://github.com/vultr/terraform-provider-vultr/pull/70)
|
||||
|
||||
### Dependency
|
||||
* updated GoVultr to v1.1.1 [70](https://github.com/vultr/terraform-provider-vultr/pull/70)
|
||||
|
||||
## 1.4.1 (September 15, 2020)
|
||||
### BUG FIXES
|
||||
* resource/vultr_server: Fix bug that did not allow user-data to be passed in as a string [65](https://github.com/vultr/terraform-provider-vultr/pull/65)
|
||||
|
||||
## 1.4.0 (August 28, 2020)
|
||||
### FEATURES
|
||||
* New Resource : vultr_server_ipv4 [61](https://github.com/vultr/terraform-provider-vultr/pull/61)
|
||||
* New Resource : vultr_reverse_ipv4 [61](https://github.com/vultr/terraform-provider-vultr/pull/61)
|
||||
* New Resource : vultr_reverse_ipv6 [20](https://github.com/vultr/terraform-provider-vultr/pull/20)
|
||||
* New Data Source : vultr_server_ipv4 [61](https://github.com/vultr/terraform-provider-vultr/pull/61)
|
||||
* New Data Source : vultr_reverse_ipv4 [61](https://github.com/vultr/terraform-provider-vultr/pull/61)
|
||||
* New Data Source : vultr_reverse_ipv6 [20](https://github.com/vultr/terraform-provider-vultr/pull/20)
|
||||
|
||||
### IMPROVEMENTS
|
||||
* resource/vultr_server: Ability to enable/disable DDOS post create [59](https://github.com/vultr/terraform-provider-vultr/pull/59)
|
||||
* resource/vultr_server: Ability to detach ISO post create [60](https://github.com/vultr/terraform-provider-vultr/pull/60)
|
||||
|
||||
## 1.3.2 (June 17, 2020)
|
||||
### IMPROVEMENTS
|
||||
* resource/vultr_dns_record: New custom importer allows you to import DNS Records [51](https://github.com/vultr/terraform-provider-vultr/pull/51)
|
||||
* resource/vultr_firewall_rule: New custom importer allows you to import Firewall Rules [52](https://github.com/vultr/terraform-provider-vultr/pull/52)
|
||||
|
||||
## 1.3.1 (June 11, 2020)
|
||||
### IMPROVEMENTS
|
||||
* resource/vultr_dns_domain: Making `server_ip` optional. If `server_ip` is not supplied terraform will now create the DNS resource with no records. [48](https://github.com/vultr/terraform-provider-vultr/pull/48)
|
||||
|
||||
## 1.3.0 (June 03, 2020)
|
||||
### BUG FIXES
|
||||
* resource/vultr_dns_record: Able to create record with `priority` of `0` [45](https://github.com/vultr/terraform-provider-vultr/pull/45)
|
||||
|
||||
### FEATURES
|
||||
* New Resource : vultr_object_storage [41](https://github.com/vultr/terraform-provider-vultr/pull/41)
|
||||
* New Data Source : vultr_object_storage [41](https://github.com/vultr/terraform-provider-vultr/pull/41)
|
||||
|
||||
## 1.2.0 (May 27, 2020)
|
||||
### BUG FIXES
|
||||
* Typo in `website/docs/index.html.markdown` [38](https://github.com/vultr/terraform-provider-vultr/pull/38)
|
||||
|
||||
### FEATURES
|
||||
* New Resource : vultr_load_balancer [37](https://github.com/vultr/terraform-provider-vultr/pull/37)
|
||||
* New Data Source : vultr_load_balancer [37](https://github.com/vultr/terraform-provider-vultr/pull/37)
|
||||
|
||||
## 1.1.5 (April 07, 2020)
|
||||
### BUG FIXES
|
||||
* resource/vultr_server: Detach ISO prior to deletion if instance was created with ISO. [34](https://github.com/vultr/terraform-provider-vultr/issues/34)
|
||||
|
||||
## 1.1.4 (March 30, 2020)
|
||||
### IMPROVEMENTS
|
||||
* resource/block_storage: Adding new optional param `live` to allow attaching/detaching of block storage to instances without restarts [31](https://github.com/vultr/terraform-provider-vultr/pull/31)
|
||||
|
||||
## 1.1.3 (March 24, 2020)
|
||||
### BUG FIXES
|
||||
* resource/reserved_ip: Adding `computed: true` to `attached_id` to prevent issues when Vultr assigns this [29](https://github.com/vultr/terraform-provider-vultr/pull/29)
|
||||
* resource/vultr_server: Adding `ForceNew: true` to `reserved_ip` to prevent any issues where the main floating ip may get deleted and cause issues with the instance [29](https://github.com/vultr/terraform-provider-vultr/pull/29/files)
|
||||
|
||||
## 1.1.2 (March 19, 2020)
|
||||
### IMPROVEMENTS
|
||||
* resource/vultr_server: New optional field `reserved_ip` which lets you assign a `reserved_ip` during server creation [#26](https://github.com/vultr/terraform-provider-vultr/pull/26).
|
||||
* resource/reserved_ip: During deletion any instances that are attached to the reserved_ip are detached [#27](https://github.com/vultr/terraform-provider-vultr/pull/27).
|
||||
* Migrated to Terraform Plugin SDK [#21](https://github.com/vultr/terraform-provider-vultr/issues/21)
|
||||
* docs/snapshot fixed typo in snapshot [#19](https://github.com/vultr/terraform-provider-vultr/pull/19)
|
||||
|
||||
## 1.1.1 (December 02, 2019)
|
||||
### IMPROVEMENTS
|
||||
* resource/vultr_block_storage: Attaches block storage on creation. Also reattaches block storage to instances if you taint the instance.[#9](https://github.com/vultr/terraform-provider-vultr/pull/9) Thanks @oogy!
|
||||
|
||||
## 1.1.0 (November 22, 2019)
|
||||
### IMPROVEMENTS
|
||||
* provider: Retry mechanism configuration `retry_limit` was added to allow adjusting how many retries should be attempted. [#7](https://github.com/vultr/terraform-provider-vultr/pull/7).
|
||||
|
||||
### BUG FIXES
|
||||
* Fixed go module name [#4](https://github.com/vultr/terraform-provider-vultr/pull/4)
|
||||
|
||||
## 1.0.5 (October 24, 2019)
|
||||
|
||||
* Initial release under the terraform-providers/ namespace
|
||||
|
||||
## [v1.0.4](https://github.com/vultr/terraform-provider-vultr/compare/v1.0.3..v1.0.4) (2019-08-09)
|
||||
### Fixes
|
||||
* Fixes issue where using a snapshot would cause drift [#96](https://github.com/vultr/terraform-provider-vultr/issues/96)
|
||||
### Enhancements
|
||||
* You will now not have to define the `os_id` for the following server options
|
||||
- `app_id`
|
||||
- `iso_id`
|
||||
- `snapshot_id`
|
||||
|
||||
## [v1.0.3](https://github.com/vultr/terraform-provider-vultr/compare/v1.0.2..v1.0.3) (2019-07-18)
|
||||
### Fixes
|
||||
* Fixes issue where you could not use `os_id` and `script_id` together [#92](https://github.com/vultr/terraform-provider-vultr/issues/92)
|
||||
### Breaking Changes
|
||||
* You will now need to provide the `os_id` on each corresponding option
|
||||
- `app_id` - uses os_id `186`
|
||||
- `iso_id` - uses os_id `159`
|
||||
- `snap_id` - uses os_id `164`
|
||||
- `script_id` - uses os_id `159` or any os specific id
|
||||
|
||||
## [v1.0.2](https://github.com/vultr/terraform-provider-vultr/compare/v1.0.1..v1.0.2) (2019-07-15)
|
||||
### Dependencies
|
||||
* Updated dependencies [PR #89](https://github.com/vultr/terraform-provider-vultr/pull/89)
|
||||
* Govultr `v0.1.3` -> `v0.1.4`
|
||||
|
||||
## [v1.0.1](https://github.com/vultr/terraform-provider-vultr/compare/v1.0.0..v1.0.1) (2019-07-08)
|
||||
### Fixes
|
||||
* Fixed bug where scriptID was not being
|
||||
properly handled in server creation [#82](https://github.com/vultr/terraform-provider-vultr/issues/82)
|
||||
### Enhancements
|
||||
* Added error handler on protocol case sensitivity [#83](https://github.com/vultr/terraform-provider-vultr/issues/83)
|
||||
### Docs
|
||||
* Typo in doc firewall_rule doc for protocol [#83](https://github.com/vultr/terraform-provider-vultr/issues/83)
|
||||
|
||||
## v1.0.0 (2019-06-24)
|
||||
### Features
|
||||
* Initial release
|
||||
* Supported Data Sources
|
||||
* Account
|
||||
* Api Key
|
||||
* Application
|
||||
* Backup
|
||||
* Bare Metal Plan
|
||||
* Bare Metal Server
|
||||
* Block Storage
|
||||
* DNS Domain
|
||||
* Firewall Group
|
||||
* Iso Private
|
||||
* Iso Public
|
||||
* Network
|
||||
* OS
|
||||
* Plan
|
||||
* Region
|
||||
* Reserved IP
|
||||
* Server
|
||||
* Snapshot
|
||||
* SSH Key
|
||||
* Startup Script
|
||||
* User
|
||||
* Supported Resources
|
||||
* Bare Metal Server
|
||||
* Block Storage
|
||||
* DNS Domain
|
||||
* DNS Record
|
||||
* Firewall Group
|
||||
* Firewall Rule
|
||||
* ISO
|
||||
* Network
|
||||
* Reserved IP
|
||||
* Server
|
||||
* Snapshot
|
||||
* SSH Key
|
||||
* Startup Scripts
|
||||
* User
|
373
playbooks/opentofu/.terraform/providers/registry.opentofu.org/vultr/vultr/2.23.1/linux_amd64/LICENSE
373
playbooks/opentofu/.terraform/providers/registry.opentofu.org/vultr/vultr/2.23.1/linux_amd64/LICENSE
@ -1,373 +0,0 @@
|
||||
Mozilla Public License Version 2.0
|
||||
==================================
|
||||
|
||||
1. Definitions
|
||||
--------------
|
||||
|
||||
1.1. "Contributor"
|
||||
means each individual or legal entity that creates, contributes to
|
||||
the creation of, or owns Covered Software.
|
||||
|
||||
1.2. "Contributor Version"
|
||||
means the combination of the Contributions of others (if any) used
|
||||
by a Contributor and that particular Contributor's Contribution.
|
||||
|
||||
1.3. "Contribution"
|
||||
means Covered Software of a particular Contributor.
|
||||
|
||||
1.4. "Covered Software"
|
||||
means Source Code Form to which the initial Contributor has attached
|
||||
the notice in Exhibit A, the Executable Form of such Source Code
|
||||
Form, and Modifications of such Source Code Form, in each case
|
||||
including portions thereof.
|
||||
|
||||
1.5. "Incompatible With Secondary Licenses"
|
||||
means
|
||||
|
||||
(a) that the initial Contributor has attached the notice described
|
||||
in Exhibit B to the Covered Software; or
|
||||
|
||||
(b) that the Covered Software was made available under the terms of
|
||||
version 1.1 or earlier of the License, but not also under the
|
||||
terms of a Secondary License.
|
||||
|
||||
1.6. "Executable Form"
|
||||
means any form of the work other than Source Code Form.
|
||||
|
||||
1.7. "Larger Work"
|
||||
means a work that combines Covered Software with other material, in
|
||||
a separate file or files, that is not Covered Software.
|
||||
|
||||
1.8. "License"
|
||||
means this document.
|
||||
|
||||
1.9. "Licensable"
|
||||
means having the right to grant, to the maximum extent possible,
|
||||
whether at the time of the initial grant or subsequently, any and
|
||||
all of the rights conveyed by this License.
|
||||
|
||||
1.10. "Modifications"
|
||||
means any of the following:
|
||||
|
||||
(a) any file in Source Code Form that results from an addition to,
|
||||
deletion from, or modification of the contents of Covered
|
||||
Software; or
|
||||
|
||||
(b) any new file in Source Code Form that contains any Covered
|
||||
Software.
|
||||
|
||||
1.11. "Patent Claims" of a Contributor
|
||||
means any patent claim(s), including without limitation, method,
|
||||
process, and apparatus claims, in any patent Licensable by such
|
||||
Contributor that would be infringed, but for the grant of the
|
||||
License, by the making, using, selling, offering for sale, having
|
||||
made, import, or transfer of either its Contributions or its
|
||||
Contributor Version.
|
||||
|
||||
1.12. "Secondary License"
|
||||
means either the GNU General Public License, Version 2.0, the GNU
|
||||
Lesser General Public License, Version 2.1, the GNU Affero General
|
||||
Public License, Version 3.0, or any later versions of those
|
||||
licenses.
|
||||
|
||||
1.13. "Source Code Form"
|
||||
means the form of the work preferred for making modifications.
|
||||
|
||||
1.14. "You" (or "Your")
|
||||
means an individual or a legal entity exercising rights under this
|
||||
License. For legal entities, "You" includes any entity that
|
||||
controls, is controlled by, or is under common control with You. For
|
||||
purposes of this definition, "control" means (a) the power, direct
|
||||
or indirect, to cause the direction or management of such entity,
|
||||
whether by contract or otherwise, or (b) ownership of more than
|
||||
fifty percent (50%) of the outstanding shares or beneficial
|
||||
ownership of such entity.
|
||||
|
||||
2. License Grants and Conditions
|
||||
--------------------------------
|
||||
|
||||
2.1. Grants
|
||||
|
||||
Each Contributor hereby grants You a world-wide, royalty-free,
|
||||
non-exclusive license:
|
||||
|
||||
(a) under intellectual property rights (other than patent or trademark)
|
||||
Licensable by such Contributor to use, reproduce, make available,
|
||||
modify, display, perform, distribute, and otherwise exploit its
|
||||
Contributions, either on an unmodified basis, with Modifications, or
|
||||
as part of a Larger Work; and
|
||||
|
||||
(b) under Patent Claims of such Contributor to make, use, sell, offer
|
||||
for sale, have made, import, and otherwise transfer either its
|
||||
Contributions or its Contributor Version.
|
||||
|
||||
2.2. Effective Date
|
||||
|
||||
The licenses granted in Section 2.1 with respect to any Contribution
|
||||
become effective for each Contribution on the date the Contributor first
|
||||
distributes such Contribution.
|
||||
|
||||
2.3. Limitations on Grant Scope
|
||||
|
||||
The licenses granted in this Section 2 are the only rights granted under
|
||||
this License. No additional rights or licenses will be implied from the
|
||||
distribution or licensing of Covered Software under this License.
|
||||
Notwithstanding Section 2.1(b) above, no patent license is granted by a
|
||||
Contributor:
|
||||
|
||||
(a) for any code that a Contributor has removed from Covered Software;
|
||||
or
|
||||
|
||||
(b) for infringements caused by: (i) Your and any other third party's
|
||||
modifications of Covered Software, or (ii) the combination of its
|
||||
Contributions with other software (except as part of its Contributor
|
||||
Version); or
|
||||
|
||||
(c) under Patent Claims infringed by Covered Software in the absence of
|
||||
its Contributions.
|
||||
|
||||
This License does not grant any rights in the trademarks, service marks,
|
||||
or logos of any Contributor (except as may be necessary to comply with
|
||||
the notice requirements in Section 3.4).
|
||||
|
||||
2.4. Subsequent Licenses
|
||||
|
||||
No Contributor makes additional grants as a result of Your choice to
|
||||
distribute the Covered Software under a subsequent version of this
|
||||
License (see Section 10.2) or under the terms of a Secondary License (if
|
||||
permitted under the terms of Section 3.3).
|
||||
|
||||
2.5. Representation
|
||||
|
||||
Each Contributor represents that the Contributor believes its
|
||||
Contributions are its original creation(s) or it has sufficient rights
|
||||
to grant the rights to its Contributions conveyed by this License.
|
||||
|
||||
2.6. Fair Use
|
||||
|
||||
This License is not intended to limit any rights You have under
|
||||
applicable copyright doctrines of fair use, fair dealing, or other
|
||||
equivalents.
|
||||
|
||||
2.7. Conditions
|
||||
|
||||
Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted
|
||||
in Section 2.1.
|
||||
|
||||
3. Responsibilities
|
||||
-------------------
|
||||
|
||||
3.1. Distribution of Source Form
|
||||
|
||||
All distribution of Covered Software in Source Code Form, including any
|
||||
Modifications that You create or to which You contribute, must be under
|
||||
the terms of this License. You must inform recipients that the Source
|
||||
Code Form of the Covered Software is governed by the terms of this
|
||||
License, and how they can obtain a copy of this License. You may not
|
||||
attempt to alter or restrict the recipients' rights in the Source Code
|
||||
Form.
|
||||
|
||||
3.2. Distribution of Executable Form
|
||||
|
||||
If You distribute Covered Software in Executable Form then:
|
||||
|
||||
(a) such Covered Software must also be made available in Source Code
|
||||
Form, as described in Section 3.1, and You must inform recipients of
|
||||
the Executable Form how they can obtain a copy of such Source Code
|
||||
Form by reasonable means in a timely manner, at a charge no more
|
||||
than the cost of distribution to the recipient; and
|
||||
|
||||
(b) You may distribute such Executable Form under the terms of this
|
||||
License, or sublicense it under different terms, provided that the
|
||||
license for the Executable Form does not attempt to limit or alter
|
||||
the recipients' rights in the Source Code Form under this License.
|
||||
|
||||
3.3. Distribution of a Larger Work
|
||||
|
||||
You may create and distribute a Larger Work under terms of Your choice,
|
||||
provided that You also comply with the requirements of this License for
|
||||
the Covered Software. If the Larger Work is a combination of Covered
|
||||
Software with a work governed by one or more Secondary Licenses, and the
|
||||
Covered Software is not Incompatible With Secondary Licenses, this
|
||||
License permits You to additionally distribute such Covered Software
|
||||
under the terms of such Secondary License(s), so that the recipient of
|
||||
the Larger Work may, at their option, further distribute the Covered
|
||||
Software under the terms of either this License or such Secondary
|
||||
License(s).
|
||||
|
||||
3.4. Notices
|
||||
|
||||
You may not remove or alter the substance of any license notices
|
||||
(including copyright notices, patent notices, disclaimers of warranty,
|
||||
or limitations of liability) contained within the Source Code Form of
|
||||
the Covered Software, except that You may alter any license notices to
|
||||
the extent required to remedy known factual inaccuracies.
|
||||
|
||||
3.5. Application of Additional Terms
|
||||
|
||||
You may choose to offer, and to charge a fee for, warranty, support,
|
||||
indemnity or liability obligations to one or more recipients of Covered
|
||||
Software. However, You may do so only on Your own behalf, and not on
|
||||
behalf of any Contributor. You must make it absolutely clear that any
|
||||
such warranty, support, indemnity, or liability obligation is offered by
|
||||
You alone, and You hereby agree to indemnify every Contributor for any
|
||||
liability incurred by such Contributor as a result of warranty, support,
|
||||
indemnity or liability terms You offer. You may include additional
|
||||
disclaimers of warranty and limitations of liability specific to any
|
||||
jurisdiction.
|
||||
|
||||
4. Inability to Comply Due to Statute or Regulation
|
||||
---------------------------------------------------
|
||||
|
||||
If it is impossible for You to comply with any of the terms of this
|
||||
License with respect to some or all of the Covered Software due to
|
||||
statute, judicial order, or regulation then You must: (a) comply with
|
||||
the terms of this License to the maximum extent possible; and (b)
|
||||
describe the limitations and the code they affect. Such description must
|
||||
be placed in a text file included with all distributions of the Covered
|
||||
Software under this License. Except to the extent prohibited by statute
|
||||
or regulation, such description must be sufficiently detailed for a
|
||||
recipient of ordinary skill to be able to understand it.
|
||||
|
||||
5. Termination
|
||||
--------------
|
||||
|
||||
5.1. The rights granted under this License will terminate automatically
|
||||
if You fail to comply with any of its terms. However, if You become
|
||||
compliant, then the rights granted under this License from a particular
|
||||
Contributor are reinstated (a) provisionally, unless and until such
|
||||
Contributor explicitly and finally terminates Your grants, and (b) on an
|
||||
ongoing basis, if such Contributor fails to notify You of the
|
||||
non-compliance by some reasonable means prior to 60 days after You have
|
||||
come back into compliance. Moreover, Your grants from a particular
|
||||
Contributor are reinstated on an ongoing basis if such Contributor
|
||||
notifies You of the non-compliance by some reasonable means, this is the
|
||||
first time You have received notice of non-compliance with this License
|
||||
from such Contributor, and You become compliant prior to 30 days after
|
||||
Your receipt of the notice.
|
||||
|
||||
5.2. If You initiate litigation against any entity by asserting a patent
|
||||
infringement claim (excluding declaratory judgment actions,
|
||||
counter-claims, and cross-claims) alleging that a Contributor Version
|
||||
directly or indirectly infringes any patent, then the rights granted to
|
||||
You by any and all Contributors for the Covered Software under Section
|
||||
2.1 of this License shall terminate.
|
||||
|
||||
5.3. In the event of termination under Sections 5.1 or 5.2 above, all
|
||||
end user license agreements (excluding distributors and resellers) which
|
||||
have been validly granted by You or Your distributors under this License
|
||||
prior to termination shall survive termination.
|
||||
|
||||
************************************************************************
|
||||
* *
|
||||
* 6. Disclaimer of Warranty *
|
||||
* ------------------------- *
|
||||
* *
|
||||
* Covered Software is provided under this License on an "as is" *
|
||||
* basis, without warranty of any kind, either expressed, implied, or *
|
||||
* statutory, including, without limitation, warranties that the *
|
||||
* Covered Software is free of defects, merchantable, fit for a *
|
||||
* particular purpose or non-infringing. The entire risk as to the *
|
||||
* quality and performance of the Covered Software is with You. *
|
||||
* Should any Covered Software prove defective in any respect, You *
|
||||
* (not any Contributor) assume the cost of any necessary servicing, *
|
||||
* repair, or correction. This disclaimer of warranty constitutes an *
|
||||
* essential part of this License. No use of any Covered Software is *
|
||||
* authorized under this License except under this disclaimer. *
|
||||
* *
|
||||
************************************************************************
|
||||
|
||||
************************************************************************
|
||||
* *
|
||||
* 7. Limitation of Liability *
|
||||
* -------------------------- *
|
||||
* *
|
||||
* Under no circumstances and under no legal theory, whether tort *
|
||||
* (including negligence), contract, or otherwise, shall any *
|
||||
* Contributor, or anyone who distributes Covered Software as *
|
||||
* permitted above, be liable to You for any direct, indirect, *
|
||||
* special, incidental, or consequential damages of any character *
|
||||
* including, without limitation, damages for lost profits, loss of *
|
||||
* goodwill, work stoppage, computer failure or malfunction, or any *
|
||||
* and all other commercial damages or losses, even if such party *
|
||||
* shall have been informed of the possibility of such damages. This *
|
||||
* limitation of liability shall not apply to liability for death or *
|
||||
* personal injury resulting from such party's negligence to the *
|
||||
* extent applicable law prohibits such limitation. Some *
|
||||
* jurisdictions do not allow the exclusion or limitation of *
|
||||
* incidental or consequential damages, so this exclusion and *
|
||||
* limitation may not apply to You. *
|
||||
* *
|
||||
************************************************************************
|
||||
|
||||
8. Litigation
|
||||
-------------
|
||||
|
||||
Any litigation relating to this License may be brought only in the
|
||||
courts of a jurisdiction where the defendant maintains its principal
|
||||
place of business and such litigation shall be governed by laws of that
|
||||
jurisdiction, without reference to its conflict-of-law provisions.
|
||||
Nothing in this Section shall prevent a party's ability to bring
|
||||
cross-claims or counter-claims.
|
||||
|
||||
9. Miscellaneous
|
||||
----------------
|
||||
|
||||
This License represents the complete agreement concerning the subject
|
||||
matter hereof. If any provision of this License is held to be
|
||||
unenforceable, such provision shall be reformed only to the extent
|
||||
necessary to make it enforceable. Any law or regulation which provides
|
||||
that the language of a contract shall be construed against the drafter
|
||||
shall not be used to construe this License against a Contributor.
|
||||
|
||||
10. Versions of the License
|
||||
---------------------------
|
||||
|
||||
10.1. New Versions
|
||||
|
||||
Mozilla Foundation is the license steward. Except as provided in Section
|
||||
10.3, no one other than the license steward has the right to modify or
|
||||
publish new versions of this License. Each version will be given a
|
||||
distinguishing version number.
|
||||
|
||||
10.2. Effect of New Versions
|
||||
|
||||
You may distribute the Covered Software under the terms of the version
|
||||
of the License under which You originally received the Covered Software,
|
||||
or under the terms of any subsequent version published by the license
|
||||
steward.
|
||||
|
||||
10.3. Modified Versions
|
||||
|
||||
If you create software not governed by this License, and you want to
|
||||
create a new license for such software, you may create and use a
|
||||
modified version of this License if you rename the license and remove
|
||||
any references to the name of the license steward (except to note that
|
||||
such modified license differs from this License).
|
||||
|
||||
10.4. Distributing Source Code Form that is Incompatible With Secondary
|
||||
Licenses
|
||||
|
||||
If You choose to distribute Source Code Form that is Incompatible With
|
||||
Secondary Licenses under the terms of this version of the License, the
|
||||
notice described in Exhibit B of this License must be attached.
|
||||
|
||||
Exhibit A - Source Code Form License Notice
|
||||
-------------------------------------------
|
||||
|
||||
This Source Code Form is subject to the terms of the Mozilla Public
|
||||
License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
|
||||
If it is not possible or desirable to put the notice in a particular
|
||||
file, then You may include the notice in a location (such as a LICENSE
|
||||
file in a relevant directory) where a recipient would be likely to look
|
||||
for such a notice.
|
||||
|
||||
You may add additional accurate notices of copyright ownership.
|
||||
|
||||
Exhibit B - "Incompatible With Secondary Licenses" Notice
|
||||
---------------------------------------------------------
|
||||
|
||||
This Source Code Form is "Incompatible With Secondary Licenses", as
|
||||
defined by the Mozilla Public License, v. 2.0.
|
@ -1,135 +0,0 @@
|
||||
Terraform Provider for Vultr
|
||||
==================
|
||||
|
||||
- Quickstart Guide: [How to Provision a Vultr Cloud Server with Terraform and Cloud-Init](https://www.vultr.com/docs/provision-a-vultr-cloud-server-with-terraform-and-cloud-init/)
|
||||
- Vultr Website: https://www.vultr.com
|
||||
- Terraform Website: https://www.terraform.io
|
||||
|
||||
<img src="https://raw.githubusercontent.com/hashicorp/terraform-website/master/public/img/logo-hashicorp.svg" width="600px">
|
||||
|
||||
Requirements
|
||||
------------
|
||||
|
||||
- [Terraform](https://www.terraform.io/downloads.html) 0.12.x+
|
||||
- [Go](https://golang.org/doc/install) 1.22.x+ (to build the provider plugin)
|
||||
|
||||
Building The Provider
|
||||
---------------------
|
||||
|
||||
Clone repository to: `$GOPATH/src/github.com/vultr/terraform-provider-vultr`
|
||||
|
||||
``` sh
|
||||
$ mkdir -p $GOPATH/src/github.com/vultr; cd $GOPATH/src/github.com/vultr
|
||||
$ git clone git@github.com:vultr/terraform-provider-vultr.git
|
||||
```
|
||||
|
||||
Enter the provider directory and build the provider
|
||||
|
||||
``` sh
|
||||
$ cd $GOPATH/src/github.com/vultr/terraform-provider-vultr
|
||||
$ make build
|
||||
```
|
||||
|
||||
Using the provider
|
||||
----------------------
|
||||
|
||||
See the [Vultr Provider documentation](website/docs/index.html.markdown) to get started using the Vultr provider.
|
||||
|
||||
Please read about [V2 changes from V1](example/V2Changes.md) for a list of new changes made to the Vultr Terraform Provider
|
||||
|
||||
### Installation
|
||||
In your terraform config, define `vultr/vultr` in your `required_providers` and set your API key:
|
||||
``` hcl
|
||||
terraform {
|
||||
required_providers {
|
||||
vultr = {
|
||||
source = "vultr/vultr"
|
||||
version = "2.22.1"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
provider "vultr" {
|
||||
api_key = "..."
|
||||
}
|
||||
```
|
||||
|
||||
After, run `terraform init` to install the provider.
|
||||
|
||||
#### Manual Installation
|
||||
If you don't have internet access on the target machine or prefer to install
|
||||
the provider locally follow the steps for the relevant operating system and architecture.
|
||||
|
||||
1) [Download](https://github.com/vultr/terraform-provider-vultr/releases) and
|
||||
extract the binary for your system and architecture
|
||||
|
||||
2) Make the local plugins directory:
|
||||
|
||||
On linux
|
||||
``` sh
|
||||
export VERSION=2.22.1 OS=linux ARCH=amd64
|
||||
mkdir -p ~/.terraform.d/plugins/local/vultr/vultr/${VERSION}/${OS}_${ARCH}/'
|
||||
```
|
||||
|
||||
On mac
|
||||
``` sh
|
||||
export VERSION=2.22.1 OS=darwin ARCH=arm64
|
||||
mkdir -p ~/.terraform.d/plugins/local/vultr/vultr/${VERSION}/${OS}_${ARCH}/'
|
||||
```
|
||||
|
||||
3) Rename and copy the binary into the local plugins directory:
|
||||
``` sh
|
||||
mv terraform-provider-vultr_v${VERSION} ~/.terraform.d/plugins/local/vultr/vultr/${VERSION}/${OS}_${ARCH}/terraform-provider-vultr_v${VERSION}
|
||||
```
|
||||
|
||||
4) Add the local provider to your terraform `main.tf` config:
|
||||
``` hcl
|
||||
terraform {
|
||||
required_providers {
|
||||
vultr = {
|
||||
source = "local/vultr/vultr"
|
||||
version = "2.22.1"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
provider "vultr" {
|
||||
api_key = "..."
|
||||
}
|
||||
```
|
||||
|
||||
5) Test everything by running `terraform init` in that same directory.
|
||||
|
||||
Developing the Provider
|
||||
---------------------------
|
||||
|
||||
If you wish to work on the provider, you'll first need [Go](http://www.golang.org) installed on your machine (version 1.11+ is *required*). You'll also need to correctly setup a [GOPATH](http://golang.org/doc/code.html#GOPATH), as well as adding `$GOPATH/bin` to your `$PATH`.
|
||||
|
||||
To compile the provider, run `make build`. This will build the provider and put the provider binary in the `$GOPATH/bin` directory.
|
||||
|
||||
``` sh
|
||||
$ make build
|
||||
...
|
||||
$ $GOPATH/bin/terraform-provider-vultr
|
||||
...
|
||||
```
|
||||
|
||||
In order to test the provider, you can simply run `make test`.
|
||||
|
||||
``` sh
|
||||
$ make test
|
||||
```
|
||||
|
||||
In order to run the full suite of acceptance tests, run `make testacc`.
|
||||
|
||||
*Note:* Acceptance tests create real resources, and often cost money to run.
|
||||
|
||||
``` sh
|
||||
$ make testacc
|
||||
```
|
||||
|
||||
In order to run a specific acceptance test, use the `TESTARGS` environment variable. For example, the following command will run `TestAccVultrUser_base` acceptance test only:
|
||||
|
||||
``` sh
|
||||
$ make testacc TESTARGS='-run=TestAccVultrUser_base'
|
||||
```
|
Binary file not shown.
@ -1,74 +0,0 @@
|
||||
// create a vultr instance meant for capturing VODs
|
||||
|
||||
// load secrets from file
|
||||
// @see https://stackoverflow.com/a/67653301/1004931
|
||||
output "secrets" {
|
||||
value = { for tuple in regexall("(.*?)=(.*)", file("../../.kamal/secrets-common")) : tuple[0] => tuple[1] }
|
||||
}
|
||||
|
||||
resource "random_id" "blah" {
|
||||
byte_length = 8
|
||||
}
|
||||
|
||||
terraform {
|
||||
required_providers {
|
||||
vultr = {
|
||||
source = "vultr/vultr"
|
||||
version = "2.23.1"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
provider "vultr" {
|
||||
api_key = secrets.VULTR_API_KEY
|
||||
}
|
||||
|
||||
resource "vultr_instance" "capture_vps" {
|
||||
label = "fp-capture-${random_id.blah.hex}"
|
||||
plan = "vc2-2c-2gb"
|
||||
region = "atl"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
|
||||
user_data = base64encode(<<-EOT
|
||||
#cloud-config
|
||||
|
||||
package_update: true
|
||||
packages:
|
||||
- git
|
||||
- mosh
|
||||
- mg
|
||||
- screen
|
||||
- tree
|
||||
- ncdu
|
||||
- pipx
|
||||
- ffmpeg
|
||||
- fd-find
|
||||
- npm
|
||||
|
||||
runcmd:
|
||||
- git clone https://github.com/insanity54/dotfiles /root/dotfiles
|
||||
- cp /root/dotfiles/.screenrc /root/
|
||||
- curl -fsSL https://getcroc.schollz.com | bash
|
||||
- curl -fsSL get.docker.com | bash
|
||||
- ufw allow 60000:61000/udp
|
||||
- pipx install yt-dlp
|
||||
- pipx ensurepath
|
||||
- git clone https://github.com/insanity54/voddo /root/voddo
|
||||
- curl -fsSL https://gitea.futureporn.net/futureporn/fp/raw/branch/main/packages/scripts/thumbnail-generator.sh > ~/.local/bin/thumbnail-generator.sh
|
||||
- chmod +x ~/.local/bin/thumbnail-generator.sh
|
||||
- curl -fsSL https://github.com/Backblaze/B2_Command_Line_Tool/releases/download/v4.3.1/b2-linux > ~/.local/bin/b2
|
||||
- chmod +x ~/.local/bin/b2
|
||||
- export DIR=/usr/local/bin; curl https://raw.githubusercontent.com/jesseduffield/lazydocker/master/scripts/install_update_linux.sh | bash
|
||||
- curl -fsSL https://dist.ipfs.tech/kubo/v0.33.2/kubo_v0.33.2_linux-amd64.tar.gz > ~/kubo_v0.33.2_linux-amd64.tar.gz
|
||||
- tar xvzf ~/kubo_v0.33.2_linux-amd64.tar.gz
|
||||
- ~/kubo/install.sh
|
||||
- ufw allow 8080
|
||||
- ufw allow 8081
|
||||
- ufw allow 4001
|
||||
|
||||
EOT
|
||||
)
|
||||
}
|
@ -1,3 +1,5 @@
|
||||
pre-commit
|
||||
ggshield
|
||||
click
|
||||
click
|
||||
ansible
|
||||
ansible-lint
|
40
terraform/.gitignore
vendored
Normal file
40
terraform/.gitignore
vendored
Normal file
@ -0,0 +1,40 @@
|
||||
# Created by https://www.toptal.com/developers/gitignore/api/terraform
|
||||
# Edit at https://www.toptal.com/developers/gitignore?templates=terraform
|
||||
|
||||
### Terraform ###
|
||||
# Local .terraform directories
|
||||
**/.terraform/*
|
||||
|
||||
# .tfstate files
|
||||
*.tfstate
|
||||
*.tfstate.*
|
||||
|
||||
# Crash log files
|
||||
crash.log
|
||||
crash.*.log
|
||||
|
||||
# Exclude all .tfvars files, which are likely to contain sensitive data, such as
|
||||
# password, private keys, and other secrets. These should not be part of version
|
||||
# control as they are data points which are potentially sensitive and subject
|
||||
# to change depending on the environment.
|
||||
*.tfvars
|
||||
*.tfvars.json
|
||||
|
||||
# Ignore override files as they are usually used to override resources locally and so
|
||||
# are not checked in
|
||||
override.tf
|
||||
override.tf.json
|
||||
*_override.tf
|
||||
*_override.tf.json
|
||||
|
||||
# Include override files you do wish to add to version control using negated pattern
|
||||
# !example_override.tf
|
||||
|
||||
# Include tfplan files to ignore the plan output of command: terraform plan -out=tfplan
|
||||
# example: *tfplan*
|
||||
|
||||
# Ignore CLI configuration files
|
||||
.terraformrc
|
||||
terraform.rc
|
||||
|
||||
# End of https://www.toptal.com/developers/gitignore/api/terraform
|
66
terraform/.terraform.lock.hcl
generated
Normal file
66
terraform/.terraform.lock.hcl
generated
Normal file
@ -0,0 +1,66 @@
|
||||
# This file is maintained automatically by "tofu init".
|
||||
# Manual edits may be lost in future updates.
|
||||
|
||||
provider "registry.opentofu.org/ansible/ansible" {
|
||||
version = "1.2.0"
|
||||
constraints = "1.2.0"
|
||||
hashes = [
|
||||
"h1:+FFI791dQLSgrP3ldRPckp6kKHKPByGlZnZHSKEIk9M=",
|
||||
"zh:06ec85f5c8809eebd7049846d3a45e5c4d052f021fd0a93681d72da8db18f03c",
|
||||
"zh:13a289fbc8ba46b4a81aae5548d0f4b7c772e60b5597493be1a2f36f1642252f",
|
||||
"zh:1e345d4dd6cdff194c5878a986d00494dfe4d51e5f05a85fa37243acada4ac98",
|
||||
"zh:3bfc27e99ae4d4ad073f89655e88d545a043f395581fe6d30f9d2ddea98de8bc",
|
||||
"zh:45798319359ac89c70fc474a8cf11888b7f4281e591fc41892a55449740aa170",
|
||||
"zh:578b8b3f58f2a368bbb1326f16a14a7ff4f701a00f1123deffd1de751f9c2e28",
|
||||
"zh:6160b0e5728e7fc905e1b17671fb0df74483c477d0262a6c1e51c89d48afe71f",
|
||||
"zh:98961ef4beb153d15742dafc1a0428bf45323e979f4b4a82a4ec4062205a0782",
|
||||
"zh:a26d76f427058ec529436bf8fbe96bf6cd4e0a29275d7a6add0d3357517e0d43",
|
||||
"zh:a70366e2e21ed51d26e7797b3679db3d812e3458e7980e906934e78599461f02",
|
||||
"zh:a9829a90cd302789dc277a1be55ddaff83e702159dd4a05646cedd17b5c337b9",
|
||||
"zh:beb105f90d9a9d7821f533bee8ccddc9daed7c3a59646e5b3777ba62253f84f1",
|
||||
"zh:bf8db622d0cb848bc843d29187b747388d73d520ee10814424fdf79693ea15d5",
|
||||
"zh:f569b65999264a9416862bca5cd2a6177d94ccb0424f3a4ef424428912b9cb3c",
|
||||
"zh:f6c47554e1e98d71dc1ca5fbb569db198f71c13b4a1375454839b44e90a91926",
|
||||
]
|
||||
}
|
||||
|
||||
provider "registry.opentofu.org/hashicorp/local" {
|
||||
version = "2.5.2"
|
||||
hashes = [
|
||||
"h1:6lS+5A/4WFAqY3/RHWFRBSiFVLPRjvLaUgxPQvjXLHU=",
|
||||
"zh:25b95b76ceaa62b5c95f6de2fa6e6242edbf51e7fc6c057b7f7101aa4081f64f",
|
||||
"zh:3c974fdf6b42ca6f93309cf50951f345bfc5726ec6013b8832bcd3be0eb3429e",
|
||||
"zh:5de843bf6d903f5cca97ce1061e2e06b6441985c68d013eabd738a9e4b828278",
|
||||
"zh:86beead37c7b4f149a54d2ae633c99ff92159c748acea93ff0f3603d6b4c9f4f",
|
||||
"zh:8e52e81d3dc50c3f79305d257da7fde7af634fed65e6ab5b8e214166784a720e",
|
||||
"zh:9882f444c087c69559873b2d72eec406a40ede21acb5ac334d6563bf3a2387df",
|
||||
"zh:a4484193d110da4a06c7bffc44cc6b61d3b5e881cd51df2a83fdda1a36ea25d2",
|
||||
"zh:a53342426d173e29d8ee3106cb68abecdf4be301a3f6589e4e8d42015befa7da",
|
||||
"zh:d25ef2aef6a9004363fc6db80305d30673fc1f7dd0b980d41d863b12dacd382a",
|
||||
"zh:fa2d522fb323e2121f65b79709fd596514b293d816a1d969af8f72d108888e4c",
|
||||
]
|
||||
}
|
||||
|
||||
provider "registry.opentofu.org/vultr/vultr" {
|
||||
version = "2.23.1"
|
||||
constraints = "2.23.1"
|
||||
hashes = [
|
||||
"h1:VNpHOLXDPr/hNlsMoHFtUPjBhJnEuUxo5ywd5UeenX8=",
|
||||
"zh:02e794393bb26377444e81523f803e40f6ee45134914047071fe6291e7fb3813",
|
||||
"zh:06a2cb287bb5c79b05331aed90519bd08b3b8bc6b75191382ef1e8713bffc1e0",
|
||||
"zh:088c1a73057cb37fb8fc3ef009b26ca437e03929df5d7802ae1eca206bc91b56",
|
||||
"zh:1f7dc7e64e5ed8c0fa29658c5730c0fca5eeb3547215175319262f7ee92eac3c",
|
||||
"zh:278b5738632ebe9ee04a966c02071ce3e0e6435af0e8da55c96c71d50e0076dd",
|
||||
"zh:2c6fc71abf11fcb0c7dae89f99bd301dfa078a63a68529ea251e6b4cb0491f86",
|
||||
"zh:487fe4cbd9b4d49c4049dc2de647e41b6e5cb0857215fe2d38a7529fd1e184ab",
|
||||
"zh:4a8758b6c579bea6049f66d5238a20ac0878a2b89dee200f7655b74b61bebbbf",
|
||||
"zh:72a86c02b5ba2d141708a55c1eb4d100644ba377263747aca11b53f82487f645",
|
||||
"zh:8cabf4b700a63fd0daf7f9fc0c5bedff699d86b641fc66144b6ceb645765a345",
|
||||
"zh:9c1602b47ba7fa2f23a1810a2ec37291c83a342888ed430fc1bed5dd2edefcda",
|
||||
"zh:a27efb29592136f7c819aa22e1349dc3169be249d2e30873b72d7aabf80359eb",
|
||||
"zh:c5c92c87e28456de6387d23bda949734d4b5deef32e79d71ec9ddf945a53fc7f",
|
||||
"zh:cce93b449fd85e013ead67ed4ccc9861673a57a3d5e06d493419ebc97dcd21c5",
|
||||
"zh:e5e24b7349c679e2118a74ef559dbe43c13f8d3369a6ce8c7c4bdb72a3c03540",
|
||||
"zh:f226a9e61789c412493ff3abad4e6403aaae46d5d3532437b1c873ec772b828f",
|
||||
]
|
||||
}
|
83
terraform/idea/k3s.tf
Normal file
83
terraform/idea/k3s.tf
Normal file
@ -0,0 +1,83 @@
|
||||
|
||||
|
||||
|
||||
# vultr instances meant for running k3s cluster
|
||||
# these are working concept notes, although it is not used
|
||||
|
||||
|
||||
|
||||
resource "vultr_instance" "k3s_server" {
|
||||
count = 1
|
||||
hostname = "k3s-server-${count.index}"
|
||||
plan = "vc2-2c-2gb"
|
||||
region = "ord"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
label = "k3s"
|
||||
tags = ["futureporn", "k3s", "server"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
vpc2_ids = [
|
||||
vultr_vpc2.futureporn_vpc2.id
|
||||
]
|
||||
}
|
||||
|
||||
resource "vultr_instance" "k3s_agent" {
|
||||
count = 3
|
||||
hostname = "k3s-agent-${count.index}"
|
||||
plan = "vc2-2c-2gb"
|
||||
region = "ord"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
label = "k3s"
|
||||
tags = ["futureporn", "k3s", "agent"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
vpc2_ids = [
|
||||
vultr_vpc2.futureporn_vpc2.id
|
||||
]
|
||||
}
|
||||
|
||||
|
||||
resource "ansible_host" "k3s_server_vps" {
|
||||
for_each = { for idx, host in vultr_instance.k3s_server : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["server"]
|
||||
variables = {
|
||||
ansible_host = each.value.main_ip
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_host" "k3s_agent_vps" {
|
||||
for_each = { for idx, host in vultr_instance.k3s_agent : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["agent"]
|
||||
variables = {
|
||||
ansible_host = each.value.main_ip
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_group" "server" {
|
||||
name = "server"
|
||||
}
|
||||
|
||||
resource "ansible_group" "agent" {
|
||||
name = "agent"
|
||||
}
|
||||
|
||||
resource "ansible_group" "k3s_cluster" {
|
||||
name = "k3s_cluster"
|
||||
children = [
|
||||
"server",
|
||||
"agent"
|
||||
]
|
||||
variables = {
|
||||
k3s_version = "v1.31.6+k3s1"
|
||||
token = local.envs.K3S_TOKEN
|
||||
api_endpoint = "{{ hostvars[groups['server'][0]]['ansible_host'] | default(groups['server'][0]) }}"
|
||||
# use_external_database = true
|
||||
# extra_server_args = "--datastore-endpoint={{ local.envs.K3S_DATABASE_URL }}"
|
||||
}
|
||||
}
|
325
terraform/main.tf
Normal file
325
terraform/main.tf
Normal file
@ -0,0 +1,325 @@
|
||||
// load secrets from file
|
||||
// @see https://stackoverflow.com/a/67653301/1004931
|
||||
// @see https://grep.app/search?q=for+tuple+in+regexall%28
|
||||
// @see https://github.com/lrmendess/open-source-datalake/blob/main/minio.tf
|
||||
locals {
|
||||
envs = { for tuple in regexall("(.*)=(.*)", file("../.env")) : tuple[0] => sensitive(tuple[1]) }
|
||||
}
|
||||
|
||||
|
||||
variable bright_port {
|
||||
default = "4000"
|
||||
}
|
||||
|
||||
variable database_host {
|
||||
default = "10.2.128.4"
|
||||
}
|
||||
|
||||
variable public_s3_endpoint {
|
||||
default = "https://futureporn-b2.b-cdn.net"
|
||||
}
|
||||
|
||||
variable patreon_redirect_uri {
|
||||
default = "https://bright.futureporn.net/auth/patreon/callback"
|
||||
}
|
||||
|
||||
variable site_url {
|
||||
default = "https://bright.futureporn.net"
|
||||
}
|
||||
|
||||
variable phx_host {
|
||||
default = "bright.futureporn.net"
|
||||
}
|
||||
|
||||
variable aws_bucket {
|
||||
default = "futureporn"
|
||||
}
|
||||
|
||||
variable aws_region {
|
||||
default = "us-west-000"
|
||||
}
|
||||
|
||||
variable aws_host {
|
||||
default = "s3.us-west-000.backblazeb2.com"
|
||||
}
|
||||
|
||||
variable "vps_user_data" {
|
||||
# most packages are installed using ansible, but we do use cloud-config
|
||||
# to install python3, an ansible dependency
|
||||
default = <<-EOT
|
||||
#cloud-config
|
||||
package_update: true
|
||||
packages:
|
||||
- python3
|
||||
- fail2ban
|
||||
|
||||
# @see https://gist.github.com/NatElkins/20880368b797470f3bc6926e3563cb26 for more hardening ideas
|
||||
|
||||
EOT
|
||||
}
|
||||
|
||||
|
||||
terraform {
|
||||
required_providers {
|
||||
vultr = {
|
||||
source = "vultr/vultr"
|
||||
version = "2.23.1"
|
||||
}
|
||||
ansible = {
|
||||
source = "ansible/ansible"
|
||||
version = "1.2.0"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
provider "vultr" {
|
||||
api_key = "${local.envs.VULTR_API_KEY}"
|
||||
}
|
||||
|
||||
|
||||
# reserved IP lets us spin down the system and spin up without losing the IP reservation
|
||||
resource "vultr_reserved_ip" "futureporn_v2_ip" {
|
||||
label = "futureporn-v2"
|
||||
region = "ord"
|
||||
ip_type = "v4"
|
||||
}
|
||||
|
||||
resource "vultr_reserved_ip" "futureporn_tracker_ip" {
|
||||
label = "futureporn-tracker"
|
||||
region = "ord"
|
||||
ip_type = "v4"
|
||||
}
|
||||
|
||||
# Virtual Private Cloud for connecting many VPS together on a private network
|
||||
# We use this network connection for app<->db comms.
|
||||
resource "vultr_vpc2" "futureporn_vpc2" {
|
||||
region = "ord"
|
||||
description = "Futureporn V2 VPC2"
|
||||
}
|
||||
|
||||
# load balancing instance
|
||||
resource "vultr_instance" "load_balancer" {
|
||||
count = 1
|
||||
hostname = "fp-lb-${count.index}"
|
||||
plan = "vc2-1c-2gb"
|
||||
region = "ord"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
label = "fp lb ${count.index}"
|
||||
tags = ["futureporn", "load_balancer", "bright"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
user_data = base64encode(var.vps_user_data)
|
||||
vpc2_ids = [
|
||||
vultr_vpc2.futureporn_vpc2.id
|
||||
]
|
||||
reserved_ip_id = vultr_reserved_ip.futureporn_v2_ip.id
|
||||
}
|
||||
|
||||
# vultr instance for running bright app
|
||||
resource "vultr_instance" "bright" {
|
||||
count = 1
|
||||
hostname = "fp-bright-${count.index}"
|
||||
plan = "vc2-2c-2gb"
|
||||
region = "ord"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
label = "fp bright ${count.index}"
|
||||
tags = ["futureporn", "phoenix", "bright"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
vpc2_ids = [
|
||||
vultr_vpc2.futureporn_vpc2.id
|
||||
]
|
||||
user_data = base64encode(var.vps_user_data)
|
||||
}
|
||||
|
||||
|
||||
# vultr instance meant for capturing VODs
|
||||
resource "vultr_instance" "capture_vps" {
|
||||
count = 0
|
||||
hostname = "fp-cap-${count.index}"
|
||||
plan = "vc2-2c-2gb"
|
||||
region = "ord"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
vpc2_ids = [vultr_vpc2.futureporn_vpc2.id]
|
||||
label = "fp capture ${count.index}"
|
||||
tags = ["futureporn", "capture"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
user_data = base64encode(var.vps_user_data)
|
||||
}
|
||||
|
||||
resource "vultr_instance" "database" {
|
||||
count = 1
|
||||
hostname = "fp-db-${count.index}"
|
||||
plan = "vc2-1c-2gb"
|
||||
region = "ord"
|
||||
backups = "enabled"
|
||||
backups_schedule {
|
||||
hour = "2"
|
||||
type = "daily"
|
||||
}
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
vpc2_ids = [vultr_vpc2.futureporn_vpc2.id]
|
||||
label = "fp database ${count.index}"
|
||||
tags = ["futureporn", "database"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
user_data = base64encode(var.vps_user_data)
|
||||
}
|
||||
|
||||
resource "vultr_instance" "tracker" {
|
||||
count = 1
|
||||
hostname = "fp-tracker-${count.index}"
|
||||
plan = "vc2-1c-2gb"
|
||||
region = "ord"
|
||||
backups = "disabled"
|
||||
ddos_protection = "false"
|
||||
os_id = 1743
|
||||
enable_ipv6 = true
|
||||
vpc2_ids = [vultr_vpc2.futureporn_vpc2.id]
|
||||
label = "fp tracker ${count.index}"
|
||||
tags = ["futureporn", "tracker"]
|
||||
ssh_key_ids = [local.envs.VULTR_SSH_KEY_ID]
|
||||
user_data = base64encode(var.vps_user_data)
|
||||
reserved_ip_id = vultr_reserved_ip.futureporn_tracker_ip.id
|
||||
}
|
||||
|
||||
resource "ansible_host" "capture_vps" {
|
||||
for_each = { for idx, host in vultr_instance.capture_vps : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["capture"] # Groups this host is part of.
|
||||
|
||||
variables = {
|
||||
# Connection vars.
|
||||
ansible_user = "root"
|
||||
ansible_host = each.value.main_ip
|
||||
|
||||
# Custom vars that we might use in roles/tasks.
|
||||
# hostname = "web1"
|
||||
# fqdn = "web1.example.com"
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_host" "load_balancer" {
|
||||
for_each = { for idx, host in vultr_instance.load_balancer : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["load_balancer"]
|
||||
variables = {
|
||||
ansible_host = each.value.main_ip
|
||||
internal_ip = each.value.internal_ip
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_host" "database" {
|
||||
for_each = { for idx, host in vultr_instance.database : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["database"]
|
||||
variables = {
|
||||
ansible_host = each.value.main_ip
|
||||
internal_ip = each.value.internal_ip
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_host" "bright" {
|
||||
for_each = { for idx, host in vultr_instance.bright : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["bright"]
|
||||
variables = {
|
||||
ansible_host = each.value.main_ip
|
||||
internal_ip = each.value.internal_ip
|
||||
vultr_instance_id = each.value.id
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_host" "tracker" {
|
||||
for_each = { for idx, host in vultr_instance.tracker : idx => host }
|
||||
name = each.value.hostname
|
||||
groups = ["tracker"]
|
||||
variables = {
|
||||
ansible_host = each.value.main_ip
|
||||
internal_ip = each.value.internal_ip
|
||||
vultr_instance_id = each.value.id
|
||||
}
|
||||
}
|
||||
|
||||
resource "ansible_group" "capture" {
|
||||
name = "capture"
|
||||
}
|
||||
|
||||
resource "ansible_group" "bright" {
|
||||
name = "bright"
|
||||
}
|
||||
|
||||
resource "ansible_group" "tracker" {
|
||||
name = "tracker"
|
||||
}
|
||||
|
||||
resource "ansible_group" "load_balancer" {
|
||||
name = "load_balancer"
|
||||
}
|
||||
|
||||
resource "ansible_group" "database" {
|
||||
name = "database"
|
||||
}
|
||||
|
||||
resource "ansible_group" "futureporn" {
|
||||
name = "futureporn"
|
||||
children = [
|
||||
"load_balancer",
|
||||
"database",
|
||||
"capture",
|
||||
"bright",
|
||||
"tracker",
|
||||
]
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
# user_data = base64encode(<<-EOT
|
||||
# #cloud-config
|
||||
|
||||
# package_update: true
|
||||
# packages:
|
||||
# - git
|
||||
# - mosh
|
||||
# - mg
|
||||
# - screen
|
||||
# - tree
|
||||
# - ncdu
|
||||
# - pipx
|
||||
# - ffmpeg
|
||||
# - fd-find
|
||||
# - npm
|
||||
|
||||
# runcmd:
|
||||
# - git clone https://github.com/insanity54/dotfiles /root/dotfiles
|
||||
# - cp /root/dotfiles/.screenrc /root/
|
||||
# - curl -fsSL https://getcroc.schollz.com | bash
|
||||
# - curl -fsSL get.docker.com | bash
|
||||
# - ufw allow 60000:61000/udp
|
||||
# - pipx install yt-dlp
|
||||
# - pipx ensurepath
|
||||
# - git clone https://github.com/insanity54/voddo /root/voddo
|
||||
# - curl -fsSL https://gitea.futureporn.net/futureporn/fp/raw/branch/main/packages/scripts/thumbnail-generator.sh > ~/.local/bin/thumbnail-generator.sh
|
||||
# - chmod +x ~/.local/bin/thumbnail-generator.sh
|
||||
# - curl -fsSL https://github.com/Backblaze/B2_Command_Line_Tool/releases/download/v4.3.1/b2-linux > ~/.local/bin/b2
|
||||
# - chmod +x ~/.local/bin/b2
|
||||
# - export DIR=/usr/local/bin; curl https://raw.githubusercontent.com/jesseduffield/lazydocker/master/scripts/install_update_linux.sh | bash
|
||||
# - curl -fsSL https://dist.ipfs.tech/kubo/v0.33.2/kubo_v0.33.2_linux-amd64.tar.gz > ~/kubo_v0.33.2_linux-amd64.tar.gz
|
||||
# - tar xvzf ~/kubo_v0.33.2_linux-amd64.tar.gz
|
||||
# - ~/kubo/install.sh
|
||||
# - ufw allow 8080
|
||||
# - ufw allow 8081
|
||||
# - ufw allow 4001
|
||||
|
||||
# EOT
|
||||
# )
|
9
terraform/templates/hosts.tpl
Normal file
9
terraform/templates/hosts.tpl
Normal file
@ -0,0 +1,9 @@
|
||||
[capture_instances]
|
||||
%{ for ip in capture_instances ~}
|
||||
${ip}
|
||||
%{ endfor ~}
|
||||
|
||||
[bright_instances]
|
||||
%{ for ip in bright_instances ~}
|
||||
${ip}
|
||||
%{ endfor ~}
|
Loading…
x
Reference in New Issue
Block a user