import django_evolution
+class SingletonAdmin (admin.ModelAdmin):
+ def has_add_permission(self, request):
+ num_objects = self.model.objects.count()
+ if num_objects >= 1:
+ return False
+ else:
+ return True
+
+
class PlStackTabularInline(admin.TabularInline):
- exclude = ['enacted']
+ pass
class ReservationInline(PlStackTabularInline):
model = Reservation
class TagInline(generic.GenericTabularInline):
model = Tag
- exclude = ['enacted']
extra = 0
suit_classes = 'suit-tab suit-tab-tags'
class NetworkLookerUpper:
- """ This is a callable that looks up a network name in a sliver and returns\r
- the ip address for that network.\r
- """\r
-\r
- def __init__(self, name):\r
- self.short_description = name\r
- self.__name__ = name\r
- self.network_name = name\r
-\r
- def __call__(self, obj):\r
- if obj is not None:\r
- for nbs in obj.networksliver_set.all():\r
- if (nbs.network.name == self.network_name):\r
- return nbs.ip\r
+ """ This is a callable that looks up a network name in a sliver and returns
+ the ip address for that network.
+ """
+
+ def __init__(self, name):
+ self.short_description = name
+ self.__name__ = name
+ self.network_name = name
+
+ def __call__(self, obj):
+ if obj is not None:
+ for nbs in obj.networksliver_set.all():
+ if (nbs.network.name == self.network_name):
+ return nbs.ip
return ""
def __str__(self):
class SliceInline(PlStackTabularInline):
model = Slice
- fields = ['name','enabled','description','slice_url']
+ fields = ['name','site', 'serviceClass', 'service']
extra = 0
suit_classes = 'suit-tab suit-tab-slices'
class PlanetStackBaseAdmin(admin.ModelAdmin):
save_on_top = False
- exclude = ['enacted']
class SliceRoleAdmin(PlanetStackBaseAdmin):
model = SliceRole
(None, {'fields': ['sites'], 'classes':['suit-tab suit-tab-sites']}),]
suit_form_tabs =(('sites', 'Sites'),('nodes','Nodes'),('deploymentprivileges','Privileges'),('tags','Tags'))
+class ServiceAttrAsTabInline(PlStackTabularInline):
+ model = ServiceAttribute
+ fields = ['name','value']
+ extra = 0
+ suit_classes = 'suit-tab suit-tab-serviceattrs'
+
+class ServiceAttributeInline(PlStackTabularInline):
+ model = ServiceAttribute
+ fields = ['name','value']
+ extra = 0
+
+class ServiceAdmin(PlanetStackBaseAdmin):
+ list_display = ("name","enabled")
+ fieldsets = [(None, {'fields': ['name','enabled','description']})]
+ inlines = [ServiceAttributeInline,]
+
class SiteAdmin(PlanetStackBaseAdmin):
fieldsets = [
(None, {'fields': ['name', 'site_url', 'enabled', 'is_public', 'login_base', 'location'], 'classes':['suit-tab suit-tab-general']}),
qs = qs.filter(site__in=sites)
return qs
+class SliceForm(forms.ModelForm):
+ class Meta:
+ model = Slice
+ widgets = {
+ 'service': LinkedSelect
+ }
+
class SliceAdmin(PlanetStackBaseAdmin):
- fieldsets = [('Slice Details', {'fields': ['name', 'site', 'serviceClass', 'description', 'slice_url'], 'classes':['suit-tab suit-tab-general']}),]
+ form = SliceForm
+ fieldsets = [('Slice Details', {'fields': ['name', 'site', 'serviceClass', 'enabled','description', 'service', 'slice_url'], 'classes':['suit-tab suit-tab-general']}),]
list_display = ('name', 'site','serviceClass', 'slice_url')
inlines = [SlicePrivilegeInline,SliverInline, TagInline, ReservationInline,SliceNetworkInline]
class NodeAdmin(admin.ModelAdmin):
form = NodeForm
- exclude = ['enacted']
list_display = ('name', 'site', 'deployment')
list_filter = ('deployment',)
inlines = [TagInline,SliverInline]
'image': LinkedSelect
}
-class ProjectAdmin(admin.ModelAdmin):
- exclude = ['enacted']
- inlines = [TagInline]
-
-class MemberAdmin(admin.ModelAdmin):
- exclude = ['enacted']
- list_display = ['role', 'rightContent_type', 'content_type', 'content_object',]
-
class TagAdmin(admin.ModelAdmin):
- exclude = ['enacted']
- list_display = ['project', 'name', 'value', 'content_type', 'content_object',]
+ list_display = ['service', 'name', 'value', 'content_type', 'content_object',]
class SliverAdmin(PlanetStackBaseAdmin):
form = SliverForm
# The fields to be used in displaying the User model.
# These override the definitions on the base UserAdmin
# that reference specific fields on auth.User.
- list_display = ('email', 'username','firstname', 'lastname', 'is_admin', 'last_login')
+ list_display = ('email', 'firstname', 'lastname', 'is_admin', 'last_login')
+ #list_display = ('email', 'username','firstname', 'lastname', 'is_admin', 'last_login')
list_filter = ()
inlines = [SlicePrivilegeInline,SitePrivilegeInline,DeploymentPrivilegeInline]
fieldsets = (
- ('Login Details', {'fields': ('email', 'username','site','password', 'is_admin', 'public_key'), 'classes':['suit-tab suit-tab-general']}),
+ ('Login Details', {'fields': ('email', 'site','password', 'is_admin', 'public_key'), 'classes':['suit-tab suit-tab-general']}),
('Contact Information', {'fields': ('firstname','lastname','phone', 'timezone'), 'classes':['suit-tab suit-tab-contact']}),
#('Important dates', {'fields': ('last_login',)}),
)
add_fieldsets = (
(None, {
'classes': ('wide',),
- 'fields': ('email', 'username','firstname', 'lastname', 'phone', 'public_key','password1', 'password2')}
+ 'fields': ('email', 'firstname', 'lastname', 'phone', 'public_key','password1', 'password2')}
),
)
search_fields = ('email',)
return super(UserAdmin, self).formfield_for_foreignkey(db_field, request, **kwargs)
class ServiceResourceInline(admin.TabularInline):
- exclude = ['enacted']
model = ServiceResource
extra = 0
class ServiceClassAdmin(admin.ModelAdmin):
- exclude = ['enacted']
list_display = ('name', 'commitment', 'membershipFee')
inlines = [ServiceResourceInline]
class ReservedResourceInline(admin.TabularInline):
- exclude = ['enacted']
model = ReservedResource
extra = 0
suit_classes = 'suit-tab suit-tab-reservedresources'
return False
class ReservationAdmin(admin.ModelAdmin):
- exclude = ['enacted']
- fieldsets = [('Reservation Details', {'fields': ['startTime', 'duration','slice'], 'classes': ['suit-tab suit-tab-general']})]
+ fieldsets = [('Reservation Details', {'fields': ['slice', 'startTime', 'duration'], 'classes': ['suit-tab suit-tab-general']})]
list_display = ('startTime', 'duration')
form = ReservationAddForm
return []
class NetworkParameterTypeAdmin(admin.ModelAdmin):
- exclude = ['enacted']
list_display = ("name", )
class RouterAdmin(admin.ModelAdmin):
- exclude = ['enacted']
list_display = ("name", )
class RouterInline(admin.TabularInline):
- # exclude = ['enacted']
model = Router.networks.through
extra = 0
verbose_name_plural = "Routers"
suit_classes = 'suit-tab suit-tab-routers'
class NetworkParameterInline(generic.GenericTabularInline):
- exclude = ['enacted']
model = NetworkParameter
extra = 1
verbose_name_plural = "Parameters"
suit_classes = 'suit-tab suit-tab-netparams'
class NetworkSliversInline(admin.TabularInline):
- exclude = ['enacted']
readonly_fields = ("ip", )
model = NetworkSliver
extra = 0
suit_classes = 'suit-tab suit-tab-networkslivers'
class NetworkSlicesInline(admin.TabularInline):
- exclude = ['enacted']
model = NetworkSlice
extra = 0
verbose_name_plural = "Slices"
suit_classes = 'suit-tab suit-tab-networkslices'
class NetworkAdmin(admin.ModelAdmin):
- exclude = ['enacted']
list_display = ("name", "subnet", "ports", "labels")
readonly_fields = ("subnet", )
('routers','Routers'),
)
class NetworkTemplateAdmin(admin.ModelAdmin):
- exclude = ['enacted']
list_display = ("name", "guaranteedBandwidth", "visibility")
# register a signal that caches the user's credentials when they log in
request.session['auth'] = auth
user_logged_in.connect(cache_credentials)
+
# Now register the new UserAdmin...
admin.site.register(User, UserAdmin)
# ... and, since we're not using Django's builtin permissions,
# unregister the Group model from admin.
-admin.site.unregister(Group)
+#admin.site.unregister(Group)
#Do not show django evolution in the admin interface
from django_evolution.models import Version, Evolution
admin.site.register(Deployment, DeploymentAdmin)
admin.site.register(Site, SiteAdmin)
admin.site.register(Slice, SliceAdmin)
-admin.site.register(Project, ProjectAdmin)
admin.site.register(ServiceClass, ServiceClassAdmin)
+admin.site.register(Service, ServiceAdmin)
admin.site.register(Reservation, ReservationAdmin)
admin.site.register(Network, NetworkAdmin)
admin.site.register(Router, RouterAdmin)
if showAll:
#admin.site.register(PlanetStack)
admin.site.register(Tag, TagAdmin)
+ admin.site.register(DeploymentRole)
+ admin.site.register(SiteRole)
+ admin.site.register(SliceRole)
+ admin.site.register(PlanetStackRole)
admin.site.register(Node, NodeAdmin)
#admin.site.register(SlicePrivilege, SlicePrivilegeAdmin)
#admin.site.register(SitePrivilege, SitePrivilegeAdmin)
- admin.site.register(Member, MemberAdmin)
admin.site.register(Sliver, SliverAdmin)
admin.site.register(Image, ImageAdmin)