blob: 6908d3cfe8d45b341dcb1d5dbc6de67104ef0874 [file] [log] [blame]
Scott Baker88e34372014-07-13 11:46:36 -07001from rest_framework.decorators import api_view
S.Çağlar Onurb6e63f02015-02-24 17:28:09 -05002from rest_framework.response import Response
3from rest_framework.reverse import reverse
4from rest_framework import serializers
5from rest_framework import generics
6from core.models import *
Scott Baker88e34372014-07-13 11:46:36 -07007from django.forms import widgets
8from core.xoslib.objects.sliceplus import SlicePlus
Scott Baker96e2b2c2015-02-10 19:26:00 -08009from plus import PlusSerializerMixin
Scott Baker6e33ea32015-02-16 23:46:01 -080010from xos.apibase import XOSListCreateAPIView, XOSRetrieveUpdateDestroyAPIView, XOSPermissionDenied
Scott Baker7becbf92016-03-29 14:42:27 -070011import json
Scott Baker88e34372014-07-13 11:46:36 -070012
Scott Bakerf0480fb2014-12-23 11:12:07 -080013if hasattr(serializers, "ReadOnlyField"):
14 # rest_framework 3.x
15 IdField = serializers.ReadOnlyField
Scott Baker7f4426f2016-03-28 10:09:51 -070016 WritableField = serializers.Field
Scott Bakerd608a392016-03-29 14:57:00 -070017 DictionaryField = serializers.DictField
18 ListField = serializers.ListField
Scott Bakerf0480fb2014-12-23 11:12:07 -080019else:
20 # rest_framework 2.x
21 IdField = serializers.Field
Scott Baker7f4426f2016-03-28 10:09:51 -070022 WritableField = serializers.WritableField
Scott Bakerf0480fb2014-12-23 11:12:07 -080023
Scott Bakerd608a392016-03-29 14:57:00 -070024 class DictionaryField(WritableField): # note: maybe just Field in rest_framework 3.x instead of WritableField
25 def to_representation(self, obj):
26 return json.dumps(obj)
Scott Baker9062b0c2015-01-08 22:34:51 -080027
Scott Bakerd608a392016-03-29 14:57:00 -070028 def to_internal_value(self, data):
29 return json.loads(data)
Scott Baker9062b0c2015-01-08 22:34:51 -080030
Scott Bakerd608a392016-03-29 14:57:00 -070031 class ListField(WritableField): # note: maybe just Field in rest_framework 3.x instead of WritableField
32 def to_representation(self, obj):
33 return json.dumps(obj)
Scott Bakerfcf655e2015-01-12 19:45:40 -080034
Scott Bakerd608a392016-03-29 14:57:00 -070035 def to_internal_value(self, data):
36 return json.loads(data)
Scott Baker03696ee2015-01-11 13:45:19 -080037
Scott Bakere791dc62014-08-28 14:02:54 -070038class SlicePlusIdSerializer(serializers.ModelSerializer, PlusSerializerMixin):
Scott Bakerf0480fb2014-12-23 11:12:07 -080039 id = IdField()
S.Çağlar Onurb6e63f02015-02-24 17:28:09 -050040
41 sliceInfo = serializers.SerializerMethodField("getSliceInfo")
42 humanReadableName = serializers.SerializerMethodField("getHumanReadableName")
Scott Bakerd608a392016-03-29 14:57:00 -070043 network_ports = serializers.CharField(required=False)
S.Çağlar Onurb6e63f02015-02-24 17:28:09 -050044 site_allocation = DictionaryField(required=False)
45 site_ready = DictionaryField(required=False)
46 users = ListField(required=False)
47 user_names = ListField(required=False) # readonly = True ?
48 current_user_can_see = serializers.SerializerMethodField("getCurrentUserCanSee")
49
50 def getCurrentUserCanSee(self, slice):
51 # user can 'see' the slice if he is the creator or he has a role
52 current_user = self.context['request'].user
53 if (slice.creator and slice.creator==current_user):
54 return True;
55 return (len(slice.getSliceInfo(current_user)["roles"]) > 0)
56
57 def getSliceInfo(self, slice):
58 return slice.getSliceInfo(user=self.context['request'].user)
59
60 def getHumanReadableName(self, obj):
61 return str(obj)
62
63 networks = serializers.PrimaryKeyRelatedField(many=True, read_only=True)
64
65 class Meta:
66 model = SlicePlus
Tony Mackd8515472015-08-19 11:58:18 -040067 fields = ('humanReadableName', 'id','created','updated','enacted','name','enabled','omf_friendly','description','slice_url','site','max_instances','service','network','mount_data_sets',
Scott Baker4618a232015-01-12 13:36:40 -080068 'default_image', 'default_flavor',
Scott Bakera4a379c2015-01-22 15:21:24 -080069 'serviceClass','creator','networks','sliceInfo','network_ports','backendIcon','backendHtml','site_allocation','site_ready','users',"user_names","current_user_can_see")
Scott Baker88e34372014-07-13 11:46:36 -070070
Scott Baker96e2b2c2015-02-10 19:26:00 -080071class SlicePlusList(XOSListCreateAPIView):
Scott Baker88e34372014-07-13 11:46:36 -070072 queryset = SlicePlus.objects.select_related().all()
73 serializer_class = SlicePlusIdSerializer
74
Scott Bakerdb236c32014-07-13 17:36:19 -070075 method_kind = "list"
76 method_name = "slicesplus"
77
Scott Baker88e34372014-07-13 11:46:36 -070078 def get_queryset(self):
Scott Baker7becbf92016-03-29 14:42:27 -070079 current_user_can_see = self.request.query_params.get('current_user_can_see', False)
Matteo Scandoloacbe9ff2016-05-24 14:24:50 -070080 site_filter = self.request.query_params.get('site', False)
Scott Bakerc18f52b2015-01-20 17:02:53 -080081
Scott Baker20101af2015-02-02 10:41:12 -080082 if (not self.request.user.is_authenticated()):
Scott Baker27a9a642015-02-16 23:34:31 -080083 raise XOSPermissionDenied("You must be authenticated in order to use this API")
Scott Baker20101af2015-02-02 10:41:12 -080084
Scott Bakerc18f52b2015-01-20 17:02:53 -080085 slices = SlicePlus.select_by_user(self.request.user)
86
Matteo Scandoloacbe9ff2016-05-24 14:24:50 -070087 if (site_filter and not current_user_can_see):
88 slices = SlicePlus.objects.filter(site=site_filter)
89
Scott Bakerc18f52b2015-01-20 17:02:53 -080090 # If current_user_can_see is set, then filter the queryset to return
91 # only those slices that the user is either creator or has privilege
92 # on.
93 if (current_user_can_see):
94 slice_ids = []
95 for slice in slices:
96 if (self.request.user == slice.creator) or (len(slice.getSliceInfo(self.request.user)["roles"]) > 0):
97 slice_ids.append(slice.id)
Matteo Scandoloacbe9ff2016-05-24 14:24:50 -070098 if (site_filter):
99 slices = SlicePlus.objects.filter(id__in=slice_ids, site=site_filter)
100 else:
101 slices = SlicePlus.objects.filter(id__in=slice_ids)
Scott Bakerc18f52b2015-01-20 17:02:53 -0800102
103 return slices
Scott Baker88e34372014-07-13 11:46:36 -0700104
Matteo Scandoloacbe9ff2016-05-24 14:24:50 -0700105
Scott Baker96e2b2c2015-02-10 19:26:00 -0800106class SlicePlusDetail(XOSRetrieveUpdateDestroyAPIView):
Scott Baker88e34372014-07-13 11:46:36 -0700107 queryset = SlicePlus.objects.select_related().all()
108 serializer_class = SlicePlusIdSerializer
109
Scott Bakerdb236c32014-07-13 17:36:19 -0700110 method_kind = "detail"
111 method_name = "slicesplus"
112
Scott Baker88e34372014-07-13 11:46:36 -0700113 def get_queryset(self):
Scott Baker20101af2015-02-02 10:41:12 -0800114 if (not self.request.user.is_authenticated()):
Scott Baker27a9a642015-02-16 23:34:31 -0800115 raise XOSPermissionDenied("You must be authenticated in order to use this API")
Scott Baker88e34372014-07-13 11:46:36 -0700116 return SlicePlus.select_by_user(self.request.user)
117
Scott Baker88e34372014-07-13 11:46:36 -0700118