2020-11-23 13:30:56 +00:00
|
|
|
package meta
|
|
|
|
|
|
|
|
import (
|
2021-12-06 15:24:53 +00:00
|
|
|
"github.com/nspcc-dev/neo-go/pkg/util/slice"
|
2020-11-23 13:30:56 +00:00
|
|
|
"github.com/nspcc-dev/neofs-node/pkg/local_object_storage/blobovnicza"
|
2022-01-26 12:11:13 +00:00
|
|
|
addressSDK "github.com/nspcc-dev/neofs-sdk-go/object/address"
|
2020-11-23 13:30:56 +00:00
|
|
|
"go.etcd.io/bbolt"
|
|
|
|
)
|
|
|
|
|
2020-12-08 09:56:14 +00:00
|
|
|
// IsSmallPrm groups the parameters of IsSmall operation.
|
|
|
|
type IsSmallPrm struct {
|
2022-01-26 12:11:13 +00:00
|
|
|
addr *addressSDK.Address
|
2020-12-08 09:56:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsSmallRes groups resulting values of IsSmall operation.
|
|
|
|
type IsSmallRes struct {
|
|
|
|
id *blobovnicza.ID
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithAddress is a IsSmall option to set the object address to check.
|
2022-01-26 12:11:13 +00:00
|
|
|
func (p *IsSmallPrm) WithAddress(addr *addressSDK.Address) *IsSmallPrm {
|
2020-12-08 09:56:14 +00:00
|
|
|
if p != nil {
|
|
|
|
p.addr = addr
|
|
|
|
}
|
|
|
|
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// BlobovniczaID returns blobovnicza identifier.
|
|
|
|
func (r *IsSmallRes) BlobovniczaID() *blobovnicza.ID {
|
|
|
|
return r.id
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsSmall wraps work with DB.IsSmall method with specified
|
|
|
|
// address and other parameters by default. Returns only
|
|
|
|
// the blobovnicza identifier.
|
2022-01-26 12:11:13 +00:00
|
|
|
func IsSmall(db *DB, addr *addressSDK.Address) (*blobovnicza.ID, error) {
|
2020-12-08 09:56:14 +00:00
|
|
|
r, err := db.IsSmall(new(IsSmallPrm).WithAddress(addr))
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return r.BlobovniczaID(), nil
|
|
|
|
}
|
|
|
|
|
2020-11-23 13:30:56 +00:00
|
|
|
// IsSmall returns blobovniczaID for small objects and nil for big objects.
|
|
|
|
// Small objects stored in blobovnicza instances. Big objects stored in FS by
|
|
|
|
// shallow path which is calculated from address and therefore it is not
|
|
|
|
// indexed in metabase.
|
2020-12-08 09:56:14 +00:00
|
|
|
func (db *DB) IsSmall(prm *IsSmallPrm) (res *IsSmallRes, err error) {
|
|
|
|
res = new(IsSmallRes)
|
|
|
|
|
2020-11-23 13:30:56 +00:00
|
|
|
err = db.boltDB.View(func(tx *bbolt.Tx) error {
|
2020-12-08 09:56:14 +00:00
|
|
|
res.id, err = db.isSmall(tx, prm.addr)
|
2020-11-23 13:30:56 +00:00
|
|
|
|
|
|
|
return err
|
|
|
|
})
|
|
|
|
|
2020-12-08 09:56:14 +00:00
|
|
|
return
|
2020-11-23 13:30:56 +00:00
|
|
|
}
|
2020-11-27 17:47:58 +00:00
|
|
|
|
2022-01-26 12:11:13 +00:00
|
|
|
func (db *DB) isSmall(tx *bbolt.Tx, addr *addressSDK.Address) (*blobovnicza.ID, error) {
|
2020-11-27 17:47:58 +00:00
|
|
|
smallBucket := tx.Bucket(smallBucketName(addr.ContainerID()))
|
|
|
|
if smallBucket == nil {
|
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
blobovniczaID := smallBucket.Get(objectKey(addr.ObjectID()))
|
2020-12-01 13:33:59 +00:00
|
|
|
if len(blobovniczaID) == 0 {
|
|
|
|
return nil, nil
|
|
|
|
}
|
2020-11-27 17:47:58 +00:00
|
|
|
|
2021-12-06 15:24:53 +00:00
|
|
|
return blobovnicza.NewIDFromBytes(slice.Copy(blobovniczaID)), nil
|
2020-11-27 17:47:58 +00:00
|
|
|
}
|