2 # Copyright 2018 CNIT - Consorzio Nazionale Interuniversitario per le Telecomunicazioni
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
8 # http://www.apache.org/licenses/LICENSE-2.0
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
17 from django
.shortcuts
import render
, redirect
18 from django
.contrib
.auth
.decorators
import login_required
19 from django
.http
import HttpResponse
, JsonResponse
23 from lib
.osm
.osmclient
.clientv2
import Client
24 import authosm
.utils
as osmutils
26 logging
.basicConfig(level
=logging
.DEBUG
)
27 log
= logging
.getLogger('instancehandler/view.py')
30 def list(request
, type=None):
31 user
= osmutils
.get_user(request
)
32 project_id
= user
.project_id
35 instance_list
= client
.ns_list(user
.get_token())
37 instance_list
= client
.vnf_list(user
.get_token())
39 result
= {'instances': instance_list
['data'] if instance_list
and instance_list
['error'] is False else [],
40 'type': type, 'project_id': project_id
}
42 if "OSM_ERROR" in request
.session
:
43 result
['alert_error'] = request
.session
["OSM_ERROR"]
44 del request
.session
["OSM_ERROR"]
46 return __response_handler(request
, result
, 'instance_list.html')
55 "nsName": request
.POST
.get('nsName', 'WithoutName'),
56 "nsDescription": request
.POST
.get('nsDescription', ''),
57 "nsdId": request
.POST
.get('nsdId', ''),
58 "vimAccountId": request
.POST
.get('vimAccountId', ''),
60 if 'ssh_key' in request
.POST
and request
.POST
.get('ssh_key') != '':
61 ns_data
["ssh-authorized-key"] = [request
.POST
.get('ssh_key')]
63 if 'config' in request
.POST
:
64 ns_config
= yaml
.load(request
.POST
.get('config'))
65 if isinstance(ns_config
, dict):
66 if "vim-network-name" in ns_config
:
67 ns_config
["vld"] = ns_config
.pop("vim-network-name")
68 if "vld" in ns_config
:
70 for vld
in ns_config
["vld"]:
71 if vld
.get("vim-network-name"):
72 if isinstance(vld
["vim-network-name"], dict):
73 vim_network_name_dict
= {}
74 for vim_account
, vim_net
in vld
["vim-network-name"].items():
75 vim_network_name_dict
[ns_data
["vimAccountId"]] = vim_net
76 vld
["vim-network-name"] = vim_network_name_dict
77 ns_data
["vld"] = ns_config
["vld"]
78 if "vnf" in ns_config
:
79 for vnf
in ns_config
["vnf"]:
80 if vnf
.get("vim_account"):
81 vnf
["vimAccountId"] = ns_data
["vimAccountId"]
83 ns_data
["vnf"] = ns_config
["vnf"]
84 except Exception as e
:
85 request
.session
["OSM_ERROR"] = "Error creating the NS; Invalid parameters provided."
86 return __response_handler(request
, {}, 'instances:list', to_redirect
=True, type='ns', )
89 user
= osmutils
.get_user(request
)
91 result
= client
.ns_create(user
.get_token(), ns_data
)
92 return __response_handler(request
, result
, 'instances:list', to_redirect
=True, type='ns',)
96 def ns_operations(request
, instance_id
=None, type=None):
97 user
= osmutils
.get_user(request
)
98 project_id
= user
.project_id
100 op_list
= client
.ns_op_list(user
.get_token(), instance_id
)
101 return __response_handler(request
,
102 {'operations': op_list
['data'] if op_list
and op_list
['error'] is False else [],
103 'type': 'ns', 'project_id': project_id
}, 'instance_operations_list.html')
107 def ns_operation(request
, op_id
, instance_id
=None, type=None):
108 user
= osmutils
.get_user(request
)
110 result
= client
.ns_op(user
.get_token(), op_id
)
111 return __response_handler(request
, result
['data'])
115 def action(request
, instance_id
=None, type=None):
116 user
= osmutils
.get_user(request
)
118 # result = client.ns_action(instance_id, action_payload)
119 primitive_param_keys
= request
.POST
.getlist('primitive_params_name')
120 primitive_param_value
= request
.POST
.getlist('primitive_params_value')
122 "vnf_member_index": request
.POST
.get('vnf_member_index'),
123 "primitive": request
.POST
.get('primitive'),
124 "primitive_params": {k
: v
for k
, v
in zip(primitive_param_keys
, primitive_param_value
) if len(k
) > 0}
127 result
= client
.ns_action(user
.get_token(), instance_id
, action_payload
)
130 return __response_handler(request
, result
['data'], url
=None,
131 status
=result
['data']['status'] if 'status' in result
['data'] else 500)
134 return __response_handler(request
, {}, url
=None, status
=200)
138 def delete(request
, instance_id
=None, type=None):
139 force
= bool(request
.GET
.get('force', False))
141 user
= osmutils
.get_user(request
)
143 result
= client
.ns_delete(user
.get_token(), instance_id
, force
)
145 return __response_handler(request
, result
, 'instances:list', to_redirect
=True, type='ns')
148 def show_topology(request
, instance_id
=None, type=None):
149 user
= osmutils
.get_user(request
)
150 project_id
= user
.project_id
151 raw_content_types
= request
.META
.get('HTTP_ACCEPT', '*/*').split(',')
152 if 'application/json' in raw_content_types
:
153 result
= {'vertices': [
154 {"info": {"type": "vnf", "property": {"custom_label": ""},
155 "group": []}, "id": "ping"},
156 {"info": {"type": "vnf", "property": {"custom_label": ""},
157 "group": []}, "id": "pong"},
158 {"info": {"type": "vdu", "property": {"custom_label": ""},
159 "group": ['pong']}, "id": "pong/ubuntu"},
160 {"info": {"type": "vdu", "property": {"custom_label": ""},
161 "group": ['ping']}, "id": "ping/ubuntu"},
162 {"info": {"type": "cp", "property": {"custom_label": ""},
163 "group": ['ping']}, "id": "ping/cp0"},
164 {"info": {"type": "cp", "property": {"custom_label": ""},
165 "group": ['ping']}, "id": "ping/cp1"},
166 {"info": {"type": "cp", "property": {"custom_label": ""},
167 "group": ['pong']}, "id": "pong/cp0"},
168 {"info": {"type": "cp", "property": {"custom_label": ""},
169 "group": ['pong']}, "id": "pong/cp1"},
170 {"info": {"type": "ns_vl", "property": {"custom_label": ""},
171 "group": []}, "id": "mgmt_vl"},
174 # {"source": "ping", "group": [], "target": "ping/cp0", "view": "Data"},
175 {"source": "pong/ubuntu", "group": ['pong'], "target": "pong/cp0", "view": "vnf"},
176 {"source": "ping/ubuntu", "group": ['ping'], "target": "ping/cp0", "view": "vnf"},
177 {"source": "pong/ubuntu", "group": ['pong'], "target": "pong/cp1", "view": "vnf"},
178 {"source": "ping/ubuntu", "group": ['ping'], "target": "ping/cp1", "view": "vnf"},
179 {"source": "pong", "group": [], "target": "mgmt_vl", "view": "ns"},
180 {"source": "ping", "group": [], "target": "mgmt_vl", "view": "ns"},
181 ], 'graph_parameters': [],
189 "callback": "addNode"
192 "callback": "removeNode"
198 "callback": "addNode"
201 "callback": "removeNode"
210 "callback": "addLink",
211 "direct_edge": False,
213 "callback": "removeLink"
221 "callback": "addLink",
222 "direct_edge": False,
224 "callback": "removeLink"
237 "callback": "addNode"
240 "callback": "removeNode"
245 "callback": "addNode"
248 "callback": "removeNode"
257 "callback": "addLink",
258 "direct_edge": False,
260 "callback": "removeLink"
268 "callback": "addLink",
269 "direct_edge": False,
271 "callback": "removeLink"
297 return __response_handler(request
, result
)
299 result
= {'type': type, 'project_id': project_id
, 'instance_id': instance_id
}
300 return __response_handler(request
, result
, 'instance_topology_view.html')
304 def show(request
, instance_id
=None, type=None):
306 user
= osmutils
.get_user(request
)
307 project_id
= user
.project_id
310 result
= client
.ns_get(user
.get_token(), instance_id
)
312 result
= client
.vnf_get(user
.get_token(), instance_id
)
314 return __response_handler(request
, result
)
318 def export_metric(request
, instance_id
=None, type=None):
319 metric_data
= request
.POST
.dict()
320 user
= osmutils
.get_user(request
)
321 project_id
= user
.project_id
323 keys
= ["collection_period",
329 metric_data
= dict(filter(lambda i
: i
[0] in keys
and len(i
[1]) > 0, metric_data
.items()))
331 result
= client
.ns_metric_export(user
.get_token(), instance_id
, metric_data
)
335 return __response_handler(request
, result
['data'], url
=None,
336 status
=result
['data']['status'] if 'status' in result
['data'] else 500)
338 return __response_handler(request
, {}, url
=None, status
=200)
342 def create_alarm(request
, instance_id
=None, type=None):
343 metric_data
= request
.POST
.dict()
345 user
= osmutils
.get_user(request
)
346 project_id
= user
.project_id
349 keys
= ["threshold_value",
358 metric_data
= dict(filter(lambda i
: i
[0] in keys
and len(i
[1]) > 0, metric_data
.items()))
360 result
= client
.ns_alarm_create(user
.get_token(), instance_id
, metric_data
)
363 return __response_handler(request
, result
['data'], url
=None,
364 status
=result
['data']['status'] if 'status' in result
['data'] else 500)
366 return __response_handler(request
, {}, url
=None, status
=200)
369 def __response_handler(request
, data_res
, url
=None, to_redirect
=None, *args
, **kwargs
):
370 raw_content_types
= request
.META
.get('HTTP_ACCEPT', '*/*').split(',')
371 if 'application/json' in raw_content_types
or url
is None:
372 return HttpResponse(json
.dumps(data_res
), content_type
="application/json")
374 return redirect(url
, *args
, **kwargs
)
376 return render(request
, url
, data_res
)