mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 08:34:30 +01:00 
			
		
		
		
	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>
		
			
				
	
	
		
			77 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2024 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package user
 | 
						|
 | 
						|
import (
 | 
						|
	"errors"
 | 
						|
 | 
						|
	user_model "code.gitea.io/gitea/models/user"
 | 
						|
	"code.gitea.io/gitea/modules/web"
 | 
						|
	"code.gitea.io/gitea/services/context"
 | 
						|
	"code.gitea.io/gitea/services/forms"
 | 
						|
	user_service "code.gitea.io/gitea/services/user"
 | 
						|
)
 | 
						|
 | 
						|
func BlockedUsers(ctx *context.Context, blocker *user_model.User) {
 | 
						|
	blocks, _, err := user_model.FindBlockings(ctx, &user_model.FindBlockingOptions{
 | 
						|
		BlockerID: blocker.ID,
 | 
						|
	})
 | 
						|
	if err != nil {
 | 
						|
		ctx.ServerError("FindBlockings", err)
 | 
						|
		return
 | 
						|
	}
 | 
						|
	if err := user_model.BlockingList(blocks).LoadAttributes(ctx); err != nil {
 | 
						|
		ctx.ServerError("LoadAttributes", err)
 | 
						|
		return
 | 
						|
	}
 | 
						|
	ctx.Data["UserBlocks"] = blocks
 | 
						|
}
 | 
						|
 | 
						|
func BlockedUsersPost(ctx *context.Context, blocker *user_model.User) {
 | 
						|
	form := web.GetForm(ctx).(*forms.BlockUserForm)
 | 
						|
	if ctx.HasError() {
 | 
						|
		ctx.ServerError("FormValidation", nil)
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	blockee, err := user_model.GetUserByName(ctx, form.Blockee)
 | 
						|
	if err != nil {
 | 
						|
		ctx.ServerError("GetUserByName", nil)
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	switch form.Action {
 | 
						|
	case "block":
 | 
						|
		if err := user_service.BlockUser(ctx, ctx.Doer, blocker, blockee, form.Note); err != nil {
 | 
						|
			if errors.Is(err, user_model.ErrCanNotBlock) || errors.Is(err, user_model.ErrBlockOrganization) {
 | 
						|
				ctx.Flash.Error(ctx.Tr("user.block.block.failure", err.Error()))
 | 
						|
			} else {
 | 
						|
				ctx.ServerError("BlockUser", err)
 | 
						|
				return
 | 
						|
			}
 | 
						|
		}
 | 
						|
	case "unblock":
 | 
						|
		if err := user_service.UnblockUser(ctx, ctx.Doer, blocker, blockee); err != nil {
 | 
						|
			if errors.Is(err, user_model.ErrCanNotUnblock) || errors.Is(err, user_model.ErrBlockOrganization) {
 | 
						|
				ctx.Flash.Error(ctx.Tr("user.block.unblock.failure", err.Error()))
 | 
						|
			} else {
 | 
						|
				ctx.ServerError("UnblockUser", err)
 | 
						|
				return
 | 
						|
			}
 | 
						|
		}
 | 
						|
	case "note":
 | 
						|
		block, err := user_model.GetBlocking(ctx, blocker.ID, blockee.ID)
 | 
						|
		if err != nil {
 | 
						|
			ctx.ServerError("GetBlocking", err)
 | 
						|
			return
 | 
						|
		}
 | 
						|
		if block != nil {
 | 
						|
			if err := user_model.UpdateBlockingNote(ctx, block.ID, form.Note); err != nil {
 | 
						|
				ctx.ServerError("UpdateBlockingNote", err)
 | 
						|
				return
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |