summaryrefslogtreecommitdiffstats
path: root/src/rgw/driver/rados/rgw_datalog_notify.cc
blob: 12cdc532f3c23687e9699ad42e0801698f4d8c88 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
// vim: ts=8 sw=2 smarttab ft=cpp

#include "rgw_datalog_notify.h"
#include "rgw_datalog.h"

// custom encoding for v1 notify API
struct EntryEncoderV1 {
  const rgw_data_notify_entry& entry;
};
struct SetEncoderV1 {
  const bc::flat_set<rgw_data_notify_entry>& entries;
};

// encode rgw_data_notify_entry as string
void encode_json(const char *name, const EntryEncoderV1& e, Formatter *f)
{
  f->dump_string(name, e.entry.key); // encode the key only
}
// encode set<rgw_data_notify_entry> as set<string>
void encode_json(const char *name, const SetEncoderV1& e, Formatter *f)
{
  f->open_array_section(name);
  for (auto& entry : e.entries) {
    encode_json("obj", EntryEncoderV1{entry}, f);
  }
  f->close_section();
}
// encode map<int, set<rgw_data_notify_entry>> as map<int, set<string>>
void encode_json(const char *name, const rgw_data_notify_v1_encoder& e, Formatter *f)
{
  f->open_array_section(name);
  for (auto& [key, val] : e.shards) {
    f->open_object_section("entry");
    encode_json("key", key, f);
    encode_json("val", SetEncoderV1{val}, f);
    f->close_section();
  }
  f->close_section();
}

struct EntryDecoderV1 {
  rgw_data_notify_entry& entry;
};
struct SetDecoderV1 {
  bc::flat_set<rgw_data_notify_entry>& entries;
};

// decode string into rgw_data_notify_entry
void decode_json_obj(EntryDecoderV1& d, JSONObj *obj)
{
  decode_json_obj(d.entry.key, obj);
  d.entry.gen = 0;
}
// decode set<string> into set<rgw_data_notify_entry>
void decode_json_obj(SetDecoderV1& d, JSONObj *obj)
{
  for (JSONObjIter o = obj->find_first(); !o.end(); ++o) {
    rgw_data_notify_entry val;
    auto decoder = EntryDecoderV1{val};
    decode_json_obj(decoder, *o);
    d.entries.insert(std::move(val));
  }
}
// decode map<int, set<string>> into map<int, set<rgw_data_notify_entry>>
void decode_json_obj(rgw_data_notify_v1_decoder& d, JSONObj *obj)
{
  for (JSONObjIter o = obj->find_first(); !o.end(); ++o) {
    int shard_id = 0;
    JSONDecoder::decode_json("key", shard_id, *o);
    bc::flat_set<rgw_data_notify_entry> val;
    SetDecoderV1 decoder{val};
    JSONDecoder::decode_json("val", decoder, *o);
    d.shards[shard_id] = std::move(val);
  }
}