Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
itminedu
synnefo
Commits
761e62df
Commit
761e62df
authored
Jun 01, 2012
by
Sofia Papagiannaki
Browse files
register email returned by shibboleth (either as a primary or additional email)
Refs: #2416
parent
a4705138
Changes
5
Hide whitespace changes
Inline
Side-by-side
snf-astakos-app/astakos/im/forms.py
View file @
761e62df
...
...
@@ -195,7 +195,7 @@ class ThirdPartyUserCreationForm(forms.ModelForm):
if
get_latest_terms
():
self
.
fields
.
keyOrder
.
append
(
'has_signed_terms'
)
#set readonly form fields
ro
=
[
"third_party_identifier"
,
"first_name"
,
"last_name"
]
ro
=
[
"third_party_identifier"
]
for
f
in
ro
:
self
.
fields
[
f
].
widget
.
attrs
[
'readonly'
]
=
True
...
...
@@ -255,6 +255,16 @@ class InvitedThirdPartyUserCreationForm(ThirdPartyUserCreationForm):
return
user
class
ShibbolethUserCreationForm
(
ThirdPartyUserCreationForm
):
additional_email
=
forms
.
CharField
(
widget
=
forms
.
HiddenInput
(),
label
=
''
,
required
=
False
)
def
__init__
(
self
,
*
args
,
**
kwargs
):
super
(
ShibbolethUserCreationForm
,
self
).
__init__
(
*
args
,
**
kwargs
)
self
.
fields
.
keyOrder
.
append
(
'additional_email'
)
# copy email value to additional_mail in case user will change it
name
=
'email'
field
=
self
.
fields
[
name
]
self
.
initial
[
'additional_email'
]
=
self
.
initial
.
get
(
name
,
field
.
initial
)
def
clean_email
(
self
):
email
=
self
.
cleaned_data
[
'email'
]
for
user
in
AstakosUser
.
objects
.
filter
(
email
=
email
):
...
...
snf-astakos-app/astakos/im/migrations/0012_auto__add_additionalmail.py
0 → 100644
View file @
761e62df
# encoding: utf-8
import
datetime
from
south.db
import
db
from
south.v2
import
SchemaMigration
from
django.db
import
models
class
Migration
(
SchemaMigration
):
def
forwards
(
self
,
orm
):
# Adding model 'AdditionalMail'
db
.
create_table
(
'im_additionalmail'
,
(
(
'id'
,
self
.
gf
(
'django.db.models.fields.AutoField'
)(
primary_key
=
True
)),
(
'owner'
,
self
.
gf
(
'django.db.models.fields.related.ForeignKey'
)(
to
=
orm
[
'im.AstakosUser'
])),
(
'email'
,
self
.
gf
(
'django.db.models.fields.EmailField'
)(
unique
=
True
,
max_length
=
75
)),
))
db
.
send_create_signal
(
'im'
,
[
'AdditionalMail'
])
def
backwards
(
self
,
orm
):
# Deleting model 'AdditionalMail'
db
.
delete_table
(
'im_additionalmail'
)
models
=
{
'auth.group'
:
{
'Meta'
:
{
'object_name'
:
'Group'
},
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'name'
:
(
'django.db.models.fields.CharField'
,
[],
{
'unique'
:
'True'
,
'max_length'
:
'80'
}),
'permissions'
:
(
'django.db.models.fields.related.ManyToManyField'
,
[],
{
'to'
:
"orm['auth.Permission']"
,
'symmetrical'
:
'False'
,
'blank'
:
'True'
})
},
'auth.permission'
:
{
'Meta'
:
{
'ordering'
:
"('content_type__app_label', 'content_type__model', 'codename')"
,
'unique_together'
:
"(('content_type', 'codename'),)"
,
'object_name'
:
'Permission'
},
'codename'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'100'
}),
'content_type'
:
(
'django.db.models.fields.related.ForeignKey'
,
[],
{
'to'
:
"orm['contenttypes.ContentType']"
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'name'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'50'
})
},
'auth.user'
:
{
'Meta'
:
{
'object_name'
:
'User'
},
'date_joined'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'default'
:
'datetime.datetime.now'
}),
'email'
:
(
'django.db.models.fields.EmailField'
,
[],
{
'max_length'
:
'75'
,
'blank'
:
'True'
}),
'first_name'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'30'
,
'blank'
:
'True'
}),
'groups'
:
(
'django.db.models.fields.related.ManyToManyField'
,
[],
{
'to'
:
"orm['auth.Group']"
,
'symmetrical'
:
'False'
,
'blank'
:
'True'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'is_active'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'True'
}),
'is_staff'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'is_superuser'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'last_login'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'default'
:
'datetime.datetime.now'
}),
'last_name'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'30'
,
'blank'
:
'True'
}),
'password'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'128'
}),
'user_permissions'
:
(
'django.db.models.fields.related.ManyToManyField'
,
[],
{
'to'
:
"orm['auth.Permission']"
,
'symmetrical'
:
'False'
,
'blank'
:
'True'
}),
'username'
:
(
'django.db.models.fields.CharField'
,
[],
{
'unique'
:
'True'
,
'max_length'
:
'30'
})
},
'contenttypes.contenttype'
:
{
'Meta'
:
{
'ordering'
:
"('name',)"
,
'unique_together'
:
"(('app_label', 'model'),)"
,
'object_name'
:
'ContentType'
,
'db_table'
:
"'django_content_type'"
},
'app_label'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'100'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'model'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'100'
}),
'name'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'100'
})
},
'im.additionalmail'
:
{
'Meta'
:
{
'object_name'
:
'AdditionalMail'
},
'email'
:
(
'django.db.models.fields.EmailField'
,
[],
{
'unique'
:
'True'
,
'max_length'
:
'75'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'owner'
:
(
'django.db.models.fields.related.ForeignKey'
,
[],
{
'to'
:
"orm['im.AstakosUser']"
})
},
'im.approvalterms'
:
{
'Meta'
:
{
'object_name'
:
'ApprovalTerms'
},
'date'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'default'
:
'datetime.datetime(2012, 6, 1, 10, 5, 42, 665990)'
,
'db_index'
:
'True'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'location'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'255'
})
},
'im.astakosuser'
:
{
'Meta'
:
{
'object_name'
:
'AstakosUser'
,
'_ormbases'
:
[
'auth.User'
]},
'activation_sent'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
,
'blank'
:
'True'
}),
'affiliation'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'255'
,
'blank'
:
'True'
}),
'auth_token'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'32'
,
'null'
:
'True'
,
'blank'
:
'True'
}),
'auth_token_created'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
}),
'auth_token_expires'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
}),
'date_signed_terms'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
,
'blank'
:
'True'
}),
'email_verified'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'has_credits'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'has_signed_terms'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'invitations'
:
(
'django.db.models.fields.IntegerField'
,
[],
{
'default'
:
'100'
}),
'is_verified'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'level'
:
(
'django.db.models.fields.IntegerField'
,
[],
{
'default'
:
'0'
}),
'provider'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'255'
,
'blank'
:
'True'
}),
'third_party_identifier'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'255'
,
'null'
:
'True'
,
'blank'
:
'True'
}),
'updated'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{}),
'user_ptr'
:
(
'django.db.models.fields.related.OneToOneField'
,
[],
{
'to'
:
"orm['auth.User']"
,
'unique'
:
'True'
,
'primary_key'
:
'True'
})
},
'im.emailchange'
:
{
'Meta'
:
{
'object_name'
:
'EmailChange'
},
'activation_key'
:
(
'django.db.models.fields.CharField'
,
[],
{
'unique'
:
'True'
,
'max_length'
:
'40'
,
'db_index'
:
'True'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'new_email_address'
:
(
'django.db.models.fields.EmailField'
,
[],
{
'max_length'
:
'75'
}),
'requested_at'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'default'
:
'datetime.datetime(2012, 6, 1, 10, 5, 42, 667593)'
}),
'user'
:
(
'django.db.models.fields.related.ForeignKey'
,
[],
{
'related_name'
:
"'emailchange_user'"
,
'unique'
:
'True'
,
'to'
:
"orm['im.AstakosUser']"
})
},
'im.invitation'
:
{
'Meta'
:
{
'object_name'
:
'Invitation'
},
'code'
:
(
'django.db.models.fields.BigIntegerField'
,
[],
{
'db_index'
:
'True'
}),
'consumed'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
,
'blank'
:
'True'
}),
'created'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'auto_now_add'
:
'True'
,
'blank'
:
'True'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'inviter'
:
(
'django.db.models.fields.related.ForeignKey'
,
[],
{
'related_name'
:
"'invitations_sent'"
,
'null'
:
'True'
,
'to'
:
"orm['im.AstakosUser']"
}),
'is_consumed'
:
(
'django.db.models.fields.BooleanField'
,
[],
{
'default'
:
'False'
}),
'realname'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'255'
}),
'username'
:
(
'django.db.models.fields.CharField'
,
[],
{
'unique'
:
'True'
,
'max_length'
:
'255'
})
},
'im.service'
:
{
'Meta'
:
{
'object_name'
:
'Service'
},
'auth_token'
:
(
'django.db.models.fields.CharField'
,
[],
{
'max_length'
:
'32'
,
'null'
:
'True'
,
'blank'
:
'True'
}),
'auth_token_created'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
}),
'auth_token_expires'
:
(
'django.db.models.fields.DateTimeField'
,
[],
{
'null'
:
'True'
}),
'icon'
:
(
'django.db.models.fields.FilePathField'
,
[],
{
'max_length'
:
'100'
,
'blank'
:
'True'
}),
'id'
:
(
'django.db.models.fields.AutoField'
,
[],
{
'primary_key'
:
'True'
}),
'name'
:
(
'django.db.models.fields.CharField'
,
[],
{
'unique'
:
'True'
,
'max_length'
:
'255'
}),
'url'
:
(
'django.db.models.fields.FilePathField'
,
[],
{
'max_length'
:
'100'
})
}
}
complete_apps
=
[
'im'
]
snf-astakos-app/astakos/im/models.py
View file @
761e62df
...
...
@@ -364,6 +364,13 @@ class Service(models.Model):
self
.
auth_token_expires
=
self
.
auth_token_created
+
\
timedelta
(
hours
=
AUTH_TOKEN_DURATION
)
class
AdditionalMail
(
models
.
Model
):
"""
Model for registring invitations
"""
owner
=
models
.
ForeignKey
(
AstakosUser
)
email
=
models
.
EmailField
(
unique
=
True
)
def
create_astakos_user
(
u
):
try
:
AstakosUser
.
objects
.
get
(
user_ptr
=
u
.
pk
)
...
...
snf-astakos-app/astakos/im/target/shibboleth.py
View file @
761e62df
...
...
@@ -35,11 +35,12 @@ from django.http import HttpResponseBadRequest
from
django.utils.translation
import
ugettext
as
_
from
django.contrib
import
messages
from
django.template
import
RequestContext
from
django.forms.models
import
inlineformset_factory
from
astakos.im.util
import
prepare_response
,
get_context
,
get_invitation
from
astakos.im.views
import
requires_anonymous
,
render_response
from
astakos.im.settings
import
DEFAULT_USER_LEVEL
from
astakos.im.models
import
AstakosUser
,
Invitation
from
astakos.im.models
import
AstakosUser
,
Invitation
,
AdditionalMail
from
astakos.im.forms
import
LoginForm
from
astakos.im.activation_backends
import
get_backend
,
SimpleBackend
...
...
@@ -52,6 +53,7 @@ class Tokens:
SHIB_DISPLAYNAME
=
"HTTP_SHIB_INETORGPERSON_DISPLAYNAME"
SHIB_EP_AFFILIATION
=
"HTTP_SHIB_EP_AFFILIATION"
SHIB_SESSION_ID
=
"HTTP_SHIB_SESSION_ID"
SHIB_MAIL
=
"HTTP_SHIB_MAIL"
@
requires_anonymous
def
login
(
request
,
backend
=
None
,
on_login_template
=
'im/login.html'
,
on_creation_template
=
'im/third_party_registration.html'
,
extra_context
=
{}):
...
...
@@ -72,6 +74,7 @@ def login(request, backend=None, on_login_template='im/login.html', on_creation
return
HttpResponseBadRequest
(
"Missing user name in request"
)
affiliation
=
tokens
.
get
(
Tokens
.
SHIB_EP_AFFILIATION
,
''
)
email
=
tokens
.
get
(
Tokens
.
SHIB_MAIL
,
None
)
try
:
user
=
AstakosUser
.
objects
.
get
(
provider
=
'shibboleth'
,
third_party_identifier
=
eppn
)
...
...
@@ -88,7 +91,8 @@ def login(request, backend=None, on_login_template='im/login.html', on_creation
context_instance
=
RequestContext
(
request
))
except
AstakosUser
.
DoesNotExist
,
e
:
user
=
AstakosUser
(
third_party_identifier
=
eppn
,
realname
=
realname
,
affiliation
=
affiliation
,
provider
=
'shibboleth'
)
affiliation
=
affiliation
,
provider
=
'shibboleth'
,
email
=
email
)
try
:
if
not
backend
:
backend
=
get_backend
(
request
)
...
...
@@ -96,8 +100,6 @@ def login(request, backend=None, on_login_template='im/login.html', on_creation
except
Exception
,
e
:
form
=
SimpleBackend
(
request
).
get_signup_form
(
provider
=
'shibboleth'
,
instance
=
user
)
messages
.
add_message
(
request
,
messages
.
ERROR
,
e
)
form
.
data
.
update
({
'third_party_identifier'
:
eppn
,
'realname'
:
realname
,
'affiliation'
:
affiliation
})
return
render_response
(
on_creation_template
,
signup_form
=
form
,
provider
=
'shibboleth'
,
...
...
snf-astakos-app/astakos/im/views.py
View file @
761e62df
...
...
@@ -326,6 +326,10 @@ def signup(request, template_name='im/signup.html', on_success='im/signup_comple
status
=
messages
.
SUCCESS
message
=
result
.
message
user
.
save
()
if
'additional_email'
in
form
.
cleaned_data
:
additional_email
=
form
.
cleaned_data
[
'additional_email'
]
if
additional_email
!=
user
.
email
:
user
.
additionalmail_set
.
create
(
email
=
additional_email
)
if
user
and
user
.
is_active
:
next
=
request
.
POST
.
get
(
'next'
,
''
)
return
prepare_response
(
request
,
user
,
next
=
next
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment