mirror of
https://github.com/goharbor/harbor.git
synced 2025-01-07 00:17:51 +01:00
158 lines
5.7 KiB
Python
158 lines
5.7 KiB
Python
|
import abc
|
||
|
import logging
|
||
|
import os
|
||
|
import sys
|
||
|
import time
|
||
|
import subprocess
|
||
|
from datetime import datetime
|
||
|
dir_path = os.path.dirname(os.path.realpath(__file__))
|
||
|
sys.path.append(dir_path + '../utils')
|
||
|
import govc_utils
|
||
|
import nlogging
|
||
|
logger = nlogging.create_logger(__name__)
|
||
|
|
||
|
class Deployer(object):
|
||
|
__metaclass__ = abc.ABCMeta
|
||
|
|
||
|
@abc.abstractmethod
|
||
|
def deploy(self):
|
||
|
return
|
||
|
|
||
|
@abc.abstractmethod
|
||
|
def destory(self):
|
||
|
return
|
||
|
|
||
|
class OVADeployer(Deployer):
|
||
|
|
||
|
def __init__(self, vc_host, vc_user, vc_password, ds, cluster, ova_path, ova_name, ova_root_password, count,
|
||
|
dry_run, auth_mode, ldap_url, ldap_searchdn, ldap_search_pwd, ldap_filter, ldap_basedn, ldap_uid,
|
||
|
ldap_scope, ldap_timeout):
|
||
|
self.vc_host = vc_host
|
||
|
self.vc_user = vc_user
|
||
|
self.vc_password = vc_password
|
||
|
self.ds = ds
|
||
|
self.cluster = cluster
|
||
|
self.ova_path = ova_path
|
||
|
self.ova_name = ova_name
|
||
|
self.ova_root_password = ova_root_password
|
||
|
self.dry_run = dry_run
|
||
|
self.count = count
|
||
|
self.auth_mode=auth_mode
|
||
|
|
||
|
if auth_mode == 'ldap_auth':
|
||
|
self.ldap_url = ldap_url
|
||
|
self.ldap_searchdn = ldap_searchdn
|
||
|
self.ldap_search_pwd = ldap_search_pwd
|
||
|
self.ldap_filter = ldap_filter
|
||
|
self.ldap_basedn = ldap_basedn
|
||
|
self.ldap_uid = ldap_uid
|
||
|
self.ldap_scope = ldap_scope
|
||
|
self.ldap_timeout = ldap_timeout
|
||
|
|
||
|
self.harbor_password='Harbor12345'
|
||
|
self.log_path=None
|
||
|
self.ip=None
|
||
|
self.netmask=None
|
||
|
self.gateway=None
|
||
|
self.dns=None
|
||
|
self.ovf_tool_path=None
|
||
|
self.DEFAULT_LOCAL_OVF_TOOL_PATH = '/home/harbor-ci/ovftool/ovftool'
|
||
|
self.ova_endpoints = []
|
||
|
self.ova_names = []
|
||
|
|
||
|
def __generate_ova_names(self):
|
||
|
for i in range(0, self.count):
|
||
|
ova_name_temp = ''
|
||
|
ova_name_temp = self.ova_name +"-"+ datetime.now().isoformat().replace(":", "-").replace(".", "-")
|
||
|
time.sleep(1)
|
||
|
self.ova_names.append(ova_name_temp)
|
||
|
|
||
|
def __set_ovf_tool(self):
|
||
|
if not self.ova_endpoints:
|
||
|
self.ovf_tool_path = self.DEFAULT_LOCAL_OVF_TOOL_PATH
|
||
|
if not os.path.isfile(self.ovf_tool_path):
|
||
|
logger.error("ovftool not found.")
|
||
|
return
|
||
|
|
||
|
def __compose_cmd(self, ova_name):
|
||
|
cmd = ''
|
||
|
|
||
|
if self.auth_mode == "db_auth":
|
||
|
cmd = (
|
||
|
'"%s" --X:"logFile"="./deploy_oms.log" --overwrite --powerOn --datastore=\'%s\' --noSSLVerify --acceptAllEulas --name=%s \
|
||
|
--X:injectOvfEnv --X:enableHiddenProperties --prop:root_pwd=\'%s\' --prop:permit_root_login=true --prop:auth_mode=\'%s\' \
|
||
|
--prop:harbor_admin_password=\'%s\' --prop:max_job_workers=5 %s \
|
||
|
vi://%s:\'%s\'@%s/Datacenter/host/%s'
|
||
|
% (self.ovf_tool_path, self.ds, ova_name,
|
||
|
self.ova_root_password, self.auth_mode,
|
||
|
self.harbor_password, self.ova_path,
|
||
|
self.vc_user, self.vc_password, self.vc_host, self.cluster
|
||
|
)
|
||
|
)
|
||
|
|
||
|
if self.auth_mode == "ldap_auth":
|
||
|
cmd = (
|
||
|
'"%s" --X:"logFile"="./deploy_oms.log" --overwrite --powerOn --datastore=\'%s\' --noSSLVerify --acceptAllEulas --name=%s \
|
||
|
--X:injectOvfEnv --X:enableHiddenProperties --prop:root_pwd=\'%s\' --prop:permit_root_login=true --prop:auth_mode=\'%s\' \
|
||
|
--prop:harbor_admin_password=\'%s\' --prop:max_job_workers=5 \
|
||
|
--prop:ldap_url=\'%s\' --prop:ldap_searchdn=\'%s\' --prop:ldap_search_pwd=\'%s\' \
|
||
|
--prop:ldap_filter=\'%s\' \
|
||
|
--prop:ldap_basedn=\'%s\' \
|
||
|
--prop:ldap_uid=\'%s\' --prop:ldap_scope=\'%s\' --prop:ldap_timeout=\'%s\' %s \
|
||
|
vi://%s:\'%s\'@%s/Datacenter/host/%s'
|
||
|
% (self.ovf_tool_path, self.ds, ova_name,
|
||
|
self.ova_root_password, self.auth_mode,
|
||
|
self.harbor_password,
|
||
|
self.ldap_url, self.ldap_searchdn,
|
||
|
self.ldap_search_pwd, self.ldap_filter,
|
||
|
self.ldap_basedn, self.ldap_uid,
|
||
|
self.ldap_scope, self.ldap_timeout,
|
||
|
self.ova_path,
|
||
|
self.vc_user, self.vc_password, self.vc_host, self.cluster
|
||
|
)
|
||
|
)
|
||
|
return cmd
|
||
|
|
||
|
def deploy(self):
|
||
|
self.__generate_ova_names()
|
||
|
self.__set_ovf_tool()
|
||
|
|
||
|
for i in range(0, self.count):
|
||
|
cmd = self.__compose_cmd(self.ova_names[i])
|
||
|
logger.info(cmd)
|
||
|
if self.dry_run == "true" :
|
||
|
logger.info("Dry run ...")
|
||
|
else:
|
||
|
try:
|
||
|
subprocess.check_output(cmd, shell=True)
|
||
|
except Exception, e:
|
||
|
logger.info(e)
|
||
|
time.sleep(5)
|
||
|
# try onre more time if any failure.
|
||
|
subprocess.check_output(cmd, shell=True)
|
||
|
logger.info("Successfully deployed harbor OVA.")
|
||
|
|
||
|
ova_endpoint = ''
|
||
|
ova_endpoint = govc_utils.getvmip(self.vc_host, self.vc_user, self.vc_password, self.ova_names[i])
|
||
|
if ova_endpoint is not '':
|
||
|
self.ova_endpoints.append(ova_endpoint)
|
||
|
|
||
|
return self.ova_endpoints, self.ova_names
|
||
|
|
||
|
def destory(self):
|
||
|
for item in self.ova_names:
|
||
|
govc_utils.destoryvm(self.vc_host, self.vc_user, self.vc_password, item)
|
||
|
|
||
|
|
||
|
class OfflineDeployer(Deployer):
|
||
|
|
||
|
def __init__(self):
|
||
|
self.vm_host = ''
|
||
|
self.vm_user = ''
|
||
|
self.vm_password = ''
|
||
|
|
||
|
def deploy(self):
|
||
|
pass
|
||
|
|
||
|
def destory(self):
|
||
|
pass
|