5e28797b99bfc21b5f288e1598eec49996eaffc2
[osm/osmclient.git] / osmclient / sol005 / client.py
1 # Copyright 2018 Telefonica
2 #
3 # All Rights Reserved.
4 #
5 # Licensed under the Apache License, Version 2.0 (the "License"); you may
6 # not use this file except in compliance with the License. You may obtain
7 # a copy of the License at
8 #
9 # http://www.apache.org/licenses/LICENSE-2.0
10 #
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13 # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14 # License for the specific language governing permissions and limitations
15 # under the License.
16
17 """
18 OSM SOL005 client API
19 """
20
21 #from osmclient.v1 import vca
22 from osmclient.sol005 import vnfd
23 from osmclient.sol005 import nsd
24 from osmclient.sol005 import nst
25 from osmclient.sol005 import nsi
26 from osmclient.sol005 import ns
27 from osmclient.sol005 import vnf
28 from osmclient.sol005 import vim
29 from osmclient.sol005 import wim
30 from osmclient.sol005 import package
31 from osmclient.sol005 import http
32 from osmclient.sol005 import sdncontroller
33 from osmclient.sol005 import project as projectmodule
34 from osmclient.sol005 import user as usermodule
35 from osmclient.sol005 import role
36 from osmclient.sol005 import pdud
37 from osmclient.sol005 import k8scluster
38 from osmclient.sol005 import repo
39 from osmclient.common import package_tool
40 import json
41 import logging
42
43
44 class Client(object):
45
46 def __init__(
47 self,
48 host=None,
49 so_port=9999,
50 user='admin',
51 password='admin',
52 project='admin',
53 **kwargs):
54
55 self._user = user
56 self._password = password
57 self._project = project
58 self._project_domain_name = kwargs.get("project_domain_name")
59 self._user_domain_name = kwargs.get("user_domain_name")
60 self._logger = logging.getLogger('osmclient')
61 self._auth_endpoint = '/admin/v1/tokens'
62 self._headers = {}
63 self._token = None
64 if len(host.split(':')) > 1:
65 # backwards compatible, port provided as part of host
66 self._host = host.split(':')[0]
67 self._so_port = host.split(':')[1]
68 else:
69 self._host = host
70 self._so_port = so_port
71
72 self._http_client = http.Http(
73 'https://{}:{}/osm'.format(self._host,self._so_port), **kwargs)
74 self._headers['Accept'] = 'application/json'
75 self._headers['Content-Type'] = 'application/yaml'
76 http_header = ['{}: {}'.format(key, val)
77 for (key, val) in list(self._headers.items())]
78 self._http_client.set_http_header(http_header)
79
80 self.vnfd = vnfd.Vnfd(self._http_client, client=self)
81 self.nsd = nsd.Nsd(self._http_client, client=self)
82 self.nst = nst.Nst(self._http_client, client=self)
83 self.package = package.Package(self._http_client, client=self)
84 self.ns = ns.Ns(self._http_client, client=self)
85 self.nsi = nsi.Nsi(self._http_client, client=self)
86 self.vim = vim.Vim(self._http_client, client=self)
87 self.wim = wim.Wim(self._http_client, client=self)
88 self.sdnc = sdncontroller.SdnController(self._http_client, client=self)
89 self.vnf = vnf.Vnf(self._http_client, client=self)
90 self.project = projectmodule.Project(self._http_client, client=self)
91 self.user = usermodule.User(self._http_client, client=self)
92 self.role = role.Role(self._http_client, client=self)
93 self.pdu = pdud.Pdu(self._http_client, client=self)
94 self.k8scluster = k8scluster.K8scluster(self._http_client, client=self)
95 self.repo = repo.Repo(self._http_client, client=self)
96 self.package_tool = package_tool.PackageTool(client=self)
97 '''
98 self.vca = vca.Vca(http_client, client=self, **kwargs)
99 self.utils = utils.Utils(http_client, **kwargs)
100 '''
101
102 def get_token(self):
103 self._logger.debug("")
104 if self._token is None:
105 postfields_dict = {'username': self._user,
106 'password': self._password,
107 'project_id': self._project}
108 if self._project_domain_name:
109 postfields_dict["project_domain_name"] = self._project_domain_name
110 if self._user_domain_name:
111 postfields_dict["user_domain_name"] = self._user_domain_name
112 http_code, resp = self._http_client.post_cmd(endpoint=self._auth_endpoint,
113 postfields_dict=postfields_dict,
114 skip_query_admin=True)
115 # if http_code not in (200, 201, 202, 204):
116 # message ='Authentication error: not possible to get auth token\nresp:\n{}'.format(resp)
117 # raise ClientException(message)
118
119 token = json.loads(resp) if resp else None
120 self._token = token['id']
121
122 if self._token is not None:
123 self._headers['Authorization'] = 'Bearer {}'.format(self._token)
124 http_header = ['{}: {}'.format(key, val)
125 for (key, val) in list(self._headers.items())]
126 self._http_client.set_http_header(http_header)
127
128 def get_version(self):
129 _, resp = self._http_client.get2_cmd(endpoint="/version", skip_query_admin=True)
130 #print(http_code, resp)
131 try:
132 resp = json.loads(resp)
133 version = resp.get("version")
134 date = resp.get("date")
135 except ValueError:
136 version = resp.split()[2]
137 date = resp.split()[4]
138 return "{} {}".format(version, date)
139
140 def set_default_params(self, **kwargs):
141 host = kwargs.pop('host', None)
142 if host != None:
143 self._host=host
144 port = kwargs.pop('port', None)
145 if port != None:
146 self._so_port=port
147 self._http_client.set_query_admin(**kwargs)