-from django.db import models as m
-from django.contrib.auth.models import User
-from django.contrib.auth.models import AnonymousUser
-from datetime import datetime
-from genshi import Markup
-from django.utils.translation import ugettext as _
import re
import random
-from django.utils import simplejson
+
+from django.db import models as m
+from django.db.models import Q
+from django.contrib.auth.models import User
+from django.contrib.auth.models import AnonymousUser
+from datetime import datetime
+from genshi import Markup
+from django.utils.translation import ugettext as _
+from django.utils import simplejson
from conifer.plumbing.genshi_support import get_request
+
# campus and library integration
-from conifer.plumbing.hooksystem import *
-from django.conf import settings
+from conifer.plumbing.hooksystem import *
+from django.conf import settings
campus = settings.CAMPUS_INTEGRATION
-# TODO: fixme, not sure if conifer.custom is a good parent.
import conifer.libsystems.z3950.marcxml as MX
-from django.utils import simplejson as json
+from django.utils import simplejson as json
#----------------------------------------------------------------------
class Meta:
unique_together = (('course', 'term', 'owner'))
+ ordering = ['-term__start', 'course__code']
def __unicode__(self):
return u'%s: %s (%s, %s)' % (
or (self.access == 'LOGIN' and user.is_authenticated()) \
or user.is_staff \
or self.is_member(user)
-
+
+
+ #--------------------------------------------------
+
+ @classmethod
+ def filter_for_user(cls, user):
+ """
+ Given a user object, return an appropriate Q filter that would
+ filter only Sites that the user has permission to view.
+ """
+ if user.is_anonymous():
+ return Q(access='ANON')
+ elif user.is_staff:
+ return Q()
+ else:
+ return (Q(access__in=('LOGIN','ANON')) \
+ | Q(group__membership__user=user))
+
#------------------------------------------------------------
# User membership in sites
fileobj_mimetype = m.CharField(max_length=128, blank=True, null=True)
+ class Meta:
+ ordering = ['title', 'author', 'published']
+
#--------------------------------------------------
# MARC
def marc_as_dict(self):
return hl_author
+ @classmethod
+ def filter_for_user(cls, user):
+ """
+ Given a user object, return an appropriate Q filter that would
+ filter only Items that the user has permission to view.
+ """
+ if user.is_anonymous():
+ return Q(site__access='ANON')
+ elif user.is_staff:
+ return Q()
+ else:
+ return (Q(site__access__in=('LOGIN','ANON')) \
+ | Q(site__group__membership__user=user))
+
+
#------------------------------------------------------------
# TODO: move this to a utility module.
_('The page you requested could not be found'))
return HttpResponse(msg._container, status=404)
-#-----------------------------------------------------------
-
-def user_filters(user):
- """Returns a dict of filters for Item, Site, etc. querysets,
- based on the given user's permissions."""
- # TODO, figure out a way of EXPLAIN'ing these queries! I have no
- # idea of their complexity.
- if user.is_anonymous():
- # then only anonymous-access sites are available.
- filters = {'items': Q(site__access='ANON'),
- 'sites': Q(access='ANON'),
- 'instructors': Q(), # TODO: do we really need a filter here?
- }
- else:
- # logged-in users have access to sites which are of the
- # LOGIN class ('all logged-in users') or in which they
- # have explicit Member-ship.
- filters = {
- 'items': (Q(site__access__in=('LOGIN','ANON')) \
- | Q(site__group__membership__user=user)),
- 'sites': (Q(access__in=('LOGIN','ANON')) | Q(group__membership__user=user)),
- 'instructors': Q(), # TODO: do we really need a filter here?
- }
- return filters
#------------------------------------------------------------
template = 'browse_index.xhtml'
elif browse_option == 'instructors':
queryset = models.User.active_instructors()
+ # TODO: fixme, user_filters is no more.
queryset = queryset.filter(user_filters(request.user)['instructors'])
template = 'instructors.xhtml'
elif browse_option == 'departments':
queryset = models.Department.objects.filter(active=True)
template = 'departments.xhtml'
elif browse_option == 'courses':
- # fixme, course filter should not be (active=True) but based on user identity.
+ # TODO: fixme, course filter should not be (active=True) but based on user identity.
+ # TODO: fixme, user_filters is no more.
for_courses = user_filters(request.user)['courses']
queryset = models.Site.objects.filter(for_courses)
template = 'courses.xhtml'
'''
sites = models.Site.objects.filter(member__user=instructor_id,
member__role='INSTR')
+ # TODO: fixme, user_filters is no more.
filters = user_filters(request.user)
courses = courses.filter(filters['courses'])
paginator = Paginator(courses.order_by('title'), count)