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 test_get_user_activation(self): from pyramid_signup.models import Activation from pyramid_signup.managers import ActivationManager from pyramid_signup.managers import UserManager from pyramid_signup.models import User 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 = ActivationManager(request) user_mgr = UserManager(request) new_user = user_mgr.get_by_username('sontek2') new_activation = mgr.get_by_code(activation.code) assert activation == new_activation assert new_user.activation == new_activation
def test_activate_invalid(self): from pyramid_signup.views import RegisterController from pyramid_signup.models import User from pyramid_signup.models import Activation from pyramid_mailer.interfaces import IMailer from pyramid_mailer.mailer import DummyMailer from pyramid_signup.managers import UserManager self.config.include('pyramid_signup') self.config.add_route('index', '/') self.config.registry.registerUtility(DummyMailer(), IMailer) user = User(username='******', password='******') user.activation = Activation() self.session.add(user) self.session.flush() request = testing.DummyRequest() request.matchdict = Mock() get = Mock() get.return_value = 'invalid' request.matchdict.get = get controller = RegisterController(request) response = controller.activate() mgr = UserManager(request) user = mgr.get_by_username('sontek') assert not user.activated assert response.status_int == 404
def test_register_creates_user(self): from pyramid_signup.views import RegisterController from pyramid_mailer.mailer import DummyMailer from pyramid_mailer.interfaces import IMailer from pyramid_signup.managers import UserManager self.config.include('pyramid_signup') self.config.registry.registerUtility(DummyMailer(), IMailer) self.config.add_route('index', '/') request = self.get_csrf_request(post={ 'Username': '******', 'Password': { 'value': 'test123', 'confirm': 'test123', }, 'Email': '*****@*****.**' }, request_method='POST') request.user = Mock() controller = RegisterController(request) response = controller.post() assert response.status_int == 302 mgr = UserManager(request) user = mgr.get_by_username('admin') assert user != None
def login(self): if self.request.method == 'GET': if self.request.user: return HTTPFound(location=self.login_redirect_view) return {'form': self.form.render()} elif self.request.method == 'POST': try: controls = self.request.POST.items() captured = self.form.validate(controls) except deform.ValidationFailure, e: return {'form': e.render(), 'errors': e.error.children} username = captured['Username'] password = captured['Password'] mgr = UserManager(self.request) user = mgr.get_user(username, password) if user: if not user.activated: self.request.session.flash( _(u'Your account is not active, please check your e-mail.' ), 'error') return {'form': self.form.render()} else: return self.authenticated(self.request, user.pk) self.request.session.flash(_('Invalid username or password.'), 'error') return {'form': self.form.render(appstruct=captured)}
def test_get_user_by_invalid_username(self): from pyramid_signup.models import User from pyramid_signup.managers import UserManager user = User(username='******', password='******') self.session.add(user) self.session.commit() request = testing.DummyRequest() mgr = UserManager(request) new_user = mgr.get_by_username('sontek1') assert new_user == None
def test_get_user_by_email(self): from pyramid_signup.models import User from pyramid_signup.managers import UserManager user = User(username='******', password='******', email='*****@*****.**') self.session.add(user) self.session.commit() request = testing.DummyRequest() mgr = UserManager(request) new_user = mgr.get_by_email(user.email) assert new_user == user
def test_register_no_email_validation(self): from pyramid_signup.views import RegisterController from pyramid_mailer.mailer import DummyMailer from pyramid_mailer.interfaces import IMailer from pyramid_signup.managers import UserManager from pyramid_signup.interfaces import ISUSession from pyramid_signup.events import NewRegistrationEvent self.config.include('pyramid_signup') self.config.registry.registerUtility(DummyMailer(), IMailer) self.config.add_route('index', '/') self.config.registry.settings['su.require_activation'] = False def handle_registration(event): request = event.request session = request.registry.getUtility(ISUSession) session.commit() self.config.add_subscriber(handle_registration, NewRegistrationEvent) request = self.get_csrf_request(post={ 'Username': '******', 'Password': { 'value': 'test123', 'confirm': 'test123', }, 'Email': '*****@*****.**' }, request_method='POST') request.user = Mock() controller = RegisterController(request) response = controller.post() assert response.status_int == 302 mgr = UserManager(request) user = mgr.get_by_username('admin') assert user.activated == True
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 user(self): pk = unauthenticated_userid(self) if pk is not None: mgr = UserManager(self) return mgr.get_by_pk(pk)
def post(self): if self.request.method == 'POST': try: controls = self.request.POST.items() captured = self.form.validate(controls) except deform.ValidationFailure, e: return {'form': e.render(), 'errors': e.error.children} email = captured['Email'] username = captured['Username'] password = captured['Password'] mgr = UserManager(self.request) user = mgr.get_by_username(username) if user: self.request.session.flash(_('That username is already used.'), 'error') return {'form': self.form.render(self.request.POST)} activation = None try: user = User(username=username, password=password, email=email) if self.require_activation: activation = Activation() self.db.add(activation) user.activation = activation body = pystache.render( _("Please activate your e-mail address by visiting {{ link }}" ), { 'link': route_url('activate', self.request, code=user.activation.code) }) subject = _("Please active your e-mail address!") message = Message(subject=subject, recipients=[user.email], body=body) self.mailer.send(message) self.request.session.flash( _('Please check your E-mail for an activation link'), 'success') else: user.activated = True self.db.add(user) self.db.flush() except Exception as exc: self.request.session.flash(exc.message, 'error') return {'form': self.form.render()} self.request.registry.notify( NewRegistrationEvent(self.request, user, activation, controls)) return HTTPFound(location=self.register_redirect_view)