mirror of
https://github.com/mattermost/focalboard.git
synced 2025-01-23 18:34:02 +02:00
Merge remote-tracking branch 'origin/main' into main
This commit is contained in:
commit
673877568c
@ -112,7 +112,7 @@ func (p *Plugin) OnActivate() error {
|
|||||||
db = layeredStore
|
db = layeredStore
|
||||||
}
|
}
|
||||||
|
|
||||||
p.wsPluginAdapter = ws.NewPluginAdapter(p.API, auth.New(cfg, db))
|
p.wsPluginAdapter = ws.NewPluginAdapter(p.API, auth.New(cfg, db), logger)
|
||||||
|
|
||||||
backendParams := notifyBackendParams{
|
backendParams := notifyBackendParams{
|
||||||
cfg: cfg,
|
cfg: cfg,
|
||||||
|
@ -7,6 +7,7 @@ import (
|
|||||||
wsMocks "github.com/mattermost/focalboard/server/ws/mocks"
|
wsMocks "github.com/mattermost/focalboard/server/ws/mocks"
|
||||||
|
|
||||||
mmModel "github.com/mattermost/mattermost-server/v6/model"
|
mmModel "github.com/mattermost/mattermost-server/v6/model"
|
||||||
|
"github.com/mattermost/mattermost-server/v6/shared/mlog"
|
||||||
|
|
||||||
"github.com/golang/mock/gomock"
|
"github.com/golang/mock/gomock"
|
||||||
)
|
)
|
||||||
@ -32,7 +33,7 @@ func SetupTestHelper(t *testing.T) *TestHelper {
|
|||||||
api: mockAPI,
|
api: mockAPI,
|
||||||
auth: mockAuth,
|
auth: mockAuth,
|
||||||
ctrl: ctrl,
|
ctrl: ctrl,
|
||||||
pa: NewPluginAdapter(mockAPI, mockAuth),
|
pa: NewPluginAdapter(mockAPI, mockAuth, mlog.CreateConsoleTestLogger(true, mlog.LvlDebug)),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@ import (
|
|||||||
|
|
||||||
mmModel "github.com/mattermost/mattermost-server/v6/model"
|
mmModel "github.com/mattermost/mattermost-server/v6/model"
|
||||||
"github.com/mattermost/mattermost-server/v6/plugin"
|
"github.com/mattermost/mattermost-server/v6/plugin"
|
||||||
|
"github.com/mattermost/mattermost-server/v6/shared/mlog"
|
||||||
)
|
)
|
||||||
|
|
||||||
const websocketMessagePrefix = "custom_focalboard_"
|
const websocketMessagePrefix = "custom_focalboard_"
|
||||||
@ -35,6 +36,7 @@ type PluginAdapter struct {
|
|||||||
api plugin.API
|
api plugin.API
|
||||||
auth auth.AuthInterface
|
auth auth.AuthInterface
|
||||||
staleThreshold time.Duration
|
staleThreshold time.Duration
|
||||||
|
logger *mlog.Logger
|
||||||
|
|
||||||
listenersMU sync.RWMutex
|
listenersMU sync.RWMutex
|
||||||
listeners map[string]*PluginAdapterClient
|
listeners map[string]*PluginAdapterClient
|
||||||
@ -45,11 +47,12 @@ type PluginAdapter struct {
|
|||||||
listenersByBlock map[string][]*PluginAdapterClient
|
listenersByBlock map[string][]*PluginAdapterClient
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPluginAdapter(api plugin.API, auth auth.AuthInterface) *PluginAdapter {
|
func NewPluginAdapter(api plugin.API, auth auth.AuthInterface, logger *mlog.Logger) *PluginAdapter {
|
||||||
return &PluginAdapter{
|
return &PluginAdapter{
|
||||||
api: api,
|
api: api,
|
||||||
auth: auth,
|
auth: auth,
|
||||||
staleThreshold: 5 * time.Minute,
|
staleThreshold: 5 * time.Minute,
|
||||||
|
logger: logger,
|
||||||
listeners: make(map[string]*PluginAdapterClient),
|
listeners: make(map[string]*PluginAdapterClient),
|
||||||
listenersByUserID: make(map[string][]*PluginAdapterClient),
|
listenersByUserID: make(map[string][]*PluginAdapterClient),
|
||||||
listenersByWorkspace: make(map[string][]*PluginAdapterClient),
|
listenersByWorkspace: make(map[string][]*PluginAdapterClient),
|
||||||
@ -204,9 +207,9 @@ func (pa *PluginAdapter) unsubscribeListenerFromBlocks(pac *PluginAdapterClient,
|
|||||||
|
|
||||||
func (pa *PluginAdapter) OnWebSocketConnect(webConnID, userID string) {
|
func (pa *PluginAdapter) OnWebSocketConnect(webConnID, userID string) {
|
||||||
if existingPAC, ok := pa.GetListenerByWebConnID(webConnID); ok {
|
if existingPAC, ok := pa.GetListenerByWebConnID(webConnID); ok {
|
||||||
pa.api.LogDebug("inactive connection found for webconn, reusing",
|
pa.logger.Debug("inactive connection found for webconn, reusing",
|
||||||
"webConnID", webConnID,
|
mlog.String("webConnID", webConnID),
|
||||||
"userID", userID,
|
mlog.String("userID", userID),
|
||||||
)
|
)
|
||||||
atomic.StoreInt64(&existingPAC.inactiveAt, 0)
|
atomic.StoreInt64(&existingPAC.inactiveAt, 0)
|
||||||
return
|
return
|
||||||
@ -227,9 +230,9 @@ func (pa *PluginAdapter) OnWebSocketConnect(webConnID, userID string) {
|
|||||||
func (pa *PluginAdapter) OnWebSocketDisconnect(webConnID, userID string) {
|
func (pa *PluginAdapter) OnWebSocketDisconnect(webConnID, userID string) {
|
||||||
pac, ok := pa.GetListenerByWebConnID(webConnID)
|
pac, ok := pa.GetListenerByWebConnID(webConnID)
|
||||||
if !ok {
|
if !ok {
|
||||||
pa.api.LogDebug("received a disconnect for an unregistered webconn",
|
pa.logger.Debug("received a disconnect for an unregistered webconn",
|
||||||
"webConnID", webConnID,
|
mlog.String("webConnID", webConnID),
|
||||||
"userID", userID,
|
mlog.String("userID", userID),
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -260,10 +263,10 @@ func commandFromRequest(req *mmModel.WebSocketRequest) (*WebsocketCommand, error
|
|||||||
func (pa *PluginAdapter) WebSocketMessageHasBeenPosted(webConnID, userID string, req *mmModel.WebSocketRequest) {
|
func (pa *PluginAdapter) WebSocketMessageHasBeenPosted(webConnID, userID string, req *mmModel.WebSocketRequest) {
|
||||||
pac, ok := pa.GetListenerByWebConnID(webConnID)
|
pac, ok := pa.GetListenerByWebConnID(webConnID)
|
||||||
if !ok {
|
if !ok {
|
||||||
pa.api.LogDebug("received a message for an unregistered webconn",
|
pa.logger.Debug("received a message for an unregistered webconn",
|
||||||
"webConnID", webConnID,
|
mlog.String("webConnID", webConnID),
|
||||||
"userID", userID,
|
mlog.String("userID", userID),
|
||||||
"action", req.Action,
|
mlog.String("action", req.Action),
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -275,11 +278,11 @@ func (pa *PluginAdapter) WebSocketMessageHasBeenPosted(webConnID, userID string,
|
|||||||
|
|
||||||
command, err := commandFromRequest(req)
|
command, err := commandFromRequest(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
pa.api.LogError("error getting command from request",
|
pa.logger.Error("error getting command from request",
|
||||||
"err", err,
|
mlog.String("action", req.Action),
|
||||||
"action", req.Action,
|
mlog.String("webConnID", webConnID),
|
||||||
"webConnID", webConnID,
|
mlog.String("userID", userID),
|
||||||
"userID", userID,
|
mlog.Err(err),
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -289,18 +292,18 @@ func (pa *PluginAdapter) WebSocketMessageHasBeenPosted(webConnID, userID string,
|
|||||||
// as there is no such thing as unauthenticated websocket
|
// as there is no such thing as unauthenticated websocket
|
||||||
// connections in plugin mode. Only a debug line is logged
|
// connections in plugin mode. Only a debug line is logged
|
||||||
case websocketActionSubscribeBlocks, websocketActionUnsubscribeBlocks:
|
case websocketActionSubscribeBlocks, websocketActionUnsubscribeBlocks:
|
||||||
pa.api.LogDebug(`Command not implemented in plugin mode`,
|
pa.logger.Debug(`Command not implemented in plugin mode`,
|
||||||
"command", command.Action,
|
mlog.String("command", command.Action),
|
||||||
"webConnID", webConnID,
|
mlog.String("webConnID", webConnID),
|
||||||
"userID", userID,
|
mlog.String("userID", userID),
|
||||||
"workspaceID", command.WorkspaceID,
|
mlog.String("workspaceID", command.WorkspaceID),
|
||||||
)
|
)
|
||||||
|
|
||||||
case websocketActionSubscribeWorkspace:
|
case websocketActionSubscribeWorkspace:
|
||||||
pa.api.LogDebug(`Command: SUBSCRIBE_WORKSPACE`,
|
pa.logger.Debug(`Command: SUBSCRIBE_WORKSPACE`,
|
||||||
"webConnID", webConnID,
|
mlog.String("webConnID", webConnID),
|
||||||
"userID", userID,
|
mlog.String("userID", userID),
|
||||||
"workspaceID", command.WorkspaceID,
|
mlog.String("workspaceID", command.WorkspaceID),
|
||||||
)
|
)
|
||||||
|
|
||||||
if !pa.auth.DoesUserHaveWorkspaceAccess(userID, command.WorkspaceID) {
|
if !pa.auth.DoesUserHaveWorkspaceAccess(userID, command.WorkspaceID) {
|
||||||
@ -309,10 +312,10 @@ func (pa *PluginAdapter) WebSocketMessageHasBeenPosted(webConnID, userID string,
|
|||||||
|
|
||||||
pa.subscribeListenerToWorkspace(pac, command.WorkspaceID)
|
pa.subscribeListenerToWorkspace(pac, command.WorkspaceID)
|
||||||
case websocketActionUnsubscribeWorkspace:
|
case websocketActionUnsubscribeWorkspace:
|
||||||
pa.api.LogDebug(`Command: UNSUBSCRIBE_WORKSPACE`,
|
pa.logger.Debug(`Command: UNSUBSCRIBE_WORKSPACE`,
|
||||||
"webConnID", webConnID,
|
mlog.String("webConnID", webConnID),
|
||||||
"userID", userID,
|
mlog.String("userID", userID),
|
||||||
"workspaceID", command.WorkspaceID,
|
mlog.String("workspaceID", command.WorkspaceID),
|
||||||
)
|
)
|
||||||
|
|
||||||
pa.unsubscribeListenerFromWorkspace(pac, command.WorkspaceID)
|
pa.unsubscribeListenerFromWorkspace(pac, command.WorkspaceID)
|
||||||
@ -362,9 +365,9 @@ func (pa *PluginAdapter) sendWorkspaceMessage(event string, workspaceID string,
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (pa *PluginAdapter) BroadcastBlockChange(workspaceID string, block model.Block) {
|
func (pa *PluginAdapter) BroadcastBlockChange(workspaceID string, block model.Block) {
|
||||||
pa.api.LogInfo("BroadcastingBlockChange",
|
pa.logger.Debug("BroadcastingBlockChange",
|
||||||
"workspaceID", workspaceID,
|
mlog.String("workspaceID", workspaceID),
|
||||||
"blockID", block.ID,
|
mlog.String("blockID", block.ID),
|
||||||
)
|
)
|
||||||
|
|
||||||
message := UpdateMsg{
|
message := UpdateMsg{
|
||||||
@ -388,10 +391,10 @@ func (pa *PluginAdapter) BroadcastBlockDelete(workspaceID, blockID, parentID str
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (pa *PluginAdapter) BroadcastSubscriptionChange(workspaceID string, subscription *model.Subscription) {
|
func (pa *PluginAdapter) BroadcastSubscriptionChange(workspaceID string, subscription *model.Subscription) {
|
||||||
pa.api.LogInfo("BroadcastingSubscriptionChange",
|
pa.logger.Debug("BroadcastingSubscriptionChange",
|
||||||
"workspaceID", workspaceID,
|
mlog.String("workspaceID", workspaceID),
|
||||||
"blockID", subscription.BlockID,
|
mlog.String("blockID", subscription.BlockID),
|
||||||
"subscriberID", subscription.SubscriberID,
|
mlog.String("subscriberID", subscription.SubscriberID),
|
||||||
)
|
)
|
||||||
|
|
||||||
message := UpdateSubscription{
|
message := UpdateSubscription{
|
||||||
|
@ -66,7 +66,7 @@ export function getCardContents(cardId: string): (state: RootState) => Array<Con
|
|||||||
for (const contentId of card.fields.contentOrder) {
|
for (const contentId of card.fields.contentOrder) {
|
||||||
if (typeof contentId === 'string' && contents[contentId]) {
|
if (typeof contentId === 'string' && contents[contentId]) {
|
||||||
result.push(contents[contentId])
|
result.push(contents[contentId])
|
||||||
} else if (typeof contentId === 'object') {
|
} else if (typeof contentId === 'object' && contentId) {
|
||||||
const subResult: ContentBlock[] = []
|
const subResult: ContentBlock[] = []
|
||||||
for (const subContentId of contentId) {
|
for (const subContentId of contentId) {
|
||||||
if (typeof subContentId === 'string' && contents[subContentId]) {
|
if (typeof subContentId === 'string' && contents[subContentId]) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user