This repository has been archived on 2023-03-18. You can view files and clone it, but cannot push or open issues or pull requests.
osr-discourse-src/app/assets/javascripts/discourse/controllers/preferences/account.js.es6
David Taylor eda1462b3b
FEATURE: List, revoke and reconnect associated accounts. Phase 1 (#6099)
Listing connections is supported for all built-in auth providers. Revoke and reconnect is currently only implemented for Facebook.
2018-07-23 16:51:57 +01:00

203 lines
5.5 KiB
JavaScript

import { iconHTML } from "discourse-common/lib/icon-library";
import CanCheckEmails from "discourse/mixins/can-check-emails";
import { default as computed } from "ember-addons/ember-computed-decorators";
import PreferencesTabController from "discourse/mixins/preferences-tab-controller";
import { setting } from "discourse/lib/computed";
import { popupAjaxError } from "discourse/lib/ajax-error";
import showModal from "discourse/lib/show-modal";
import { findAll } from "discourse/models/login-method";
export default Ember.Controller.extend(
CanCheckEmails,
PreferencesTabController,
{
saveAttrNames: ["name", "title"],
canEditName: setting("enable_names"),
canSaveUser: true,
newNameInput: null,
newTitleInput: null,
passwordProgress: null,
cannotDeleteAccount: Em.computed.not("currentUser.can_delete_account"),
deleteDisabled: Em.computed.or(
"model.isSaving",
"deleting",
"cannotDeleteAccount"
),
reset() {
this.setProperties({
passwordProgress: null
});
},
@computed()
nameInstructions() {
return I18n.t(
this.siteSettings.full_name_required
? "user.name.instructions_required"
: "user.name.instructions"
);
},
@computed("model.availableTitles")
canSelectTitle(availableTitles) {
return availableTitles.length > 0;
},
@computed()
canChangePassword() {
return (
!this.siteSettings.enable_sso && this.siteSettings.enable_local_logins
);
},
@computed("model.associated_accounts")
associatedAccountsLoaded(associatedAccounts) {
return typeof associatedAccounts !== "undefined";
},
@computed("model.associated_accounts.[]")
authProviders(accounts) {
const allMethods = findAll(
this.siteSettings,
this.capabilities,
this.site.isMobileDevice
);
const result = allMethods.map(method => {
return {
method,
account: accounts.find(account => account.name === method.name) // Will be undefined if no account
};
});
return result.filter(value => {
return value.account || value.method.get("canConnect");
});
},
@computed("model.id")
disableConnectButtons(userId) {
return userId !== this.get("currentUser.id");
},
@computed()
canUpdateAssociatedAccounts() {
return (
findAll(this.siteSettings, this.capabilities, this.site.isMobileDevice)
.length > 0
);
},
actions: {
save() {
this.set("saved", false);
const model = this.get("model");
model.set("name", this.get("newNameInput"));
model.set("title", this.get("newTitleInput"));
return model
.save(this.get("saveAttrNames"))
.then(() => {
this.set("saved", true);
})
.catch(popupAjaxError);
},
changePassword() {
if (!this.get("passwordProgress")) {
this.set(
"passwordProgress",
I18n.t("user.change_password.in_progress")
);
return this.get("model")
.changePassword()
.then(() => {
// password changed
this.setProperties({
changePasswordProgress: false,
passwordProgress: I18n.t("user.change_password.success")
});
})
.catch(() => {
// password failed to change
this.setProperties({
changePasswordProgress: false,
passwordProgress: I18n.t("user.change_password.error")
});
});
}
},
delete() {
this.set("deleting", true);
const self = this,
message = I18n.t("user.delete_account_confirm"),
model = this.get("model"),
buttons = [
{
label: I18n.t("cancel"),
class: "d-modal-cancel",
link: true,
callback: () => {
this.set("deleting", false);
}
},
{
label:
iconHTML("exclamation-triangle") +
I18n.t("user.delete_account"),
class: "btn btn-danger",
callback() {
model.delete().then(
function() {
bootbox.alert(I18n.t("user.deleted_yourself"), function() {
window.location.pathname = Discourse.getURL("/");
});
},
function() {
bootbox.alert(I18n.t("user.delete_yourself_not_allowed"));
self.set("deleting", false);
}
);
}
}
];
bootbox.dialog(message, buttons, { classes: "delete-account" });
},
showTwoFactorModal() {
showModal("second-factor-intro");
},
revokeAccount(account) {
const model = this.get("model");
this.set("revoking", true);
model
.revokeAssociatedAccount(account.name)
.then(result => {
if (result.success) {
model.get("associated_accounts").removeObject(account);
} else {
bootbox.alert(result.message);
}
})
.catch(popupAjaxError)
.finally(() => {
this.set("revoking", false);
});
},
connectAccount(method) {
method.doLogin();
}
}
}
);