37 lines
1006 B
Go
37 lines
1006 B
Go
package synctree
|
|
|
|
import (
|
|
"github.com/anytypeio/any-sync/commonspace/object/tree/treechangeproto"
|
|
"github.com/anytypeio/any-sync/commonspace/objectsync"
|
|
)
|
|
|
|
type queuedClient struct {
|
|
SyncClient
|
|
queue objectsync.ActionQueue
|
|
}
|
|
|
|
func newQueuedClient(client SyncClient, queue objectsync.ActionQueue) SyncClient {
|
|
return &queuedClient{
|
|
SyncClient: client,
|
|
queue: queue,
|
|
}
|
|
}
|
|
|
|
func (q *queuedClient) BroadcastAsync(message *treechangeproto.TreeSyncMessage) (err error) {
|
|
return q.queue.Send(func() error {
|
|
return q.SyncClient.BroadcastAsync(message)
|
|
})
|
|
}
|
|
|
|
func (q *queuedClient) SendAsync(peerId string, message *treechangeproto.TreeSyncMessage, replyId string) (err error) {
|
|
return q.queue.Send(func() error {
|
|
return q.SyncClient.SendAsync(peerId, message, replyId)
|
|
})
|
|
}
|
|
|
|
func (q *queuedClient) BroadcastAsyncOrSendResponsible(message *treechangeproto.TreeSyncMessage) (err error) {
|
|
return q.queue.Send(func() error {
|
|
return q.SyncClient.BroadcastAsyncOrSendResponsible(message)
|
|
})
|
|
}
|