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

141 lines
2.8 KiB

7 years ago
5 years ago
7 years ago
5 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. package filer
  2. import (
  3. "bytes"
  4. "fmt"
  5. "os"
  6. "time"
  7. "github.com/golang/protobuf/proto"
  8. "github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
  9. )
  10. func (entry *Entry) EncodeAttributesAndChunks() ([]byte, error) {
  11. message := &filer_pb.Entry{}
  12. entry.ToExistingProtoEntry(message)
  13. return proto.Marshal(message)
  14. }
  15. func (entry *Entry) DecodeAttributesAndChunks(blob []byte) error {
  16. message := &filer_pb.Entry{}
  17. if err := proto.UnmarshalMerge(blob, message); err != nil {
  18. return fmt.Errorf("decoding value blob for %s: %v", entry.FullPath, err)
  19. }
  20. FromPbEntryToExistingEntry(message, entry)
  21. return nil
  22. }
  23. func EntryAttributeToPb(entry *Entry) *filer_pb.FuseAttributes {
  24. return &filer_pb.FuseAttributes{
  25. Crtime: entry.Attr.Crtime.Unix(),
  26. Mtime: entry.Attr.Mtime.Unix(),
  27. FileMode: uint32(entry.Attr.Mode),
  28. Uid: entry.Uid,
  29. Gid: entry.Gid,
  30. Mime: entry.Mime,
  31. Collection: entry.Attr.Collection,
  32. Replication: entry.Attr.Replication,
  33. TtlSec: entry.Attr.TtlSec,
  34. DiskType: entry.Attr.DiskType,
  35. UserName: entry.Attr.UserName,
  36. GroupName: entry.Attr.GroupNames,
  37. SymlinkTarget: entry.Attr.SymlinkTarget,
  38. Md5: entry.Attr.Md5,
  39. FileSize: entry.Attr.FileSize,
  40. Rdev: entry.Attr.Rdev,
  41. }
  42. }
  43. func PbToEntryAttribute(attr *filer_pb.FuseAttributes) Attr {
  44. t := Attr{}
  45. if attr == nil {
  46. return t
  47. }
  48. t.Crtime = time.Unix(attr.Crtime, 0)
  49. t.Mtime = time.Unix(attr.Mtime, 0)
  50. t.Mode = os.FileMode(attr.FileMode)
  51. t.Uid = attr.Uid
  52. t.Gid = attr.Gid
  53. t.Mime = attr.Mime
  54. t.Collection = attr.Collection
  55. t.Replication = attr.Replication
  56. t.TtlSec = attr.TtlSec
  57. t.DiskType = attr.DiskType
  58. t.UserName = attr.UserName
  59. t.GroupNames = attr.GroupName
  60. t.SymlinkTarget = attr.SymlinkTarget
  61. t.Md5 = attr.Md5
  62. t.FileSize = attr.FileSize
  63. t.Rdev = attr.Rdev
  64. return t
  65. }
  66. func EqualEntry(a, b *Entry) bool {
  67. if a == b {
  68. return true
  69. }
  70. if a == nil && b != nil || a != nil && b == nil {
  71. return false
  72. }
  73. if !proto.Equal(EntryAttributeToPb(a), EntryAttributeToPb(b)) {
  74. return false
  75. }
  76. if len(a.Chunks) != len(b.Chunks) {
  77. return false
  78. }
  79. if !eq(a.Extended, b.Extended) {
  80. return false
  81. }
  82. if !bytes.Equal(a.Md5, b.Md5) {
  83. return false
  84. }
  85. for i := 0; i < len(a.Chunks); i++ {
  86. if !proto.Equal(a.Chunks[i], b.Chunks[i]) {
  87. return false
  88. }
  89. }
  90. if !bytes.Equal(a.HardLinkId, b.HardLinkId) {
  91. return false
  92. }
  93. if a.HardLinkCounter != b.HardLinkCounter {
  94. return false
  95. }
  96. if !bytes.Equal(a.Content, b.Content) {
  97. return false
  98. }
  99. if !proto.Equal(a.Remote, b.Remote) {
  100. return false
  101. }
  102. if a.Quota != b.Quota {
  103. return false
  104. }
  105. return true
  106. }
  107. func eq(a, b map[string][]byte) bool {
  108. if len(a) != len(b) {
  109. return false
  110. }
  111. for k, v := range a {
  112. if w, ok := b[k]; !ok || !bytes.Equal(v, w) {
  113. return false
  114. }
  115. }
  116. return true
  117. }