@ssl_required
@login_required
def home(request):
- myarticles = NewsArticle.objects.filter(submitter=request.user)
- myevents = Event.objects.filter(submitter=request.user)
- myorgs = Organisation.objects.filter(submitter=request.user)
- myproducts = Product.objects.filter(publisher__submitter=request.user)
+ myarticles = NewsArticle.objects.filter(org__managers=request.user)
+ myevents = Event.objects.filter(org__managers=request.user)
+ myorgs = Organisation.objects.filter(managers=request.user)
+ myproducts = Product.objects.filter(publisher__managers=request.user)
return render_to_response('account/index.html', {
'newsarticles': myarticles,
'events': myevents,
list_display = ('name', 'approved', 'lastconfirmed',)
list_filter = ('approved',)
ordering = ('name', )
-
+ filter_horizontal = ('managers', )
+ search_fields = ('name', )
admin.site.register(Version)
admin.site.register(OrganisationType)
class OrganisationForm(forms.ModelForm):
class Meta:
model = Organisation
- exclude = ('lastconfirmed', 'approved', 'submitter', )
+ exclude = ('lastconfirmed', 'approved', 'managers', )
email = models.EmailField(null=False, blank=True)
phone = models.CharField(max_length=100, null=False, blank=True)
orgtype = models.ForeignKey(OrganisationType, null=False, blank=False)
- submitter = models.ForeignKey(User, null=False, blank=False)
+ managers = models.ManyToManyField(User, null=False, blank=False)
lastconfirmed = models.DateTimeField(null=False, blank=False, default=datetime.now())
send_notification = True
def __init__(self, *args, **kwargs):
super(ProductForm, self).__init__(*args, **kwargs)
def filter_by_user(self, user):
- print "Filter to user %s" % user
- self.fields['publisher'].queryset = Organisation.objects.filter(submitter=user)
+ self.fields['publisher'].queryset = Organisation.objects.filter(managers=user, approved=True)
class Meta:
model = Product
exclude = ('lastconfirmed', 'approved', )
return self.name
def verify_submitter(self, user):
- return (user == self.publisher.submitter)
+ return (len(self.publisher.managers.filter(pk=user.pk)) == 1)
class Meta:
ordering = ('name',)
def __init__(self, *args, **kwargs):
super(EventForm, self).__init__(*args, **kwargs)
def filter_by_user(self, user):
- self.fields['org'].queryset = Organisation.objects.filter(submitter=user)
+ self.fields['org'].queryset = Organisation.objects.filter(managers=user, approved=True)
class Meta:
model = Event
exclude = ('submitter', 'approved', )
from core.models import Country, Organisation
class Event(models.Model, PgModel):
- submitter = models.ForeignKey(User, null=False, blank=False)
approved = models.BooleanField(null=False, blank=False, default=False)
org = models.ForeignKey(Organisation, null=False, blank=False)
def __unicode__(self):
return "%s: %s" % (self.startdate, self.title)
+ def verify_submitter(self, user):
+ return (len(self.org.managers.filter(pk=user.pk)) == 1)
+
@property
- def has_submitter(self):
- # If submitter is 0 it means migrated, so have no submitter
- if self.submitter_id == 0: return False
- return True
+ def has_organisation(self):
+ mgrs = self.org.managers.all()
+ if len(mgrs) == 1:
+ if mgrs[0].pk == 0:
+ return False # Migration organisation
+ else:
+ return True # Has an actual organisation
+ return False # Has no organisastion at all
@property
def displaydate(self):
from django import forms
+from pgweb.core.models import Organisation
from models import NewsArticle
class NewsArticleForm(forms.ModelForm):
+ def __init__(self, *args, **kwargs):
+ super(NewsArticleForm, self).__init__(*args, **kwargs)
+ def filter_by_user(self, user):
+ self.fields['org'].queryset = Organisation.objects.filter(managers=user, approved=True)
class Meta:
model = NewsArticle
exclude = ('submitter', 'approved', )
from django.db import models
-from django.contrib.auth.models import User
from datetime import date
+from pgweb.core.models import Organisation
from pgweb.util.bases import PgModel
class NewsArticle(PgModel, models.Model):
- submitter = models.ForeignKey(User, null=False, blank=False)
+ org = models.ForeignKey(Organisation, null=False, blank=False)
approved = models.BooleanField(null=False, blank=False, default=False)
date = models.DateField(null=False, blank=False, default=date.today)
title = models.CharField(max_length=200, null=False, blank=False)
def __unicode__(self):
return "%s: %s" % (self.date, self.title)
+ def verify_submitter(self, user):
+ return (len(self.org.managers.filter(pk=user.pk)) == 1)
+
class Meta:
ordering = ('-date',)
<p>
{{obj.details|markdown:"safe"}}
</p>
-{%if obj.has_submitter%}
-<p>Posted by {{obj.submitter.email}}.</p>
+{%if obj.has_organisation%}
+<p>Posted by {{obj.org}}{%if obj.org.email%} ({{obj.org.email}}){%endif%}.</p>
{%else%}
<p><i>This event has been migrated from a previous version of the PostgreSQL
website. We apologise for any formatting issues caused by the migration.</i></p>