1 # Copyright 2018 Telefonica
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
9 # http://www.apache.org/licenses/LICENSE-2.0
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
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
50 self
._password
= password
51 self
._project
= project
52 self
._auth
_endpoint
= '/admin/v1/tokens'
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]
61 self
._so
_port
= so_port
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
)
71 token
= self
.get_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
)
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
)
92 self.vca = vca.Vca(http_client, client=self, **kwargs)
93 self.utils = utils.Utils(http_client, **kwargs)
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: