Merge pull request #1769 from normanjaeckel/LoginLogout

Fixed login and logout view.
This commit is contained in:
Oskar Hahn 2015-12-12 09:30:00 +01:00
commit fae3747da6
3 changed files with 26 additions and 30 deletions

View File

@ -558,14 +558,14 @@ angular.module('OpenSlidesApp.users.site', ['OpenSlidesApp.users'])
'/users/setpassword/', '/users/setpassword/',
{'old_password': $scope.oldPassword, 'new_password': $scope.newPassword} {'old_password': $scope.oldPassword, 'new_password': $scope.newPassword}
).then( ).then(
function(data) { function (response) {
// Success. // Success.
$state.go('users.user.list'); $state.go('users.user.list');
}, },
function(data) { function (response) {
// Error, e. g. wrong old password. // Error, e. g. wrong old password.
$scope.oldPassword = $scope.newPassword = $scope.newPassword2 = ''; $scope.oldPassword = $scope.newPassword = $scope.newPassword2 = '';
$scope.formError = data; $scope.formError = response.data.detail;
} }
); );
} }
@ -712,8 +712,8 @@ angular.module('OpenSlidesApp.users.site', ['OpenSlidesApp.users'])
'operator', 'operator',
'ngDialog', 'ngDialog',
function($scope, $http, DS, User, operator, ngDialog) { function($scope, $http, DS, User, operator, ngDialog) {
$scope.logout = function() { $scope.logout = function () {
$http.post('/users/logout/').success(function(data) { $http.post('/users/logout/').then(function (response) {
operator.setUser(null); operator.setUser(null);
// TODO: remove all data from cache and reload page // TODO: remove all data from cache and reload page
// DS.flush(); // DS.flush();
@ -750,18 +750,20 @@ angular.module('OpenSlidesApp.users.site', ['OpenSlidesApp.users'])
$http.post( $http.post(
'/users/login/', '/users/login/',
{'username': $scope.username, 'password': $scope.password} {'username': $scope.username, 'password': $scope.password}
).success(function(data) { ).then(
if (data.success) { function (response) {
operator.setUser(data.user_id); // Success: User logged in.
operator.setUser(response.data.user_id);
$scope.closeThisDialog(); $scope.closeThisDialog();
} else { },
function (response) {
// Error: Username or password is not correct.
$scope.alerts.push({ $scope.alerts.push({
type: 'danger', type: 'danger',
msg: gettextCatalog.getString('Username or password was not correct.') msg: response.data.detail
}); });
//Username or password is not correct.
} }
}); );
}; };
// guest login // guest login
$scope.guestLogin = function () { $scope.guestLogin = function () {

View File

@ -195,17 +195,13 @@ class UserLoginView(APIView):
def post(self, *args, **kwargs): def post(self, *args, **kwargs):
form = AuthenticationForm(self.request, data=self.request.data) form = AuthenticationForm(self.request, data=self.request.data)
if form.is_valid(): if not form.is_valid():
raise ValidationError({'detail': _('Username or password is not correct.')})
self.user = form.get_user() self.user = form.get_user()
auth_login(self.request, self.user) auth_login(self.request, self.user)
self.success = True
else:
self.success = False
return super().post(*args, **kwargs) return super().post(*args, **kwargs)
def get_context_data(self, **context): def get_context_data(self, **context):
context['success'] = self.success
if self.success:
context['user_id'] = self.user.pk context['user_id'] = self.user.pk
return super().get_context_data(**context) return super().get_context_data(**context)
@ -217,6 +213,8 @@ class UserLogoutView(APIView):
http_method_names = ['post'] http_method_names = ['post']
def post(self, *args, **kwargs): def post(self, *args, **kwargs):
if not self.request.user.is_authenticated():
raise ValidationError({'detail': _('You are not authenticated.')})
auth_logout(self.request) auth_logout(self.request)
return super().post(*args, **kwargs) return super().post(*args, **kwargs)
@ -250,7 +248,7 @@ class SetPasswordView(APIView):
user.set_password(request.data['new_password']) user.set_password(request.data['new_password'])
user.save() user.save()
else: else:
raise ValidationError(_('Password does not match.')) raise ValidationError({'detail': _('Old password does not match.')})
return super().post(request, *args, **kwargs) return super().post(request, *args, **kwargs)

View File

@ -43,7 +43,7 @@ class TestUserLogoutView(TestCase):
def test_post_anonymous(self): def test_post_anonymous(self):
response = self.client.post(self.url) response = self.client.post(self.url)
self.assertEqual(response.status_code, 200) self.assertEqual(response.status_code, 400)
def test_post_authenticated_user(self): def test_post_authenticated_user(self):
self.client.login(username='admin', password='admin') self.client.login(username='admin', password='admin')
@ -69,8 +69,7 @@ class TestUserLoginView(TestCase):
def test_post_no_data(self): def test_post_no_data(self):
response = self.client.post(self.url) response = self.client.post(self.url)
self.assertEqual(response.status_code, 200) self.assertEqual(response.status_code, 400)
self.assertEqual(response.content, b'{"success":false}')
def test_post_correct_data(self): def test_post_correct_data(self):
response = self.client.post( response = self.client.post(
@ -80,17 +79,14 @@ class TestUserLoginView(TestCase):
self.assertEqual(response.status_code, 200) self.assertEqual(response.status_code, 200)
self.assertEqual( self.assertEqual(
json.loads(response.content.decode('utf-8')), json.loads(response.content.decode('utf-8')),
{'success': True, 'user_id': 1}) {'user_id': 1})
def test_post_incorrect_data(self): def test_post_incorrect_data(self):
response = self.client.post( response = self.client.post(
self.url, self.url,
{'username': 'wrong', 'password': 'wrong'}) {'username': 'wrong', 'password': 'wrong'})
self.assertEqual(response.status_code, 200) self.assertEqual(response.status_code, 400)
self.assertEqual(
json.loads(response.content.decode('utf-8')),
{'success': False})
class TestUsersPasswordsPDF(TestCase): class TestUsersPasswordsPDF(TestCase):