mattermost-community-enterp.../public/pluginapi/channel.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

287 lines
8.9 KiB
Go

package pluginapi
import (
"net/http"
"time"
"github.com/pkg/errors"
"github.com/mattermost/mattermost/server/public/model"
"github.com/mattermost/mattermost/server/public/plugin"
)
// ChannelService exposes methods to manipulate channels.
type ChannelService struct {
api plugin.API
}
// Get gets a channel.
//
// Minimum server version: 5.2
func (c *ChannelService) Get(channelID string) (*model.Channel, error) {
channel, appErr := c.api.GetChannel(channelID)
return channel, normalizeAppErr(appErr)
}
// GetByName gets a channel by its name, given a team id.
//
// Minimum server version: 5.2
func (c *ChannelService) GetByName(teamID, channelName string, includeDeleted bool) (*model.Channel, error) {
channel, appErr := c.api.GetChannelByName(teamID, channelName, includeDeleted)
return channel, normalizeAppErr(appErr)
}
// GetDirect gets a direct message channel.
//
// Note that if the channel does not exist it will create it.
//
// Minimum server version: 5.2
func (c *ChannelService) GetDirect(userID1, userID2 string) (*model.Channel, error) {
channel, appErr := c.api.GetDirectChannel(userID1, userID2)
return channel, normalizeAppErr(appErr)
}
// GetGroup gets a group message channel.
//
// Note that if the channel does not exist it will create it.
//
// Minimum server version: 5.2
func (c *ChannelService) GetGroup(userIDs []string) (*model.Channel, error) {
channel, appErr := c.api.GetGroupChannel(userIDs)
return channel, normalizeAppErr(appErr)
}
// GetByNameForTeamName gets a channel by its name, given a team name.
//
// Minimum server version: 5.2
func (c *ChannelService) GetByNameForTeamName(teamName, channelName string, includeDeleted bool) (*model.Channel, error) {
channel, appErr := c.api.GetChannelByNameForTeamName(teamName, channelName, includeDeleted)
return channel, normalizeAppErr(appErr)
}
// ListForTeamForUser gets a list of channels for given user ID in given team ID.
//
// Minimum server version: 5.6
func (c *ChannelService) ListForTeamForUser(teamID, userID string, includeDeleted bool) ([]*model.Channel, error) {
channels, appErr := c.api.GetChannelsForTeamForUser(teamID, userID, includeDeleted)
return channels, normalizeAppErr(appErr)
}
// ListPublicChannelsForTeam gets a list of all channels.
//
// Minimum server version: 5.2
func (c *ChannelService) ListPublicChannelsForTeam(teamID string, page, perPage int) ([]*model.Channel, error) {
channels, appErr := c.api.GetPublicChannelsForTeam(teamID, page, perPage)
return channels, normalizeAppErr(appErr)
}
// Search returns the channels on a team matching the provided search term.
//
// Minimum server version: 5.6
func (c *ChannelService) Search(teamID, term string) ([]*model.Channel, error) {
channels, appErr := c.api.SearchChannels(teamID, term)
return channels, normalizeAppErr(appErr)
}
// Create creates a channel.
//
// Minimum server version: 5.2
func (c *ChannelService) Create(channel *model.Channel) error {
createdChannel, appErr := c.api.CreateChannel(channel)
if appErr != nil {
return normalizeAppErr(appErr)
}
*channel = *createdChannel
return c.waitForChannelCreation(channel.Id)
}
// Update updates a channel.
//
// Minimum server version: 5.2
func (c *ChannelService) Update(channel *model.Channel) error {
updatedChannel, appErr := c.api.UpdateChannel(channel)
if appErr != nil {
return normalizeAppErr(appErr)
}
*channel = *updatedChannel
return nil
}
// Delete deletes a channel.
//
// Minimum server version: 5.2
func (c *ChannelService) Delete(channelID string) error {
return normalizeAppErr(c.api.DeleteChannel(channelID))
}
// GetChannelStats gets statistics for a channel.
//
// Minimum server version: 5.6
func (c *ChannelService) GetChannelStats(channelID string) (*model.ChannelStats, error) {
channelStats, appErr := c.api.GetChannelStats(channelID)
return channelStats, normalizeAppErr(appErr)
}
// GetMember gets a channel membership for a user.
//
// Minimum server version: 5.2
func (c *ChannelService) GetMember(channelID, userID string) (*model.ChannelMember, error) {
channelMember, appErr := c.api.GetChannelMember(channelID, userID)
return channelMember, normalizeAppErr(appErr)
}
// ListMembers gets a channel membership for all users.
//
// Minimum server version: 5.6
func (c *ChannelService) ListMembers(channelID string, page, perPage int) ([]*model.ChannelMember, error) {
channelMembers, appErr := c.api.GetChannelMembers(channelID, page, perPage)
return channelMembersToChannelMemberSlice(channelMembers), normalizeAppErr(appErr)
}
// ListMembersByIDs gets a channel membership for a particular User
//
// Minimum server version: 5.6
func (c *ChannelService) ListMembersByIDs(channelID string, userIDs []string) ([]*model.ChannelMember, error) {
channelMembers, appErr := c.api.GetChannelMembersByIds(channelID, userIDs)
return channelMembersToChannelMemberSlice(channelMembers), normalizeAppErr(appErr)
}
// ListMembersForUser returns all channel memberships on a team for a user.
//
// Minimum server version: 5.10
func (c *ChannelService) ListMembersForUser(teamID, userID string, page, perPage int) ([]*model.ChannelMember, error) {
channelMembers, appErr := c.api.GetChannelMembersForUser(teamID, userID, page, perPage)
return channelMembers, normalizeAppErr(appErr)
}
// AddMember joins a user to a channel (as if they joined themselves).
// This means the user will not receive notifications for joining the channel.
//
// Minimum server version: 5.2
func (c *ChannelService) AddMember(channelID, userID string) (*model.ChannelMember, error) {
channelMember, appErr := c.api.AddChannelMember(channelID, userID)
return channelMember, normalizeAppErr(appErr)
}
// AddUser adds a user to a channel as if the specified user had invited them.
// This means the user will receive the regular notifications for being added to the channel.
//
// Minimum server version: 5.18
func (c *ChannelService) AddUser(channelID, userID, asUserID string) (*model.ChannelMember, error) {
channelMember, appErr := c.api.AddUserToChannel(channelID, userID, asUserID)
return channelMember, normalizeAppErr(appErr)
}
// DeleteMember deletes a channel membership for a user.
//
// Minimum server version: 5.2
func (c *ChannelService) DeleteMember(channelID, userID string) error {
appErr := c.api.DeleteChannelMember(channelID, userID)
return normalizeAppErr(appErr)
}
// UpdateChannelMemberRoles updates a user's roles for a channel.
//
// Minimum server version: 5.2
func (c *ChannelService) UpdateChannelMemberRoles(channelID, userID, newRoles string) (*model.ChannelMember, error) {
channelMember, appErr := c.api.UpdateChannelMemberRoles(channelID, userID, newRoles)
return channelMember, normalizeAppErr(appErr)
}
// UpdateChannelMemberNotifications updates a user's notification properties for a channel.
//
// Minimum server version: 5.2
func (c *ChannelService) UpdateChannelMemberNotifications(channelID, userID string, notifications map[string]string) (*model.ChannelMember, error) {
channelMember, appErr := c.api.UpdateChannelMemberNotifications(channelID, userID, notifications)
return channelMember, normalizeAppErr(appErr)
}
// CreateSidebarCategory creates a new sidebar category for a set of channels.
//
// Minimum server version: 5.38
func (c *ChannelService) CreateSidebarCategory(
userID, teamID string, newCategory *model.SidebarCategoryWithChannels) error {
category, appErr := c.api.CreateChannelSidebarCategory(userID, teamID, newCategory)
if appErr != nil {
return normalizeAppErr(appErr)
}
*newCategory = *category
return nil
}
// GetSidebarCategories returns sidebar categories.
//
// Minimum server version: 5.38
func (c *ChannelService) GetSidebarCategories(userID, teamID string) (*model.OrderedSidebarCategories, error) {
categories, appErr := c.api.GetChannelSidebarCategories(userID, teamID)
return categories, normalizeAppErr(appErr)
}
// UpdateSidebarCategories updates the channel sidebar categories.
//
// Minimum server version: 5.38
func (c *ChannelService) UpdateSidebarCategories(
userID, teamID string, categories []*model.SidebarCategoryWithChannels) error {
updatedCategories, appErr := c.api.UpdateChannelSidebarCategories(userID, teamID, categories)
if appErr != nil {
return normalizeAppErr(appErr)
}
copy(categories, updatedCategories)
return nil
}
func (c *ChannelService) waitForChannelCreation(channelID string) error {
if len(c.api.GetConfig().SqlSettings.DataSourceReplicas) == 0 {
return nil
}
now := time.Now()
for time.Since(now) < 1500*time.Millisecond {
time.Sleep(100 * time.Millisecond)
if _, err := c.api.GetChannel(channelID); err == nil {
// Channel found
return nil
} else if err.StatusCode != http.StatusNotFound {
return err
}
}
return errors.Errorf("giving up waiting for channel creation, channelID=%s", channelID)
}
func channelMembersToChannelMemberSlice(cm model.ChannelMembers) []*model.ChannelMember {
cmp := make([]*model.ChannelMember, len(cm))
for i := range cm {
cmp[i] = &(cm)[i]
}
return cmp
}