import React, { PureComponent } from 'react'; import { connect, ConnectedProps } from 'react-redux'; import { NavModel } from '@grafana/data'; import { featureEnabled } from '@grafana/runtime'; import Page from 'app/core/components/Page/Page'; import { contextSrv } from 'app/core/core'; import { GrafanaRouteComponentProps } from 'app/core/navigation/types'; import { getNavModel } from 'app/core/selectors/navModel'; import { StoreState, UserDTO, UserOrg, UserSession, SyncInfo, UserAdminError, AccessControlAction } from 'app/types'; import { UserLdapSyncInfo } from './UserLdapSyncInfo'; import { UserOrgs } from './UserOrgs'; import { UserPermissions } from './UserPermissions'; import { UserProfile } from './UserProfile'; import { UserSessions } from './UserSessions'; import { loadAdminUserPage, revokeSession, revokeAllSessions, updateUser, setUserPassword, disableUser, enableUser, deleteUser, updateUserPermissions, addOrgUser, updateOrgUserRole, deleteOrgUser, syncLdapUser, } from './state/actions'; interface OwnProps extends GrafanaRouteComponentProps<{ id: string }> { navModel: NavModel; user?: UserDTO; orgs: UserOrg[]; sessions: UserSession[]; ldapSyncInfo?: SyncInfo; isLoading: boolean; error?: UserAdminError; } export class UserAdminPage extends PureComponent { async componentDidMount() { const { match, loadAdminUserPage } = this.props; loadAdminUserPage(parseInt(match.params.id, 10)); } onUserUpdate = (user: UserDTO) => { this.props.updateUser(user); }; onPasswordChange = (password: string) => { const { user, setUserPassword } = this.props; user && setUserPassword(user.id, password); }; onUserDelete = (userId: number) => { this.props.deleteUser(userId); }; onUserDisable = (userId: number) => { this.props.disableUser(userId); }; onUserEnable = (userId: number) => { this.props.enableUser(userId); }; onGrafanaAdminChange = (isGrafanaAdmin: boolean) => { const { user, updateUserPermissions } = this.props; user && updateUserPermissions(user.id, isGrafanaAdmin); }; onOrgRemove = (orgId: number) => { const { user, deleteOrgUser } = this.props; user && deleteOrgUser(user.id, orgId); }; onOrgRoleChange = (orgId: number, newRole: string) => { const { user, updateOrgUserRole } = this.props; user && updateOrgUserRole(user.id, orgId, newRole); }; onOrgAdd = (orgId: number, role: string) => { const { user, addOrgUser } = this.props; user && addOrgUser(user, orgId, role); }; onSessionRevoke = (tokenId: number) => { const { user, revokeSession } = this.props; user && revokeSession(tokenId, user.id); }; onAllSessionsRevoke = () => { const { user, revokeAllSessions } = this.props; user && revokeAllSessions(user.id); }; onUserSync = () => { const { user, syncLdapUser } = this.props; user && syncLdapUser(user.id); }; render() { const { navModel, user, orgs, sessions, ldapSyncInfo, isLoading } = this.props; const isLDAPUser = user && user.isExternal && user.authLabels && user.authLabels.includes('LDAP'); const canReadSessions = contextSrv.hasPermission(AccessControlAction.UsersAuthTokenList); const canReadLDAPStatus = contextSrv.hasPermission(AccessControlAction.LDAPStatusRead); return ( {user && ( <> {isLDAPUser && featureEnabled('ldapsync') && ldapSyncInfo && canReadLDAPStatus && ( )} )} {orgs && ( )} {sessions && canReadSessions && ( )} ); } } const mapStateToProps = (state: StoreState) => ({ navModel: getNavModel(state.navIndex, 'global-users'), user: state.userAdmin.user, sessions: state.userAdmin.sessions, orgs: state.userAdmin.orgs, ldapSyncInfo: state.ldap.syncInfo, isLoading: state.userAdmin.isLoading, error: state.userAdmin.error, }); const mapDispatchToProps = { loadAdminUserPage, updateUser, setUserPassword, disableUser, enableUser, deleteUser, updateUserPermissions, addOrgUser, updateOrgUserRole, deleteOrgUser, revokeSession, revokeAllSessions, syncLdapUser, }; const connector = connect(mapStateToProps, mapDispatchToProps); type Props = OwnProps & ConnectedProps; export default connector(UserAdminPage);