def backend_icon(obj): # backend_status, enacted, updated):
#return "%s %s %s" % (str(obj.updated), str(obj.enacted), str(obj.backend_status))
- if (obj.enacted is not None) and obj.enacted >= obj.updated:
+ if (obj.enacted is not None) and obj.enacted >= obj.updated or obj.backend_status.startswith("1 -"):
return '<span style="min-width:16px;"><img src="/static/admin/img/icon_success.gif"></span>'
else:
if ((obj.backend_status is not None) and obj.backend_status.startswith("0 -")) or obj.backend_status == "Provisioning in progress" or obj.backend_status=="":
class SliverAdmin(PlanetStackBaseAdmin):
form = SliverForm
fieldsets = [
- ('Sliver Details', {'fields': ['backend_status_text', 'slice', 'deployment', 'node', 'ip', 'instance_id', 'instance_name', 'flavor', 'image', ], 'classes': ['suit-tab suit-tab-general'], })
+ ('Sliver Details', {'fields': ['backend_status_text', 'slice', 'deployment', 'node', 'ip', 'instance_id', 'instance_name', 'flavor', 'image', 'ssh_command'], 'classes': ['suit-tab suit-tab-general'], })
]
- readonly_fields = ('backend_status_text', )
+ readonly_fields = ('backend_status_text', 'ssh_command', )
list_display = ['backend_status_icon', 'ip', 'instance_id', 'instance_name', 'slice', 'flavor', 'image', 'node', 'deployment']
list_display_links = ('backend_status_icon', 'ip',)
user_readonly_fields = ['slice', 'deployment', 'node', 'ip', 'instance_name', 'flavor', 'image']
+ def ssh_command(self, obj):
+ ssh_command = obj.get_ssh_command()
+ if ssh_command:
+ return ssh_command
+ else:
+ return "(not available)"
+
def formfield_for_foreignkey(self, db_field, request, **kwargs):
if db_field.name == 'slice':
kwargs['queryset'] = Slice.select_by_user(request.user)
def get_formsets(self, request, obj=None):
# make some fields read only if we are updating an existing record
if obj == None:
- #self.readonly_fields = ('ip', 'instance_name')
- self.readonly_fields = ('backend_status_text',)
+ self.readonly_fields = ('backend_status_text', 'ssh_command', )
else:
- self.readonly_fields = ('backend_status_text',)
- #self.readonly_fields = ('ip', 'instance_name', 'slice', 'image', 'key')
+ self.readonly_fields = ('backend_status_text', 'ssh_command',)
for inline in self.get_inline_instances(request, obj):
# hide MyInline in the add view
list_display = ('backend_status_icon', 'email', 'firstname', 'lastname', 'site', 'last_login')
list_display_links = ("email",)
list_filter = ('site',)
- inlines = [SlicePrivilegeInline,SitePrivilegeInline,UserDashboardViewInline]
+ inlines = [SlicePrivilegeInline,SitePrivilegeInline]
admin_inlines = [ControllerUserInline]
fieldListLoginDetails = ['backend_status_text', 'email','site','password','is_active','is_readonly','is_admin','public_key']
fieldListContactInfo = ['firstname','lastname','phone','timezone']
fieldsets = (
('Login Details', {'fields': ['backend_status_text', 'email', 'site','password', 'is_active', 'is_readonly', 'is_admin', 'public_key'], 'classes':['suit-tab suit-tab-general']}),
('Contact Information', {'fields': ('firstname','lastname','phone', 'timezone'), 'classes':['suit-tab suit-tab-contact']}),
- #('Dashboard Views', {'fields': ('dashboards',), 'classes':['suit-tab suit-tab-dashboards']}),
#('Important dates', {'fields': ('last_login',)}),
)
add_fieldsets = (
(None, {
'classes': ('wide',),
- 'fields': ('site', 'email', 'firstname', 'lastname', 'is_admin','is_admin', 'is_readonly', 'phone', 'public_key','password1', 'password2')},
+ 'fields': ('site', 'email', 'firstname', 'lastname', 'is_admin', 'is_readonly', 'phone', 'public_key','password1', 'password2')},
),
)
readonly_fields = ('backend_status_text', )
tabs = [('general','Login Details'),
('contact','Contact Information'),
('sliceprivileges','Slice Privileges'),
- ('siteprivileges','Site Privileges'),
- ('dashboards','Dashboard Views')]
+ ('siteprivileges','Site Privileges')]
request=getattr(_thread_locals, "request", None)
if request and request.user.is_admin:
return User.select_by_user(request.user)
def get_form(self, request, obj=None, **kwargs):
+ # copy login details list
+ login_details_fields = list(self.fieldListLoginDetails)
if not request.user.is_admin:
- self.fieldsets = (
- ('Login Details', {'fields': ['backend_status_text', 'email', 'site','password','public_key'], 'classes':['suit-tab suit-tab-general']}),
- ('Contact Information', {'fields': ('firstname','lastname','phone', 'timezone'), 'classes':['suit-tab suit-tab-contact']}),
- )
+ # only admins can see 'is_admin' and 'is_readonly' fields
+ if 'is_admin' in login_details_fields:
+ login_details_fields.remove('is_admin')
+ if 'is_readonly' in login_details_fields:
+ login_details_fields.remove('is_readonly')
+ #if len(request.user.siteprivileges.filter(role__role = 'pi')) > 0:
+ # only admins and pis can change a user's site
+ # self.readonly_fields = ('backend_status_text', 'site')
+ self.fieldsets = (
+ ('Login Details', {'fields': login_details_fields, 'classes':['suit-tab suit-tab-general']}),
+ ('Contact Information', {'fields': self.fieldListContactInfo, 'classes':['suit-tab suit-tab-contact']}),
+ )
return super(UserAdmin, self).get_form(request, obj, **kwargs)
class ControllerDashboardViewInline(PlStackTabularInline):