login_ctrl.ts 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. import _ from 'lodash';
  2. import coreModule from '../core_module';
  3. import config from 'app/core/config';
  4. export class LoginCtrl {
  5. /** @ngInject */
  6. constructor($scope, backendSrv, contextSrv, $location) {
  7. $scope.formModel = {
  8. user: '',
  9. email: '',
  10. password: '',
  11. };
  12. $scope.command = {};
  13. $scope.result = '';
  14. $scope.loggingIn = false;
  15. contextSrv.sidemenu = false;
  16. $scope.oauth = config.oauth;
  17. $scope.oauthEnabled = _.keys(config.oauth).length > 0;
  18. $scope.ldapEnabled = config.ldapEnabled;
  19. $scope.authProxyEnabled = config.authProxyEnabled;
  20. $scope.disableLoginForm = config.disableLoginForm;
  21. $scope.disableUserSignUp = config.disableUserSignUp;
  22. $scope.loginHint = config.loginHint;
  23. $scope.loginMode = true;
  24. $scope.submitBtnText = 'Log in';
  25. $scope.init = () => {
  26. $scope.$watch('loginMode', $scope.loginModeChanged);
  27. if (config.loginError) {
  28. $scope.appEvent('alert-warning', ['Login Failed', config.loginError]);
  29. }
  30. };
  31. $scope.submit = () => {
  32. if ($scope.loginMode) {
  33. $scope.login();
  34. } else {
  35. $scope.signUp();
  36. }
  37. };
  38. $scope.changeView = () => {
  39. const loginView = document.querySelector('#login-view');
  40. const changePasswordView = document.querySelector('#change-password-view');
  41. loginView.className += ' add';
  42. setTimeout(() => {
  43. loginView.className += ' hidden';
  44. }, 250);
  45. setTimeout(() => {
  46. changePasswordView.classList.remove('hidden');
  47. }, 251);
  48. setTimeout(() => {
  49. changePasswordView.classList.remove('remove');
  50. }, 301);
  51. setTimeout(() => {
  52. document.getElementById('newPassword').focus();
  53. }, 400);
  54. };
  55. $scope.changePassword = () => {
  56. $scope.command.oldPassword = 'admin';
  57. if ($scope.command.newPassword !== $scope.command.confirmNew) {
  58. $scope.appEvent('alert-warning', ['New passwords do not match', '']);
  59. return;
  60. }
  61. backendSrv.put('/api/user/password', $scope.command).then(() => {
  62. $scope.toGrafana();
  63. });
  64. };
  65. $scope.skip = () => {
  66. $scope.toGrafana();
  67. };
  68. $scope.loginModeChanged = newValue => {
  69. $scope.submitBtnText = newValue ? 'Log in' : 'Sign up';
  70. };
  71. $scope.signUp = () => {
  72. if (!$scope.loginForm.$valid) {
  73. return;
  74. }
  75. backendSrv.post('/api/user/signup', $scope.formModel).then(result => {
  76. if (result.status === 'SignUpCreated') {
  77. $location.path('/signup').search({ email: $scope.formModel.email });
  78. } else {
  79. window.location.href = config.appSubUrl + '/';
  80. }
  81. });
  82. };
  83. $scope.login = () => {
  84. delete $scope.loginError;
  85. if (!$scope.loginForm.$valid) {
  86. return;
  87. }
  88. $scope.loggingIn = true;
  89. backendSrv
  90. .post('/login', $scope.formModel)
  91. .then(result => {
  92. $scope.result = result;
  93. if ($scope.formModel.password !== 'admin' || $scope.ldapEnabled || $scope.authProxyEnabled) {
  94. $scope.toGrafana();
  95. return;
  96. } else {
  97. $scope.changeView();
  98. }
  99. })
  100. .catch(() => {
  101. $scope.loggingIn = false;
  102. });
  103. };
  104. $scope.toGrafana = () => {
  105. const params = $location.search();
  106. if (params.redirect && params.redirect[0] === '/') {
  107. window.location.href = config.appSubUrl + params.redirect;
  108. } else if ($scope.result.redirectUrl) {
  109. window.location.href = $scope.result.redirectUrl;
  110. } else {
  111. window.location.href = config.appSubUrl + '/';
  112. }
  113. };
  114. $scope.init();
  115. }
  116. }
  117. coreModule.controller('LoginCtrl', LoginCtrl);