summaryrefslogtreecommitdiff
path: root/coip/apps/user/models.py
blob: 9521d892ee2c9afb1979032c2f172bdd81339dd8 (plain)
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
'''
Created on Jul 5, 2010

@author: leifj
'''
from django.db import models
from django.contrib.auth.models import User
from coip.apps.name.models import Name, lookup
from coip.apps.membership.models import add_member
from django.dispatch.dispatcher import receiver
from django.db.models.signals import post_save

class Identifier(models.Model):
    
    FEDERATION=0
    EMAIL=1
    SSHKEY=2
    GRIDCERT=3
    INTERNAL=4
    
    timecreated = models.DateTimeField(auto_now_add=True)
    lastupdated = models.DateTimeField(auto_now=True)
    
    user = models.ForeignKey(User,related_name='identifiers')
    display_name = models.CharField(max_length=255,blank=True,null=True)
    type = models.SmallIntegerField(default=0,choices=((0,'Federation Identifier'),(1,'Email Address'),(2,'SSH Key'),(3,'eScience Certificate'),(4,'Internal User')))
    idp = models.CharField(max_length=255,blank=True,null=True)
    verified = models.BooleanField()
    value = models.CharField(max_length=1023)
    verification_code = models.CharField(max_length=1023,blank=True,null=True)
    
    #class Meta:
    #    unique_together = ('value','idp')
        
    def __unicode__(self):
        return "%s [%s]" % (self.value,self.display_name)

class UserProfile(models.Model):
    user = models.OneToOneField(User)
    home = models.ForeignKey(Name,blank=True,null=True,editable=False)
    identifier = models.ForeignKey(Identifier,editable=False,blank=True,null=True)
    timecreated = models.DateTimeField(auto_now_add=True)
    lastupdated = models.DateTimeField(auto_now=True)
    
    def __unicode__(self):
        return "%s" % (self.user.__unicode__())

@receiver(post_save,sender=User)
def _create_profile(sender,**kwargs):
    user = kwargs['instance']
    created = kwargs['created']
    if created:
        profile,profile_created = UserProfile.objects.get_or_create(user=user)
        urn = lookup("urn",True)
        anyuser = lookup("system:anyuser",True)
        urn.setacl(anyuser,'rl')
        profile.home = lookup('user:'+user.username,autocreate=True)
        add_member(profile.home,user,hidden=True)
        profile.home.setpacl(profile.home, "rwlida")
        profile.home.setacl(profile.home,"rwla") #don't allow users to delete or reset acls on their home, nor invite members - that would be confusing as hell
        profile.home.short = user.get_full_name()
        profile.home.save()
        profile.save()