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())
|