Merge pull request #7045 from Budibase/prevent-self-deletion
Prevent self deletion
This commit is contained in:
commit
04418ea2f3
|
@ -237,18 +237,21 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
{#if userId !== $auth.user._id}
|
||||||
<ActionMenu align="right">
|
<div>
|
||||||
<span slot="control">
|
<ActionMenu align="right">
|
||||||
<Icon hoverable name="More" />
|
<span slot="control">
|
||||||
</span>
|
<Icon hoverable name="More" />
|
||||||
<MenuItem on:click={resetPasswordModal.show} icon="Refresh"
|
</span>
|
||||||
>Force Password Reset</MenuItem
|
<MenuItem on:click={resetPasswordModal.show} icon="Refresh">
|
||||||
>
|
Force password reset
|
||||||
<MenuItem on:click={deleteModal.show} icon="Delete">Delete</MenuItem
|
</MenuItem>
|
||||||
>
|
<MenuItem on:click={deleteModal.show} icon="Delete">
|
||||||
</ActionMenu>
|
Delete
|
||||||
</div>
|
</MenuItem>
|
||||||
|
</ActionMenu>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
</Layout>
|
</Layout>
|
||||||
<Layout gap="S" noPadding>
|
<Layout gap="S" noPadding>
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
import ImportUsersModal from "./_components/ImportUsersModal.svelte"
|
import ImportUsersModal from "./_components/ImportUsersModal.svelte"
|
||||||
import { createPaginationStore } from "helpers/pagination"
|
import { createPaginationStore } from "helpers/pagination"
|
||||||
import { Constants } from "@budibase/frontend-core"
|
import { Constants } from "@budibase/frontend-core"
|
||||||
|
import { get } from "svelte/store"
|
||||||
|
|
||||||
const accessTypes = [
|
const accessTypes = [
|
||||||
{
|
{
|
||||||
|
@ -198,6 +199,10 @@
|
||||||
const deleteRows = async () => {
|
const deleteRows = async () => {
|
||||||
try {
|
try {
|
||||||
let ids = selectedRows.map(user => user._id)
|
let ids = selectedRows.map(user => user._id)
|
||||||
|
if (ids.includes(get(auth).user._id)) {
|
||||||
|
notifications.error("You cannot delete yourself")
|
||||||
|
return
|
||||||
|
}
|
||||||
await users.bulkDelete(ids)
|
await users.bulkDelete(ids)
|
||||||
notifications.success(`Successfully deleted ${selectedRows.length} rows`)
|
notifications.success(`Successfully deleted ${selectedRows.length} rows`)
|
||||||
selectedRows = []
|
selectedRows = []
|
||||||
|
|
|
@ -3,17 +3,18 @@ import { checkInviteCode } from "../../../utilities/redis"
|
||||||
import { sendEmail } from "../../../utilities/email"
|
import { sendEmail } from "../../../utilities/email"
|
||||||
import { users } from "../../../sdk"
|
import { users } from "../../../sdk"
|
||||||
import env from "../../../environment"
|
import env from "../../../environment"
|
||||||
import { User, CloudAccount } from "@budibase/types"
|
import { CloudAccount, User } from "@budibase/types"
|
||||||
import {
|
import {
|
||||||
events,
|
|
||||||
errors,
|
|
||||||
accounts,
|
accounts,
|
||||||
users as usersCore,
|
|
||||||
tenancy,
|
|
||||||
cache,
|
cache,
|
||||||
|
errors,
|
||||||
|
events,
|
||||||
|
tenancy,
|
||||||
|
users as usersCore,
|
||||||
} from "@budibase/backend-core"
|
} from "@budibase/backend-core"
|
||||||
import { checkAnyUserExists } from "../../../utilities/users"
|
import { checkAnyUserExists } from "../../../utilities/users"
|
||||||
import { groups as groupUtils } from "@budibase/pro"
|
import { groups as groupUtils } from "@budibase/pro"
|
||||||
|
|
||||||
const MAX_USERS_UPLOAD_LIMIT = 1000
|
const MAX_USERS_UPLOAD_LIMIT = 1000
|
||||||
|
|
||||||
export const save = async (ctx: any) => {
|
export const save = async (ctx: any) => {
|
||||||
|
@ -117,8 +118,7 @@ export const adminUser = async (ctx: any) => {
|
||||||
export const countByApp = async (ctx: any) => {
|
export const countByApp = async (ctx: any) => {
|
||||||
const appId = ctx.params.appId
|
const appId = ctx.params.appId
|
||||||
try {
|
try {
|
||||||
const response = await users.countUsersByApp(appId)
|
ctx.body = await users.countUsersByApp(appId)
|
||||||
ctx.body = response
|
|
||||||
} catch (err: any) {
|
} catch (err: any) {
|
||||||
ctx.throw(err.status || 400, err)
|
ctx.throw(err.status || 400, err)
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,9 @@ export const countByApp = async (ctx: any) => {
|
||||||
|
|
||||||
export const destroy = async (ctx: any) => {
|
export const destroy = async (ctx: any) => {
|
||||||
const id = ctx.params.id
|
const id = ctx.params.id
|
||||||
|
if (id === ctx.user._id) {
|
||||||
|
ctx.throw(400, "Unable to delete self.")
|
||||||
|
}
|
||||||
|
|
||||||
await users.destroy(id, ctx.user)
|
await users.destroy(id, ctx.user)
|
||||||
|
|
||||||
|
@ -136,6 +139,10 @@ export const destroy = async (ctx: any) => {
|
||||||
|
|
||||||
export const bulkDelete = async (ctx: any) => {
|
export const bulkDelete = async (ctx: any) => {
|
||||||
const { userIds } = ctx.request.body
|
const { userIds } = ctx.request.body
|
||||||
|
if (userIds?.indexOf(ctx.user._id) !== -1) {
|
||||||
|
ctx.throw(400, "Unable to delete self.")
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
let usersResponse = await users.bulkDelete(userIds)
|
let usersResponse = await users.bulkDelete(userIds)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue