]> cat aescling's git repositories - mastodon.git/blob - boxfile.yml
Suppress backtrace when delivering toots (#12798)
[mastodon.git] / boxfile.yml
1 run.config:
2 engine: ruby
3 engine.config:
4 runtime: ruby-2.5
5
6 extra_packages:
7 # basic servers:
8 - nginx
9 - nodejs
10
11 # for images:
12 - ImageMagick
13 - jemalloc
14
15 # for videos:
16 - ffmpeg3
17
18 # to prep the .env file:
19 - gettext-tools
20
21 # for node-gyp, used in the asset compilation process:
22 - python-2
23
24 # i18n:
25 - libidn
26
27 cache_dirs:
28 - node_modules
29
30 extra_path_dirs:
31 - node_modules/.bin
32
33 build_triggers:
34 - .ruby-version
35 - Gemfile
36 - Gemfile.lock
37 - package.json
38 - yarn.lock
39
40 extra_steps:
41 - cp .env.nanobox .env
42 - yarn
43
44 fs_watch: true
45
46
47 deploy.config:
48 extra_steps:
49 - NODE_ENV=production bundle exec rake assets:precompile
50 transform:
51 - "envsubst < /app/.env.nanobox > /app/.env.production"
52 - |-
53 if [ -z "$LOCAL_DOMAIN" ]
54 then
55 . /app/.env.production
56 export LOCAL_DOMAIN
57 fi
58 erb /app/nanobox/nginx-web.conf.erb > /app/nanobox/nginx-web.conf
59 erb /app/nanobox/nginx-stream.conf.erb > /app/nanobox/nginx-stream.conf
60 - touch /app/log/production.log
61 before_live:
62 web.web:
63 - bin/tootctl cache clear
64 - bundle exec rake db:migrate:setup
65 after_live:
66 worker.sidekiq:
67 - |-
68 if [[ "${ES_ENABLED}" != "false" ]]
69 then
70 bin/tootctl search deploy
71 fi
72
73
74 web.web:
75 start:
76 nginx: nginx -c /app/nanobox/nginx-web.conf
77 rails: bundle exec puma -C /app/config/puma.rb
78
79 routes:
80 - '/'
81
82 writable_dirs:
83 - tmp
84
85 log_watch:
86 rails: 'log/production.log'
87
88 network_dirs:
89 data.storage:
90 - public/system
91
92
93 web.stream:
94 start:
95 nginx: nginx -c /app/nanobox/nginx-stream.conf
96 node: yarn run start
97
98 routes:
99 - '/api/v1/streaming*'
100 # Somehow we're getting requests for scheme://domain//api/v1/streaming* - match those, too
101 - '//api/v1/streaming*'
102
103 writable_dirs:
104 - tmp
105
106
107 worker.sidekiq:
108 start:
109 default: bundle exec sidekiq -c 5 -q default -L /app/log/sidekiq.log
110 mailers: bundle exec sidekiq -c 5 -q mailers -L /app/log/sidekiq.log
111 pull: bundle exec sidekiq -c 5 -q pull -L /app/log/sidekiq.log
112 push: bundle exec sidekiq -c 5 -q push -L /app/log/sidekiq.log
113
114 writable_dirs:
115 - tmp
116
117 log_watch:
118 rails: 'log/production.log'
119 sidekiq: 'log/sidekiq.log'
120
121 network_dirs:
122 data.storage:
123 - public/system
124
125
126 data.db:
127 image: nanobox/postgresql:9.6
128
129 cron:
130 - id: backup
131 schedule: '0 3 * * *'
132 command: |
133 PGPASSWORD=${DATA_DB_PASS} pg_dump -U ${DATA_DB_USER} -w -Fc -O gonano |
134 gzip |
135 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/backup-${HOSTNAME}-$(date -u +%Y-%m-%d.%H-%M-%S).sql.gz -X POST -T - >&2
136 curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
137 sed 's/,/\n/g' |
138 grep ${HOSTNAME} |
139 sort |
140 head -n-${BACKUP_COUNT:-1} |
141 sed 's/.*: \?"\(.*\)".*/\1/' |
142 while read file
143 do
144 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
145 done
146
147
148 data.elastic:
149 image: nanobox/elasticsearch:5
150
151 cron:
152 - id: backup
153 schedule: '0 3 * * *'
154 command: |
155 id=$(cat /proc/sys/kernel/random/uuid)
156 curl -X PUT -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}" -d "{\"type\": \"fs\",\"settings\": {\"location\": \"/var/tmp/${id}\",\"compress\": true}}"
157 curl -X PUT -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}/backup?wait_for_completion=true&pretty"
158 tar -cz -C "/var/tmp/${id}" . |
159 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/backup-${HOSTNAME}-$(date -u +%Y-%m-%d.%H-%M-%S).tgz -X POST -T - >&2
160 curl -X DELETE -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}"
161 rm -rf "/var/tmp/${id}"
162 curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
163 sed 's/,/\n/g' |
164 grep ${HOSTNAME} |
165 sort |
166 head -n-${BACKUP_COUNT:-1} |
167 sed 's/.*: \?"\(.*\)".*/\1/' |
168 while read file
169 do
170 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
171 done
172
173
174 data.redis:
175 image: nanobox/redis:4.0
176
177 cron:
178 - id: backup
179 schedule: '0 3 * * *'
180 command: |
181 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/backup-${HOSTNAME}-$(date -u +%Y-%m-%d.%H-%M-%S).rdb -X POST -T /data/var/db/redis/dump.rdb >&2
182 curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
183 sed 's/,/\n/g' |
184 grep ${HOSTNAME} |
185 sort |
186 head -n-${BACKUP_COUNT:-1} |
187 sed 's/.*: \?"\(.*\)".*/\1/' |
188 while read file
189 do
190 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
191 done
192
193
194 data.storage:
195 image: nanobox/unfs:0.9
196
197 cron:
198 - id: backup
199 schedule: '0 3 * * *'
200 command: |
201 tar cz -C /data/var/db/unfs/ . |
202 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/backup-${HOSTNAME}-$(date -u +%Y-%m-%d.%H-%M-%S).tgz -X POST -T - >&2
203 curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
204 sed 's/,/\n/g' |
205 grep ${HOSTNAME} |
206 sort |
207 head -n-${BACKUP_COUNT:-1} |
208 sed 's/.*: \?"\(.*\)".*/\1/' |
209 while read file
210 do
211 curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
212 done
This page took 0.090552 seconds and 4 git commands to generate.