ServiceAccountCreatePage.acc5efcb810b8ea01ff8.js.map 8.4 KB

1
  1. {"version":3,"file":"ServiceAccountCreatePage.acc5efcb810b8ea01ff8.js","mappings":"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","sources":["webpack://grafana/./public/app/features/serviceaccounts/ServiceAccountCreatePage.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState } from 'react';\nimport { connect } from 'react-redux';\nimport { useHistory } from 'react-router-dom';\n\nimport { NavModel } from '@grafana/data';\nimport { getBackendSrv } from '@grafana/runtime';\nimport { Form, Button, Input, Field } from '@grafana/ui';\nimport Page from 'app/core/components/Page/Page';\nimport { UserRolePicker } from 'app/core/components/RolePicker/UserRolePicker';\nimport { fetchBuiltinRoles, fetchRoleOptions, updateUserRoles } from 'app/core/components/RolePicker/api';\nimport { contextSrv } from 'app/core/core';\nimport { AccessControlAction, OrgRole, Role, ServiceAccountCreateApiResponse, ServiceAccountDTO } from 'app/types';\n\nimport { getNavModel } from '../../core/selectors/navModel';\nimport { StoreState } from '../../types';\n\ninterface ServiceAccountCreatePageProps {\n navModel: NavModel;\n}\n\nconst createServiceAccount = async (sa: ServiceAccountDTO) => getBackendSrv().post('/api/serviceaccounts/', sa);\nconst updateServiceAccount = async (id: number, sa: ServiceAccountDTO) =>\n getBackendSrv().patch(`/api/serviceaccounts/${id}`, sa);\n\nconst ServiceAccountCreatePage: React.FC<ServiceAccountCreatePageProps> = ({ navModel }) => {\n const [roleOptions, setRoleOptions] = useState<Role[]>([]);\n const [builtinRoles, setBuiltinRoles] = useState<{ [key: string]: Role[] }>({});\n const [pendingRoles, setPendingRoles] = useState<Role[]>([]);\n\n const currentOrgId = contextSrv.user.orgId;\n const [serviceAccount, setServiceAccount] = useState<ServiceAccountDTO>({\n id: 0,\n orgId: contextSrv.user.orgId,\n role: OrgRole.Viewer,\n tokens: 0,\n name: '',\n login: '',\n isDisabled: false,\n createdAt: '',\n teams: [],\n });\n\n useEffect(() => {\n async function fetchOptions() {\n try {\n if (contextSrv.hasPermission(AccessControlAction.ActionRolesList)) {\n let options = await fetchRoleOptions(currentOrgId);\n setRoleOptions(options);\n }\n\n if (contextSrv.hasPermission(AccessControlAction.ActionBuiltinRolesList)) {\n const builtInRoles = await fetchBuiltinRoles(currentOrgId);\n setBuiltinRoles(builtInRoles);\n }\n } catch (e) {\n console.error('Error loading options', e);\n }\n }\n if (contextSrv.licensedAccessControlEnabled()) {\n fetchOptions();\n }\n }, [currentOrgId]);\n\n const history = useHistory();\n\n const onSubmit = useCallback(\n async (data: ServiceAccountDTO) => {\n data.role = serviceAccount.role;\n const response = await createServiceAccount(data);\n try {\n const newAccount: ServiceAccountCreateApiResponse = {\n avatarUrl: response.avatarUrl,\n id: response.id,\n isDisabled: response.isDisabled,\n login: response.login,\n name: response.name,\n orgId: response.orgId,\n role: response.role,\n tokens: response.tokens,\n };\n await updateServiceAccount(response.id, data);\n await updateUserRoles(pendingRoles, newAccount.id, newAccount.orgId);\n } catch (e) {\n console.error(e);\n }\n history.push('/org/serviceaccounts/');\n },\n [history, serviceAccount.role, pendingRoles]\n );\n\n const onRoleChange = (role: OrgRole) => {\n setServiceAccount({\n ...serviceAccount,\n role: role,\n });\n };\n\n const onPendingRolesUpdate = (roles: Role[], userId: number, orgId: number | undefined) => {\n // keep the new role assignments for user\n setPendingRoles(roles);\n };\n\n return (\n <Page navModel={navModel}>\n <Page.Contents>\n <h1>Create service account</h1>\n <Form onSubmit={onSubmit} validateOn=\"onBlur\">\n {({ register, errors }) => {\n return (\n <>\n <Field\n label=\"Display name\"\n required\n invalid={!!errors.name}\n error={errors.name ? 'Display name is required' : undefined}\n >\n <Input id=\"display-name-input\" {...register('name', { required: true })} />\n </Field>\n {contextSrv.accessControlEnabled() && (\n <Field label=\"Role\">\n <UserRolePicker\n userId={serviceAccount.id || 0}\n orgId={serviceAccount.orgId}\n builtInRole={serviceAccount.role}\n builtInRoles={builtinRoles}\n onBuiltinRoleChange={(newRole) => onRoleChange(newRole)}\n builtinRolesDisabled={false}\n roleOptions={roleOptions}\n updateDisabled={true}\n onApplyRoles={onPendingRolesUpdate}\n pendingRoles={pendingRoles}\n />\n </Field>\n )}\n <Button type=\"submit\">Create</Button>\n </>\n );\n }}\n </Form>\n </Page.Contents>\n </Page>\n );\n};\n\nconst mapStateToProps = (state: StoreState) => ({\n navModel: getNavModel(state.navIndex, 'serviceaccounts'),\n});\n\nexport default connect(mapStateToProps)(ServiceAccountCreatePage);\n"],"names":["connect","state","navModel","getNavModel","navIndex","roleOptions","setRoleOptions","useState","builtinRoles","setBuiltinRoles","pendingRoles","setPendingRoles","currentOrgId","contextSrv","serviceAccount","setServiceAccount","id","orgId","role","OrgRole","tokens","name","login","isDisabled","createdAt","teams","useEffect","async","AccessControlAction","options","fetchRoleOptions","builtInRoles","fetchBuiltinRoles","e","console","error","fetchOptions","history","useHistory","onSubmit","useCallback","data","response","getBackendSrv","post","sa","createServiceAccount","newAccount","avatarUrl","patch","updateServiceAccount","updateUserRoles","push","onPendingRolesUpdate","roles","userId","Form","validateOn","register","errors","Field","label","required","invalid","undefined","Input","builtInRole","onBuiltinRoleChange","newRole","onRoleChange","builtinRolesDisabled","updateDisabled","onApplyRoles","Button","type"],"sourceRoot":""}