fleet/frontend/components/forms/admin/AppConfigForm/validate.js
John Murphy 019191c36b SSO Login and Configuration Support (#1506)
Closes issue #1456 This PR adds a single sign on option to the login form, exposes single sign on to the end user, and allows an admin user to set single sign on configuration options.
2017-05-17 10:58:40 -05:00

84 lines
2 KiB
JavaScript

import { size, some, trim } from 'lodash';
import APP_CONSTANTS from 'app_constants';
import validJwtToken from 'components/forms/validators/valid_jwt_token';
const { APP_SETTINGS } = APP_CONSTANTS;
export default (formData) => {
const errors = {};
const {
authentication_type: authType,
kolide_server_url: kolideServerUrl,
license,
org_name: orgName,
password: smtpPassword,
sender_address: smtpSenderAddress,
server: smtpServer,
port: smtpServerPort,
user_name: smtpUserName,
enable_sso: enableSSO,
metadata,
metadata_url: metadataURL,
entity_id: entityID,
idp_name: idpName,
} = formData;
if (enableSSO) {
if (!metadata && !metadataURL) {
errors.metadata_url = 'Metadata URL must be present';
}
if (!entityID) {
errors.entity_id = 'Entity ID must be present';
}
if (!idpName) {
errors.idp_name = 'Identity Provider Name must be present';
}
}
if (!kolideServerUrl) {
errors.kolide_server_url = 'Kolide Server URL must be present';
}
if (!license) {
errors.license = 'License must be present';
}
if (license && !validJwtToken(trim(license))) {
errors.license = 'License is not a valid JWT token';
}
if (!orgName) {
errors.org_name = 'Organization Name must be present';
}
if (some([smtpSenderAddress, smtpServer, smtpUserName]) ||
(smtpPassword && smtpPassword !== APP_SETTINGS.FAKE_PASSWORD) ||
(smtpServerPort !== APP_SETTINGS.DEFAULT_SMTP_PORT)) {
if (!smtpSenderAddress) {
errors.sender_address = 'SMTP Sender Address must be present';
}
if (!smtpServer) {
errors.server = 'SMTP Server must be present';
}
if (!smtpServerPort) {
errors.server = 'SMTP Server Port must be present';
}
if (authType !== 'authtype_none') {
if (!smtpUserName) {
errors.user_name = 'SMTP Username must be present';
}
if (!smtpPassword) {
errors.password = 'SMTP Password must be present';
}
}
}
const valid = !size(errors);
return { valid, errors };
};