mirror of
https://github.com/rr-/szurubooru.git
synced 2025-07-17 08:26:24 +00:00
front/auth: move auth state to API
This commit is contained in:
@ -8,42 +8,16 @@ class AuthController {
|
||||
this.api = api;
|
||||
this.topNavigationController = topNavigationController;
|
||||
this.loginView = loginView;
|
||||
this.currentUser = null;
|
||||
/* TODO: load from cookies */
|
||||
}
|
||||
|
||||
isLoggedIn() {
|
||||
return this.currentUser !== null;
|
||||
}
|
||||
|
||||
hasPrivilege() {
|
||||
return true;
|
||||
}
|
||||
|
||||
login(userName, userPassword) {
|
||||
return new Promise((resolve, reject) => {
|
||||
this.api.userName = userName;
|
||||
this.api.userPassword = userPassword;
|
||||
this.api.get('/user/' + userName)
|
||||
.then(resolve)
|
||||
.catch(reject);
|
||||
});
|
||||
}
|
||||
|
||||
logout(user) {
|
||||
this.currentUser = null;
|
||||
this.api.userName = null;
|
||||
this.api.userPassword = null;
|
||||
/* TODO: clear cookie */
|
||||
}
|
||||
|
||||
loginRoute() {
|
||||
this.topNavigationController.activate('login');
|
||||
this.loginView.render({
|
||||
login: (userName, userPassword, doRemember) => {
|
||||
return new Promise((resolve, reject) => {
|
||||
this
|
||||
.login(userName, userPassword)
|
||||
this.api.login(userName, userPassword);
|
||||
this.api.get('/user/' + userName)
|
||||
.then(response => {
|
||||
if (doRemember) {
|
||||
/* TODO: set cookie */
|
||||
@ -59,6 +33,7 @@ class AuthController {
|
||||
|
||||
logoutRoute() {
|
||||
this.topNavigationController.activate('logout');
|
||||
/* TODO: clear cookie */
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user