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 role
36 from osmclient
.sol005
import pdud
37 from osmclient
.sol005
import k8scluster
38 from osmclient
.sol005
import vca
39 from osmclient
.sol005
import repo
40 from osmclient
.sol005
import osmrepo
41 from osmclient
.sol005
import subscription
42 from osmclient
.common
import package_tool
59 self
._password
= password
60 self
._project
= project
61 self
._project
_domain
_name
= kwargs
.get("project_domain_name")
62 self
._user
_domain
_name
= kwargs
.get("user_domain_name")
63 self
._logger
= logging
.getLogger("osmclient")
64 self
._auth
_endpoint
= "/admin/v1/tokens"
67 if len(host
.split(":")) > 1:
68 # backwards compatible, port provided as part of host
69 self
._host
= host
.split(":")[0]
70 self
._so
_port
= host
.split(":")[1]
73 self
._so
_port
= so_port
75 self
._http
_client
= http
.Http(
76 "https://{}:{}/osm".format(self
._host
, self
._so
_port
), **kwargs
78 self
._headers
["Accept"] = "application/json"
79 self
._headers
["Content-Type"] = "application/yaml"
81 "{}: {}".format(key
, val
) for (key
, val
) in list(self
._headers
.items())
83 self
._http
_client
.set_http_header(http_header
)
85 self
.vnfd
= vnfd
.Vnfd(self
._http
_client
, client
=self
)
86 self
.nsd
= nsd
.Nsd(self
._http
_client
, client
=self
)
87 self
.nst
= nst
.Nst(self
._http
_client
, client
=self
)
88 self
.package
= package
.Package(self
._http
_client
, client
=self
)
89 self
.ns
= ns
.Ns(self
._http
_client
, client
=self
)
90 self
.nsi
= nsi
.Nsi(self
._http
_client
, client
=self
)
91 self
.vim
= vim
.Vim(self
._http
_client
, client
=self
)
92 self
.wim
= wim
.Wim(self
._http
_client
, client
=self
)
93 self
.sdnc
= sdncontroller
.SdnController(self
._http
_client
, client
=self
)
94 self
.vnf
= vnf
.Vnf(self
._http
_client
, client
=self
)
95 self
.project
= projectmodule
.Project(self
._http
_client
, client
=self
)
96 self
.user
= usermodule
.User(self
._http
_client
, client
=self
)
97 self
.role
= role
.Role(self
._http
_client
, client
=self
)
98 self
.pdu
= pdud
.Pdu(self
._http
_client
, client
=self
)
99 self
.k8scluster
= k8scluster
.K8scluster(self
._http
_client
, client
=self
)
100 self
.vca
= vca
.VCA(self
._http
_client
, client
=self
)
101 self
.repo
= repo
.Repo(self
._http
_client
, client
=self
)
102 self
.osmrepo
= osmrepo
.OSMRepo(self
._http
_client
, client
=self
)
103 self
.package_tool
= package_tool
.PackageTool(client
=self
)
104 self
.subscription
= subscription
.Subscription(self
._http
_client
, client
=self
)
106 self.vca = vca.Vca(http_client, client=self, **kwargs)
107 self.utils = utils.Utils(http_client, **kwargs)
111 self
._logger
.debug("")
112 if self
._token
is None:
114 "username": self
._user
,
115 "password": self
._password
,
116 "project_id": self
._project
,
118 if self
._project
_domain
_name
:
119 postfields_dict
["project_domain_name"] = self
._project
_domain
_name
120 if self
._user
_domain
_name
:
121 postfields_dict
["user_domain_name"] = self
._user
_domain
_name
122 http_code
, resp
= self
._http
_client
.post_cmd(
123 endpoint
=self
._auth
_endpoint
,
124 postfields_dict
=postfields_dict
,
125 skip_query_admin
=True,
127 # if http_code not in (200, 201, 202, 204):
128 # message ='Authentication error: not possible to get auth token\nresp:\n{}'.format(resp)
129 # raise ClientException(message)
131 token
= json
.loads(resp
) if resp
else None
132 self
._token
= token
["id"]
134 if self
._token
is not None:
135 self
._headers
["Authorization"] = "Bearer {}".format(self
._token
)
137 "{}: {}".format(key
, val
)
138 for (key
, val
) in list(self
._headers
.items())
140 self
._http
_client
.set_http_header(http_header
)
142 def get_version(self
):
143 _
, resp
= self
._http
_client
.get2_cmd(endpoint
="/version", skip_query_admin
=True)
144 # print(http_code, resp)
146 resp
= json
.loads(resp
)
147 version
= resp
.get("version")
148 date
= resp
.get("date")
150 version
= resp
.split()[2]
151 date
= resp
.split()[4]
152 return "{} {}".format(version
, date
)
154 def set_default_params(self
, **kwargs
):
155 host
= kwargs
.pop("host", None)
158 port
= kwargs
.pop("port", None)
161 self
._http
_client
.set_query_admin(**kwargs
)