summaryrefslogtreecommitdiffstats
path: root/routers
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2022-05-08 22:22:55 +0200
committerGitHub <noreply@github.com>2022-05-08 22:22:55 +0200
commit9efa47131f3fa576bd0ef73fa4c5b96c95d89906 (patch)
tree80c65663cc9aab9f51f1e321a16bb84b7badc29b /routers
parentRestore reviewed-on message (#19657) (diff)
downloadforgejo-9efa47131f3fa576bd0ef73fa4c5b96c95d89906.tar.xz
forgejo-9efa47131f3fa576bd0ef73fa4c5b96c95d89906.zip
Admin should not delete himself (#19423)
Admin should not be able to delete themselves. Also partially fix #15449
Diffstat (limited to 'routers')
-rw-r--r--routers/api/v1/admin/user.go6
-rw-r--r--routers/web/admin/users.go9
2 files changed, 15 insertions, 0 deletions
diff --git a/routers/api/v1/admin/user.go b/routers/api/v1/admin/user.go
index 775802449a..6263a67048 100644
--- a/routers/api/v1/admin/user.go
+++ b/routers/api/v1/admin/user.go
@@ -310,6 +310,12 @@ func DeleteUser(ctx *context.APIContext) {
return
}
+ // admin should not delete themself
+ if ctx.ContextUser.ID == ctx.Doer.ID {
+ ctx.Error(http.StatusUnprocessableEntity, "", fmt.Errorf("you cannot delete yourself"))
+ return
+ }
+
if err := user_service.DeleteUser(ctx.ContextUser); err != nil {
if models.IsErrUserOwnRepos(err) ||
models.IsErrUserHasOrgs(err) ||
diff --git a/routers/web/admin/users.go b/routers/web/admin/users.go
index 57da319d79..7841ac569f 100644
--- a/routers/web/admin/users.go
+++ b/routers/web/admin/users.go
@@ -416,6 +416,15 @@ func DeleteUser(ctx *context.Context) {
return
}
+ // admin should not delete themself
+ if u.ID == ctx.Doer.ID {
+ ctx.Flash.Error(ctx.Tr("admin.users.cannot_delete_self"))
+ ctx.JSON(http.StatusOK, map[string]interface{}{
+ "redirect": setting.AppSubURL + "/admin/users/" + url.PathEscape(ctx.Params(":userid")),
+ })
+ return
+ }
+
if err = user_service.DeleteUser(u); err != nil {
switch {
case models.IsErrUserOwnRepos(err):