1
0
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:
Hosted Weblate 2022-02-08 09:09:41 +01:00
commit 673877568c
4 changed files with 43 additions and 39 deletions

View File

@ -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,

View File

@ -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)),
} }
} }

View File

@ -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{

View File

@ -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]) {