aboutsummaryrefslogtreecommitdiff
path: root/app/bad.nextcloud/deploy/nextcloud.hcl
blob: 8311bbec8a4135bc94e05b65ad3f32fc924201b9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
job "nextcloud" {
  datacenters = ["neptune"]
  type = "service"
  
  group "nextcloud" {
    count = 1

    network {
      port "http" {
        to = 80
      }
    }

    ephemeral_disk {
      size    = 10000
    }

    restart {
      attempts = 10
      delay    = "30s"
    }

    task "restore-db" {
      lifecycle {
        hook = "prestart"
        sidecar = false
      }

      driver = "docker"
      config {
        image = "litestream/litestream:0.3.7"
        args = [
          "restore", "-config", "/etc/litestream.yml", "/ephemeral/nextcloud.db"
        ]
        volumes = [
          "../alloc/data:/ephemeral",
          "secrets/litestream.yml:/etc/litestream.yml"
        ]
      }

      template {
        data = file("../config/litestream.yml")
        destination = "secrets/litestream.yml"
      }

      resources {
        memory = 200
        cpu = 1000
      }
    }

    task "nextcloud" {
      driver = "docker"
      config {
        image = "nextcloud:22.2.3-apache"
        ports = [ "http" ]

        volumes = [
          "../alloc/data:/ephemeral",
        ]
      }

      template {
        data = <<EOH
SQLITE_DATABASE=/ephemeral/nextcloud.db
NEXTCLOUD_ADMIN_USER={{ key "secrets/nextcloud/admin_user" }}
NEXTCLOUD_ADMIN_PASSWORD={{ key "secrets/nextcloud/admin_pass" }}
NEXTCLOUD_TRUSTED_DOMAINS=cloud.home.adnab.me
OBJECTSTORE_S3_HOST={{ env "node.unique.network.ip-address" }}
OBJECTSTORE_S3_PORT=3990
OBJECTSTORE_S3_BUCKET=nextcloud-data
OBJECTSTORE_S3_KEY={{ key "secrets/nextcloud/s3_access_key" }}
OBJECTSTORE_S3_SECRET={{ key "secrets/nextcloud/s3_secret_key" }}
OBJECTSTORE_S3_SSL=false
OBJECTSTORE_S3_REGION=garage-staging
OBJECTSTORE_S3_USEPATH_STYLE=true
EOH
        destination = "secrets/env"
        env = true
      }

      resources {
        memory = 2500
        cpu = 1000
      }

      service {
        port = "http"
        tags = [
          "tricot cloud.home.adnab.me 100",
        ]
        check {
          type = "http"
          path = "/"
          interval = "10s"
          timeout = "2s"
        }
      }
    }

    task "replicate-db" {
      driver = "docker"
      config {
        image = "litestream/litestream:0.3.7"
        args = [
          "replicate", "-config", "/etc/litestream.yml"
        ]
        volumes = [
          "../alloc/data:/ephemeral",
          "secrets/litestream.yml:/etc/litestream.yml"
        ]
      }

      template {
        data = file("../config/litestream.yml")
        destination = "secrets/litestream.yml"
      }

      resources {
        memory = 200
        cpu = 100
      }
    }
  }
}