blob: 6194b0ac719b2cc2aceeb77c365ecc8958ef7ae1 [file] [log] [blame]
lombardoffb37bca2018-05-03 16:20:04 +02001#
2# Copyright 2017 CNIT - Consorzio Nazionale Interuniversitario per le Telecomunicazioni
3#
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
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
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.
15#
16
17import json
lombardofrf5776442018-06-26 10:37:40 +020018import logging
lombardoffb37bca2018-05-03 16:20:04 +020019
lombardofrf5776442018-06-26 10:37:40 +020020import yaml
lombardoffb37bca2018-05-03 16:20:04 +020021from django.contrib.auth.decorators import login_required
22from django.http import HttpResponse, JsonResponse
23from django.middleware.csrf import get_token
24from django.shortcuts import render, redirect
lombardoffb37bca2018-05-03 16:20:04 +020025from lib.util import Util
lombardoffb37bca2018-05-03 16:20:04 +020026from projecthandler.osm_model import OsmProject
lombardofr07930222018-06-19 16:59:45 +020027from lib.osm.osmclient.clientv2 import Client
lombardoffb37bca2018-05-03 16:20:04 +020028
29
lombardofrf5776442018-06-26 10:37:40 +020030logging.basicConfig(level=logging.DEBUG)
31log = logging.getLogger('projecthandler/view.py')
lombardoffb37bca2018-05-03 16:20:04 +020032
lombardoffb37bca2018-05-03 16:20:04 +020033
34@login_required
35def home(request):
36 return render(request, 'home.html', {})
37
38
39@login_required
40def create_new_project(request):
lombardofr099364f2018-06-12 11:21:02 +020041 return render(request, 'home.html', {})
lombardoffb37bca2018-05-03 16:20:04 +020042
43
44@login_required
45def user_projects(request):
46 csrf_token_value = get_token(request)
lombardofr099364f2018-06-12 11:21:02 +020047 user = request.user
48 projects = user.get_projects()
lombardoffb37bca2018-05-03 16:20:04 +020049
50 return render(request, 'projectlist.html', {
51 'projects': list(projects),
52 'csrf_token': csrf_token_value
53 })
54
55
56@login_required
57def open_project(request, project_id=None):
58 try:
lombardofr099364f2018-06-12 11:21:02 +020059 user = request.user
60 client = Client()
lombardofrf5776442018-06-26 10:37:40 +020061 ##TODO change with adhoc api call
62 nsd = client.nsd_list(request.session['token'])
63 vnfd = client.vnfd_list(request.session['token'])
64 ns = client.ns_list(request.session['token'])
65 vnf = client.vnf_list(request.session['token'])
lombardofr099364f2018-06-12 11:21:02 +020066 project_overview = {
67 'owner': user.username,
68 'name': project_id,
69 'updated_date': '-',
70 'created_date': '-',
71 'info': '-',
72 'type': 'osm',
lombardofrf5776442018-06-26 10:37:40 +020073 'nsd': len(nsd['data']) if nsd and nsd['error'] is False else 0,
74 'vnfd': len(vnfd['data']) if vnfd and vnfd['error'] is False else 0,
75 'ns': len(ns['data']) if ns and ns['error'] is False else 0,
76 'vnf': len(vnf['data']) if vnf and vnf['error'] is False else 0,
lombardofr099364f2018-06-12 11:21:02 +020077 }
78 return render(request, 'osm/osm_project_details.html',
lombardoffb37bca2018-05-03 16:20:04 +020079 {'project_overview': project_overview, 'project_id': project_id})
80
81 except Exception as e:
82 print e
83 return render(request, 'error.html', {'error_msg': 'Error open project! Please retry.'})
84
85
86@login_required
87def delete_project(request, project_id=None):
88 if request.method == 'POST':
89
90 try:
lombardofr099364f2018-06-12 11:21:02 +020091 ##TODO delete project
lombardoffb37bca2018-05-03 16:20:04 +020092 return redirect('projects:projects_list')
93 except Exception as e:
94 print e
95 return render(request, 'error.html', {'error_msg': 'Error deleting Project.'})
96
97 elif request.method == 'GET':
98 try:
lombardofr099364f2018-06-12 11:21:02 +020099 return render(request, 'osm/osm_project_delete.html',
100 {'project_id': project_id, 'project_name': project_id})
lombardoffb37bca2018-05-03 16:20:04 +0200101
102 except Exception as e:
103 print e
104 return render(request, 'error.html', {'error_msg': 'Project not found.'})
105
106
lombardoffb37bca2018-05-03 16:20:04 +0200107@login_required
108def show_descriptors(request, project_id=None, descriptor_type=None):
lombardofr099364f2018-06-12 11:21:02 +0200109 client = Client()
lombardofrf5776442018-06-26 10:37:40 +0200110 print request.GET.dict()
lombardofr099364f2018-06-12 11:21:02 +0200111 try:
112 if descriptor_type == 'nsd':
lombardofrf5776442018-06-26 10:37:40 +0200113 descriptors = client.nsd_list(request.session['token'])
lombardofr099364f2018-06-12 11:21:02 +0200114 elif descriptor_type == 'vnfd':
lombardofrf5776442018-06-26 10:37:40 +0200115 descriptors = client.vnfd_list(request.session['token'])
lombardofr099364f2018-06-12 11:21:02 +0200116 except Exception as e:
lombardofrf5776442018-06-26 10:37:40 +0200117 log.exception(e)
lombardofr099364f2018-06-12 11:21:02 +0200118 descriptors = []
119
120 url = 'osm/osm_project_descriptors.html'
lombardof07db64f2018-05-11 13:47:10 +0200121 return __response_handler(request, {
lombardofrf5776442018-06-26 10:37:40 +0200122 'descriptors': descriptors['data'] if descriptors and descriptors['error'] is False else [],
lombardoffb37bca2018-05-03 16:20:04 +0200123 'project_id': project_id,
lombardofr099364f2018-06-12 11:21:02 +0200124 'project_type': 'osm',
lombardoffb37bca2018-05-03 16:20:04 +0200125 'descriptor_type': descriptor_type
lombardof07db64f2018-05-11 13:47:10 +0200126 },url)
lombardoffb37bca2018-05-03 16:20:04 +0200127
128
129@login_required
lombardoffb37bca2018-05-03 16:20:04 +0200130def delete_descriptor(request, project_id=None, descriptor_type=None, descriptor_id=None):
lombardofr099364f2018-06-12 11:21:02 +0200131
132 try:
133 client = Client()
134 if descriptor_type == 'nsd':
lombardofrf5776442018-06-26 10:37:40 +0200135 result = client.nsd_delete(request.session['token'], descriptor_id)
lombardofr099364f2018-06-12 11:21:02 +0200136 elif descriptor_type == 'vnfd':
lombardofrf5776442018-06-26 10:37:40 +0200137 result = client.vnfd_delete(request.session['token'], descriptor_id)
lombardofr099364f2018-06-12 11:21:02 +0200138 except Exception as e:
lombardofrf5776442018-06-26 10:37:40 +0200139 log.exception(e)
140 result = {'error': True, 'data': str(e)}
lombardoffb37bca2018-05-03 16:20:04 +0200141
lombardofrf5776442018-06-26 10:37:40 +0200142 url = 'osm/osm_project_descriptors.html'
143 descriptors = {}
144 try:
145 if descriptor_type == 'nsd':
146 descriptors = client.nsd_list(request.session['token'])
147 elif descriptor_type == 'vnfd':
148 descriptors = client.vnfd_list(request.session['token'])
149 except Exception as e:
150 log.exception(e)
151
152 return __response_handler(request, {
153 'descriptors': descriptors['data'] if descriptors and descriptors['error'] is False else [],
lombardoffb37bca2018-05-03 16:20:04 +0200154 'project_id': project_id,
lombardofrf5776442018-06-26 10:37:40 +0200155 'project_type': 'osm',
lombardoffb37bca2018-05-03 16:20:04 +0200156 'descriptor_type': descriptor_type,
lombardofrf5776442018-06-26 10:37:40 +0200157 'alert_message': {
158 'success': False if result['error'] is True else True,
159 'message': 'An error occurred while processing your request.' if result and result['error'] is True else "Record deleted successfully"}
160 }, url)
161
lombardoffb37bca2018-05-03 16:20:04 +0200162
163
164@login_required
lombardoffb37bca2018-05-03 16:20:04 +0200165def new_descriptor(request, project_id=None, descriptor_type=None):
lombardofr099364f2018-06-12 11:21:02 +0200166
lombardofrf5776442018-06-26 10:37:40 +0200167 page = 'osm/descriptor/descriptor_new.html'
lombardoffb37bca2018-05-03 16:20:04 +0200168 if request.method == 'GET':
169 request_id = request.GET.get('id', '')
lombardofrf5776442018-06-26 10:37:40 +0200170
171 return __response_handler(request, {
lombardoffb37bca2018-05-03 16:20:04 +0200172 'project_id': project_id,
173 'descriptor_type': descriptor_type,
174 'descriptor_id': request_id,
lombardofrf5776442018-06-26 10:37:40 +0200175 }, page)
lombardoffb37bca2018-05-03 16:20:04 +0200176 elif request.method == 'POST':
lombardoffb37bca2018-05-03 16:20:04 +0200177 data_type = request.POST.get('type')
178 print "TYPE", data_type
179 if data_type == "file":
180 file_uploaded = request.FILES['file']
lombardofrf5776442018-06-26 10:37:40 +0200181
182 try:
183 client = Client()
184 if descriptor_type == 'nsd':
185 result = client.nsd_onboard(request.session['token'], file_uploaded)
186 elif descriptor_type == 'vnfd':
187 result = client.vnfd_onboard(request.session['token'], file_uploaded)
188 else:
189 log.debug('Create descriptor: Unknown data type')
190 result = {'error': True, 'data': 'Create descriptor: Unknown data type'}
191
192 except Exception as e:
193 log.exception(e)
194 result = {'error': True, 'data': str(e)}
lombardoffb37bca2018-05-03 16:20:04 +0200195 else:
lombardofrf5776442018-06-26 10:37:40 +0200196 result = {'error': True, 'data': 'Create descriptor: Unknown data type'}
lombardoffb37bca2018-05-03 16:20:04 +0200197
lombardofrf5776442018-06-26 10:37:40 +0200198 if result['error']:
199 print result
200 return __response_handler(request, result['data'], url=None, status=result['data']['status'] if 'status' in result['data'] else 500)
lombardoffb37bca2018-05-03 16:20:04 +0200201
lombardofrf5776442018-06-26 10:37:40 +0200202 else:
203 return __response_handler(request, {}, url=None, status=200)
lombardoffb37bca2018-05-03 16:20:04 +0200204
205
206@login_required
207def edit_descriptor(request, project_id=None, descriptor_id=None, descriptor_type=None):
208 if request.method == 'POST':
209 print "edit_descriptor"
lombardofrf5776442018-06-26 10:37:40 +0200210 new_data = request.POST.get('text'),
211 data_type = request.POST.get('type')
212 #print new_data
213 try:
214 client = Client()
215 if descriptor_type == 'nsd':
216 if data_type == 'yaml':
217 new_data = yaml.load(request.POST.get('text'))
218 elif data_type == 'json':
219 new_data = json.loads(request.POST.get('text'))
220 print new_data
221 result = client.nsd_update(request.session['token'], descriptor_id, new_data)
222 elif descriptor_type == 'vnfd':
223 if data_type == 'yaml':
224 new_data = yaml.load(request.POST.get('text'))
225 elif data_type == 'json':
226 new_data = json.loads(request.POST.get('text'))
227 print new_data
228 result = client.vnfd_update(request.session['token'], descriptor_id, new_data)
229
230 else:
231 log.debug('Update descriptor: Unknown data type')
232 result = {'error': True, 'data': 'Update descriptor: Unknown data type'}
233 except Exception as e:
234 log.exception(e)
235 result = {'error': True, 'data': str(e)}
236 print result
237 if result['error'] == True:
238 return __response_handler(request, result['data'], url=None, status=result['data']['status'] if 'status' in result['data'] else 500)
239
240 else:
241 return __response_handler(request, {}, url=None, status=200)
lombardoffb37bca2018-05-03 16:20:04 +0200242
243 elif request.method == 'GET':
lombardoffb37bca2018-05-03 16:20:04 +0200244
lombardofrf5776442018-06-26 10:37:40 +0200245 page = 'osm/descriptor/descriptor_view.html'
246 try:
247 client = Client()
248 if descriptor_type == 'nsd':
249 result = client.nsd_get(request.session['token'], descriptor_id)
250 print result
251 elif descriptor_type == 'vnfd':
252 result = client.vnfd_get(request.session['token'], descriptor_id)
lombardoffb37bca2018-05-03 16:20:04 +0200253
lombardofrf5776442018-06-26 10:37:40 +0200254 print result
255 except Exception as e:
256 log.exception(e)
257 result = {'error': True, 'data': str(e)}
258
259 if isinstance(result, dict) and 'error' in result and result['error']:
260 return render(request, 'error.html')
261
262 descriptor_string_json = json.dumps(result, indent=2)
263 descriptor_string_yaml = Util.json2yaml(result)
lombardoffb37bca2018-05-03 16:20:04 +0200264 # print descriptor
265 return render(request, page, {
266 'project_id': project_id,
267 'descriptor_id': descriptor_id,
lombardoffb37bca2018-05-03 16:20:04 +0200268 'descriptor_type': descriptor_type,
269 'descriptor_strings': {'descriptor_string_yaml': descriptor_string_yaml,
270 'descriptor_string_json': descriptor_string_json}})
271
272
lombardofrf5776442018-06-26 10:37:40 +0200273@login_required
274def get_package_files_list(request, project_id, descriptor_id, descriptor_type):
lombardoffb37bca2018-05-03 16:20:04 +0200275 files_list = []
276 try:
lombardofrf5776442018-06-26 10:37:40 +0200277 client = Client()
278 if descriptor_type == 'nsd':
279 artifacts_res = client.nsd_artifacts(request.session['token'], descriptor_id)
280 elif descriptor_type == 'vnfd':
281 artifacts_res = client.vnf_packages_artifacts(request.session['token'], descriptor_id)
282 else:
283 return False
284
285 files_list = yaml.load(artifacts_res['data'] if artifacts_res and artifacts_res['error'] is False else [])
lombardoffb37bca2018-05-03 16:20:04 +0200286 result = {'files': files_list}
287 except Exception as e:
lombardofrf5776442018-06-26 10:37:40 +0200288 log.exception(e)
lombardoffb37bca2018-05-03 16:20:04 +0200289 url = 'error.html'
290 result = {'error_msg': 'Unknown error.'}
291 return __response_handler(request, result)
292
lombardofrf5776442018-06-26 10:37:40 +0200293@login_required
lombardofr099364f2018-06-12 11:21:02 +0200294def download_pkg(request, project_id, descriptor_id, descriptor_type):
lombardofrf5776442018-06-26 10:37:40 +0200295 file_name = "osm_export.tar.gz"
296 tar_pkg = None
297 try:
298 client = Client()
299 if descriptor_type == 'nsd':
300 tar_pkg = client.get_nsd_pkg(request.session['token'], descriptor_id)
301 elif descriptor_type == 'vnfd':
302 tar_pkg = client.get_vnfd_pkg(request.session['token'], descriptor_id)
303
304 except Exception as e:
305 log.exception(e)
lombardoffb37bca2018-05-03 16:20:04 +0200306
307 response = HttpResponse(content_type="application/tgz")
lombardofrf5776442018-06-26 10:37:40 +0200308 response["Content-Disposition"] = "attachment; filename="+ file_name
lombardoffb37bca2018-05-03 16:20:04 +0200309 response.write(tar_pkg.getvalue())
310 return response
311
312
lombardoffb37bca2018-05-03 16:20:04 +0200313@login_required
314def custom_action(request, project_id=None, descriptor_id=None, descriptor_type=None, action_name=None):
315 if request.method == 'GET':
lombardoffb37bca2018-05-03 16:20:04 +0200316 print "Custom action: " + action_name
lombardofr099364f2018-06-12 11:21:02 +0200317 return globals()[action_name](request, project_id, descriptor_id, descriptor_type)
lombardoffb37bca2018-05-03 16:20:04 +0200318
319
320def __response_handler(request, data_res, url=None, to_redirect=None, *args, **kwargs):
321 raw_content_types = request.META.get('HTTP_ACCEPT', '*/*').split(',')
lombardofrf5776442018-06-26 10:37:40 +0200322 if 'application/json' in raw_content_types or url is None:
323 return HttpResponse(json.dumps(data_res), content_type="application/json", *args, **kwargs)
lombardoffb37bca2018-05-03 16:20:04 +0200324 elif to_redirect:
325 return redirect(url, *args, **kwargs)
326 else:
327 return render(request, url, data_res)