2016-11-11 04:54:47 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#coding: UTF-8
|
|
|
|
|
|
|
|
"""
|
|
|
|
This script calls the appropriate seafile init scripts (e.g.
|
|
|
|
setup-seafile.sh or setup-seafile-mysql.sh. It's supposed to run inside the
|
|
|
|
container.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import os
|
|
|
|
from os.path import abspath, basename, exists, dirname, join, isdir
|
|
|
|
import shutil
|
|
|
|
import sys
|
2016-11-14 06:47:40 +00:00
|
|
|
import uuid
|
2016-11-11 04:54:47 +00:00
|
|
|
|
2016-11-15 04:11:58 +00:00
|
|
|
from utils import call, get_conf, get_install_dir, get_script, render_nginx_conf
|
2016-11-11 04:54:47 +00:00
|
|
|
|
|
|
|
installdir = get_install_dir()
|
|
|
|
topdir = dirname(installdir)
|
2016-11-12 06:03:52 +00:00
|
|
|
shared_seafiledir = '/shared/seafile'
|
2016-11-15 04:11:58 +00:00
|
|
|
ssl_dir = '/shared/ssl'
|
|
|
|
|
|
|
|
def init_letsencryt():
|
|
|
|
if not exists(ssl_dir):
|
|
|
|
os.mkdir(ssl_dir)
|
|
|
|
|
|
|
|
domain = get_conf('server.hostname')
|
|
|
|
context = {
|
|
|
|
'https': False,
|
|
|
|
'domain': domain,
|
|
|
|
}
|
|
|
|
render_nginx_conf('/templates/seafile.nginx.conf',
|
|
|
|
'/etc/nginx/sites-enabled/seafile.nginx.conf', context)
|
|
|
|
call('nginx -s reload')
|
|
|
|
call('/scripts/ssl.sh {0} {1}'.format(ssl_dir, domain))
|
2016-11-11 04:54:47 +00:00
|
|
|
|
|
|
|
def main():
|
2016-11-12 06:03:52 +00:00
|
|
|
if not exists(shared_seafiledir):
|
|
|
|
os.mkdir(shared_seafiledir)
|
2016-11-15 04:11:58 +00:00
|
|
|
|
|
|
|
if get_conf('server.https', '').lower() == 'true':
|
|
|
|
init_letsencryt()
|
|
|
|
|
2016-11-11 04:54:47 +00:00
|
|
|
env = {
|
|
|
|
'SERVER_NAME': 'seafile',
|
2016-11-14 06:47:40 +00:00
|
|
|
'SERVER_IP': get_conf('server.hostname'),
|
2016-11-14 12:21:05 +00:00
|
|
|
'MYSQL_USER': 'seafile',
|
|
|
|
'MYSQL_USER_PASSWD': str(uuid.uuid4()),
|
|
|
|
'MYSQL_USER_HOST': '127.0.0.1',
|
|
|
|
# Default MariaDB root user has empty password and can only connect from localhost.
|
|
|
|
'MYSQL_ROOT_PASSWD': '',
|
2016-11-11 04:54:47 +00:00
|
|
|
}
|
2016-11-14 06:47:40 +00:00
|
|
|
|
2016-11-14 12:21:05 +00:00
|
|
|
# Change the script to allow mysql root password to be empty
|
|
|
|
call('''sed -i -e 's/if not mysql_root_passwd/if not mysql_root_passwd and "MYSQL_ROOT_PASSWD" not in os.environ/g' {}'''
|
2016-11-15 04:11:58 +00:00
|
|
|
.format(get_script('setup-seafile-mysql.py')))
|
2016-11-14 06:47:40 +00:00
|
|
|
|
2016-11-14 12:21:05 +00:00
|
|
|
setup_script = get_script('setup-seafile-mysql.sh')
|
2016-11-14 06:47:40 +00:00
|
|
|
call('{} auto -n seafile'.format(setup_script), env=env)
|
|
|
|
|
|
|
|
files_to_copy = ['conf', 'ccnet', 'seafile-data', 'seahub-data',]
|
|
|
|
for fn in files_to_copy:
|
2016-11-11 04:54:47 +00:00
|
|
|
src = join(topdir, fn)
|
2016-11-12 06:03:52 +00:00
|
|
|
dst = join(shared_seafiledir, fn)
|
|
|
|
if not exists(dst) and exists(src):
|
|
|
|
shutil.move(src, shared_seafiledir)
|
2016-11-11 04:54:47 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|