From 23b426ec4ac128b5901efe41e7c2075a3864bdea Mon Sep 17 00:00:00 2001 From: Evgenii Stratonikov Date: Thu, 26 Dec 2024 14:10:31 +0300 Subject: [PATCH 1/2] [#1584] go.mod: Update sdk-go Signed-off-by: Evgenii Stratonikov --- cmd/frostfs-cli/modules/container/list.go | 2 +- go.mod | 32 +++++++++--------- go.sum | Bin 41910 -> 42274 bytes .../transport/container/grpc/service.go | 7 ++++ 4 files changed, 24 insertions(+), 17 deletions(-) diff --git a/cmd/frostfs-cli/modules/container/list.go b/cmd/frostfs-cli/modules/container/list.go index f01e4db4d..4afca6c17 100644 --- a/cmd/frostfs-cli/modules/container/list.go +++ b/cmd/frostfs-cli/modules/container/list.go @@ -51,7 +51,7 @@ var listContainersCmd = &cobra.Command{ var prm internalclient.ListContainersPrm prm.SetClient(cli) - prm.Account = idUser + prm.OwnerID = idUser res, err := internalclient.ListContainers(cmd.Context(), prm) commonCmd.ExitOnErr(cmd, "rpc error: %w", err) diff --git a/go.mod b/go.mod index 8ec78ca81..39a3cf123 100644 --- a/go.mod +++ b/go.mod @@ -8,7 +8,7 @@ require ( git.frostfs.info/TrueCloudLab/frostfs-crypto v0.6.0 git.frostfs.info/TrueCloudLab/frostfs-locode-db v0.4.1-0.20240710074952-65761deb5c0d git.frostfs.info/TrueCloudLab/frostfs-observability v0.0.0-20241112082307-f17779933e88 - git.frostfs.info/TrueCloudLab/frostfs-sdk-go v0.0.0-20241206094944-81c423e7094d + git.frostfs.info/TrueCloudLab/frostfs-sdk-go v0.0.0-20241226115718-82e48c8a634d git.frostfs.info/TrueCloudLab/hrw v1.2.1 git.frostfs.info/TrueCloudLab/multinet v0.0.0-20241015075604-6cb0d80e0972 git.frostfs.info/TrueCloudLab/policy-engine v0.0.0-20240814080254-96225afacb88 @@ -27,7 +27,7 @@ require ( github.com/klauspost/compress v1.17.4 github.com/mailru/easyjson v0.7.7 github.com/mr-tron/base58 v1.2.0 - github.com/multiformats/go-multiaddr v0.12.1 + github.com/multiformats/go-multiaddr v0.14.0 github.com/nspcc-dev/neo-go v0.106.3 github.com/olekukonko/tablewriter v0.0.5 github.com/panjf2000/ants/v2 v2.9.0 @@ -40,15 +40,15 @@ require ( github.com/ssgreg/journald v1.0.0 github.com/stretchr/testify v1.9.0 go.etcd.io/bbolt v1.3.10 - go.opentelemetry.io/otel v1.28.0 - go.opentelemetry.io/otel/trace v1.28.0 + go.opentelemetry.io/otel v1.31.0 + go.opentelemetry.io/otel/trace v1.31.0 go.uber.org/zap v1.27.0 golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 - golang.org/x/sync v0.7.0 - golang.org/x/sys v0.22.0 - golang.org/x/term v0.21.0 - google.golang.org/grpc v1.66.2 - google.golang.org/protobuf v1.34.2 + golang.org/x/sync v0.10.0 + golang.org/x/sys v0.28.0 + golang.org/x/term v0.27.0 + google.golang.org/grpc v1.69.2 + google.golang.org/protobuf v1.36.1 gopkg.in/yaml.v3 v3.0.1 ) @@ -119,15 +119,15 @@ require ( go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.28.0 // indirect go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.28.0 // indirect go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.28.0 // indirect - go.opentelemetry.io/otel/metric v1.28.0 // indirect - go.opentelemetry.io/otel/sdk v1.28.0 // indirect + go.opentelemetry.io/otel/metric v1.31.0 // indirect + go.opentelemetry.io/otel/sdk v1.31.0 // indirect go.opentelemetry.io/proto/otlp v1.3.1 // indirect go.uber.org/multierr v1.11.0 // indirect - golang.org/x/crypto v0.24.0 // indirect - golang.org/x/net v0.26.0 // indirect - golang.org/x/text v0.16.0 // indirect - google.golang.org/genproto/googleapis/api v0.0.0-20240701130421-f6361c86f094 // indirect - google.golang.org/genproto/googleapis/rpc v0.0.0-20240701130421-f6361c86f094 // indirect + golang.org/x/crypto v0.31.0 // indirect + golang.org/x/net v0.33.0 // indirect + golang.org/x/text v0.21.0 // indirect + google.golang.org/genproto/googleapis/api v0.0.0-20241015192408-796eee8c2d53 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20241223144023-3abc09e42ca8 // indirect gopkg.in/ini.v1 v1.67.0 // indirect lukechampine.com/blake3 v1.2.1 // indirect rsc.io/tmplfunc v0.0.3 // indirect diff --git a/go.sum b/go.sum index 17b18d41e82d9c89ff687ddd15e0346dfb9f6ccb..6c5b79e804eb3674bce1e14e0a9f90a4a797805b 100644 GIT binary patch delta 2273 zcmZ{kORwW*8OJq;sYb03Or>E4D2$FeLQq+Ae7~JVCCBkKcH&#?I17aBI2T_NJ8^6a zRj@`yXE1^aby4Vs6>1d~v7Q`1olmY zXJ$W>x;O7!9zJ^QUr)NrAAKFcudq|46&cD3wV7ILlbeh*s~!%PjOnh`44^_>Czx3_ zvpsm`gmHKC!%O;zo!OJjS}6?Wc$ncBfi#Ybt!aCBW-Loi=q)g6-X{vPB9`u2&%#ZpQyg;_yC*qTyH=7lg6?ApN z&+G&j+f2P}vklU)sBYn`3Xd&jFF=B&p`61=K_u>49VoEwQ}OM?Uj+XNio&-QhNT<~ zG|7SbkcbW!t=1RQ9C94OTyI-#wpoA*+?G;`EZy$S{JZa7R`At{J@bzs7RKC!<`;3a z3D_x9auANPFgiLGR^0+zwnUKhV@~Fd5pNwnkNB`R< zJDG3c#$PsA-WpoKBlG8Q_xJ3L>sS0NI^&Yu_LZHRPcV3}PMPIsGb~nu&j6c^NN76F z;pupuosRJKOLeWdsOQ_FJHa_VRq$ef&$o_V*0mz@ARWim zTwJdkMZs~;Ay<;zVscblp}Q+ZvQ>jq1oukB*&VQklv%1>4VUA=!emr`&{%4{8TDAG zT{Ly;;CM1^Cm8Bd$E3Hqf99_vFIHeakID%4jC?l;_w$0n$A~9*3mGE-waRBrmgunP z&QiJQ?&se-q5m_A$uu@%(o~VDu51k=%o#`LB~hzd9U^#{DM#>DKE4BpIocl{-d|t5 z_VOB5OTRJI%8nE!G(}kQ=Ye6xeQ-4_gQlelp^bQu!0KZ%*HnAlWLT8I+Qf=c1W zBSG3LFdbU%M9235VfA(+l#sg7Paj^NxU;E?6UD$~fbQ36u~GK|y@>?2o&xP)Qum4- zgtduPIf=6yV%?A5dwjV6o^*l2(5)LC>P6IF)zL!Ok4LP>Q+oukU9p1f5Ud2(^k=c< z(bOW8_6e8aip3cCRiI zru+2g4=)hvaPy1k0wHg4MYSK^nRR{T5g!MPrwX<>fN*V zA6=igvy-pXGMlb5DDW0JB#a7iga9tNBV{eanI`EKLGHv{qFScf{pse>;n%-}FHq#m zKc{VUhKY;4mxagmAj)!WG_ohq_HYHdGCZ8OfzU&jQ*e`?;Oi52=EkI+uX<`a(pZ@? z!(dglrifzziE1pLYEC`0loY6@F{gJozxsCfk7xG|%V%HQM2PRVHi>Y zGQ-i+OPt#|GvNjd1~j{Q>d$Pq0!)rXfk2!3z8_L+PbtNDJOIYso!>p^?*H~d_t9^@ zseVP|S=(Y|POQC-0of+igl+DteB2rYin%0AXyIkGWiJ)Bge;yVGx2o zJ^oMuM28p>c+{z=wc%=JIn%rz0gY>nWHTsNY=|s`te&<~=^0Di+n5AFFfZcNuZTM< znFN*xm;IT;Nuuf`l9fq8o9^*F0kJ$ipT|Bm1^RZHMz^Uy`QUYgzCuog#;8f_+}5A4 zknavFV;kgg!lSjYRqWL+HQm~2V%Y>p=5}&Nls=+o@~Vku91$r!i6mx=bw7_vUKn~} zQqQ8vkX|g;*$l}^S(u(C^!V`k2g277;tD?5o1PXLl{MdbNhmE;RGWfMPnwbw6%09- z@wn#rnK#h}T*OEA@)|vIXKH%RkRu;jr`dk#6Bq`-0BbwE;Saq?CssxtZCOy~ao^y& P|9tqZ!yiBV#=ZXncm&x* delta 1997 zcma)+ORMB)8ONDpH{W_cE z`rRMyF%SlkBXTtQkbvD0f_nJ*xV;YHTdr7(K&n>hbcgN{MbbI@5XvzvFdgIN<7%(L zt9610=E@!3dhLVZ*Z1C*{%aT*3H;{w9wEpLd?|HIfe8h!Y>Lorrhp3$=2l@erWa@c@11DO zPt&q+uqI1(10}pS{EL5sJfn9i;HkEYCQ2%MTvY6VY-W^XA=sujHTFazOacMx!Wgpj zo;^{*58g)+;s&~?L8F|x)((iaDnz#uYpQ!mrxQg2l_<5NP_mTjU?|JT%!jv%uYKqG z2;W@TJMI!AqL?E%m!LC6kh;EqeYMRlqr*}=r74Cbibfg0=2L$31&x3Bcz9N1e< zI6IY>3&p`SEe}g{p^~B)no-Tv&NP=n;GnNY^*Q3bmuiRH;-Oe|L}%B*-bodRkveUq zD5jD~A4NtlCZA>r!6;BZhS4?QZ^d2O zaV$6v7gp;umKrk#2vibQ7ISg<{o$*(7w*o~ZCFz*L!FPaPH{VGNr}24(M+>R%8nRQ zWd^tCsvgN>Mmarh?AK8Qd*Q9~32rQNNLy9b=%}qgVADad#LNtrN7iJ+c~-I(kJDP! zhfV*^?S;GJ9b3{aGP=x}h#^{Fk?MlS$f?~!3$-XQv6)>))U>I!0y{kW=+UWrJiUVP z7iy~(Q{R~68mViR47Hs!)k-LEH`6VTR$`Wy?PBHl`hgri{^;Rr`035>|MtOoNuO`Z zTtx6Z+?NuaHKyE8<#Kl?dEjy>NG~o#$)W^X1&pmvy3+ zwU^K{Ze+9^waE=kI>d@o^S!~OYv}aZ6XEJH{GaFEkR!Iu*!67BHkQm!4bg0~Ro>?F z9<*J$USjB6JrtrGj=udM$dgSL+~idNw&31t_t!`0=8|-$2_H5bJn;Zo&m|*NQI}VR zzEp#G#cwQ^q>fIatLc4hDP-dCWO(=V*PniRkArXshEZsQz#sY;ioq^{`R70R@&!Ra z-mAP@6@W!hC9#laGlWW_$Vuz5%=UFjlD3^vyp=*j`122jCqH{r`5$q2YWh>qLq#9d zFII8BX8xSGREALKk9<1*hNJ5du(2A^8A94XY9_4)F_x> ztzppSe7p3iOa>MuJyW^`L-8{VNNjJ}X7(IL2y6K6uiia<>zDi&&P)H?jI~QFS=6*& z@C*X4r4bq8O1O8aB0KMaZv~pW75u%Ag~6Gwb~S0>DJ8EK-x1BQwqLm#1Goz5Vn{um2k>tb(5a diff --git a/pkg/network/transport/container/grpc/service.go b/pkg/network/transport/container/grpc/service.go index 49d083a90..d932ecc07 100644 --- a/pkg/network/transport/container/grpc/service.go +++ b/pkg/network/transport/container/grpc/service.go @@ -6,6 +6,9 @@ import ( containersvc "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/services/container" "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/container" containerGRPC "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/container/grpc" + "google.golang.org/grpc" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" ) // Server wraps FrostFS API Container service and @@ -80,3 +83,7 @@ func (s *Server) List(ctx context.Context, req *containerGRPC.ListRequest) (*con return resp.ToGRPCMessage().(*containerGRPC.ListResponse), nil } + +func (s *Server) ListStream(_ *containerGRPC.ListStreamRequest, _ grpc.ServerStreamingServer[containerGRPC.ListStreamResponse]) error { + return status.Error(codes.Unimplemented, "method ListStream not implemented") +} -- 2.45.2 From f527556735d07fd2e623fc524d294accaec714da Mon Sep 17 00:00:00 2001 From: Evgenii Stratonikov Date: Thu, 26 Dec 2024 14:12:35 +0300 Subject: [PATCH 2/2] Revert "[#1492] metabase: Ensure Unmarshal() is called on a cloned slice" This reverts commit 8ed7a676d50e24489e2abeb5269d6eb3332df1f8. Signed-off-by: Evgenii Stratonikov --- pkg/local_object_storage/metabase/exists.go | 3 +-- pkg/local_object_storage/metabase/get.go | 11 +++++------ pkg/local_object_storage/metabase/iterators.go | 3 +-- pkg/local_object_storage/metabase/list.go | 4 ++-- pkg/local_object_storage/metabase/put.go | 3 +-- 5 files changed, 10 insertions(+), 14 deletions(-) diff --git a/pkg/local_object_storage/metabase/exists.go b/pkg/local_object_storage/metabase/exists.go index 411beb6b3..ccd2a622d 100644 --- a/pkg/local_object_storage/metabase/exists.go +++ b/pkg/local_object_storage/metabase/exists.go @@ -1,7 +1,6 @@ package meta import ( - "bytes" "context" "fmt" "time" @@ -227,7 +226,7 @@ func getSplitInfo(tx *bbolt.Tx, cnr cid.ID, key []byte) (*objectSDK.SplitInfo, e splitInfo := objectSDK.NewSplitInfo() - err := splitInfo.Unmarshal(bytes.Clone(rawSplitInfo)) + err := splitInfo.Unmarshal(rawSplitInfo) if err != nil { return nil, fmt.Errorf("can't unmarshal split info from root index: %w", err) } diff --git a/pkg/local_object_storage/metabase/get.go b/pkg/local_object_storage/metabase/get.go index 1cbf78ab2..145190f56 100644 --- a/pkg/local_object_storage/metabase/get.go +++ b/pkg/local_object_storage/metabase/get.go @@ -1,7 +1,6 @@ package meta import ( - "bytes" "context" "fmt" "time" @@ -112,7 +111,7 @@ func (db *DB) get(tx *bbolt.Tx, addr oid.Address, key []byte, checkStatus, raw b // check in primary index data := getFromBucket(tx, primaryBucketName(cnr, bucketName), key) if len(data) != 0 { - return obj, obj.Unmarshal(bytes.Clone(data)) + return obj, obj.Unmarshal(data) } data = getFromBucket(tx, ecInfoBucketName(cnr, bucketName), key) @@ -123,13 +122,13 @@ func (db *DB) get(tx *bbolt.Tx, addr oid.Address, key []byte, checkStatus, raw b // if not found then check in tombstone index data = getFromBucket(tx, tombstoneBucketName(cnr, bucketName), key) if len(data) != 0 { - return obj, obj.Unmarshal(bytes.Clone(data)) + return obj, obj.Unmarshal(data) } // if not found then check in locker index data = getFromBucket(tx, bucketNameLockers(cnr, bucketName), key) if len(data) != 0 { - return obj, obj.Unmarshal(bytes.Clone(data)) + return obj, obj.Unmarshal(data) } // if not found then check if object is a virtual @@ -185,7 +184,7 @@ func getVirtualObject(tx *bbolt.Tx, cnr cid.ID, key []byte, raw bool) (*objectSD child := objectSDK.New() - err = child.Unmarshal(bytes.Clone(data)) + err = child.Unmarshal(data) if err != nil { return nil, fmt.Errorf("can't unmarshal child with parent: %w", err) } @@ -219,7 +218,7 @@ func getECInfoError(tx *bbolt.Tx, cnr cid.ID, data []byte) error { objData := getFromBucket(tx, primaryBucketName(cnr, make([]byte, bucketKeySize)), key) if len(objData) != 0 { obj := objectSDK.New() - if err := obj.Unmarshal(bytes.Clone(objData)); err != nil { + if err := obj.Unmarshal(objData); err != nil { return err } chunk := objectSDK.ECChunk{} diff --git a/pkg/local_object_storage/metabase/iterators.go b/pkg/local_object_storage/metabase/iterators.go index 5d42e4125..0ca07725c 100644 --- a/pkg/local_object_storage/metabase/iterators.go +++ b/pkg/local_object_storage/metabase/iterators.go @@ -1,7 +1,6 @@ package meta import ( - "bytes" "context" "errors" "fmt" @@ -195,7 +194,7 @@ func iteratePhyObjects(tx *bbolt.Tx, f func(cid.ID, oid.ID, *objectSDK.Object) e } return b.ForEach(func(k, v []byte) error { - if oid.Decode(k) == nil && obj.Unmarshal(bytes.Clone(v)) == nil { + if oid.Decode(k) == nil && obj.Unmarshal(v) == nil { return f(cid, oid, obj) } diff --git a/pkg/local_object_storage/metabase/list.go b/pkg/local_object_storage/metabase/list.go index a7ff2222f..b007ef0da 100644 --- a/pkg/local_object_storage/metabase/list.go +++ b/pkg/local_object_storage/metabase/list.go @@ -247,7 +247,7 @@ func selectNFromBucket(bkt *bbolt.Bucket, // main bucket var ecInfo *objectcore.ECInfo if objType == objectSDK.TypeRegular { var o objectSDK.Object - if err := o.Unmarshal(bytes.Clone(v)); err != nil { + if err := o.Unmarshal(v); err != nil { return nil, nil, nil, err } isLinkingObj = isLinkObject(&o) @@ -413,7 +413,7 @@ func (db *DB) iterateOverObjectsInContainer(ctx context.Context, tx *bbolt.Tx, p var ecInfo *objectcore.ECInfo if prm.ObjectType == objectSDK.TypeRegular { var o objectSDK.Object - if err := o.Unmarshal(bytes.Clone(v)); err != nil { + if err := o.Unmarshal(v); err != nil { return err } isLinkingObj = isLinkObject(&o) diff --git a/pkg/local_object_storage/metabase/put.go b/pkg/local_object_storage/metabase/put.go index 6f9dc1bf0..383bc1143 100644 --- a/pkg/local_object_storage/metabase/put.go +++ b/pkg/local_object_storage/metabase/put.go @@ -1,7 +1,6 @@ package meta import ( - "bytes" "context" "encoding/binary" "errors" @@ -320,7 +319,7 @@ func updateSplitInfoIndex(tx *bbolt.Tx, objKey []byte, cnr cid.ID, bucketName [] return si.Marshal() default: oldSI := objectSDK.NewSplitInfo() - if err := oldSI.Unmarshal(bytes.Clone(old)); err != nil { + if err := oldSI.Unmarshal(old); err != nil { return nil, err } si = util.MergeSplitInfo(si, oldSI) -- 2.45.2