rec_meta.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. // package rec_meta -- мета-информация записи KV-хранилища.
  2. package rec_meta
  3. import (
  4. "gitp78su.ipnodns.ru/svi/kern/v4/lev0/alias"
  5. "gitp78su.ipnodns.ru/svi/kern/v4/lev0/helpers"
  6. "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
  7. "gitp78su.ipnodns.ru/svi/kern/v4/lev0/voc"
  8. )
  9. var (
  10. hassert = helpers.Hassert
  11. )
  12. // RecMeta -- мета-информация записи KV-хранилища.
  13. //
  14. // Вся информация о записи хранится в JSON-строке, без форматирования
  15. // для того, что можно было файл индексов бакета писать построчно.
  16. // Даже если ключ содержит пробелы или экранированное форматирование
  17. // JSON их экранирует внутри.
  18. type RecMeta struct {
  19. Key_ *alias.AStoreKey `json:"key"` // Ключ
  20. Vers_ int64 `json:"vers"` // Версия записи
  21. Operation_ string `json:"operation"` // Тип операции над записью
  22. createdAt_ ktypes.ITime `voc:"created_at"` // Дата создания записи
  23. updateAt_ ktypes.ITimeMut `voc:"update_at"` // Дата последнего обновления
  24. // Хеш мета-информации записи (вместе с значением, но без этого поля разумеется)
  25. Sha_ string `json:"sha"`
  26. Offset_ int64 `json:"-"` // Смещение в файле, игнорируется при записи
  27. }
  28. // NewRecMeta -- создание новой мета-информации записи KV-хранилища.
  29. func NewRecMeta(key *alias.AStoreKey) *RecMeta {
  30. hassert(key != nil, "NewRecMeta: key==nil")
  31. sf := &RecMeta{
  32. Key_: key,
  33. Vers_: 1,
  34. Operation_: "create",
  35. createdAt_: voc.NewETime(voc.VTimeOptDefault()),
  36. updateAt_: voc.NewETime(voc.VTimeOptDefault(), voc.VTimeOptMut()),
  37. }
  38. _ = ktypes.IRecMeta(sf)
  39. return sf
  40. }
  41. // Key -- ключ записи.
  42. func (sf *RecMeta) Key() *alias.AStoreKey {
  43. return sf.Key_
  44. }
  45. // Vers -- версия записи.
  46. func (sf *RecMeta) Vers() int64 {
  47. return sf.Vers_
  48. }
  49. // Operation -- тип операции над записью.
  50. func (sf *RecMeta) Operation() string {
  51. return sf.Operation_
  52. }
  53. // CreatedAt -- дата создания записи.
  54. func (sf *RecMeta) CreatedAt() ktypes.ITime {
  55. return sf.createdAt_
  56. }
  57. // UpdateAt -- дата последнего обновления.
  58. func (sf *RecMeta) UpdateAt() ktypes.ITimeMut {
  59. return sf.updateAt_
  60. }