support of PDUs
[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 package
30 from osmclient.sol005 import http
31 from osmclient.sol005 import sdncontroller
32 from osmclient.sol005 import project as projectmodule
33 from osmclient.sol005 import user as usermodule
34 from osmclient.sol005 import pdud
35 from osmclient.common.exceptions import ClientException
36 import json
37
38 class Client(object):
39
40 def __init__(
41 self,
42 host=None,
43 so_port=9999,
44 user='admin',
45 password='admin',
46 project='admin',
47 **kwargs):
48
49 self._user = user
50 self._password = password
51 self._project = project
52 self._auth_endpoint = '/admin/v1/tokens'
53 self._headers = {}
54
55 if len(host.split(':')) > 1:
56 # backwards compatible, port provided as part of host
57 self._host = host.split(':')[0]
58 self._so_port = host.split(':')[1]
59 else:
60 self._host = host
61 self._so_port = so_port
62
63 self._http_client = http.Http(
64 'https://{}:{}/osm'.format(self._host,self._so_port))
65 self._headers['Accept'] = 'application/json'
66 self._headers['Content-Type'] = 'application/yaml'
67 http_header = ['{}: {}'.format(key,val)
68 for (key,val) in list(self._headers.items())]
69 self._http_client.set_http_header(http_header)
70
71 token = self.get_token()
72 if not token:
73 raise ClientException(
74 'Authentication error: not possible to get auth token')
75 self._headers['Authorization'] = 'Bearer {}'.format(token)
76 http_header.append('Authorization: Bearer {}'.format(token))
77 self._http_client.set_http_header(http_header)
78
79 self.vnfd = vnfd.Vnfd(self._http_client, client=self)
80 self.nsd = nsd.Nsd(self._http_client, client=self)
81 self.nst = nst.Nst(self._http_client, client=self)
82 self.package = package.Package(self._http_client, client=self)
83 self.ns = ns.Ns(self._http_client, client=self)
84 self.nsi = nsi.Nsi(self._http_client, client=self)
85 self.vim = vim.Vim(self._http_client, client=self)
86 self.sdnc = sdncontroller.SdnController(self._http_client, client=self)
87 self.vnf = vnf.Vnf(self._http_client, client=self)
88 self.project = projectmodule.Project(self._http_client, client=self)
89 self.user = usermodule.User(self._http_client, client=self)
90 self.pdu = pdud.Pdu(self._http_client, client=self)
91 '''
92 self.vca = vca.Vca(http_client, client=self, **kwargs)
93 self.utils = utils.Utils(http_client, **kwargs)
94 '''
95
96 def get_token(self):
97 postfields_dict = {'username': self._user,
98 'password': self._password,
99 'project_id': self._project}
100 http_code, resp = self._http_client.post_cmd(endpoint=self._auth_endpoint,
101 postfields_dict=postfields_dict)
102 if http_code not in (200, 201, 202, 204):
103 raise ClientException(resp)
104 token = json.loads(resp) if resp else None
105 if token is not None:
106 return token['_id']
107 return None
108