6e15e5bbea602e2e49a3a1608bd270883ede1259
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
.common
import utils
22 from osmclient
.common
.exceptions
import ClientException
23 from osmclient
.common
.exceptions
import NotFound
29 def __init__(self
, http
=None, client
=None):
32 self
._apiName
= '/admin'
33 self
._apiVersion
= '/v1'
34 self
._apiResource
= '/vim_accounts'
35 self
._apiBase
= '{}{}{}'.format(self
._apiName
,
36 self
._apiVersion
, self
._apiResource
)
37 def create(self
, name
, vim_access
, sdn_controller
=None, sdn_port_mapping
=None):
38 if 'vim-type' not in vim_access
:
39 #'openstack' not in vim_access['vim-type']):
40 raise Exception("vim type not provided")
43 vim_account
['name'] = name
44 vim_account
= self
.update_vim_account_dict(vim_account
, vim_access
)
47 if 'config' in vim_access
and vim_access
['config'] is not None:
48 vim_config
= yaml
.safe_load(vim_access
['config'])
50 sdnc
= self
._client
.sdnc
.get(sdn_controller
)
51 vim_config
['sdn-controller'] = sdnc
['_id']
53 with
open(sdn_port_mapping
, 'r') as f
:
54 vim_config
['sdn-port-mapping'] = yaml
.safe_load(f
.read())
56 vim_account
['config'] = vim_config
57 #vim_account['config'] = json.dumps(vim_config)
59 http_code
, resp
= self
._http
.post_cmd(endpoint
=self
._apiBase
,
60 postfields_dict
=vim_account
)
61 #print 'HTTP CODE: {}'.format(http_code)
62 #print 'RESP: {}'.format(resp)
63 if http_code
in (200, 201, 202, 204):
65 resp
= json
.loads(resp
)
66 if not resp
or 'id' not in resp
:
67 raise ClientException('unexpected response from server - {}'.format(
74 msg
= json
.loads(resp
)
77 raise ClientException("failed to create vim {} - {}".format(name
, msg
))
79 def update(self
, vim_name
, vim_account
, sdn_controller
, sdn_port_mapping
):
80 vim
= self
.get(vim_name
)
83 if 'config' in vim_account
:
84 if config
=="" and (sdncontroller
or sdn_port_mapping
):
85 raise ClientException("clearing config is incompatible with updating SDN info")
89 vim_config
= yaml
.safe_load(vim_account
['config'])
91 sdnc
= self
._client
.sdnc
.get(sdn_controller
)
92 vim_config
['sdn-controller'] = sdnc
['_id']
94 with
open(sdn_port_mapping
, 'r') as f
:
95 vim_config
['sdn-port-mapping'] = yaml
.safe_load(f
.read())
96 vim_account
['config'] = vim_config
97 #vim_account['config'] = json.dumps(vim_config)
98 http_code
, resp
= self
._http
.put_cmd(endpoint
='{}/{}'.format(self
._apiBase
,vim
['_id']),
99 postfields_dict
=vim_account
)
100 #print 'HTTP CODE: {}'.format(http_code)
101 #print 'RESP: {}'.format(resp)
102 if http_code
in (200, 201, 202, 204):
104 resp
= json
.loads(resp
)
105 if not resp
or 'id' not in resp
:
106 raise ClientException('unexpected response from server - {}'.format(
113 msg
= json
.loads(resp
)
116 raise ClientException("failed to update vim {} - {}".format(vim_name
, msg
))
118 def update_vim_account_dict(self
, vim_account
, vim_access
):
119 vim_account
['vim_type'] = vim_access
['vim-type']
120 vim_account
['description'] = vim_access
['description']
121 vim_account
['vim_url'] = vim_access
['vim-url']
122 vim_account
['vim_user'] = vim_access
['vim-username']
123 vim_account
['vim_password'] = vim_access
['vim-password']
124 vim_account
['vim_tenant_name'] = vim_access
['vim-tenant-name']
127 def get_id(self
, name
):
128 """Returns a VIM id from a VIM name
130 for vim
in self
.list():
131 if name
== vim
['name']:
133 raise NotFound("vim {} not found".format(name
))
135 def delete(self
, vim_name
, force
=False):
137 if not utils
.validate_uuid4(vim_name
):
138 vim_id
= self
.get_id(vim_name
)
141 querystring
= '?FORCE=True'
142 http_code
, resp
= self
._http
.delete_cmd('{}/{}{}'.format(self
._apiBase
,
143 vim_id
, querystring
))
144 #print 'HTTP CODE: {}'.format(http_code)
145 #print 'RESP: {}'.format(resp)
147 print 'Deletion in progress'
148 elif http_code
== 204:
154 msg
= json
.loads(resp
)
157 raise ClientException("failed to delete vim {} - {}".format(vim_name
, msg
))
159 def list(self
, filter=None):
160 """Returns a list of VIM accounts
164 filter_string
= '?{}'.format(filter)
165 resp
= self
._http
.get_cmd('{}{}'.format(self
._apiBase
,filter_string
))
169 for datacenter
in resp
:
170 vim_accounts
.append({"name": datacenter
['name'], "uuid": datacenter
['_id']
171 if '_id' in datacenter
else None})
175 """Returns a VIM account based on name or id
178 if not utils
.validate_uuid4(name
):
179 vim_id
= self
.get_id(name
)
180 resp
= self
._http
.get_cmd('{}/{}'.format(self
._apiBase
,vim_id
))
181 if not resp
or '_id' not in resp
:
182 raise ClientException('failed to get vim info: '.format(
186 raise NotFound("vim {} not found".format(name
))