script.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. class LoginPage {
  2. start() {
  3. this.loginInput = DOM.get('.login-form>.login-form-login>.login-form-login-input').focus();
  4. this.passwordInput = DOM.get('.login-form>.login-form-password>.login-form-password-input');
  5. this.loginButton = DOM.get('.login-form>.login-form-button');
  6. this.failureText = DOM.get('.login-form>.login-form-failure');
  7. this.registerEventHandlers();
  8. return this;
  9. }
  10. registerEventHandlers() {
  11. this.loginButton.on(DOM.Events.Click, this.authorize.bind(this));
  12. window_.on(DOM.Events.KeyDown, (e) => {
  13. if(e.key === DOM.Keys.Enter)
  14. this.authorize();
  15. });
  16. }
  17. authorize(e) {
  18. const login = this.loginInput.getValue();
  19. const password = this.passwordInput.getValue();
  20. CDUtils.SHA256(password).then((hashedPassword) => {
  21. fetch('/authorize', {
  22. method: 'POST',
  23. headers:{
  24. 'Content-Type': 'application/x-www-form-urlencoded'
  25. },
  26. body: new URLSearchParams({
  27. 'login': login,
  28. 'password': hashedPassword
  29. })
  30. }).then((res) => {
  31. if(res.status === 200)
  32. Url.goTo('/');
  33. else if(res.status === 403)
  34. this.failureText.setInnerHTML('Wrong login or password');
  35. else
  36. this.failureText.setInnerHTML('Internal server error');
  37. })
  38. });
  39. }
  40. }
  41. window_.on(DOM.Events.Load, (e) => {
  42. window.page = new LoginPage().start();
  43. });