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 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 pdud
36 from osmclient
.common
.exceptions
import ClientException
51 self
._password
= password
52 self
._project
= project
53 self
._auth
_endpoint
= '/admin/v1/tokens'
56 if len(host
.split(':')) > 1:
57 # backwards compatible, port provided as part of host
58 self
._host
= host
.split(':')[0]
59 self
._so
_port
= host
.split(':')[1]
62 self
._so
_port
= so_port
64 self
._http
_client
= http
.Http(
65 'https://{}:{}/osm'.format(self
._host
,self
._so
_port
))
66 self
._headers
['Accept'] = 'application/json'
67 self
._headers
['Content-Type'] = 'application/yaml'
68 http_header
= ['{}: {}'.format(key
,val
)
69 for (key
,val
) in list(self
._headers
.items())]
70 self
._http
_client
.set_http_header(http_header
)
72 token
= self
.get_token()
74 raise ClientException(
75 'Authentication error: not possible to get auth token')
76 self
._headers
['Authorization'] = 'Bearer {}'.format(token
)
77 http_header
.append('Authorization: Bearer {}'.format(token
))
78 self
._http
_client
.set_http_header(http_header
)
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
.pdu
= pdud
.Pdu(self
._http
_client
, client
=self
)
94 self.vca = vca.Vca(http_client, client=self, **kwargs)
95 self.utils = utils.Utils(http_client, **kwargs)
99 postfields_dict
= {'username': self
._user
,
100 'password': self
._password
,
101 'project_id': self
._project
}
102 http_code
, resp
= self
._http
_client
.post_cmd(endpoint
=self
._auth
_endpoint
,
103 postfields_dict
=postfields_dict
)
104 if http_code
not in (200, 201, 202, 204):
105 raise ClientException(resp
)
106 token
= json
.loads(resp
) if resp
else None
107 if token
is not None: