blob: f7e78f8ac554ddde7ee1743fcf741e7e70b2bdbc [file] [log] [blame]
Jeremy Mowery8b664f72015-12-04 11:52:16 -07001
2from core.admin import ReadOnlyAwareAdmin, SliceInline
3from core.middleware import get_request
4from core.models import User
5from django import forms
6from django.contrib import admin
Jeremy Mowery8e91e872015-12-06 22:43:19 -07007from subprocess import Popen, PIPE
Jeremy Mowery6b557322016-01-05 00:30:24 -07008from services.vpn.models import VPNService, VPNTenant, VPN_KIND
Jeremy Mowery8b664f72015-12-04 11:52:16 -07009
10class VPNServiceAdmin(ReadOnlyAwareAdmin):
11 model = VPNService
12 verbose_name = "VPN Service"
13
14 list_display = ("backend_status_icon", "name", "enabled")
15
16 list_display_links = ('backend_status_icon', 'name', )
17
18 fieldsets = [(None, {'fields': ['backend_status_text', 'name', 'enabled',
19 'versionNumber', 'description', "view_url"],
20 'classes':['suit-tab suit-tab-general']})]
21
22 readonly_fields = ('backend_status_text', )
23
24 inlines = [SliceInline]
25
26 extracontext_registered_admins = True
27
28 user_readonly_fields = ["name", "enabled", "versionNumber", "description"]
29
30 suit_form_tabs = (('general', 'VPN Service Details'),
31 ('administration', 'Tenants'),
32 ('slices', 'Slices'),)
33
34 suit_form_includes = (('vpnserviceadmin.html',
35 'top',
36 'administration'),)
37
38 def queryset(self, request):
39 return VPNService.get_service_objects_by_user(request.user)
40
41class VPNTenantForm(forms.ModelForm):
42 creator = forms.ModelChoiceField(queryset=User.objects.all())
Jeremy Moweryb05f2512015-12-07 20:59:23 -070043 server_key = forms.CharField(required=False, widget=forms.Textarea)
Jeremy Mowerybd2ed3a2016-01-05 16:52:43 -070044 client_conf = forms.CharField(required=False, widget=forms.Textarea)
45 server_address = forms.GenericIPAddressField(protocol='IPv4', required=True)
46 client_address = forms.GenericIPAddressField(protocol='IPv4', required=True)
Jeremy Moweryb3fcf1b2016-01-06 15:46:02 -070047 is_persistent = forms.BooleanField(required=False)
48 can_view_subnet = forms.BooleanField(required=False)
Jeremy Mowery8b664f72015-12-04 11:52:16 -070049
50 def __init__(self, *args, **kwargs):
51 super(VPNTenantForm, self).__init__(*args, **kwargs)
52 self.fields['kind'].widget.attrs['readonly'] = True
Jeremy Moweryb05f2512015-12-07 20:59:23 -070053 self.fields['server_key'].widget.attrs['readonly'] = True
Jeremy Mowerybd2ed3a2016-01-05 16:52:43 -070054 self.fields['client_conf'].widget.attrs['readonly'] = True
Jeremy Mowery8b664f72015-12-04 11:52:16 -070055 self.fields[
56 'provider_service'].queryset = VPNService.get_service_objects().all()
57
58 self.fields['kind'].initial = VPN_KIND
59
60 if self.instance:
61 self.fields['creator'].initial = self.instance.creator
62 self.fields['server_key'].initial = self.instance.server_key
Jeremy Mowerybd2ed3a2016-01-05 16:52:43 -070063 self.fields['client_conf'].initial = self.instance.client_conf
64 self.fields['server_address'].initial = self.instance.server_address
65 self.fields['client_address'].initial = self.instance.client_address
Jeremy Mowery4a23e7d2016-01-06 15:16:33 -070066 self.fields['is_persistent'].initial = self.instance.is_persistent
67 self.fields['can_view_subnet'].initial = self.instance.can_view_subnet
Jeremy Mowery8b664f72015-12-04 11:52:16 -070068
Jeremy Mowery8b664f72015-12-04 11:52:16 -070069 if (not self.instance) or (not self.instance.pk):
70 self.fields['creator'].initial = get_request().user
Jeremy Mowerye1260de2015-12-06 23:10:49 -070071 self.fields['server_key'].initial = self.generate_VPN_key()
Jeremy Mowerybd2ed3a2016-01-05 16:52:43 -070072 self.fields['server_address'].initial = "10.8.0.1"
73 self.fields['client_address'].initial = "10.8.0.2"
Jeremy Mowery4a23e7d2016-01-06 15:16:33 -070074 self.fields['is_persistent'].initial = True
75 self.fields['can_view_subnet'].initial = False
Jeremy Mowery8b664f72015-12-04 11:52:16 -070076 if VPNService.get_service_objects().exists():
77 self.fields["provider_service"].initial = VPNService.get_service_objects().all()[0]
78
79 def save(self, commit=True):
80 self.instance.creator = self.cleaned_data.get("creator")
Jeremy Mowery4be1fb02015-12-07 21:40:36 -070081 self.instance.server_key = self.cleaned_data.get("server_key")
Jeremy Mowerybd2ed3a2016-01-05 16:52:43 -070082 self.instance.server_address = self.cleaned_data.get("server_address")
83 self.instance.client_address = self.cleaned_data.get("client_address")
Jeremy Mowery4a23e7d2016-01-06 15:16:33 -070084 self.instance.is_persistent = self.cleaned_data.get('is_persistent')
85 self.instance.can_view_subnet = self.cleaned_data.get('can_view_subnet')
Jeremy Mowery8b664f72015-12-04 11:52:16 -070086 return super(VPNTenantForm, self).save(commit=commit)
87
Jeremy Mowerye1260de2015-12-06 23:10:49 -070088 def generate_VPN_key(self):
Jeremy Mowery8e91e872015-12-06 22:43:19 -070089 proc = Popen("openvpn --genkey --secret /dev/stdout", shell=True, stdout=PIPE)
90 (stdout, stderr) = proc.communicate()
91 return stdout
92
Jeremy Mowery8b664f72015-12-04 11:52:16 -070093 class Meta:
94 model = VPNTenant
95
96class VPNTenantAdmin(ReadOnlyAwareAdmin):
97 verbose_name = "VPN Tenant Admin"
98 list_display = ('id', 'backend_status_icon', 'instance')
99 list_display_links = ('id', 'backend_status_icon', 'instance')
100 fieldsets = [(None, {'fields': ['backend_status_text', 'kind',
101 'provider_service', 'instance', 'creator',
Jeremy Mowerybd2ed3a2016-01-05 16:52:43 -0700102 'server_key', 'client_conf',
Jeremy Mowery4a23e7d2016-01-06 15:16:33 -0700103 'server_address', 'client_address',
104 'is_persistent', 'can_view_subnet'],
Jeremy Mowery8b664f72015-12-04 11:52:16 -0700105 'classes': ['suit-tab suit-tab-general']})]
Jeremy Moweryb05f2512015-12-07 20:59:23 -0700106 readonly_fields = ('backend_status_text', 'instance')
Jeremy Mowery8b664f72015-12-04 11:52:16 -0700107 form = VPNTenantForm
108
109 suit_form_tabs = (('general', 'Details'),)
110
111 def queryset(self, request):
112 return VPNTenant.get_tenant_objects_by_user(request.user)
113
114# Associate the admin forms with the models.
115admin.site.register(VPNService, VPNServiceAdmin)
116admin.site.register(VPNTenant, VPNTenantAdmin)