Gab Social. All are welcome.
This commit is contained in:
280
boxfile.yml
Normal file
280
boxfile.yml
Normal file
@@ -0,0 +1,280 @@
|
||||
run.config:
|
||||
engine: ruby
|
||||
engine.config:
|
||||
runtime: ruby-2.5
|
||||
|
||||
extra_packages:
|
||||
# basic servers:
|
||||
- nginx
|
||||
- nodejs
|
||||
|
||||
# for images:
|
||||
- ImageMagick
|
||||
- jemalloc
|
||||
|
||||
# for videos:
|
||||
- ffmpeg3
|
||||
|
||||
# to prep the .env file:
|
||||
- gettext-tools
|
||||
|
||||
# for node-gyp, used in the asset compilation process:
|
||||
- python-2
|
||||
|
||||
# i18n:
|
||||
- libidn
|
||||
|
||||
cache_dirs:
|
||||
- node_modules
|
||||
|
||||
extra_path_dirs:
|
||||
- node_modules/.bin
|
||||
|
||||
build_triggers:
|
||||
- .ruby-version
|
||||
- Gemfile
|
||||
- Gemfile.lock
|
||||
- package.json
|
||||
- yarn.lock
|
||||
|
||||
extra_steps:
|
||||
- cp .env.nanobox .env
|
||||
- yarn
|
||||
|
||||
fs_watch: true
|
||||
|
||||
|
||||
deploy.config:
|
||||
extra_steps:
|
||||
- NODE_ENV=production bundle exec rake assets:precompile
|
||||
transform:
|
||||
- "envsubst < /app/.env.nanobox > /app/.env.production"
|
||||
- |-
|
||||
if [ -z "$LOCAL_DOMAIN" ]
|
||||
then
|
||||
. /app/.env.production
|
||||
export LOCAL_DOMAIN
|
||||
fi
|
||||
erb /app/nanobox/nginx-web.conf.erb > /app/nanobox/nginx-web.conf
|
||||
erb /app/nanobox/nginx-stream.conf.erb > /app/nanobox/nginx-stream.conf
|
||||
- touch /app/log/production.log
|
||||
before_live:
|
||||
web.web:
|
||||
- bundle exec rake db:migrate:setup
|
||||
- |-
|
||||
if [[ "${ES_ENABLED}" != "false" ]]
|
||||
then
|
||||
bundle exec rake chewy:deploy
|
||||
fi
|
||||
|
||||
|
||||
web.web:
|
||||
start:
|
||||
nginx: nginx -c /app/nanobox/nginx-web.conf
|
||||
rails: bundle exec puma -C /app/config/puma.rb
|
||||
|
||||
routes:
|
||||
- '/'
|
||||
|
||||
writable_dirs:
|
||||
- tmp
|
||||
|
||||
log_watch:
|
||||
rails: 'log/production.log'
|
||||
|
||||
network_dirs:
|
||||
data.storage:
|
||||
- public/system
|
||||
|
||||
|
||||
web.stream:
|
||||
start:
|
||||
nginx: nginx -c /app/nanobox/nginx-stream.conf
|
||||
node: yarn run start
|
||||
|
||||
routes:
|
||||
- '/api/v1/streaming*'
|
||||
# Somehow we're getting requests for scheme://domain//api/v1/streaming* - match those, too
|
||||
- '//api/v1/streaming*'
|
||||
|
||||
writable_dirs:
|
||||
- tmp
|
||||
|
||||
|
||||
worker.sidekiq:
|
||||
start:
|
||||
default: bundle exec sidekiq -c 5 -q default -L /app/log/sidekiq.log
|
||||
mailers: bundle exec sidekiq -c 5 -q mailers -L /app/log/sidekiq.log
|
||||
pull: bundle exec sidekiq -c 5 -q pull -L /app/log/sidekiq.log
|
||||
push: bundle exec sidekiq -c 5 -q push -L /app/log/sidekiq.log
|
||||
|
||||
writable_dirs:
|
||||
- tmp
|
||||
|
||||
log_watch:
|
||||
rails: 'log/production.log'
|
||||
sidekiq: 'log/sidekiq.log'
|
||||
|
||||
network_dirs:
|
||||
data.storage:
|
||||
- public/system
|
||||
|
||||
|
||||
worker.cron_only:
|
||||
start: sleep 365d
|
||||
|
||||
writable_dirs:
|
||||
- tmp
|
||||
|
||||
log_watch:
|
||||
rake: 'log/production.log'
|
||||
|
||||
network_dirs:
|
||||
data.storage:
|
||||
- public/system
|
||||
|
||||
cron:
|
||||
# 20:00 (8 pm), server time: send out the daily digest emails to everyone
|
||||
# who opted to receive one
|
||||
- id: send_digest_emails
|
||||
schedule: '00 20 * * *'
|
||||
command: 'bundle exec rake gabsocial:emails:digest'
|
||||
|
||||
# 00:10 (ten past midnight), server time: remove local copies of remote
|
||||
# users' media once they are older than a certain age (use NUM_DAYS evar to
|
||||
# change this from the default of 7 days)
|
||||
- id: clear_remote_media
|
||||
schedule: '10 00 * * *'
|
||||
command: 'bundle exec rake gabsocial:media:remove_remote'
|
||||
|
||||
# 00:20 (twenty past midnight), server time: remove subscriptions to remote
|
||||
# users that nobody follows locally (anymore)
|
||||
- id: clear_unfollowed_subs
|
||||
schedule: '20 00 * * *'
|
||||
command: 'bundle exec rake gabsocial:push:clear'
|
||||
|
||||
# 00:30 (half past midnight), server time: update local copies of remote
|
||||
# users' avatars to match whatever they currently have set on their profile
|
||||
- id: update_remote_avatars
|
||||
schedule: '30 00 * * *'
|
||||
command: 'bundle exec rake gabsocial:media:redownload_avatars'
|
||||
|
||||
############################################################################
|
||||
# This task is one you might want to enable, or might not. It keeps disk
|
||||
# usage low, but makes "shadow bans" (scenarios where the user is silenced,
|
||||
# but not intended to be made aware that the silencing has occurred) much
|
||||
# more difficult to put in place, as users would then notice their media is
|
||||
# vanishing on a regular basis. Enable it if you aren't worried about users
|
||||
# knowing they've been silenced (on the instance level), and want to save
|
||||
# disk space. Leave it disabled otherwise.
|
||||
############################################################################
|
||||
# # 00:00 (midnight), server time: remove media posted by silenced users
|
||||
# - id: clear_silenced_media
|
||||
# schedule: '00 00 * * *'
|
||||
# command: 'bundle exec rake gabsocial:media:remove_silenced'
|
||||
|
||||
############################################################################
|
||||
# The following two tasks can be uncommented to automatically open and close
|
||||
# registrations on a schedule. The format of 'schedule' is a standard cron
|
||||
# time expression: minute hour day month day-of-week; search for "cron
|
||||
# time expressions" for more info on how to set these up. The examples here
|
||||
# open registration only from 8 am to 4 pm, server time.
|
||||
############################################################################
|
||||
# # 08:00 (8 am), server time: open registrations so new users can join
|
||||
# - id: open_registrations
|
||||
# schedule: '00 08 * * *'
|
||||
# command: 'bundle exec rake gabsocial:settings:open_registrations'
|
||||
#
|
||||
# # 16:00 (4 pm), server time: close registrations so new users *can't* join
|
||||
# - id: close_registrations
|
||||
# schedule: '00 16 * * *'
|
||||
# command: 'bundle exec rake gabsocial:settings:close_registrations'
|
||||
|
||||
|
||||
data.db:
|
||||
image: nanobox/postgresql:9.6
|
||||
|
||||
cron:
|
||||
- id: backup
|
||||
schedule: '0 3 * * *'
|
||||
command: |
|
||||
PGPASSWORD=${DATA_DB_PASS} pg_dump -U ${DATA_DB_USER} -w -Fc -O gonano |
|
||||
gzip |
|
||||
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
|
||||
curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
|
||||
sed 's/,/\n/g' |
|
||||
grep ${HOSTNAME} |
|
||||
sort |
|
||||
head -n-${BACKUP_COUNT:-1} |
|
||||
sed 's/.*: \?"\(.*\)".*/\1/' |
|
||||
while read file
|
||||
do
|
||||
curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
|
||||
done
|
||||
|
||||
|
||||
data.elastic:
|
||||
image: nanobox/elasticsearch:5
|
||||
|
||||
cron:
|
||||
- id: backup
|
||||
schedule: '0 3 * * *'
|
||||
command: |
|
||||
id=$(cat /proc/sys/kernel/random/uuid)
|
||||
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}}"
|
||||
curl -X PUT -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}/backup?wait_for_completion=true&pretty"
|
||||
tar -cz -C "/var/tmp/${id}" . |
|
||||
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
|
||||
curl -X DELETE -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}"
|
||||
rm -rf "/var/tmp/${id}"
|
||||
curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
|
||||
sed 's/,/\n/g' |
|
||||
grep ${HOSTNAME} |
|
||||
sort |
|
||||
head -n-${BACKUP_COUNT:-1} |
|
||||
sed 's/.*: \?"\(.*\)".*/\1/' |
|
||||
while read file
|
||||
do
|
||||
curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
|
||||
done
|
||||
|
||||
|
||||
data.redis:
|
||||
image: nanobox/redis:4.0
|
||||
|
||||
cron:
|
||||
- id: backup
|
||||
schedule: '0 3 * * *'
|
||||
command: |
|
||||
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
|
||||
curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
|
||||
sed 's/,/\n/g' |
|
||||
grep ${HOSTNAME} |
|
||||
sort |
|
||||
head -n-${BACKUP_COUNT:-1} |
|
||||
sed 's/.*: \?"\(.*\)".*/\1/' |
|
||||
while read file
|
||||
do
|
||||
curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
|
||||
done
|
||||
|
||||
|
||||
data.storage:
|
||||
image: nanobox/unfs:0.9
|
||||
|
||||
cron:
|
||||
- id: backup
|
||||
schedule: '0 3 * * *'
|
||||
command: |
|
||||
tar cz -C /data/var/db/unfs/ . |
|
||||
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
|
||||
curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
|
||||
sed 's/,/\n/g' |
|
||||
grep ${HOSTNAME} |
|
||||
sort |
|
||||
head -n-${BACKUP_COUNT:-1} |
|
||||
sed 's/.*: \?"\(.*\)".*/\1/' |
|
||||
while read file
|
||||
do
|
||||
curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
|
||||
done
|
||||
Reference in New Issue
Block a user