mattermost-community-enterp.../public/pluginapi/team.go
Claude ec1f89217a Merge: Complete Mattermost Server with Community Enterprise
Full Mattermost server source with integrated Community Enterprise features.
Includes vendor directory for offline/air-gapped builds.

Structure:
- enterprise-impl/: Enterprise feature implementations
- enterprise-community/: Init files that register implementations
- enterprise/: Bridge imports (community_imports.go)
- vendor/: All dependencies for offline builds

Build (online):
  go build ./cmd/mattermost

Build (offline/air-gapped):
  go build -mod=vendor ./cmd/mattermost

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-17 23:59:07 +09:00

232 lines
6.0 KiB
Go

package pluginapi
import (
"bytes"
"io"
"github.com/mattermost/mattermost/server/public/model"
"github.com/mattermost/mattermost/server/public/plugin"
)
// TeamService exposes methods to manipulate teams and their members.
type TeamService struct {
api plugin.API
}
// Get gets a team.
//
// Minimum server version: 5.2
func (t *TeamService) Get(teamID string) (*model.Team, error) {
team, appErr := t.api.GetTeam(teamID)
return team, normalizeAppErr(appErr)
}
// GetByName gets a team by its name.
//
// Minimum server version: 5.2
func (t *TeamService) GetByName(name string) (*model.Team, error) {
team, appErr := t.api.GetTeamByName(name)
return team, normalizeAppErr(appErr)
}
// TeamListOption is used to filter team listing.
type TeamListOption func(*ListTeamsOptions)
// ListTeamsOptions holds options about filter out team listing.
type ListTeamsOptions struct {
UserID string
}
// FilterTeamsByUser option is used to filter teams by user.
func FilterTeamsByUser(userID string) TeamListOption {
return func(o *ListTeamsOptions) {
o.UserID = userID
}
}
// List gets a list of teams by options.
//
// Minimum server version: 5.2
// Minimum server version when LimitTeamsToUser() option is used: 5.6
func (t *TeamService) List(options ...TeamListOption) ([]*model.Team, error) {
opts := ListTeamsOptions{}
for _, o := range options {
o(&opts)
}
var teams []*model.Team
var appErr *model.AppError
if opts.UserID != "" {
teams, appErr = t.api.GetTeamsForUser(opts.UserID)
} else {
teams, appErr = t.api.GetTeams()
}
return teams, normalizeAppErr(appErr)
}
// Search search a team.
//
// Minimum server version: 5.8
func (t *TeamService) Search(term string) ([]*model.Team, error) {
teams, appErr := t.api.SearchTeams(term)
return teams, normalizeAppErr(appErr)
}
// Create creates a team.
//
// Minimum server version: 5.2
func (t *TeamService) Create(team *model.Team) error {
createdTeam, appErr := t.api.CreateTeam(team)
if appErr != nil {
return normalizeAppErr(appErr)
}
*team = *createdTeam
return nil
}
// Update updates a team.
//
// Minimum server version: 5.2
func (t *TeamService) Update(team *model.Team) error {
updatedTeam, appErr := t.api.UpdateTeam(team)
if appErr != nil {
return normalizeAppErr(appErr)
}
*team = *updatedTeam
return nil
}
// Delete deletes a team.
//
// Minimum server version: 5.2
func (t *TeamService) Delete(teamID string) error {
return normalizeAppErr(t.api.DeleteTeam(teamID))
}
// GetIcon gets the team icon.
//
// Minimum server version: 5.6
func (t *TeamService) GetIcon(teamID string) (io.Reader, error) {
contentBytes, appErr := t.api.GetTeamIcon(teamID)
if appErr != nil {
return nil, normalizeAppErr(appErr)
}
return bytes.NewReader(contentBytes), nil
}
// SetIcon sets the team icon.
//
// Minimum server version: 5.6
func (t *TeamService) SetIcon(teamID string, content io.Reader) error {
contentBytes, err := io.ReadAll(content)
if err != nil {
return err
}
return normalizeAppErr(t.api.SetTeamIcon(teamID, contentBytes))
}
// DeleteIcon removes the team icon.
//
// Minimum server version: 5.6
func (t *TeamService) DeleteIcon(teamID string) error {
return normalizeAppErr(t.api.RemoveTeamIcon(teamID))
}
// GetUsers lists users of the team.
//
// Minimum server version: 5.6
func (t *TeamService) ListUsers(teamID string, page, count int) ([]*model.User, error) {
users, appErr := t.api.GetUsersInTeam(teamID, page, count)
return users, normalizeAppErr(appErr)
}
// ListUnreadForUser gets the unread message and mention counts for each team to which the given user belongs.
//
// Minimum server version: 5.6
func (t *TeamService) ListUnreadForUser(userID string) ([]*model.TeamUnread, error) {
teamUnreads, appErr := t.api.GetTeamsUnreadForUser(userID)
return teamUnreads, normalizeAppErr(appErr)
}
// GetMember returns a specific membership.
//
// Minimum server version: 5.2
func (t *TeamService) GetMember(teamID, userID string) (*model.TeamMember, error) {
teamMember, appErr := t.api.GetTeamMember(teamID, userID)
return teamMember, normalizeAppErr(appErr)
}
// ListMembers returns the memberships of a specific team.
//
// Minimum server version: 5.2
func (t *TeamService) ListMembers(teamID string, page, perPage int) ([]*model.TeamMember, error) {
teamMembers, appErr := t.api.GetTeamMembers(teamID, page, perPage)
return teamMembers, normalizeAppErr(appErr)
}
// ListMembersForUser returns all team memberships for a user.
//
// Minimum server version: 5.10
func (t *TeamService) ListMembersForUser(userID string, page, perPage int) ([]*model.TeamMember, error) {
teamMembers, appErr := t.api.GetTeamMembersForUser(userID, page, perPage)
return teamMembers, normalizeAppErr(appErr)
}
// CreateMember creates a team membership.
//
// Minimum server version: 5.2
func (t *TeamService) CreateMember(teamID, userID string) (*model.TeamMember, error) {
teamMember, appErr := t.api.CreateTeamMember(teamID, userID)
return teamMember, normalizeAppErr(appErr)
}
// CreateMembers creates a team membership for all provided user ids.
//
// Minimum server version: 5.2
func (t *TeamService) CreateMembers(teamID string, userIDs []string, requestorID string) ([]*model.TeamMember, error) {
teamMembers, appErr := t.api.CreateTeamMembers(teamID, userIDs, requestorID)
return teamMembers, normalizeAppErr(appErr)
}
// DeleteMember deletes a team membership.
//
// Minimum server version: 5.2
func (t *TeamService) DeleteMember(teamID, userID, requestorID string) error {
return normalizeAppErr(t.api.DeleteTeamMember(teamID, userID, requestorID))
}
// UpdateMemberRoles updates the role for a team membership.
//
// Minimum server version: 5.2
func (t *TeamService) UpdateMemberRoles(teamID, userID, newRoles string) (*model.TeamMember, error) {
teamMember, appErr := t.api.UpdateTeamMemberRoles(teamID, userID, newRoles)
return teamMember, normalizeAppErr(appErr)
}
// GetStats gets a team's statistics
//
// Minimum server version: 5.8
func (t *TeamService) GetStats(teamID string) (*model.TeamStats, error) {
teamStats, appErr := t.api.GetTeamStats(teamID)
return teamStats, normalizeAppErr(appErr)
}