You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

shard_store.go 1.4 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package obs
  2. import (
  3. awss3 "github.com/aws/aws-sdk-go-v2/service/s3"
  4. "github.com/huaweicloud/huaweicloud-sdk-go-obs/obs"
  5. clitypes "gitlink.org.cn/cloudream/jcs-pub/client/types"
  6. "gitlink.org.cn/cloudream/jcs-pub/common/pkgs/storage/s3"
  7. "gitlink.org.cn/cloudream/jcs-pub/common/pkgs/storage/types"
  8. cortypes "gitlink.org.cn/cloudream/jcs-pub/coordinator/types"
  9. )
  10. type ShardStore struct {
  11. *s3.ShardStore
  12. stgType *cortypes.OBSType
  13. cred *cortypes.OBSCred
  14. }
  15. func NewShardStore(detail *clitypes.UserSpaceDetail, stgType *cortypes.OBSType, cred *cortypes.OBSCred, s3Cli *awss3.Client, bkt string) (*ShardStore, error) {
  16. sd := ShardStore{
  17. stgType: stgType,
  18. cred: cred,
  19. }
  20. var err error
  21. sd.ShardStore, err = s3.NewShardStore(detail, s3Cli, bkt, s3.ShardStoreOption{
  22. UseAWSSha256: false,
  23. })
  24. if err != nil {
  25. return nil, err
  26. }
  27. return &sd, nil
  28. }
  29. func (s *ShardStore) HTTPBypassRead(fileHash clitypes.FileHash) (types.HTTPRequest, error) {
  30. cli, err := obs.New(s.cred.AK, s.cred.SK, s.stgType.Endpoint)
  31. if err != nil {
  32. return types.HTTPRequest{}, err
  33. }
  34. getSigned, err := cli.CreateSignedUrl(&obs.CreateSignedUrlInput{
  35. Method: "GET",
  36. Bucket: s.Bucket,
  37. Key: s.GetFilePathFromHash(fileHash),
  38. Expires: 3600,
  39. })
  40. if err != nil {
  41. return types.HTTPRequest{}, err
  42. }
  43. return types.HTTPRequest{
  44. URL: getSigned.SignedUrl,
  45. Method: "GET",
  46. }, nil
  47. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。