From 379b46af87ffdea12d543b2a46f7200ac0ffd98f Mon Sep 17 00:00:00 2001 From: Youngteac Hong Date: Wed, 20 Nov 2024 10:22:25 +0900 Subject: [PATCH] Move encode/decode functions to database --- pkg/document/innerpresence/presence.go | 41 +++-------------------- server/backend/database/change_info.go | 29 ++++++++++++++++ server/backend/database/mongo/registry.go | 5 +-- 3 files changed, 37 insertions(+), 38 deletions(-) diff --git a/pkg/document/innerpresence/presence.go b/pkg/document/innerpresence/presence.go index 102b50fdc..d116a39fd 100644 --- a/pkg/document/innerpresence/presence.go +++ b/pkg/document/innerpresence/presence.go @@ -20,8 +20,6 @@ package innerpresence import ( - "encoding/json" - "fmt" "sync" ) @@ -100,36 +98,8 @@ const ( // PresenceChange represents the change of presence. type PresenceChange struct { - ChangeType PresenceChangeType `json:"changeType"` - Presence Presence `json:"presence"` -} - -// EncodeToBytes encodes the given presence change into bytes array. -func EncodeToBytes(p *PresenceChange) ([]byte, error) { - if p == nil { - return nil, nil - } - - bytes, err := json.Marshal(p) - if err != nil { - return nil, fmt.Errorf("marshal presence change to bytes: %w", err) - } - - return bytes, nil -} - -// PresenceChangeFromBytes unmarshals the given bytes array into PresenceChange. -func PresenceChangeFromBytes(bytes []byte) (*PresenceChange, error) { - if bytes == nil { - return nil, nil - } - - p := &PresenceChange{} - if err := json.Unmarshal(bytes, p); err != nil { - return nil, fmt.Errorf("unmarshal presence change: %w", err) - } - - return p, nil + ChangeType PresenceChangeType + Presence Presence } // Presence represents custom presence that can be defined by the client. @@ -146,10 +116,8 @@ func (p Presence) Set(key string, value string) { } // Clear clears the presence. -func (p Presence) Clear() { - for k := range p { - delete(p, k) - } +func (p *Presence) Clear() { + *p = make(map[string]string) } // DeepCopy copies itself deeply. @@ -157,6 +125,7 @@ func (p Presence) DeepCopy() Presence { if p == nil { return nil } + clone := make(map[string]string) for k, v := range p { clone[k] = v diff --git a/server/backend/database/change_info.go b/server/backend/database/change_info.go index 04495fcd0..6f18adce3 100644 --- a/server/backend/database/change_info.go +++ b/server/backend/database/change_info.go @@ -18,6 +18,7 @@ package database import ( "errors" + "fmt" "google.golang.org/protobuf/proto" @@ -111,3 +112,31 @@ func (i *ChangeInfo) DeepCopy() *ChangeInfo { return clone } + +// EncodePresenceChange encodes the given PresenceChange into bytes array. +func EncodePresenceChange(p *innerpresence.PresenceChange) ([]byte, error) { + if p == nil { + return nil, nil + } + + bytes, err := proto.Marshal(converter.ToPresenceChange(p)) + if err != nil { + return nil, fmt.Errorf("encode presence change to bytes: %w", err) + } + + return bytes, nil +} + +// PresenceChangeFromBytes decodes the given bytes array into PresenceChange. +func PresenceChangeFromBytes(bytes []byte) (*innerpresence.PresenceChange, error) { + if bytes == nil { + return nil, nil + } + + pbChange := &api.PresenceChange{} + if err := proto.Unmarshal(bytes, pbChange); err != nil { + return nil, fmt.Errorf("decode presence change: %w", err) + } + + return converter.FromPresenceChange(pbChange), nil +} diff --git a/server/backend/database/mongo/registry.go b/server/backend/database/mongo/registry.go index f1103fcc8..4d95f4c72 100644 --- a/server/backend/database/mongo/registry.go +++ b/server/backend/database/mongo/registry.go @@ -31,6 +31,7 @@ import ( api "github.com/yorkie-team/yorkie/api/yorkie/v1" "github.com/yorkie-team/yorkie/pkg/document/innerpresence" "github.com/yorkie-team/yorkie/pkg/document/time" + "github.com/yorkie-team/yorkie/server/backend/database" ) var tID = reflect.TypeOf(types.ID("")) @@ -152,7 +153,7 @@ func presenceChangeEncoder(_ bsoncodec.EncodeContext, vw bsonrw.ValueWriter, val return nil } - bytes, err := innerpresence.EncodeToBytes(presenceChange) + bytes, err := database.EncodePresenceChange(presenceChange) if err != nil { return fmt.Errorf("encode error: %w", err) } @@ -183,7 +184,7 @@ func presenceChangeDecoder(_ bsoncodec.DecodeContext, vr bsonrw.ValueReader, val return fmt.Errorf("decode error: %w", err) } - presenceChange, err := innerpresence.PresenceChangeFromBytes(data) + presenceChange, err := database.PresenceChangeFromBytes(data) if err != nil { return fmt.Errorf("decode error: %w", err) }