2019-08-21 20:24:37 +02:00
|
|
|
import server from "../../services/server.js";
|
|
|
|
import protectedSessionHolder from "../../services/protected_session_holder.js";
|
2019-10-20 10:00:18 +02:00
|
|
|
import toastService from "../../services/toast.js";
|
2019-08-21 20:24:37 +02:00
|
|
|
|
|
|
|
export default class ChangePasswordOptions {
|
|
|
|
constructor() {
|
|
|
|
this.$form = $("#change-password-form");
|
|
|
|
this.$oldPassword = $("#old-password");
|
|
|
|
this.$newPassword1 = $("#new-password1");
|
|
|
|
this.$newPassword2 = $("#new-password2");
|
|
|
|
|
|
|
|
this.$form.submit(() => this.save());
|
|
|
|
}
|
|
|
|
|
|
|
|
optionsLoaded(options) {}
|
|
|
|
|
|
|
|
save() {
|
|
|
|
const oldPassword = this.$oldPassword.val();
|
|
|
|
const newPassword1 = this.$newPassword1.val();
|
|
|
|
const newPassword2 = this.$newPassword2.val();
|
|
|
|
|
|
|
|
this.$oldPassword.val('');
|
|
|
|
this.$newPassword1.val('');
|
|
|
|
this.$newPassword2.val('');
|
|
|
|
|
|
|
|
if (newPassword1 !== newPassword2) {
|
|
|
|
alert("New passwords are not the same.");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
server.post('password/change', {
|
|
|
|
'current_password': oldPassword,
|
|
|
|
'new_password': newPassword1
|
|
|
|
}).then(result => {
|
|
|
|
if (result.success) {
|
|
|
|
alert("Password has been changed. Trilium will be reloaded after you press OK.");
|
|
|
|
|
|
|
|
// password changed so current protected session is invalid and needs to be cleared
|
|
|
|
protectedSessionHolder.resetProtectedSession();
|
|
|
|
}
|
|
|
|
else {
|
2019-10-20 10:00:18 +02:00
|
|
|
toastService.showError(result.message);
|
2019-08-21 20:24:37 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|