mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	Add user blocking (#29028)
Fixes #17453 This PR adds the abbility to block a user from a personal account or organization to restrict how the blocked user can interact with the blocker. The docs explain what's the consequence of blocking a user. Screenshots:    --------- Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
		| @@ -57,6 +57,7 @@ import ( | ||||
| 	issue_service "code.gitea.io/gitea/services/issue" | ||||
| 	pull_service "code.gitea.io/gitea/services/pull" | ||||
| 	repo_service "code.gitea.io/gitea/services/repository" | ||||
| 	user_service "code.gitea.io/gitea/services/user" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| @@ -1258,9 +1259,11 @@ func NewIssuePost(ctx *context.Context) { | ||||
| 	if err := issue_service.NewIssue(ctx, repo, issue, labelIDs, attachments, assigneeIDs); err != nil { | ||||
| 		if repo_model.IsErrUserDoesNotHaveAccessToRepo(err) { | ||||
| 			ctx.Error(http.StatusBadRequest, "UserDoesNotHaveAccessToRepo", err.Error()) | ||||
| 			return | ||||
| 		} else if errors.Is(err, user_model.ErrBlockedUser) { | ||||
| 			ctx.JSONError(ctx.Tr("repo.issues.new.blocked_user")) | ||||
| 		} else { | ||||
| 			ctx.ServerError("NewIssue", err) | ||||
| 		} | ||||
| 		ctx.ServerError("NewIssue", err) | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| @@ -2047,6 +2050,10 @@ func ViewIssue(ctx *context.Context) { | ||||
| 	} | ||||
| 	ctx.Data["Tags"] = tags | ||||
|  | ||||
| 	ctx.Data["CanBlockUser"] = func(blocker, blockee *user_model.User) bool { | ||||
| 		return user_service.CanBlockUser(ctx, ctx.Doer, blocker, blockee) | ||||
| 	} | ||||
|  | ||||
| 	ctx.HTML(http.StatusOK, tplIssueView) | ||||
| } | ||||
|  | ||||
| @@ -2250,7 +2257,11 @@ func UpdateIssueContent(ctx *context.Context) { | ||||
| 	} | ||||
|  | ||||
| 	if err := issue_service.ChangeContent(ctx, issue, ctx.Doer, ctx.Req.FormValue("content")); err != nil { | ||||
| 		ctx.ServerError("ChangeContent", err) | ||||
| 		if errors.Is(err, user_model.ErrBlockedUser) { | ||||
| 			ctx.JSONError(ctx.Tr("repo.issues.edit.blocked_user")) | ||||
| 		} else { | ||||
| 			ctx.ServerError("ChangeContent", err) | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| @@ -3108,7 +3119,11 @@ func NewComment(ctx *context.Context) { | ||||
|  | ||||
| 	comment, err := issue_service.CreateIssueComment(ctx, ctx.Doer, ctx.Repo.Repository, issue, form.Content, attachments) | ||||
| 	if err != nil { | ||||
| 		ctx.ServerError("CreateIssueComment", err) | ||||
| 		if errors.Is(err, user_model.ErrBlockedUser) { | ||||
| 			ctx.JSONError(ctx.Tr("repo.issues.comment.blocked_user")) | ||||
| 		} else { | ||||
| 			ctx.ServerError("CreateIssueComment", err) | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| @@ -3152,7 +3167,11 @@ func UpdateCommentContent(ctx *context.Context) { | ||||
| 		return | ||||
| 	} | ||||
| 	if err = issue_service.UpdateComment(ctx, comment, ctx.Doer, oldContent); err != nil { | ||||
| 		ctx.ServerError("UpdateComment", err) | ||||
| 		if errors.Is(err, user_model.ErrBlockedUser) { | ||||
| 			ctx.JSONError(ctx.Tr("repo.issues.comment.blocked_user")) | ||||
| 		} else { | ||||
| 			ctx.ServerError("UpdateComment", err) | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| @@ -3260,9 +3279,9 @@ func ChangeIssueReaction(ctx *context.Context) { | ||||
|  | ||||
| 	switch ctx.Params(":action") { | ||||
| 	case "react": | ||||
| 		reaction, err := issues_model.CreateIssueReaction(ctx, ctx.Doer.ID, issue.ID, form.Content) | ||||
| 		reaction, err := issue_service.CreateIssueReaction(ctx, ctx.Doer, issue, form.Content) | ||||
| 		if err != nil { | ||||
| 			if issues_model.IsErrForbiddenIssueReaction(err) { | ||||
| 			if issues_model.IsErrForbiddenIssueReaction(err) || errors.Is(err, user_model.ErrBlockedUser) { | ||||
| 				ctx.ServerError("ChangeIssueReaction", err) | ||||
| 				return | ||||
| 			} | ||||
| @@ -3367,9 +3386,9 @@ func ChangeCommentReaction(ctx *context.Context) { | ||||
|  | ||||
| 	switch ctx.Params(":action") { | ||||
| 	case "react": | ||||
| 		reaction, err := issues_model.CreateCommentReaction(ctx, ctx.Doer.ID, comment.Issue.ID, comment.ID, form.Content) | ||||
| 		reaction, err := issue_service.CreateCommentReaction(ctx, ctx.Doer, comment, form.Content) | ||||
| 		if err != nil { | ||||
| 			if issues_model.IsErrForbiddenIssueReaction(err) { | ||||
| 			if issues_model.IsErrForbiddenIssueReaction(err) || errors.Is(err, user_model.ErrBlockedUser) { | ||||
| 				ctx.ServerError("ChangeIssueReaction", err) | ||||
| 				return | ||||
| 			} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user