1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-19 05:09:42 +02:00
documize/gui/app/components/customize/auth-settings.js

278 lines
9.1 KiB
JavaScript
Raw Normal View History

2017-03-14 17:19:53 +00:00
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
//
// This software (Documize Community Edition) is licensed under
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
//
// You can operate outside the AGPL restrictions by purchasing
// Documize Enterprise Edition and obtaining a commercial license
// by contacting <sales@documize.com>.
//
// https://documize.com
2018-04-20 14:38:10 +01:00
import { computed } from '@ember/object';
import { empty } from '@ember/object/computed';
import { set } from '@ember/object';
import { copy } from '@ember/object/internals';
import { inject as service } from '@ember/service';
import Notifier from '../../mixins/notifier';
2018-09-03 18:19:46 +01:00
import ModalMixin from '../../mixins/modal';
import encoding from '../../utils/encoding';
import Component from '@ember/component';
2017-03-14 17:19:53 +00:00
2018-09-03 18:19:46 +01:00
export default Component.extend(ModalMixin, Notifier, {
appMeta: service(),
2018-09-03 18:19:46 +01:00
globalSvc: service('global'),
2018-09-03 17:36:54 +01:00
2018-04-20 14:38:10 +01:00
isDocumizeProvider: computed('authProvider', function() {
return this.get('authProvider') === this.get('constants').AuthProvider.Documize;
}),
isKeycloakProvider: computed('authProvider', function() {
return this.get('authProvider') === this.get('constants').AuthProvider.Keycloak;
}),
2018-09-03 17:36:54 +01:00
isLDAPProvider: computed('authProvider', function() {
return this.get('authProvider') === this.get('constants').AuthProvider.LDAP;
}),
KeycloakUrlError: empty('keycloakConfig.url'),
KeycloakRealmError: empty('keycloakConfig.realm'),
KeycloakClientIdError: empty('keycloakConfig.clientId'),
KeycloakPublicKeyError: empty('keycloakConfig.publicKey'),
KeycloakAdminUserError: empty('keycloakConfig.adminUser'),
KeycloakAdminPasswordError: empty('keycloakConfig.adminPassword'),
keycloakFailure: '',
2018-09-03 17:36:54 +01:00
ldapErrorServerHost: empty('ldapConfig.serverHost'),
ldapErrorServerPort: computed('ldapConfig.serverPort', function() {
return is.empty(this.get('ldapConfig.serverPort')) || is.not.number(parseInt(this.get('ldapConfig.serverPort')));
}),
ldapErrorBindDN: empty('ldapConfig.bindDN'),
ldapErrorBindPassword: empty('ldapConfig.bindPassword'),
ldapErrorNoFilter: computed('ldapConfig.{userFilter,groupFilter}', function() {
return is.empty(this.get('ldapConfig.userFilter')) && is.empty(this.get('ldapConfig.groupFilter'));
}),
ldapErrorAttributeUserRDN: empty('ldapConfig.attributeUserRDN'),
ldapErrorAttributeUserFirstname: empty('ldapConfig.attributeUserFirstname'),
ldapErrorAttributeUserLastname: empty('ldapConfig.attributeUserLastname'),
ldapErrorAttributeUserEmail: empty('ldapConfig.attributeUserEmail'),
ldapErrorAttributeGroupMember: computed('ldapConfig.{groupFilter,attributeGroupMember}', function() {
return is.not.empty(this.get('ldapConfig.groupFilter')) && is.empty(this.get('ldapConfig.attributeGroupMember'));
}),
2018-09-05 15:54:00 +01:00
ldapPreview: null,
ldapConfig: null,
2018-09-03 17:36:54 +01:00
init() {
this._super(...arguments);
2018-08-28 10:19:22 +01:00
this.keycloakConfig = {
url: '',
realm: '',
clientId: '',
publicKey: '',
adminUser: '',
adminPassword: '',
group: '',
disableLogout: false,
defaultPermissionAddSpace: false
};
},
2017-03-14 17:19:53 +00:00
didReceiveAttrs() {
this._super(...arguments);
let provider = this.get('authProvider');
2018-04-20 14:38:10 +01:00
let constants = this.get('constants');
2017-03-14 17:19:53 +00:00
2018-09-05 15:54:00 +01:00
this.set('ldapPreview', {isError: true, message: 'Unable to connect'});
2017-03-14 17:19:53 +00:00
switch (provider) {
case constants.AuthProvider.Documize:
// nothing to do
2017-03-14 17:19:53 +00:00
break;
2018-09-03 17:36:54 +01:00
case constants.AuthProvider.Keycloak: // eslint-disable-line no-case-declarations
let config = this.get('authConfig');
if (is.undefined(config) || is.null(config) || is.empty(config) ) {
config = {};
} else {
config = JSON.parse(config);
2017-03-17 08:46:33 +00:00
config.publicKey = encoding.Base64.decode(config.publicKey);
config.defaultPermissionAddSpace = config.hasOwnProperty('defaultPermissionAddSpace') ? config.defaultPermissionAddSpace : false;
config.disableLogout = config.hasOwnProperty('disableLogout') ? config.disableLogout : true;
}
this.set('keycloakConfig', config);
2017-03-14 17:19:53 +00:00
break;
2018-09-03 17:36:54 +01:00
case constants.AuthProvider.LDAP: // eslint-disable-line no-case-declarations
let ldapConfig = this.get('authConfig');
if (is.undefined(ldapConfig) || is.null(ldapConfig) || is.empty(ldapConfig) ) {
ldapConfig = {};
} else {
2018-09-04 17:19:26 +01:00
ldapConfig = JSON.parse(ldapConfig);
2018-09-03 17:36:54 +01:00
ldapConfig.defaultPermissionAddSpace = ldapConfig.hasOwnProperty('defaultPermissionAddSpace') ? ldapConfig.defaultPermissionAddSpace : false;
ldapConfig.disableLogout = ldapConfig.hasOwnProperty('disableLogout') ? ldapConfig.disableLogout : true;
}
this.set('ldapConfig', ldapConfig);
break;
2017-03-14 17:19:53 +00:00
}
},
actions: {
onDocumize() {
2018-04-20 14:38:10 +01:00
let constants = this.get('constants');
2017-03-14 17:19:53 +00:00
this.set('authProvider', constants.AuthProvider.Documize);
},
onKeycloak() {
2018-04-20 14:38:10 +01:00
let constants = this.get('constants');
2017-03-14 17:19:53 +00:00
this.set('authProvider', constants.AuthProvider.Keycloak);
},
2018-09-03 17:36:54 +01:00
onLDAP() {
let constants = this.get('constants');
this.set('authProvider', constants.AuthProvider.LDAP);
},
onLDAPEncryption(e) {
this.set('ldapConfig.encryptionType', e);
},
2018-09-03 18:19:46 +01:00
onLDAPPreview() {
let config = this.get('ldapConfig');
config.serverPort = parseInt(this.get('ldapConfig.serverPort'));
this.get('globalSvc').previewLDAP(config).then((preview) => {
this.set('ldapPreview', preview);
this.modalOpen("#ldap-preview-modal", {"show": true});
this.notifySuccess('Saved');
2018-09-03 18:19:46 +01:00
});
},
2017-03-14 17:19:53 +00:00
onSave() {
2018-04-20 14:38:10 +01:00
let constants = this.get('constants');
2017-03-14 17:19:53 +00:00
let provider = this.get('authProvider');
let config = this.get('authConfig');
this.set('keycloakFailure', '');
2017-03-14 17:19:53 +00:00
switch (provider) {
case constants.AuthProvider.Documize:
config = {};
break;
2018-09-03 17:36:54 +01:00
2017-03-14 17:19:53 +00:00
case constants.AuthProvider.Keycloak:
if (this.get('KeycloakUrlError')) {
this.$("#keycloak-url").focus();
return;
}
if (this.get('KeycloakRealmError')) {
this.$("#keycloak-realm").focus();
return;
}
if (this.get('KeycloakClientIdError')) {
this.$("#keycloak-clientId").focus();
return;
}
2017-03-16 13:33:34 +00:00
if (this.get('KeycloakPublicKeyError')) {
this.$("#keycloak-publicKey").focus();
return;
}
2017-03-17 19:01:32 +00:00
if (this.get('KeycloakAdminUserError')) {
this.$("#keycloak-admin-user").focus();
return;
}
if (this.get('KeycloakAdminPasswordError')) {
this.$("#keycloak-admin-password").focus();
return;
}
config = copy(this.get('keycloakConfig'));
2017-03-28 10:25:32 +01:00
config.url = config.url.trim();
config.realm = config.realm.trim();
config.clientId = config.clientId.trim();
config.publicKey = config.publicKey.trim();
config.group = is.undefined(config.group) ? '' : config.group.trim();
config.adminUser = config.adminUser.trim();
config.adminPassword = config.adminPassword.trim();
config.defaultPermissionAddSpace = config.hasOwnProperty('defaultPermissionAddSpace') ? config.defaultPermissionAddSpace : true;
config.disableLogout = config.hasOwnProperty('disableLogout') ? config.disableLogout : true;
2017-03-28 10:25:32 +01:00
if (is.endWith(config.url, '/')) {
config.url = config.url.substring(0, config.url.length-1);
}
set(config, 'publicKey', encoding.Base64.encode(this.get('keycloakConfig.publicKey')));
2017-03-14 17:19:53 +00:00
break;
2018-09-03 17:36:54 +01:00
case constants.AuthProvider.LDAP:
if (this.get('ldapErrorServerHost')) {
this.$("#ldap-host").focus();
return;
}
if (this.get('ldapErrorServerPort')) {
this.$("#ldap-port").focus();
return;
}
config = copy(this.get('ldapConfig'));
config.serverHost = config.serverHost.trim();
config.serverPort = parseInt(this.get('ldapConfig.serverPort'));
2018-09-04 17:19:26 +01:00
if (is.not.empty(config.groupFilter) && is.empty(config.attributeGroupMember)) {
this.$('#ldap-attributeGroupMember').focus();
return;
}
2018-09-03 17:36:54 +01:00
break;
2017-03-14 17:19:53 +00:00
}
2017-11-28 12:49:48 +00:00
2017-03-28 10:25:32 +01:00
let data = { authProvider: provider, authConfig: JSON.stringify(config) };
2017-03-14 17:19:53 +00:00
2017-03-28 10:25:32 +01:00
this.get('onSave')(data).then(() => {
2018-09-03 17:36:54 +01:00
// Without sync we cannot log in
2018-09-04 17:19:26 +01:00
// Keycloak sync process
2017-03-28 10:25:32 +01:00
if (data.authProvider === constants.AuthProvider.Keycloak) {
2018-09-04 17:19:26 +01:00
this.get('onSyncKeycloak')().then((response) => {
if (response.isError) {
this.set('keycloakFailure', response.message);
console.log(response.message); // eslint-disable-line no-console
data.authProvider = constants.AuthProvider.Documize;
this.get('onSave')(data).then(() => {});
} else {
if (data.authProvider === this.get('appMeta.authProvider')) {
console.log(response.message); // eslint-disable-line no-console
} else {
this.get('onChange')(data);
}
}
});
}
// LDAP sync process
if (data.authProvider === constants.AuthProvider.LDAP) {
this.get('onSyncLDAP')().then((response) => {
2017-03-28 10:25:32 +01:00
if (response.isError) {
this.set('keycloakFailure', response.message);
2018-04-23 12:46:34 +01:00
console.log(response.message); // eslint-disable-line no-console
2017-03-28 10:25:32 +01:00
data.authProvider = constants.AuthProvider.Documize;
this.get('onSave')(data).then(() => {});
2017-03-28 10:25:32 +01:00
} else {
if (data.authProvider === this.get('appMeta.authProvider')) {
2018-04-23 12:46:34 +01:00
console.log(response.message); // eslint-disable-line no-console
2017-03-28 10:25:32 +01:00
} else {
this.get('onChange')(data);
}
}
});
}
2018-09-03 17:36:54 +01:00
this.notifySuccess('Saved');
2017-03-14 17:19:53 +00:00
});
2017-03-19 14:25:21 +00:00
}
2017-03-14 17:19:53 +00:00
}
});