[#335] Improve determining AccessBox latest version #391
3 changed files with 31 additions and 10 deletions
|
@ -76,7 +76,7 @@ func (x *AuthmateFrostFS) GetCredsObject(ctx context.Context, addr oid.Address)
|
||||||
|
|
||||||
credObjID := addr.Object()
|
credObjID := addr.Object()
|
||||||
if last := versions.GetLast(); last != nil {
|
if last := versions.GetLast(); last != nil {
|
||||||
credObjID = last.OjbID
|
credObjID = last.ObjID
|
||||||
}
|
}
|
||||||
|
|
||||||
res, err := x.frostFS.ReadObject(ctx, layer.PrmObjectRead{
|
res, err := x.frostFS.ReadObject(ctx, layer.PrmObjectRead{
|
||||||
|
@ -107,7 +107,7 @@ func (x *AuthmateFrostFS) CreateObject(ctx context.Context, prm tokens.PrmObject
|
||||||
}
|
}
|
||||||
|
|
||||||
if versions.GetLast() == nil {
|
if versions.GetLast() == nil {
|
||||||
versions.AppendVersion(&crdt.ObjectVersion{OjbID: addr.Object()})
|
versions.AppendVersion(&crdt.ObjectVersion{ObjID: addr.Object()})
|
||||||
}
|
}
|
||||||
|
|
||||||
for key, val := range versions.GetCRDTHeaders() {
|
for key, val := range versions.GetCRDTHeaders() {
|
||||||
|
|
|
@ -20,13 +20,13 @@ type ObjectVersions struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type ObjectVersion struct {
|
type ObjectVersion struct {
|
||||||
OjbID oid.ID
|
ObjID oid.ID
|
||||||
Headers map[string]string
|
Headers map[string]string
|
||||||
CreationEpoch uint64
|
CreationEpoch uint64
|
||||||
}
|
}
|
||||||
|
|
||||||
func (o *ObjectVersion) VersionID() string {
|
func (o *ObjectVersion) VersionID() string {
|
||||||
return o.OjbID.EncodeToString()
|
return o.ObjID.EncodeToString()
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewObjectVersions(name string) *ObjectVersions {
|
func NewObjectVersions(name string) *ObjectVersions {
|
||||||
|
@ -42,7 +42,7 @@ func NewObjectVersion(obj *object.Object) *ObjectVersion {
|
||||||
}
|
}
|
||||||
|
|
||||||
return &ObjectVersion{
|
return &ObjectVersion{
|
||||||
OjbID: objID,
|
ObjID: objID,
|
||||||
Headers: headers,
|
Headers: headers,
|
||||||
CreationEpoch: obj.CreationEpoch(),
|
CreationEpoch: obj.CreationEpoch(),
|
||||||
}
|
}
|
||||||
|
@ -108,8 +108,15 @@ func (v *ObjectVersions) getAddHeader() string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func less(ov1, ov2 *ObjectVersion) bool {
|
func less(ov1, ov2 *ObjectVersion) bool {
|
||||||
|
versionID1, versionID2 := ov1.VersionID(), ov2.VersionID()
|
||||||
dkirillov marked this conversation as resolved
Outdated
|
|||||||
|
if strings.Contains(ov1.Headers[versionsAddAttr], versionID2) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if strings.Contains(ov2.Headers[versionsAddAttr], versionID1) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
if ov1.CreationEpoch == ov2.CreationEpoch {
|
if ov1.CreationEpoch == ov2.CreationEpoch {
|
||||||
dkirillov marked this conversation as resolved
dkirillov
commented
On this line we will compute VersionIDs, that have already been computed above (line 111, 114). So probably we can compute this just one in the beginning of the function:
On this line we will compute VersionIDs, that have already been computed above (line 111, 114). So probably we can compute this just one in the beginning of the function:
```golang
func less(ov1, ov2 *ObjectVersion) bool {
versionID1, versionID2 := ov1.VersionID(), ov2.VersionID()
// ...
}
```
|
|||||||
return ov1.VersionID() < ov2.VersionID()
|
return versionID1 < versionID2
|
||||||
}
|
}
|
||||||
return ov1.CreationEpoch < ov2.CreationEpoch
|
return ov1.CreationEpoch < ov2.CreationEpoch
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,10 +20,10 @@ func TestObjectVersionsSort(t *testing.T) {
|
||||||
|
|
||||||
t.Run("sort by oids", func(t *testing.T) {
|
t.Run("sort by oids", func(t *testing.T) {
|
||||||
versions := NewObjectVersions("test")
|
versions := NewObjectVersions("test")
|
||||||
versions.AppendVersion(&ObjectVersion{CreationEpoch: 3, OjbID: getTestOID(2)})
|
versions.AppendVersion(&ObjectVersion{CreationEpoch: 3, ObjID: getTestOID(2)})
|
||||||
versions.AppendVersion(&ObjectVersion{CreationEpoch: 3, OjbID: getTestOID(1)})
|
versions.AppendVersion(&ObjectVersion{CreationEpoch: 3, ObjID: getTestOID(1)})
|
||||||
versions.AppendVersion(&ObjectVersion{CreationEpoch: 1, OjbID: getTestOID(3)})
|
versions.AppendVersion(&ObjectVersion{CreationEpoch: 1, ObjID: getTestOID(3)})
|
||||||
versions.AppendVersion(&ObjectVersion{CreationEpoch: 2, OjbID: getTestOID(4)})
|
versions.AppendVersion(&ObjectVersion{CreationEpoch: 2, ObjID: getTestOID(4)})
|
||||||
|
|
||||||
last := versions.GetLast()
|
last := versions.GetLast()
|
||||||
require.Equal(t, uint64(3), last.CreationEpoch)
|
require.Equal(t, uint64(3), last.CreationEpoch)
|
||||||
|
@ -36,3 +36,17 @@ func getTestOID(val byte) oid.ID {
|
||||||
res.SetSHA256([32]byte{val})
|
res.SetSHA256([32]byte{val})
|
||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestObjectVersionsSort1(t *testing.T) {
|
||||||
|
t.Run("sort by headers", func(t *testing.T) {
|
||||||
|
versions := NewObjectVersions("test")
|
||||||
|
versions.AppendVersion(&ObjectVersion{Headers: versions.GetCRDTHeaders(), ObjID: getTestOID(2)})
|
||||||
|
versions.AppendVersion(&ObjectVersion{Headers: versions.GetCRDTHeaders(), ObjID: getTestOID(3)})
|
||||||
|
versions.AppendVersion(&ObjectVersion{Headers: versions.GetCRDTHeaders(), ObjID: getTestOID(4)})
|
||||||
|
versions.AppendVersion(&ObjectVersion{Headers: versions.GetCRDTHeaders(), ObjID: getTestOID(1)})
|
||||||
|
|
||||||
|
last := versions.GetLast()
|
||||||
|
require.Equal(t, uint64(0), last.CreationEpoch)
|
||||||
|
require.Equal(t, getTestOID(1).String(), last.VersionID())
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue
It seems we can use just