@okta/okta-auth-js
Version:
The Okta Auth SDK
100 lines (97 loc) • 3.59 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
exports.EnrollProfile = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _Remediator = require("./Base/Remediator");
var _authenticator = require("../authenticator");
/* eslint-disable @typescript-eslint/no-non-null-assertion */
/*!
* Copyright (c) 2015-present, Okta, Inc. and/or its affiliates. All rights reserved.
* The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
*
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*
* See the License for the specific language governing permissions and limitations under the License.
*/
class EnrollProfile extends _Remediator.Remediator {
constructor(remediation, values = {}, options = {}) {
super(remediation, values, options);
// credentials are only required when Profile Enrollment policy requires them
// if credentials are included in the remediation, they are considered required
// otherwise it will be omitted
(0, _defineProperty2.default)(this, "authenticator", null);
const credentials = this.getCredentialsFromRemediation();
if (credentials) {
this.authenticator = this.authenticator = new _authenticator.OktaPassword({});
}
}
canRemediate() {
// ensure credentials can be verified, if required
if (this.authenticator && !this.authenticator.canVerify(this.values)) {
return false;
}
const userProfileFromValues = this.getData().userProfile;
if (!userProfileFromValues) {
return false;
}
// eslint-disable-next-line max-len
const userProfileFromRemediation = this.remediation.value.find(({
name
}) => name === 'userProfile');
return userProfileFromRemediation.form.value.reduce((canRemediate, curr) => {
if (curr.required) {
canRemediate = canRemediate && !!userProfileFromValues[curr.name];
}
return canRemediate;
}, true);
}
getCredentialsFromRemediation() {
return this.remediation.value.find(({
name
}) => name === 'credentials');
}
mapUserProfile({
form: {
value: profileAttributes
}
}) {
const attributeNames = profileAttributes.map(({
name
}) => name);
const data = attributeNames.reduce((attributeValues, attributeName) => this.values[attributeName] ? {
...attributeValues,
[attributeName]: this.values[attributeName]
} : attributeValues, {});
if (Object.keys(data).length === 0) {
return;
}
return data;
}
mapCredentials() {
const val = this.authenticator && this.authenticator.mapCredentials(this.values);
if (!val) {
return;
}
return val;
}
getInputUserProfile(input) {
return [...input.form.value];
}
getInputCredentials(input) {
return [...input.form.value];
}
getErrorMessages(errorRemediation) {
return errorRemediation.value[0].form.value.reduce((errors, field) => {
if (field.messages) {
errors.push(field.messages.value[0].message);
}
return errors;
}, []);
}
}
exports.EnrollProfile = EnrollProfile;
(0, _defineProperty2.default)(EnrollProfile, "remediationName", 'enroll-profile');
//# sourceMappingURL=EnrollProfile.js.map
;