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
22 from lib
.osm
.osmclient
.client
import Client
26 def list(request
, project_id
=None, type=None):
29 result
= client
.ns_list()
31 result
= client
.vnf_list()
33 result
= {'instances': result
, 'type': type, 'project_id': project_id
}
35 return __response_handler(request
, result
, 'instance_list.html')
39 def create(request
, project_id
=None):
42 "nsName": request
.POST
.get('nsName', 'WithoutName'),
43 "nsDescription": request
.POST
.get('nsDescription', ''),
44 "nsdId": request
.POST
.get('nsdId', ''),
45 "vimAccountId": request
.POST
.get('vimAccountId', ''),
47 if 'ssh_key' in request
.POST
and request
.POST
.get('ssh_key') != '':
48 ns_data
["ssh-authorized-key"] = [request
.POST
.get('ssh_key')]
50 if 'config' in request
.POST
:
51 ns_config
= yaml
.load(request
.POST
.get('config'))
52 if isinstance(ns_config
, dict):
53 if "vim-network-name" in ns_config
:
54 ns_config
["vld"] = ns_config
.pop("vim-network-name")
55 if "vld" in ns_config
:
56 for vld
in ns_config
["vld"]:
57 if vld
.get("vim-network-name"):
58 if isinstance(vld
["vim-network-name"], dict):
59 vim_network_name_dict
= {}
60 for vim_account
, vim_net
in vld
["vim-network-name"].items():
61 vim_network_name_dict
[ns_data
["vimAccountId"]] = vim_net
62 vld
["vim-network-name"] = vim_network_name_dict
63 ns_data
["vld"] = ns_config
["vld"]
64 if "vnf" in ns_config
:
65 for vnf
in ns_config
["vnf"]:
66 if vnf
.get("vim_account"):
67 vnf
["vimAccountId"] = ns_data
["vimAccountId"]
69 ns_data
["vnf"] = ns_config
["vnf"]
72 result
= client
.ns_create(ns_data
)
73 return __response_handler(request
, result
, 'projects:instances:list', to_redirect
=True, type='ns', project_id
=project_id
)
76 def ns_operations(request
, project_id
=None, instance_id
=None, type=None):
78 result
= client
.ns_op_list(instance_id
)
79 return __response_handler(request
, {'operations': result
, 'type': 'ns', 'project_id': project_id
}, 'instance_operations_list.html')
82 def ns_operation(request
, op_id
, project_id
=None, instance_id
=None, type=None):
84 result
= client
.ns_op(op_id
)
85 return __response_handler(request
, result
)
88 def action(request
, project_id
=None, instance_id
=None, type=None):
92 # result = client.ns_action(instance_id, action_payload)
93 primitive_param_keys
= request
.POST
.getlist('primitive_params_name')
94 primitive_param_value
= request
.POST
.getlist('primitive_params_value')
96 "vnf_member_index": request
.POST
.get('vnf_member_index'),
97 "primitive": request
.POST
.get('primitive'),
98 "primitive_params": {k
: v
for k
, v
in zip(primitive_param_keys
, primitive_param_value
) if len(k
) > 0}
101 result
= client
.ns_action(instance_id
, action_payload
)
102 return __response_handler(request
, result
, None, to_redirect
=False, status
=result
['status'] if 'status' in result
else None )
106 def delete(request
, project_id
=None, instance_id
=None, type=None):
107 force
= bool(request
.GET
.get('force', False))
110 result
= client
.ns_delete(instance_id
, force
)
112 return __response_handler(request
, result
, 'projects:instances:list', to_redirect
=True, type='ns', project_id
=project_id
)
116 def show(request
, project_id
=None, instance_id
=None, type=None):
120 result
= client
.ns_get(instance_id
)
122 result
= client
.vnf_get(instance_id
)
124 return __response_handler(request
, result
)
127 def __response_handler(request
, data_res
, url
=None, to_redirect
=None, *args
, **kwargs
):
128 raw_content_types
= request
.META
.get('HTTP_ACCEPT', '*/*').split(',')
129 if 'application/json' in raw_content_types
or url
is None:
130 return JsonResponse(data_res
, *args
, **kwargs
)
132 return redirect(url
, *args
, **kwargs
)
134 return render(request
, url
, data_res
)