Merge pull request #1769 from normanjaeckel/LoginLogout
Fixed login and logout view.
This commit is contained in:
commit
fae3747da6
@ -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 () {
|
||||||
|
@ -195,18 +195,14 @@ 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():
|
||||||
self.user = form.get_user()
|
raise ValidationError({'detail': _('Username or password is not correct.')})
|
||||||
auth_login(self.request, self.user)
|
self.user = form.get_user()
|
||||||
self.success = True
|
auth_login(self.request, self.user)
|
||||||
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
|
context['user_id'] = self.user.pk
|
||||||
if self.success:
|
|
||||||
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)
|
||||||
|
|
||||||
|
|
||||||
|
@ -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):
|
||||||
|
Loading…
Reference in New Issue
Block a user