2018-08-16 12:36:27 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import time
|
|
|
|
import swagger_client
|
|
|
|
|
|
|
|
class Server:
|
|
|
|
def __init__(self, endpoint, verify_ssl):
|
|
|
|
self.endpoint = endpoint
|
|
|
|
self.verify_ssl = verify_ssl
|
|
|
|
|
|
|
|
class Credential:
|
|
|
|
def __init__(self, type, username, password):
|
|
|
|
self.type = type
|
|
|
|
self.username = username
|
|
|
|
self.password = password
|
|
|
|
|
|
|
|
def _create_client(server, credential, debug):
|
|
|
|
cfg = swagger_client.Configuration()
|
|
|
|
cfg.host = server.endpoint
|
|
|
|
cfg.verify_ssl = server.verify_ssl
|
|
|
|
# support basic auth only for now
|
|
|
|
cfg.username = credential.username
|
|
|
|
cfg.password = credential.password
|
|
|
|
cfg.debug = debug
|
|
|
|
return swagger_client.ProductsApi(swagger_client.ApiClient(cfg))
|
|
|
|
|
2018-10-31 06:13:31 +01:00
|
|
|
def _assert_status_code(expect_code, return_code):
|
|
|
|
if str(return_code) != str(expect_code):
|
|
|
|
raise Exception(r"HTTPS status code is not {} but {}".format(expect_code, return_code))
|
|
|
|
|
2018-08-16 12:36:27 +02:00
|
|
|
def _random_name(prefix):
|
2018-09-19 11:49:43 +02:00
|
|
|
return "%s-%d" % (prefix, int(round(time.time() * 1000)))
|
2018-08-16 12:36:27 +02:00
|
|
|
|
|
|
|
def _get_id_from_header(header):
|
2018-11-01 11:26:04 +01:00
|
|
|
try:
|
|
|
|
location = header["Location"]
|
|
|
|
return location.split("/")[-1]
|
|
|
|
except Exception:
|
|
|
|
return None
|
2018-08-16 12:36:27 +02:00
|
|
|
|
2018-10-31 06:13:31 +01:00
|
|
|
def _get_string_from_unicode(udata):
|
|
|
|
result=''
|
|
|
|
for u in udata:
|
|
|
|
tmp = u.encode('utf8')
|
|
|
|
result = result + tmp.strip('\n\r\t')
|
|
|
|
return result
|
|
|
|
|
2018-08-16 12:36:27 +02:00
|
|
|
class Base:
|
|
|
|
def __init__(self,
|
|
|
|
server = Server(endpoint="http://localhost:8080/api", verify_ssl=False),
|
|
|
|
credential = Credential(type="basic_auth", username="admin", password="Harbor12345"),
|
|
|
|
debug = True):
|
|
|
|
if not isinstance(server.verify_ssl, bool):
|
|
|
|
server.verify_ssl = server.verify_ssl == "True"
|
|
|
|
self.server = server
|
|
|
|
self.credential = credential
|
|
|
|
self.debug = debug
|
|
|
|
self.client = _create_client(server, credential, debug)
|
|
|
|
|
|
|
|
def _get_client(self, **kwargs):
|
|
|
|
if len(kwargs) == 0:
|
|
|
|
return self.client
|
|
|
|
server = self.server
|
|
|
|
if "endpoint" in kwargs:
|
|
|
|
server.endpoint = kwargs.get("endpoint")
|
|
|
|
if "verify_ssl" in kwargs:
|
|
|
|
if not isinstance(kwargs.get("verify_ssl"), bool):
|
|
|
|
server.verify_ssl = kwargs.get("verify_ssl") == "True"
|
|
|
|
else:
|
|
|
|
server.verify_ssl = kwargs.get("verify_ssl")
|
|
|
|
credential = self.credential
|
|
|
|
if "type" in kwargs:
|
|
|
|
credential.type = kwargs.get("type")
|
|
|
|
if "username" in kwargs:
|
|
|
|
credential.username = kwargs.get("username")
|
|
|
|
if "password" in kwargs:
|
|
|
|
credential.password = kwargs.get("password")
|
2018-11-01 11:26:04 +01:00
|
|
|
return _create_client(server, credential, self.debug)
|