docker-seafile-client/start.py

54 lines
1.6 KiB
Python
Raw Normal View History

2019-04-13 18:45:06 +00:00
#!/usr/bin/env python3
import argparse
2022-01-30 15:27:37 +00:00
import logging
2019-04-13 18:45:06 +00:00
import os
import os.path
import sys
2022-01-30 15:27:37 +00:00
from dsc import SeafileClient, start_seaf_daemon
from dsc.misc import setup_uid, create_dir
_lg = logging.getLogger('dsc')
2019-04-13 18:45:06 +00:00
def main():
2022-01-30 15:27:37 +00:00
logging.basicConfig(format="%(asctime)s %(message)s", level=logging.INFO)
2019-04-13 18:45:06 +00:00
parser = argparse.ArgumentParser()
2021-02-28 20:24:37 +00:00
parser.add_argument("--uid", default=os.getenv("SEAFILE_UID", default=1000), type=int)
parser.add_argument("--gid", default=os.getenv("SEAFILE_GID", default=100), type=int)
parser.add_argument("--data-dir", default=os.getenv("DATA_DIR", default="/data"))
2019-04-13 18:45:06 +00:00
parser.add_argument("--host", default=os.getenv("SERVER_HOST"))
parser.add_argument("--username", default=os.getenv("USERNAME"))
parser.add_argument("--password", default=os.getenv("PASSWORD"))
parser.add_argument("--libs", default=os.getenv("LIBRARY_ID"))
args = parser.parse_args()
setup_uid(args.uid, args.gid)
create_dir(args.data_dir)
2022-01-30 15:27:37 +00:00
start_seaf_daemon()
libs_to_sync = set()
2020-08-25 18:16:05 +00:00
client = SeafileClient(args.host, args.username, args.password)
2022-01-30 15:27:37 +00:00
for arg_lib in args.libs.split(sep=":"):
lib_id = client.get_library_id(arg_lib)
if lib_id:
libs_to_sync.add(lib_id)
else:
_lg.warning("Library %s is not found on server %s", arg_lib, args.host)
# don't start to sync libraries already in sync
libs_to_sync -= client.get_local_libraries()
for lib_id in libs_to_sync:
2019-04-13 18:45:06 +00:00
client.sync_lib(lib_id, args.data_dir)
2019-08-13 19:38:00 +00:00
client.watch_status()
2019-04-13 18:45:06 +00:00
return 0
if __name__ == "__main__":
sys.exit(main())