mirror of
https://github.com/ggogel/seafile-containerized.git
synced 2024-11-16 09:01:38 +00:00
Fixed letsencrypt init.
This commit is contained in:
parent
acad1bd947
commit
542a57ced4
|
@ -15,7 +15,10 @@ import sys
|
||||||
import uuid
|
import uuid
|
||||||
import time
|
import time
|
||||||
|
|
||||||
from utils import call, get_conf, get_install_dir, get_script, render_template, get_seafile_version
|
from utils import (
|
||||||
|
call, get_conf, get_install_dir, show_progress
|
||||||
|
get_script, render_template, get_seafile_version, eprint
|
||||||
|
)
|
||||||
|
|
||||||
seafile_version = get_seafile_version()
|
seafile_version = get_seafile_version()
|
||||||
installdir = get_install_dir()
|
installdir = get_install_dir()
|
||||||
|
@ -25,6 +28,7 @@ ssl_dir = '/shared/ssl'
|
||||||
generated_dir = '/bootstrap/generated'
|
generated_dir = '/bootstrap/generated'
|
||||||
|
|
||||||
def init_letsencrypt():
|
def init_letsencrypt():
|
||||||
|
show_progress('Preparing for letsencrypt ...')
|
||||||
if not exists(ssl_dir):
|
if not exists(ssl_dir):
|
||||||
os.mkdir(ssl_dir)
|
os.mkdir(ssl_dir)
|
||||||
|
|
||||||
|
@ -39,6 +43,10 @@ def init_letsencrypt():
|
||||||
'/etc/nginx/sites-enabled/seafile.nginx.conf', context)
|
'/etc/nginx/sites-enabled/seafile.nginx.conf', context)
|
||||||
call('nginx -s reload')
|
call('nginx -s reload')
|
||||||
call('/scripts/ssl.sh {0} {1}'.format(ssl_dir, domain))
|
call('/scripts/ssl.sh {0} {1}'.format(ssl_dir, domain))
|
||||||
|
# if call('/scripts/ssl.sh {0} {1}'.format(ssl_dir, domain), check_call=False) != 0:
|
||||||
|
# eprint('Now waiting 1000s for postmortem')
|
||||||
|
# time.sleep(1000)
|
||||||
|
# sys.exit(1)
|
||||||
|
|
||||||
# Now create the final nginx configuratin
|
# Now create the final nginx configuratin
|
||||||
context = {
|
context = {
|
||||||
|
@ -65,6 +73,7 @@ def is_https():
|
||||||
return get_conf('server.https', '').lower() == 'true'
|
return get_conf('server.https', '').lower() == 'true'
|
||||||
|
|
||||||
def generate_local_dockerfile():
|
def generate_local_dockerfile():
|
||||||
|
show_progress('Generating local Dockerfile ...')
|
||||||
context = {
|
context = {
|
||||||
'seafile_version': seafile_version,
|
'seafile_version': seafile_version,
|
||||||
'https': is_https(),
|
'https': is_https(),
|
||||||
|
@ -89,28 +98,12 @@ def do_parse_ports():
|
||||||
sys.stdout.write(' '.join(['-p {}'.format(part.strip()) for part in conf.split(',')]))
|
sys.stdout.write(' '.join(['-p {}'.format(part.strip()) for part in conf.split(',')]))
|
||||||
sys.stdout.flush()
|
sys.stdout.flush()
|
||||||
|
|
||||||
def main():
|
|
||||||
args = parse_args()
|
|
||||||
if args.parse_ports:
|
|
||||||
do_parse_ports()
|
|
||||||
return
|
|
||||||
if not exists(shared_seafiledir):
|
|
||||||
os.mkdir(shared_seafiledir)
|
|
||||||
if not exists(generated_dir):
|
|
||||||
os.mkdir(generated_dir)
|
|
||||||
|
|
||||||
generate_local_dockerfile()
|
|
||||||
|
|
||||||
if is_https():
|
|
||||||
init_letsencrypt()
|
|
||||||
|
|
||||||
init_seafile_server()
|
|
||||||
|
|
||||||
def init_seafile_server():
|
def init_seafile_server():
|
||||||
if exists(join(shared_seafiledir, 'seafile-data')):
|
if exists(join(shared_seafiledir, 'seafile-data')):
|
||||||
print 'Skipping running setup-seafile-mysql.py because there is existing seafile-data folder.'
|
show_progress('Skipping running setup-seafile-mysql.py because there is existing seafile-data folder.')
|
||||||
return
|
return
|
||||||
|
|
||||||
|
show_progress('Now running setup-seafile-mysql.py in auto mode.')
|
||||||
env = {
|
env = {
|
||||||
'SERVER_NAME': 'seafile',
|
'SERVER_NAME': 'seafile',
|
||||||
'SERVER_IP': get_conf('server.hostname'),
|
'SERVER_IP': get_conf('server.hostname'),
|
||||||
|
@ -135,6 +128,26 @@ def init_seafile_server():
|
||||||
if not exists(dst) and exists(src):
|
if not exists(dst) and exists(src):
|
||||||
shutil.move(src, shared_seafiledir)
|
shutil.move(src, shared_seafiledir)
|
||||||
|
|
||||||
|
def main():
|
||||||
|
args = parse_args()
|
||||||
|
if args.parse_ports:
|
||||||
|
do_parse_ports()
|
||||||
|
return
|
||||||
|
if not exists(shared_seafiledir):
|
||||||
|
os.mkdir(shared_seafiledir)
|
||||||
|
if not exists(generated_dir):
|
||||||
|
os.mkdir(generated_dir)
|
||||||
|
|
||||||
|
generate_local_dockerfile()
|
||||||
|
|
||||||
|
if is_https():
|
||||||
|
init_letsencrypt()
|
||||||
|
|
||||||
|
init_seafile_server()
|
||||||
|
|
||||||
|
show_progress('bootstrap done.')
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
# TODO: validate the content of bootstrap.conf is valid
|
# TODO: validate the content of bootstrap.conf is valid
|
||||||
main()
|
main()
|
||||||
|
|
|
@ -236,3 +236,8 @@ def render_template(template, target, context):
|
||||||
content = env.get_template(basename(template)).render(**context)
|
content = env.get_template(basename(template)).render(**context)
|
||||||
with open(target, 'w') as fp:
|
with open(target, 'w') as fp:
|
||||||
fp.write(content)
|
fp.write(content)
|
||||||
|
|
||||||
|
def show_progress(msg):
|
||||||
|
eprint('---------------------')
|
||||||
|
eprint(msg)
|
||||||
|
eprint('---------------------')
|
||||||
|
|
Loading…
Reference in a new issue