#!/usr/bin/python # -*- coding: utf-8 -*- from __future__ import print_function, unicode_literals # We require Python 2.6 or later from string import Template import os import sys from io import open if sys.version_info[:3][0] == 2: import ConfigParser as ConfigParser import StringIO as StringIO if sys.version_info[:3][0] == 3: import configparser as ConfigParser import io as StringIO #Read configurations conf = StringIO.StringIO() conf.write("[configuration]\n") conf.write(open("harbor.cfg").read()) conf.seek(0, os.SEEK_SET) rcp = ConfigParser.RawConfigParser() rcp.readfp(conf) hostname = rcp.get("configuration", "hostname") ui_url = rcp.get("configuration", "ui_url_protocol") + "://" + hostname email_server = rcp.get("configuration", "email_server") email_server_port = rcp.get("configuration", "email_server_port") email_username = rcp.get("configuration", "email_username") email_password = rcp.get("configuration", "email_password") email_from = rcp.get("configuration", "email_from") harbor_admin_password = rcp.get("configuration", "harbor_admin_password") auth_mode = rcp.get("configuration", "auth_mode") ldap_url = rcp.get("configuration", "ldap_url") ldap_basedn = rcp.get("configuration", "ldap_basedn") db_password = rcp.get("configuration", "db_password") self_registration = rcp.get("configuration", "self_registration") customize_crt = rcp.get("configuration", "customize_crt") crt_countryname = rcp.get("configuration", "crt_countryname") crt_state = rcp.get("configuration", "crt_state") crt_name = rcp.get("configuration", "crt_name") crt_organizationname = rcp.get("configuration", "crt_organizationname") crt_organizationalunitname = rcp.get("configuration", "crt_organizationalunitname") ######## base_dir = os.path.dirname(__file__) config_dir = os.path.join(base_dir, "config") templates_dir = os.path.join(base_dir, "templates") ui_config_dir = os.path.join(config_dir,"ui") if not os.path.exists(ui_config_dir): os.makedirs(os.path.join(config_dir, "ui")) db_config_dir = os.path.join(config_dir, "db") if not os.path.exists(db_config_dir): os.makedirs(os.path.join(config_dir, "db")) def render(src, dest, **kw): t = Template(open(src, 'r').read()) with open(dest, 'w') as f: f.write(t.substitute(**kw)) print("Generated configuration file: %s" % dest) ui_conf_env = os.path.join(config_dir, "ui", "env") ui_conf = os.path.join(config_dir, "ui", "app.conf") registry_conf = os.path.join(config_dir, "registry", "config.yml") db_conf_env = os.path.join(config_dir, "db", "env") conf_files = [ ui_conf, ui_conf_env, registry_conf, db_conf_env ] def rmdir(cf): for f in cf: if os.path.exists(f): print("Clearing the configuration file: %s" % f) os.remove(f) rmdir(conf_files) render(os.path.join(templates_dir, "ui", "env"), ui_conf_env, hostname=hostname, db_password=db_password, ui_url=ui_url, auth_mode=auth_mode, harbor_admin_password=harbor_admin_password, ldap_url=ldap_url, ldap_basedn=ldap_basedn, self_registration=self_registration) render(os.path.join(templates_dir, "ui", "app.conf"), ui_conf, email_server=email_server, email_server_port=email_server_port, email_username=email_username, email_password=email_password, email_from=email_from, ui_url=ui_url) render(os.path.join(templates_dir, "registry", "config.yml"), registry_conf, ui_url=ui_url) render(os.path.join(templates_dir, "db", "env"), db_conf_env, db_password=db_password) if customize_crt == 'on': import subprocess is_fail = False FNULL = open(os.devnull, 'w') shell_status = subprocess.check_call(["which", "openssl"], stdout=FNULL, stderr=subprocess.STDOUT) if shell_status == 1: print("cannot find openssl installed in this computer.") is_fail = True else: private_key_pem = os.path.join(config_dir, "ui", "private_key.pem") root_crt = os.path.join(config_dir, "registry", "root.crt") crt_conf_files = [ private_key_pem, root_crt ] rmdir(crt_conf_files) shell_status = subprocess.call(["openssl", "genrsa", "-out", private_key_pem, "4096"],\ stdout=FNULL, stderr=subprocess.STDOUT) if shell_status == 0: print("private_key.pem has been generated in %s/ui" % config_dir) else: print("gennerate private_key.pem fail.") is_fail = True subj = "/C={0}/ST={1}/L={2}/O={3}/OU={4}"\ .format(crt_countryname, crt_state, crt_name, crt_organizationname, crt_organizationalunitname) shell_status = subprocess.call(["openssl", "req", "-new", "-x509", "-key",\ private_key_pem, "-out", root_crt, "-days", "3650", "-subj", subj], \ stdout=FNULL, stderr=subprocess.STDOUT) if shell_status == 0: print("root.crt has been generated in %s/registry" % config_dir) else: print("gennerate root.crt fail.") is_fail = True FNULL.close() try: if is_fail is True: print("some problems occur.") sys.exit(1) except Exception as e: pass print("The configuration files are ready, please use docker-compose to start the service.")