re-arch into media directory

This commit is contained in:
Nemo 2018-05-29 18:56:00 +05:30
parent 8efb575290
commit 1a714d87b2
23 changed files with 146 additions and 104 deletions

View File

@ -1,26 +1,3 @@
resource "docker_container" "mongorocks" {
name = "mongorocks"
image = "${docker_image.percona-mongodb-server.latest}"
restart = "unless-stopped"
destroy_grace_seconds = 30
must_run = true
memory = 256
volumes {
volume_name = "${docker_volume.mongorocks_data_volume.name}"
container_path = "/data/db"
host_path = "${docker_volume.mongorocks_data_volume.mountpoint}"
}
command = [
"--storageEngine=rocksdb",
"--httpinterface",
"--rest",
"--master",
]
}
resource "docker_container" "mariadb" {
name = "mariadb"
image = "${docker_image.mariadb.latest}"
@ -59,3 +36,12 @@ resource "docker_container" "mariadb" {
"--version=${var.mariadb-version}-MariaDB",
]
}
resource "docker_image" "mariadb" {
name = "${data.docker_registry_image.mariadb.name}"
pull_triggers = ["${data.docker_registry_image.mariadb.sha256_digest}"]
}
data "docker_registry_image" "mariadb" {
name = "mariadb:${var.mariadb-version}"
}

32
db/mongorocks.tf Normal file
View File

@ -0,0 +1,32 @@
resource "docker_container" "mongorocks" {
name = "mongorocks"
image = "${docker_image.percona-mongodb-server.latest}"
restart = "unless-stopped"
destroy_grace_seconds = 30
must_run = true
memory = 256
volumes {
volume_name = "${docker_volume.mongorocks_data_volume.name}"
container_path = "/data/db"
host_path = "${docker_volume.mongorocks_data_volume.mountpoint}"
}
command = [
"--storageEngine=rocksdb",
"--httpinterface",
"--rest",
"--master",
]
}
resource "docker_image" "percona-mongodb-server" {
name = "${data.docker_registry_image.percona-mongodb-server.name}"
pull_triggers = ["${data.docker_registry_image.percona-mongodb-server.sha256_digest}"]
}
# Database versions shouldn't be upgraded
data "docker_registry_image" "percona-mongodb-server" {
name = "percona/percona-server-mongodb:3.4"
}

7
db/outputs.tf Normal file
View File

@ -0,0 +1,7 @@
output "names-mariadb" {
value = "${docker_container.mariadb.name}"
}
output "names-mongorocks" {
value = "${docker_container.mongorocks.name}"
}

10
db/variables.tf Normal file
View File

@ -0,0 +1,10 @@
variable "mariadb-version" {
description = "mariadb version to use for fetching the docker image"
default = "10.2.14"
}
variable "ips" {
type = "map"
}
variable "mysql_root_password" {}

7
db/volumes.tf Normal file
View File

@ -0,0 +1,7 @@
resource "docker_volume" "mariadb_volume" {
name = "mariadb_volume"
}
resource "docker_volume" "mongorocks_data_volume" {
name = "mongorocks_data_volume"
}

View File

@ -1,28 +1,9 @@
# Database versions shouldn't be upgraded
data "docker_registry_image" "mariadb" {
name = "mariadb:${var.mariadb-version}"
}
data "docker_registry_image" "percona-mongodb-server" {
name = "percona/percona-server-mongodb:3.4"
}
data "docker_registry_image" "traefik" {
# Critical and I like upgrading it
# for updating config for new features
name = "traefik:1.6-alpine"
}
# YOLO everything else
data "docker_registry_image" "emby" {
name = "emby/embyserver:latest"
}
data "docker_registry_image" "transmission" {
name = "linuxserver/transmission:latest"
}
data "docker_registry_image" "wikijs" {
name = "requarks/wiki:latest"
}

View File

@ -1,18 +1,3 @@
resource "docker_image" "emby" {
name = "${data.docker_registry_image.emby.name}"
pull_triggers = ["${data.docker_registry_image.emby.sha256_digest}"]
}
resource "docker_image" "mariadb" {
name = "${data.docker_registry_image.mariadb.name}"
pull_triggers = ["${data.docker_registry_image.mariadb.sha256_digest}"]
}
resource "docker_image" "transmission" {
name = "${data.docker_registry_image.transmission.name}"
pull_triggers = ["${data.docker_registry_image.transmission.sha256_digest}"]
}
resource "docker_image" "traefik16" {
name = "${data.docker_registry_image.traefik.name}"
pull_triggers = ["${data.docker_registry_image.traefik.sha256_digest}"]
@ -23,11 +8,6 @@ resource "docker_image" "wikijs" {
pull_triggers = ["${data.docker_registry_image.wikijs.sha256_digest}"]
}
resource "docker_image" "percona-mongodb-server" {
name = "${data.docker_registry_image.percona-mongodb-server.name}"
pull_triggers = ["${data.docker_registry_image.percona-mongodb-server.sha256_digest}"]
}
resource "docker_image" "ubooquity" {
name = "${data.docker_registry_image.ubooquity.name}"
pull_triggers = ["${data.docker_registry_image.ubooquity.sha256_digest}"]

View File

@ -33,5 +33,5 @@ resource "docker_container" "lychee" {
"PGID=984",
]
links = ["${docker_container.mariadb.name}"]
links = ["${var.links-mariadb}"]
}

View File

@ -1 +1,6 @@
// This is the default network we use
// for any new container
resource "docker_network" "bb8-default" {
name = "bb8"
driver = "bridge"
}

View File

@ -2,18 +2,6 @@ output "lychee-ip" {
value = "${docker_container.lychee.ip_address}"
}
output "names-transmission" {
value = "${docker_container.transmission.name}"
}
output "names-emby" {
value = "${docker_container.emby.name}"
}
output "names-mariadb" {
value = "${docker_container.mariadb.name}"
}
output "names-traefik" {
value = "${docker_container.traefik.name}"
}

View File

@ -6,10 +6,6 @@ variable "web_password" {
type = "string"
}
variable "mysql_root_password" {
type = "string"
}
variable "cloudflare_key" {
type = "string"
description = "cloudflare API Key"
@ -54,7 +50,6 @@ variable "ips" {
type = "map"
}
variable "mariadb-version" {
description = "mariadb version to use for fetching the docker image"
default = "10.2.14"
}
variable "links-mariadb" {}
variable "links-mongorocks" {}

View File

@ -1,7 +1 @@
resource "docker_volume" "mariadb_volume" {
name = "mariadb_volume"
}
resource "docker_volume" "mongorocks_data_volume" {
name = "mongorocks_data_volume"
}

View File

@ -43,7 +43,7 @@ resource "docker_container" "wiki" {
"traefik.port", 9999,
"traefik.frontend.headers.customResponseHeaders", "${var.xpoweredby}||Referrer-Policy:${var.refpolicy}||X-Frame-Options:${var.xfo_allow}",
))}"
links = ["${docker_container.mongorocks.name}"]
links = ["${var.links-mongorocks}"]
env = [
"WIKI_ADMIN_EMAIL=me@captnemo.in",
"SESSION_SECRET=${var.wiki_session_secret}",

27
main.tf
View File

@ -17,14 +17,21 @@ module "docker" {
source = "docker"
web_username = "${var.web_username}"
web_password = "${var.web_password}"
mysql_root_password = "${var.mysql_root_password}"
cloudflare_key = "${var.cloudflare_key}"
cloudflare_email = "bb8@captnemo.in"
wiki_session_secret = "${var.wiki_session_secret}"
links-mariadb = "${module.db.names-mariadb}"
links-mongorocks = "${module.db.names-mongorocks}"
ips = "${var.ips}"
domain = "bb8.fun"
}
module "db" {
source = "db"
mysql_root_password = "${var.mysql_root_password}"
ips = "${var.ips}"
}
module "timemachine" {
source = "timemachine"
ips = "${var.ips}"
@ -56,7 +63,7 @@ module "tt-rss" {
source = "tt-rss"
domain = "rss.captnemo.in"
mysql_password = "${var.mysql-ttrss-password}"
links-db = "${module.docker.names-mariadb}"
links-db = "${module.db.names-mariadb}"
traefik-labels = "${var.traefik-common-labels}"
}
@ -81,21 +88,25 @@ module "heimdall" {
}
module "media" {
source = "media"
domain = "bb8.fun"
links-emby = "${module.docker.names-emby}"
links-transmission = "${module.docker.names-transmission}"
links-mariadb = "${module.docker.names-mariadb}"
source = "media"
domain = "bb8.fun"
// TODO: remove self links
links-emby = "${module.media.names-emby}"
links-transmission = "${module.media.names-transmission}"
links-mariadb = "${module.db.names-mariadb}"
links-mongorocks = "${module.db.names-mongorocks}"
traefik-labels = "${var.traefik-common-labels}"
airsonic-smtp-password = "${var.airsonic-smtp-password}"
airsonic-db-password = "${var.mysql_airsonic_password}"
ips = "${var.ips}"
}
module "monitoring" {
source = "monitoring"
gf-security-admin-password = "${var.gf-security-admin-password}"
domain = "bb8.fun"
transmission = "${module.docker.names-transmission}"
transmission = "${module.media.names-transmission}"
traefik-labels = "${var.traefik-common-labels}"
ips = "${var.ips}"
links-traefik = "${module.docker.names-traefik}"

View File

@ -13,7 +13,7 @@ resource "docker_container" "emby" {
}
labels = "${merge(
local.traefik_common_labels,
var.traefik-labels,
map(
"traefik.frontend.rule", "Host:emby.in.${var.domain},emby.${var.domain}",
"traefik.frontend.passHostHeader", "true",
@ -34,3 +34,12 @@ resource "docker_container" "emby" {
"TZ=Asia/Kolkata",
]
}
resource "docker_image" "emby" {
name = "${data.docker_registry_image.emby.name}"
pull_triggers = ["${data.docker_registry_image.emby.sha256_digest}"]
}
data "docker_registry_image" "emby" {
name = "emby/embyserver:latest"
}

View File

@ -43,5 +43,5 @@ resource "docker_container" "lidarr" {
"TZ=Asia/Kolkata",
]
links = ["${var.links-emby}", "${var.links-transmission}"]
networks = ["${docker_network.media.id}"]
}

9
media/network.tf Normal file
View File

@ -0,0 +1,9 @@
resource "docker_network" "media" {
name = "media"
driver = "bridge"
ipam_config {
subnet = "172.18.0.0/16"
gateway = "172.18.0.1"
}
}

7
media/outputs.tf Normal file
View File

@ -0,0 +1,7 @@
output "names-transmission" {
value = "${docker_container.transmission.name}"
}
output "names-emby" {
value = "${docker_container.emby.name}"
}

View File

@ -44,5 +44,5 @@ resource "docker_container" "radarr" {
"TZ=Asia/Kolkata",
]
links = ["${var.links-emby}", "${var.links-transmission}"]
networks = ["${docker_network.media.id}"]
}

View File

@ -43,5 +43,5 @@ resource "docker_container" "sonarr" {
"TZ=Asia/Kolkata",
]
links = ["${var.links-emby}", "${var.links-transmission}"]
networks = ["${docker_network.media.id}"]
}

View File

@ -3,7 +3,7 @@ resource "docker_container" "transmission" {
image = "${docker_image.transmission.latest}"
labels = "${merge(
local.traefik_common_labels,
var.traefik-labels,
map(
"traefik.frontend.auth.basic", "${var.basic_auth}",
"traefik.port", 9091,
@ -42,8 +42,19 @@ resource "docker_container" "transmission" {
"TZ=Asia/Kolkata",
]
networks = ["${docker_network.media.id}"]
memory = 1024
restart = "unless-stopped"
destroy_grace_seconds = 10
must_run = true
}
resource "docker_image" "transmission" {
name = "${data.docker_registry_image.transmission.name}"
pull_triggers = ["${data.docker_registry_image.transmission.sha256_digest}"]
}
data "docker_registry_image" "transmission" {
name = "linuxserver/transmission:latest"
}

View File

@ -5,9 +5,19 @@ variable "domain" {
variable "links-emby" {}
variable "links-transmission" {}
variable "links-mariadb" {}
variable "links-mongorocks" {}
variable "airsonic-smtp-password" {}
variable "airsonic-db-password" {}
variable "traefik-labels" {
type = "map"
}
// TODO: Remove duplication
variable "basic_auth" {
default = "tatooine:$2y$05$iPbatint3Gulbs6kUtyALO9Yq5sBJ..aiF82bcIziH4ytz9nFoPr6,reddit:$2y$05$ghKxSydYCpAT8r2VVMDmWO/BBecghGfLsRJUkr3ii7XxPyxBqp8Oy"
}
variable "ips" {
type = "map"
}