def test_get_user_by_activation_with_multiple_users(self): from pyramid_signup.models import User from pyramid_signup.models import Activation from pyramid_signup.managers import UserManager user1 = User(username='******', password='******', email='*****@*****.**') user2 = User(username='******', password='******', email='*****@*****.**') activation = Activation() user2.activation = activation self.session.add(user1) self.session.add(user2) self.session.commit() request = testing.DummyRequest() mgr = UserManager(request) new_user = mgr.get_by_activation(activation) assert new_user == user2
def reset_password(self): schema = self.request.registry.getUtility(ISUResetPasswordSchema) schema = schema().bind(request=self.request) form = self.request.registry.getUtility(ISUResetPasswordForm) form = form(schema) code = self.request.matchdict.get('code', None) act_mgr = ActivationManager(self.request) user_mgr = UserManager(self.request) activation = act_mgr.get_by_code(code) if activation: user = user_mgr.get_by_activation(activation) if user: if self.request.method == 'GET': return { 'form': form.render( appstruct=dict( Username=user.username ) ) } elif self.request.method == 'POST': try: controls = self.request.POST.items() captured = form.validate(controls) except deform.ValidationFailure, e: return {'form': e.render(), 'errors': e.error.children} password = captured['Password'] user.password = password self.db.add(user) self.db.delete(activation) self.request.registry.notify( PasswordResetEvent(self.request, user, password) ) self.request.session.flash(_('Your password has been reset!'), 'success') return HTTPFound(location=self.reset_password_redirect_view)
def test_get_user_by_activation(self): from pyramid_signup.models import User from pyramid_signup.models import Activation from pyramid_signup.managers import UserManager user = User(username="******", password="******", email="*****@*****.**") activation = Activation() user.activation = activation self.session.add(user) self.session.commit() request = testing.DummyRequest() mgr = UserManager(request) new_user = mgr.get_by_activation(activation) assert new_user == user
def activate(self): code = self.request.matchdict.get('code', None) act_mgr = ActivationManager(self.request) user_mgr = UserManager(self.request) activation = act_mgr.get_by_code(code) if activation: user = user_mgr.get_by_activation(activation) if user: self.db.delete(activation) user.activated = True self.db.add(user) self.db.flush() self.request.registry.notify( RegistrationActivatedEvent(self.request, user, activation) ) self.request.session.flash(_('Your e-mail address has been verified.'), 'success') return HTTPFound(location=self.activate_redirect_view) return HTTPNotFound()
def activate(self): code = self.request.matchdict.get('code', None) act_mgr = ActivationManager(self.request) user_mgr = UserManager(self.request) activation = act_mgr.get_by_code(code) if activation: user = user_mgr.get_by_activation(activation) if user: self.db.delete(activation) user.activated = True self.db.add(user) self.db.flush() self.request.registry.notify( RegistrationActivatedEvent(self.request, user, activation)) self.request.session.flash( _('Your e-mail address has been verified.'), 'success') return HTTPFound(location=self.activate_redirect_view) return HTTPNotFound()