-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsiadmin.py
executable file
·296 lines (255 loc) · 11.2 KB
/
siadmin.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
from django.contrib.admin import AdminSite,ModelAdmin
from django.views.decorators.cache import never_cache
from django.utils.text import capfirst
from django.utils.safestring import mark_safe
from django.utils.translation import ugettext as _
from django import http, template
from django.shortcuts import render_to_response
from si.forms import SessionForm
from si.models import Student,Course,Session
from django.contrib.auth.models import User,Group
from django.contrib.auth.admin import GroupAdmin,UserAdmin
from django.core.urlresolvers import reverse
import urllib2
import urllib
from django.http import HttpResponse
from settings import STATIC_URL
def generate_excel(modeladmin,request,queryset):
php_script = STATIC_URL + 'gen_excel.php'
post_data = []
count = 0;
for course in queryset:
csv = ''
csv += str(course.year) + ','
csv += str(course.term) + ','
csv += str(course.department) + ','
csv += str(course.code) + ','
csv += str(course.section) + ','
csv += str(course.professor) + ','
first_test = str(course.exam)
csv += first_test + ','
midterm = str(course.midterm)
total_sessions = str(len(Session.objects.filter(course=course)))
csv += total_sessions + ','
csv += str(course.user.first_name) + ' ' + str(course.user.last_name) + ','
studs = Student.objects.filter(course=course)
for stud in studs:
csv += str(stud.last_name) + ','
csv += str(stud.first_name) + ','
csv += str(stud.interest) + ','
csv += str(stud.taken) + ','
csv += str(stud.future) + ','
csv += str(len(Session.objects.filter(
student=stud,course=course,date__lte=first_test))) + ','
csv += str(len(Session.objects.filter(
student=stud,course=course,date__lte=midterm))) + ','
csv += str(len(Session.objects.filter(
student=stud,course=course,date__gt=midterm))) + ','
csv = csv[:-1]
post_data.append(('csv' + str(count),csv))
count += 1
result = urllib2.urlopen(php_script,urllib.urlencode(post_data))
content = result.read()
response = HttpResponse(content,content_type='Content-Type: application/vnd.ms-excel')
response['Content-Disposition'] = 'attachment; filename=report.xls'
return response
class SiAdminSite(AdminSite):
login_template = 'si/login.html'
index_template = 'si/index.html'
logout_template='si/logged_out.html'
@never_cache
def index(self, request, extra_context=None):
"""
Displays the main admin index page, which lists all of the installed
apps that have been registered in this site.
"""
app_dict = {}
user = request.user
for model, model_admin in self._registry.items():
app_label = model._meta.app_label
has_module_perms = user.has_module_perms(app_label)
if has_module_perms:
perms = model_admin.get_model_perms(request)
# Check whether user has any perm for this module.
# If so, add the module to the model_list.
if True in perms.values():
model_dict = {
'name': capfirst(model._meta.verbose_name_plural),
'admin_url': mark_safe('%s/%s/' % (app_label, model.__name__.lower())),
'perms': perms,
}
if app_label in app_dict:
app_dict[app_label]['models'].append(model_dict)
else:
app_dict[app_label] = {
'name': app_label.title(),
'app_url': app_label + '/',
'has_module_perms': has_module_perms,
'models': [model_dict],
}
# Sort the apps alphabetically.
app_list = app_dict.values()
app_list.sort(key=lambda x: x['name'])
# Sort the models alphabetically within each app.
for app in app_list:
app['models'].sort(key=lambda x: x['name'])
# change Si to SI
for app in app_list:
if app['name'] == 'Si':
app['name'] = 'SI'
context = {
'title': _('Site administration'),
'app_list': app_list,
'root_path': self.root_path,
}
context.update(extra_context or {})
context_instance = template.RequestContext(request, current_app=self.name)
return render_to_response(self.index_template or 'admin/index.html', context,
context_instance=context_instance
)
def app_index(self, request, app_label, extra_context=None):
user = request.user
has_module_perms = user.has_module_perms(app_label)
app_dict = {}
for model, model_admin in self._registry.items():
if app_label == model._meta.app_label:
if has_module_perms:
perms = model_admin.get_model_perms(request)
# Check whether user has any perm for this module.
# If so, add the module to the model_list.
if True in perms.values():
model_dict = {
'name': capfirst(model._meta.verbose_name_plural),
'admin_url': '%s/' % model.__name__.lower(),
'perms': perms,
}
if app_dict:
app_dict['models'].append(model_dict),
else:
# First time around, now that we know there's
# something to display, add in the necessary meta
# information.
name = app_label.title()
if name == 'Si':
name = 'SI'
app_dict = {
'name': name,
'app_url': '',
'has_module_perms': has_module_perms,
'models': [model_dict],
}
if not app_dict:
raise http.Http404('The requested admin page does not exist.')
# Sort the models alphabetically within each app.
app_dict['models'].sort(key=lambda x: x['name'])
title = capfirst(app_label)
if name == 'SI':
title = name
context = {
'title': _('%s administration') % title,
'app_list': [app_dict],
'root_path': self.root_path,
}
context.update(extra_context or {})
context_instance = template.RequestContext(request, current_app=self.name)
return render_to_response(self.app_index_template or ('admin/%s/app_index.html' % app_label,
'admin/app_index.html'), context,
context_instance=context_instance
)
class StudentAdmin(ModelAdmin):
search_fields= ['first_name','last_name','course__department','course__code'
,'course__section']
list_display = ('first_name','last_name','course')
#list_filter = ('course__department','course__code','course__section','course__id')
'''list_display = ('first_name','last_name','course')
list_filter = ('course__department','course__code','course__section','course__id')'''
exclude = ["user"]
def formfield_for_foreignkey(self, db_field, request, **kwargs):
if db_field.name == "course" and not request.user.is_superuser:
kwargs["queryset"] = Course.objects.filter(user=request.user)
return super(StudentAdmin, self).formfield_for_foreignkey(db_field, request, **kwargs)
def queryset(self,request):
qs = super(StudentAdmin,self).queryset(request)
if request.user.is_superuser:
return qs
else:
return qs.filter(user=request.user)
def save_model(self,request,obj,form,change):
if not request.user.is_superuser:
obj.user = request.user
obj.save()
def has_change_permission(self,request,obj=None):
if not obj:
return True
if request.user.is_superuser or obj.user == request.user:
return True
else:
return False
has_delete_permission = has_change_permission
class CourseAdmin(ModelAdmin):
exclude = ["user"]
search_fields= ['course__department','course__code','course__section']
actions = [generate_excel]
def queryset(self,request):
qs = super(CourseAdmin,self).queryset(request)
if request.user.is_superuser:
return qs
else:
return qs.filter(user=request.user)
def save_model(self,request,obj,form,change):
obj.user = request.user
obj.save()
def has_change_permission(self,request,obj=None):
if not obj:
return True
if request.user.is_superuser or obj.user == request.user:
return True
else:
return False
has_delete_permission = has_change_permission
class SessionAdmin(ModelAdmin):
list_display = ('date','signin_link','course')
exclude = ["user"]
filter_horizontal = ['student']
form = SessionForm
def signin_link(self,obj):
return u'<a href="%ssignin/%s/">%s</a>' % (str(reverse('si.views.index')),obj.id, str(obj) + ' (' + str(obj.course) + ')')
signin_link.allow_tags = True
signin_link.short_description = "Signin Page"
'''
def __init__(self,*args,**kwargs):
super(SessionAdmin,self).__init__(*args,**kwargs)
#self.list_display_links = (None,)
'''
def formfield_for_manytomany(self,db_field,request,**kwargs):
if db_field.name == 'student' and not request.user.is_superuser:
kwargs['queryset'] = Student.objects.filter(user=request.user)
return super(SessionAdmin,self).formfield_for_manytomany(db_field,request,**kwargs)
def formfield_for_foreignkey(self, db_field, request, **kwargs):
if db_field.name == 'course' and not request.user.is_superuser:
kwargs['queryset'] = Course.objects.filter(user=request.user)
return super(SessionAdmin, self).formfield_for_foreignkey(db_field, request, **kwargs)
def queryset(self,request):
qs = super(SessionAdmin,self).queryset(request)
if request.user.is_superuser:
return qs
else:
return qs.filter(user=request.user)
def save_model(self,request,obj,form,change):
if not request.user.is_superuser:
obj.user = request.user
obj.save()
def has_change_permission(self,request,obj=None):
if not obj:
return True
if request.user.is_superuser or obj.user == request.user:
return True
else:
return False
has_delete_permission = has_change_permission
site = SiAdminSite(name="SI")
site.register(Session,SessionAdmin)
site.register(Student,StudentAdmin)
site.register(Course,CourseAdmin)
site.register(User,UserAdmin)
site.register(Group,GroupAdmin)