All Downloads are FREE. Search and download functionalities are using the official Maven repository.

web-interface.assets.325e2d4b-8208.24f4944175a4bde0257c.js.map Maven / Gradle / Ivy

There is a newer version: 6.0.1
Show newest version
{"version":3,"file":"325e2d4b-8208.24f4944175a4bde0257c.js","mappings":"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","sources":["webpack://graylog-web-interface/./src/components/users/UserCreate/UsernameFormGroup.tsx","webpack://graylog-web-interface/./src/components/users/UserCreate/UserCreate.tsx","webpack://graylog-web-interface/./src/components/users/UserCreate/index.js","webpack://graylog-web-interface/./src/pages/UserCreatePage.tsx"],"sourcesContent":["/*\n * Copyright (C) 2020 Graylog, Inc.\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the Server Side Public License, version 1,\n * as published by MongoDB, Inc.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * Server Side Public License for more details.\n *\n * You should have received a copy of the Server Side Public License\n * along with this program. If not, see\n * .\n */\nimport * as React from 'react';\n\nimport { FormikFormGroup } from 'components/common';\n\nconst UsernameFormGroup = () => {\n  return (\n    \n  );\n};\n\nexport default UsernameFormGroup;\n","/*\n * Copyright (C) 2020 Graylog, Inc.\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the Server Side Public License, version 1,\n * as published by MongoDB, Inc.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * Server Side Public License for more details.\n *\n * You should have received a copy of the Server Side Public License\n * along with this program. If not, see\n * .\n */\nimport * as React from 'react';\nimport { useState } from 'react';\nimport * as Immutable from 'immutable';\nimport { Formik, Form } from 'formik';\nimport { PluginStore } from 'graylog-web-plugin/plugin';\n\nimport history from 'util/History';\nimport AppConfig from 'util/AppConfig';\nimport type { DescriptiveItem } from 'components/common/PaginatedItemOverview';\nimport User from 'logic/users/User';\nimport UsersDomain from 'domainActions/users/UsersDomain';\nimport PaginatedItem from 'components/common/PaginatedItemOverview/PaginatedItem';\nimport RolesSelector from 'components/permissions/RolesSelector';\nimport { Alert, Col, Row, Input } from 'components/bootstrap';\nimport Routes from 'routing/Routes';\nimport { UsersActions } from 'stores/users/UsersStore';\nimport debounceWithPromise from 'views/logic/debounceWithPromise';\nimport { FormSubmit } from 'components/common';\n\nimport TimezoneFormGroup from './TimezoneFormGroup';\nimport TimeoutFormGroup from './TimeoutFormGroup';\nimport FirstNameFormGroup from './FirstNameFormGroup';\nimport LastNameFormGroup from './LastNameFormGroup';\nimport EmailFormGroup from './EmailFormGroup';\nimport PasswordFormGroup, { validatePasswords } from './PasswordFormGroup';\nimport UsernameFormGroup from './UsernameFormGroup';\nimport ServiceAccountFormGroup from './ServiceAccountFormGroup';\n\nimport { Headline } from '../../common/Section/SectionComponent';\n\nconst isCloud = AppConfig.isCloud();\n\nconst oktaUserForm = isCloud ? PluginStore.exports('cloud')[0].oktaUserForm : null;\n\nconst _onSubmit = (formData, roles, setSubmitError) => {\n  let data = { ...formData, roles: roles.toJS(), permissions: [] };\n  delete data.password_repeat;\n\n  if (isCloud && oktaUserForm) {\n    const { onCreate } = oktaUserForm;\n    data = onCreate(data);\n  } else {\n    data.username = data.username.trim();\n  }\n\n  setSubmitError(null);\n\n  return UsersDomain.create(data).then(() => {\n    history.push(Routes.SYSTEM.USERS.OVERVIEW);\n  }, (error) => setSubmitError(error));\n};\n\nconst _validateUsername = async (errors: { [name: string]: string }, username: string) => {\n  const newErrors = { ...errors };\n\n  try {\n    await UsersActions.loadByUsername(username);\n    newErrors.username = 'Username is already taken';\n  // eslint-disable-next-line no-empty\n  } catch (error) {}\n\n  return newErrors;\n};\n\nconst debounceTimeoutMs = 600;\nconst debouncedValidateUsername = debounceWithPromise(_validateUsername, debounceTimeoutMs);\n\nconst _validate = async (values) => {\n  let errors = {};\n\n  const { password, password_repeat: passwordRepeat, username } = values;\n\n  if (username) {\n    errors = await debouncedValidateUsername(errors, username);\n  }\n\n  if (isCloud && oktaUserForm) {\n    const { validations: { password: validateCloudPasswords } } = oktaUserForm;\n\n    errors = validateCloudPasswords(errors, password, passwordRepeat);\n  } else {\n    errors = validatePasswords(errors, password, passwordRepeat);\n  }\n\n  return errors;\n};\n\ntype RequestError = { additional: { res: { text: string }}};\n\nconst PasswordGroup = () => {\n  if (isCloud && oktaUserForm) {\n    const { fields: { password: CloudPasswordFormGroup } } = oktaUserForm;\n\n    return ;\n  }\n\n  return ;\n};\n\nconst UserNameGroup = () => {\n  if (isCloud && oktaUserForm) {\n    const { fields: { username: CloudUserNameFormGroup } } = oktaUserForm;\n\n    return CloudUserNameFormGroup && ;\n  }\n\n  return (\n    \n  );\n};\n\nconst EmailGroup = () => {\n  if (isCloud && oktaUserForm) {\n    const { fields: { email: CloudEmailFormGroup } } = oktaUserForm;\n\n    return CloudEmailFormGroup && ;\n  }\n\n  return (\n    \n  );\n};\n\nconst UserCreate = () => {\n  const initialRole = { name: 'Reader', description: 'Grants basic permissions for every Graylog user (built-in)', id: '' };\n  const [user, setUser] = useState(User.empty().toBuilder().roles(Immutable.Set([initialRole.name])).build());\n  const [submitError, setSubmitError] = useState();\n  const [selectedRoles, setSelectedRoles] = useState>(Immutable.Set([initialRole]));\n\n  const _onAssignRole = (roles: Immutable.Set) => {\n    setSelectedRoles(selectedRoles.union(roles));\n    const roleNames = roles.map((r) => r.name);\n\n    return Promise.resolve(\n      setUser(user.toBuilder().roles(user.roles.union(roleNames)).build()),\n    );\n  };\n\n  const _onUnassignRole = (role: DescriptiveItem) => {\n    setSelectedRoles(selectedRoles.remove(role));\n    setUser(user.toBuilder().roles(user.roles.remove(role?.name)).build());\n  };\n\n  const _handleCancel = () => history.push(Routes.SYSTEM.USERS.OVERVIEW);\n  const hasValidRole = selectedRoles.size > 0 && selectedRoles.filter((role) => role.name === 'Reader' || role.name === 'Admin');\n\n  const showSubmitError = (errors) => {\n    if (isCloud && oktaUserForm) {\n      const { extractSubmitError } = oktaUserForm;\n\n      return extractSubmitError(errors);\n    }\n\n    return errors?.additional?.res?.text;\n  };\n\n  return (\n    \n      \n         _onSubmit(data, user.roles, setSubmitError)}\n                validate={_validate}\n                initialValues={{}}>\n          {({ isSubmitting, isValid }) => (\n            
\n
\n Profile\n \n \n \n \n
\n
\n Settings\n \n \n \n
\n
\n Roles\n \n role.name} submitOnSelect />\n \n\n \n <>\n {selectedRoles.map((role) => (\n _onUnassignRole(data)}\n key={role.id} />\n ))}\n {!hasValidRole && You need to select at least one of the Reader or Admin roles.}\n \n \n
\n
\n Password\n \n
\n {submitError && (\n \n \n \n Failed to create user
\n {showSubmitError(submitError)}\n
\n \n
\n )}\n \n \n \n \n \n
\n )}\n
\n \n
\n );\n};\n\nexport default UserCreate;\n","/*\n * Copyright (C) 2020 Graylog, Inc.\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the Server Side Public License, version 1,\n * as published by MongoDB, Inc.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * Server Side Public License for more details.\n *\n * You should have received a copy of the Server Side Public License\n * along with this program. If not, see\n * .\n */\nimport UserCreate from './UserCreate';\n\nexport default UserCreate;\n","/*\n * Copyright (C) 2020 Graylog, Inc.\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the Server Side Public License, version 1,\n * as published by MongoDB, Inc.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * Server Side Public License for more details.\n *\n * You should have received a copy of the Server Side Public License\n * along with this program. If not, see\n * .\n */\nimport * as React from 'react';\n\nimport { LinkContainer } from 'components/common/router';\nimport Routes from 'routing/Routes';\nimport DocsHelper from 'util/DocsHelper';\nimport { Button } from 'components/bootstrap';\nimport { PageHeader, DocumentTitle } from 'components/common';\nimport UserCreate from 'components/users/UserCreate';\nimport UsersPageNavigation from 'components/users/navigation/UsersPageNavigation';\n\nconst UserCreatePage = () => (\n \n \n \n \n \n )}\n documentationLink={{\n title: 'Permissions documentation',\n path: DocsHelper.PAGES.USERS_ROLES,\n }}>\n \n Use this page to create new Graylog users. The users and their permissions created here are not limited\n to the web interface but valid and required for the REST APIs of your Graylog server nodes, too.\n \n \n\n \n \n);\n\nexport default UserCreatePage;\n"],"names":["label","name","required","help","isCloud","AppConfig","oktaUserForm","PluginStore","debouncedValidateUsername","debounceWithPromise","async","errors","username","newErrors","UsersActions","error","_validate","password","password_repeat","passwordRepeat","values","validations","validateCloudPasswords","validatePasswords","PasswordGroup","fields","CloudPasswordFormGroup","PasswordFormGroup","UserNameGroup","CloudUserNameFormGroup","EmailGroup","email","CloudEmailFormGroup","EmailFormGroup","initialRole","description","id","user","setUser","useState","User","toBuilder","roles","Immutable","build","submitError","setSubmitError","selectedRoles","setSelectedRoles","_onAssignRole","union","roleNames","map","r","Promise","resolve","_handleCancel","history","Routes","hasValidRole","size","filter","role","className","lg","Formik","onSubmit","data","formData","toJS","permissions","onCreate","trim","UsersDomain","then","_onSubmit","validate","initialValues","isSubmitting","isValid","Form","FirstNameFormGroup","LastNameFormGroup","TimeoutFormGroup","TimezoneFormGroup","ServiceAccountFormGroup","labelClassName","wrapperClassName","RolesSelector","assignedRolesIds","identifier","submitOnSelect","PaginatedItem","item","onDeleteItem","remove","_onUnassignRole","key","bsStyle","xs","xsOffset","extractSubmitError","additional","res","text","showSubmitError","md","mdOffset","disabledSubmit","submitButtonText","submitLoadingText","isAsyncSubmit","onCancel","title","UsersPageNavigation","actions","to","documentationLink","path","DocsHelper"],"sourceRoot":""}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy