mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 09:44:21 +00:00 
			
		
		
		
	API Endpoints for collaborators (#375)
This commit is contained in:
		@@ -103,6 +103,15 @@ func (repo *Repository) GetCollaborators() ([]*Collaborator, error) {
 | 
			
		||||
	return repo.getCollaborators(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (repo *Repository) isCollaborator(e Engine, userID int64) (bool, error) {
 | 
			
		||||
	return e.Get(&Collaboration{RepoID: repo.ID, UserID: userID})
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// IsCollaborator check if a user is a collaborator of a repository
 | 
			
		||||
func (repo *Repository) IsCollaborator(userID int64) (bool, error) {
 | 
			
		||||
	return repo.isCollaborator(x, userID)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// ChangeCollaborationAccessMode sets new access mode for the collaboration.
 | 
			
		||||
func (repo *Repository) ChangeCollaborationAccessMode(uid int64, mode AccessMode) error {
 | 
			
		||||
	// Discard invalid input
 | 
			
		||||
 
 | 
			
		||||
@@ -270,7 +270,12 @@ func RegisterRoutes(m *macaron.Macaron) {
 | 
			
		||||
						Patch(bind(api.EditHookOption{}), repo.EditHook).
 | 
			
		||||
						Delete(repo.DeleteHook)
 | 
			
		||||
				})
 | 
			
		||||
				m.Put("/collaborators/:collaborator", bind(api.AddCollaboratorOption{}), repo.AddCollaborator)
 | 
			
		||||
				m.Group("/collaborators", func() {
 | 
			
		||||
					m.Get("", repo.ListCollaborators)
 | 
			
		||||
					m.Combo("/:collaborator").Get(repo.IsCollaborator).
 | 
			
		||||
						Put(bind(api.AddCollaboratorOption{}), repo.AddCollaborator).
 | 
			
		||||
						Delete(repo.DeleteCollaborator)
 | 
			
		||||
				})
 | 
			
		||||
				m.Get("/raw/*", context.RepoRef(), repo.GetRawFile)
 | 
			
		||||
				m.Get("/archive/*", repo.GetArchive)
 | 
			
		||||
				m.Group("/branches", func() {
 | 
			
		||||
 
 | 
			
		||||
@@ -11,8 +11,72 @@ import (
 | 
			
		||||
	"code.gitea.io/gitea/modules/context"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// ListCollaborators list a repository's collaborators
 | 
			
		||||
func ListCollaborators(ctx *context.APIContext) {
 | 
			
		||||
	access, err := models.AccessLevel(ctx.User, ctx.Repo.Repository)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Error(500, "AccessLevel", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if access < models.AccessModeWrite {
 | 
			
		||||
		ctx.Error(403, "", "User does not have push access")
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	collaborators, err := ctx.Repo.Repository.GetCollaborators()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Error(500, "ListCollaborators", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	users := make([]*api.User, len(collaborators))
 | 
			
		||||
	for i, collaborator := range collaborators {
 | 
			
		||||
		users[i] = collaborator.APIFormat()
 | 
			
		||||
	}
 | 
			
		||||
	ctx.JSON(200, users)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// IsCollaborator check if a user is a collaborator of a repository
 | 
			
		||||
func IsCollaborator(ctx *context.APIContext) {
 | 
			
		||||
	access, err := models.AccessLevel(ctx.User, ctx.Repo.Repository)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Error(500, "AccessLevel", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if access < models.AccessModeWrite {
 | 
			
		||||
		ctx.Error(403, "", "User does not have push access")
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	user, err := models.GetUserByName(ctx.Params(":collaborator"))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		if models.IsErrUserNotExist(err) {
 | 
			
		||||
			ctx.Error(422, "", err)
 | 
			
		||||
		} else {
 | 
			
		||||
			ctx.Error(500, "GetUserByName", err)
 | 
			
		||||
		}
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	isColab, err := ctx.Repo.Repository.IsCollaborator(user.ID)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Error(500, "IsCollaborator", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if isColab {
 | 
			
		||||
		ctx.Status(204)
 | 
			
		||||
	} else {
 | 
			
		||||
		ctx.Status(404)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// AddCollaborator add a collaborator of a repository
 | 
			
		||||
func AddCollaborator(ctx *context.APIContext, form api.AddCollaboratorOption) {
 | 
			
		||||
	access, err := models.AccessLevel(ctx.User, ctx.Repo.Repository)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Error(500, "AccessLevel", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if access < models.AccessModeWrite {
 | 
			
		||||
		ctx.Error(403, "", "User does not have push access")
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	collaborator, err := models.GetUserByName(ctx.Params(":collaborator"))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		if models.IsErrUserNotExist(err) {
 | 
			
		||||
@@ -37,3 +101,32 @@ func AddCollaborator(ctx *context.APIContext, form api.AddCollaboratorOption) {
 | 
			
		||||
 | 
			
		||||
	ctx.Status(204)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// DeleteCollaborator delete a collaborator from a repository
 | 
			
		||||
func DeleteCollaborator(ctx *context.APIContext) {
 | 
			
		||||
	access, err := models.AccessLevel(ctx.User, ctx.Repo.Repository)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Error(500, "AccessLevel", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if access < models.AccessModeWrite {
 | 
			
		||||
		ctx.Error(403, "", "User does not have push access")
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	collaborator, err := models.GetUserByName(ctx.Params(":collaborator"))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		if models.IsErrUserNotExist(err) {
 | 
			
		||||
			ctx.Error(422, "", err)
 | 
			
		||||
		} else {
 | 
			
		||||
			ctx.Error(500, "GetUserByName", err)
 | 
			
		||||
		}
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if err := ctx.Repo.Repository.DeleteCollaboration(collaborator.ID); err != nil {
 | 
			
		||||
		ctx.Error(500, "DeleteCollaboration", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Status(204)
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user