| lombardofr | 3c7234a | 2019-12-03 11:23:17 +0100 | [diff] [blame] | 1 | # |
| 2 | # Copyright 2019 EveryUP Srl |
| 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 | |
| 17 | from django.shortcuts import render, redirect |
| 18 | from sf_t3d.decorators import login_required |
| 19 | from django.http import HttpResponse |
| 20 | import json |
| 21 | import logging |
| 22 | import authosm.utils as osmutils |
| 23 | from lib.osm.osmclient.clientv2 import Client |
| 24 | |
| 25 | logging.basicConfig(level=logging.DEBUG) |
| 26 | log = logging.getLogger('k8srepohandler/view.py') |
| 27 | |
| 28 | |
| 29 | @login_required |
| 30 | def list(request): |
| 31 | user = osmutils.get_user(request) |
| 32 | project_id = user.project_id |
| 33 | result = {'project_id': project_id} |
| 34 | raw_content_types = request.META.get('HTTP_ACCEPT', '*/*').split(',') |
| 35 | if 'application/json' not in raw_content_types: |
| 36 | return __response_handler(request, result, 'k8srepo_list.html') |
| 37 | client = Client() |
| 38 | result_client = client.k8sr_list(user.get_token()) |
| 39 | |
| 40 | result['k8sr'] = result_client['data'] if result_client and result_client['error'] is False else [] |
| 41 | |
| 42 | return __response_handler(request, result, 'k8srepo_list.html') |
| 43 | |
| 44 | |
| 45 | @login_required |
| 46 | def create(request): |
| 47 | user = osmutils.get_user(request) |
| 48 | project_id = user.project_id |
| 49 | result = {'project_id': project_id} |
| 50 | client = Client() |
| 51 | try: |
| 52 | new_k8sr = { |
| 53 | "name": request.POST.get('name'), |
| 54 | "type": request.POST.get('type'), |
| 55 | "url": request.POST.get('url'), |
| 56 | "description": request.POST.get('description'), |
| 57 | } |
| 58 | except Exception as e: |
| 59 | return __response_handler(request, {'status': 400, 'code': 'BAD_REQUEST', 'detail': e.message}, url=None, status=400) |
| 60 | result = client.k8sr_create(user.get_token(), new_k8sr) |
| 61 | if result['error']: |
| 62 | return __response_handler(request, result['data'], url=None, status=result['data']['status'] if 'status' in result['data'] else 500) |
| 63 | else: |
| 64 | return __response_handler(request, result, 'k8sr:list', to_redirect=True) |
| 65 | |
| 66 | |
| 67 | @login_required |
| 68 | def update(request, k8sr_id=None): |
| 69 | user = osmutils.get_user(request) |
| 70 | try: |
| 71 | update_k8sr_dict = request.POST.dict() |
| 72 | client = Client() |
| 73 | res = client.k8sr_update(user.get_token(), k8sr_id, update_k8sr_dict) |
| 74 | except Exception as e: |
| 75 | log.exception(e) |
| 76 | return __response_handler(request, res, 'k8sr:list', to_redirect=True) |
| 77 | |
| 78 | |
| 79 | @login_required |
| 80 | def show(request, k8sr_id=None): |
| 81 | user = osmutils.get_user(request) |
| 82 | project_id = user.project_id |
| 83 | client = Client() |
| 84 | result_client = client.k8sr_get(user.get_token(), k8sr_id) |
| 85 | |
| 86 | return __response_handler(request, result_client) |
| 87 | |
| 88 | |
| 89 | @login_required |
| 90 | def delete(request, k8sr_id=None): |
| 91 | user = osmutils.get_user(request) |
| 92 | try: |
| 93 | client = Client() |
| 94 | del_res = client.k8sr_delete(user.get_token(), k8sr_id) |
| 95 | except Exception as e: |
| 96 | log.exception(e) |
| 97 | return __response_handler(request, del_res, 'k8sr:list', to_redirect=True) |
| 98 | |
| 99 | |
| 100 | def __response_handler(request, data_res, url=None, to_redirect=None, *args, **kwargs): |
| 101 | raw_content_types = request.META.get('HTTP_ACCEPT', '*/*').split(',') |
| 102 | if 'application/json' in raw_content_types or url is None: |
| 103 | return HttpResponse(json.dumps(data_res), content_type="application/json", *args, **kwargs) |
| 104 | elif to_redirect: |
| 105 | return redirect(url, *args, **kwargs) |
| 106 | else: |
| 107 | return render(request, url, data_res) |