Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mon 11220 unified sql #112

Merged
merged 123 commits into from
Dec 8, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
123 commits
Select commit Hold shift + click to select a range
360566d
wip(storage): attempt to make a rebuild message with protobuf
bouda1 Oct 11, 2021
025291c
wip(storage): new protobuf files added
bouda1 Oct 11, 2021
85a722b
wip(bbdo): serialization with protobuf
bouda1 Oct 12, 2021
a8a62b5
wip(storage): protobuf serialization
bouda1 Oct 12, 2021
f6110c1
wip(storage): serialization/deserialization work with bbdo.
bouda1 Oct 12, 2021
2e42384
cleanup(events_io): several warnings fixed
bouda1 Oct 13, 2021
e717004
fix(storage): rebuild with protobuf is better
bouda1 Oct 14, 2021
23f7bae
fix(storage): rebuild with grpc should almost work
bouda1 Oct 14, 2021
5bcdb9f
cleanup(collect): dos ascii => unix ascii and warnings removed.
bouda1 Oct 15, 2021
196b810
fix(storage): de_rebuild2 numeration must not be aligned with others …
bouda1 Oct 15, 2021
1509391
fix(rrd): this patch to fix a link error
bouda1 Oct 15, 2021
f6322ef
enh(cmake): protobuf events are a little better
bouda1 Nov 2, 2021
3b1c85b
fix(mysql): ping has a timeout now.
bouda1 Nov 2, 2021
b0a79a2
fix(cmake): unused files removed
bouda1 Nov 2, 2021
907b842
fix(cmake): protobuf dependencies are better now.
bouda1 Nov 3, 2021
e9322a7
wip(broker/unified_sql): first step for this new module
bouda1 Nov 3, 2021
5aa7c97
wip(broker/unified_sql): factory and connector should be ok
bouda1 Nov 3, 2021
e137de7
wip(unified_sql): conflict_manager a almost a stream now
bouda1 Nov 5, 2021
b12c96a
enh(unified_sql): this new module compiles
bouda1 Nov 5, 2021
74d650c
cleanup(neb): coding style applied on neb headers
bouda1 Nov 5, 2021
05fcdb8
cleanup(tests): coding style applied and warnings removed
bouda1 Nov 5, 2021
80fb6de
enh(protobuf): work on harmonization of events in collect
bouda1 Nov 5, 2021
35706f3
cleanup(various): coding style reapplied
bouda1 Nov 5, 2021
067ef3b
cleanup(various): coding style reapplied
bouda1 Nov 5, 2021
cf28576
fix(cmake/storage): no more needed hack removed
bouda1 Nov 5, 2021
aab8cfb
fix(connector/test): embedded_perl includes order
bouda1 Nov 5, 2021
24335d0
enh(broker/test): new unit test for unified_sql config
bouda1 Nov 5, 2021
4e97048
fix(unified_sql): a first working version.
bouda1 Nov 8, 2021
e94ca7a
enh(protobuf): namespace updated
bouda1 Nov 9, 2021
f84a908
enh(broker/config/state): bbdo_version introduced in configuration
bouda1 Nov 12, 2021
7701007
fix(bbdo/bbdo_version): It is no more a static value
bouda1 Nov 12, 2021
c23fd0f
fix(broker/storage): events are external to broker now
bouda1 Nov 12, 2021
16c7e12
enh(bbdo/protobuf): event generator script added
bouda1 Nov 12, 2021
6e546ee
fix(unified_sql): the unit test passes
bouda1 Nov 5, 2021
c904cc0
enh(storage/events): on the road of externalization
bouda1 Nov 13, 2021
1ef97cd
cleanup(parse_perfdata): the perfdata parser is moved to misc.
bouda1 Nov 15, 2021
ea408d9
fix(exceptions::perfdata): no more exceptions::perfdata exceptions
bouda1 Nov 15, 2021
3f0c47d
fix(parse_perfdata): does not thrw exception anymore and changed api
bouda1 Nov 15, 2021
2eb2a74
fix(misc::parse_perfdata): this fix is needed because of another func…
bouda1 Nov 16, 2021
62db314
wip(broker): Just tests commented to have something that compiles
bouda1 Nov 16, 2021
2b62fd4
fix(cmake): compilation is back and in C++14 with cmake3
bouda1 Nov 16, 2021
617d8cc
fix(broker/unified_sql/test): code re-established
bouda1 Nov 16, 2021
92074d7
cleanup(broker/events): coding style and optimization
bouda1 Nov 16, 2021
af2232f
fix(broker/stats/tests): A test is disabled.
bouda1 Nov 16, 2021
8649081
fix(bam): bam event types are stored in bbdo folder now.
bouda1 Nov 17, 2021
77d65df
fix(broker/bam): bam events are moved to bbdo.
bouda1 Nov 17, 2021
a8e0825
enh(cmake): bbdo events are faster to compile
bouda1 Nov 17, 2021
dd53e1e
fix(broker/unified_sql): Thread is started and unified_sql works now.
bouda1 Nov 18, 2021
578cd2d
fix(unified_sql): mfifo was still read from two inputs.
bouda1 Nov 18, 2021
c07758d
fix(unified_sql): mfifo removed from stream
bouda1 Nov 19, 2021
c0cbbf4
fix(broker/unified_sql): events badly acknowledged
bouda1 Nov 19, 2021
b74fead
fix(broker/unified_sql): acknowledgement is better now
bouda1 Nov 19, 2021
cedb632
fix(broker/unified_sql): not needed stat removed
bouda1 Nov 20, 2021
75d7c67
enh(broker/notification): This module is no more used.
bouda1 Nov 20, 2021
ce6c83d
cleanup(hook): tests about them are also removed
bouda1 Nov 22, 2021
b2c0b4c
fix(broker/hook): hook and hookers are removed.
bouda1 Nov 22, 2021
eb7101a
cleanup(broker/tets): tests on engine are more apropriate to gtest
bouda1 Nov 22, 2021
d5d544e
enh(broker/engine): attempt to simplify and optimize engine
bouda1 Nov 22, 2021
67a31ae
fix(unified_sql): no more thread in unified_sql
bouda1 Nov 23, 2021
40b98d1
enh(broker/unified_sql): indices/metrics deletion re-enabled.
bouda1 Nov 23, 2021
1c9ed0f
fix(broker/remove_graph): it works also with unified_sql
bouda1 Nov 23, 2021
e7e9be2
enh(robot/broker): new test for unified_sql
bouda1 Nov 24, 2021
05e296f
wip(broker/tests): try to fix the issue with duplicated events
bouda1 Nov 29, 2021
4604c95
fix(broker/status): status events could be sent several times
bouda1 Nov 30, 2021
51e52e6
cleanup(broker/kpi_event.hh): unused functions removed.
bouda1 Nov 30, 2021
33a1287
fix(bbdo/generate-accessor.py): several fixes in the python script.
bouda1 Nov 30, 2021
27fbd74
cleanup(bbdo/metric.hh): comments removed
bouda1 Nov 30, 2021
7abf99d
cleanup(broker/kpi.hh): coding style applied.
bouda1 Nov 30, 2021
b5b42ce
fix(broker/io): comment removed in events.hh
bouda1 Nov 30, 2021
bfadcb7
cleanup(broker/io::protobuf): comments added.
bouda1 Dec 1, 2021
ec4dce5
cleanup(broker/brokerrpc): new comments
bouda1 Dec 1, 2021
93184d1
fix(broker/lua): no need anymore of bam module.
bouda1 Dec 1, 2021
03e6e7f
cleanup(broker/lua): coding style applied on main.cc
bouda1 Dec 1, 2021
c8c5067
cleanup(broker/rrd): coding style
bouda1 Dec 1, 2021
bcbf34f
fix(broker/lua/simu): tests re-enabled
bouda1 Dec 1, 2021
a182b4a
fix(broker/mysql_connection): mysql_ping must be called just when needed
bouda1 Dec 1, 2021
809b658
fix(tests/broker-database): tests are more stable
bouda1 Dec 1, 2021
534fb37
fix(tests/broker-database): Two timeouts are set to greater values
bouda1 Dec 1, 2021
943059e
fix(cmake): table_max_size file generation dependency fixed
bouda1 Dec 1, 2021
a48a693
fix(cmake): dependency added
bouda1 Dec 1, 2021
c2d4c3a
fix(packaging): new spec file
bouda1 Dec 2, 2021
dd5f198
fix(cmake): clib library should have a better place
bouda1 Dec 2, 2021
7bb8558
wip(packaging): new packaging almost finished
bouda1 Dec 3, 2021
9e7e743
fix(cmake/connector): two rpm added
bouda1 Dec 3, 2021
fa147d7
fix(cmake/packaging): collect is packaged in one step
bouda1 Dec 3, 2021
31f8e6e
fix(cmake/packaging): rsync not on the ci
bouda1 Dec 4, 2021
76eecd9
fix(cmake/packaging): this is shorter and better
bouda1 Dec 4, 2021
c3c4074
fix(cmake/packaging): typo
bouda1 Dec 4, 2021
b2f5bff
fix(packagine/specfile): file packaged twice
bouda1 Dec 4, 2021
9d826b6
fix(packaging/script): bad path to the spec file
bouda1 Dec 4, 2021
47eb7e6
fix(cmake/packaging): new debug message
bouda1 Dec 4, 2021
ad05d10
fix(packaging/script): variable not interpreted
bouda1 Dec 4, 2021
e9151f6
fix(cmake/engine): No need to look for centreon-clib
bouda1 Dec 4, 2021
85d9bd3
fix(cmake/connector): no need to look for the clib
bouda1 Dec 4, 2021
af438b6
fix(packaging/clib): its detection is useless
bouda1 Dec 4, 2021
6b34c6c
fix(packaging/debian): clib files changed path
bouda1 Dec 4, 2021
fc8e050
fix(packaging/debian): centreon-clib.pc is no more distributed
bouda1 Dec 5, 2021
f3c8cf3
fix(packaging/debian): bad paths fixed
bouda1 Dec 5, 2021
97e8545
fix(packaging/debian): missing files fixed
bouda1 Dec 5, 2021
1a9b938
fix(packaging/debian): a bad path fixed again
bouda1 Dec 5, 2021
f90e87a
fix(packaging/rpm): unused variables removed
bouda1 Dec 5, 2021
d6df6d2
cleanup(packaging/clib): this is no more used
bouda1 Dec 5, 2021
f23eb59
fix(packaging/engine): old packaging removed
bouda1 Dec 5, 2021
be8499b
fix(packaging): last changes
bouda1 Dec 5, 2021
d21a46e
fix(packaging/debian): little update of the packagin script
bouda1 Dec 6, 2021
1630a32
fix(packagine/rpm): centreon-engine user not defined
bouda1 Dec 6, 2021
8e8d875
fix(packaging/global): services had old conf variables
bouda1 Dec 6, 2021
a74241c
fix(packaging/debian): the distrib directory could fail
bouda1 Dec 6, 2021
684ff74
fix(tests/resources): two little fixes in specific-duplication.py
bouda1 Dec 6, 2021
9b8d1b4
fix(packaging/rpm): services should be better
bouda1 Dec 6, 2021
9cf5969
fix(various): several remarks fixed after PR review
bouda1 Dec 6, 2021
0806e81
fix(packaging): let's try to make paths more standard
bouda1 Dec 6, 2021
e256800
fix(packagine/connectors): standard paths are used
bouda1 Dec 6, 2021
557921b
fix(packaging): paths become standard
bouda1 Dec 7, 2021
a7c4ce0
fix(packaging): absolute paths for sbin were missing
bouda1 Dec 7, 2021
3b1e801
fix(broker/influxdb/graphite): compilation errors fixed
bouda1 Dec 7, 2021
74e7e55
fix(packaging/debian): bad variables definitions
bouda1 Dec 7, 2021
cf2a388
fix(broker/config): new errors when a directory is not accessible
bouda1 Dec 7, 2021
7ec2612
fix(cmake/libdir): libdir changes from a distrib to another
bouda1 Dec 7, 2021
541cc53
fix(packaging/debian): libdir has changed
bouda1 Dec 7, 2021
1de398a
fix(packaging/debian): bad paths in debian packaging
bouda1 Dec 7, 2021
c148aaf
fix(broker/config/test): the parser checks paths now
bouda1 Dec 7, 2021
b07fd65
fix(broker/test): the parser failed because of new checks
bouda1 Dec 7, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
wip(storage): serialization/deserialization work with bbdo.
The first application of this new feature is in progress.
storage creates the event, sends it to rrd.
rrd deserializes it and begins to read, but cannot for now
rebuild a graph.
  • Loading branch information
bouda1 committed Dec 3, 2021
commit f6110c143ead9eaeaec9111faf0b589cbcf8e05c
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/ba_duration_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -123,4 +123,4 @@ static io::data* new_ba_duration_event() {
return new ba_duration_event;
}
io::event_info::event_operations const ba_duration_event::operations = {
&new_ba_duration_event};
&new_ba_duration_event, nullptr, nullptr};
7 changes: 4 additions & 3 deletions centreon-broker/bam/src/ba_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -64,8 +64,8 @@ ba_event& ba_event::operator=(ba_event const& other) {
*/
bool ba_event::operator==(ba_event const& other) const {
return ba_id == other.ba_id && first_level == other.first_level &&
end_time == other.end_time && in_downtime == other.in_downtime &&
start_time == other.start_time && status == other.status;
end_time == other.end_time && in_downtime == other.in_downtime &&
start_time == other.start_time && status == other.status;
}

/**
Expand Down Expand Up @@ -98,4 +98,5 @@ mapping::entry const ba_event::entries[] = {
static io::data* new_ba_event() {
return new ba_event;
}
io::event_info::event_operations const ba_event::operations = {&new_ba_event};
io::event_info::event_operations const ba_event::operations = {
&new_ba_event, nullptr, nullptr};
3 changes: 2 additions & 1 deletion centreon-broker/bam/src/ba_status.cc
Original file line number Diff line number Diff line change
Expand Up @@ -104,4 +104,5 @@ mapping::entry const ba_status::entries[] = {
static io::data* new_ba_status() {
return new ba_status;
}
io::event_info::event_operations const ba_status::operations = {&new_ba_status};
io::event_info::event_operations const ba_status::operations = {
&new_ba_status, nullptr, nullptr};
8 changes: 1 addition & 7 deletions centreon-broker/bam/src/dimension_ba_bv_relation_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -84,12 +84,6 @@ void dimension_ba_bv_relation_event::_internal_copy(
bv_id = other.bv_id;
}

/**************************************
* *
* Static Objects *
* *
**************************************/

// Mapping.
mapping::entry const dimension_ba_bv_relation_event::entries[] = {
mapping::entry(&bam::dimension_ba_bv_relation_event::ba_id,
Expand All @@ -106,4 +100,4 @@ static io::data* new_dimension_ba_bv_relation_event() {
}
io::event_info::event_operations const
dimension_ba_bv_relation_event::operations = {
&new_dimension_ba_bv_relation_event};
&new_dimension_ba_bv_relation_event, nullptr, nullptr};
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/dimension_ba_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -125,4 +125,4 @@ static io::data* new_dimension_ba_event() {
return new dimension_ba_event;
}
io::event_info::event_operations const dimension_ba_event::operations = {
&new_dimension_ba_event};
&new_dimension_ba_event, nullptr, nullptr};
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@ mapping::entry const dimension_ba_timeperiod_relation::entries[] = {
static io::data* new_dimension_ba_timeperiod_relation() {
return new dimension_ba_timeperiod_relation;
}

io::event_info::event_operations const
dimension_ba_timeperiod_relation::operations = {
&new_dimension_ba_timeperiod_relation};
&new_dimension_ba_timeperiod_relation, nullptr, nullptr};
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/dimension_bv_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -109,4 +109,4 @@ static io::data* new_dimension_bv_event() {
return new dimension_bv_event;
}
io::event_info::event_operations const dimension_bv_event::operations = {
&new_dimension_bv_event};
&new_dimension_bv_event, nullptr, nullptr};
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/dimension_kpi_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -145,4 +145,4 @@ static io::data* new_dimension_kpi_event() {
return new dimension_kpi_event(0);
}
io::event_info::event_operations const dimension_kpi_event::operations = {
&new_dimension_kpi_event};
&new_dimension_kpi_event, nullptr, nullptr};
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/dimension_timeperiod.cc
Original file line number Diff line number Diff line change
Expand Up @@ -73,4 +73,4 @@ static io::data* new_dimension_timeperiod() {
return new dimension_timeperiod(0, "");
}
io::event_info::event_operations const dimension_timeperiod::operations = {
&new_dimension_timeperiod};
&new_dimension_timeperiod, nullptr, nullptr};
Original file line number Diff line number Diff line change
Expand Up @@ -101,4 +101,4 @@ static io::data* new_dimension_timeperiod_exception() {
}
io::event_info::event_operations const
dimension_timeperiod_exception::operations = {
&new_dimension_timeperiod_exception};
&new_dimension_timeperiod_exception, nullptr, nullptr};
Original file line number Diff line number Diff line change
Expand Up @@ -94,4 +94,4 @@ static io::data* new_dimension_timeperiod_exclusion() {
}
io::event_info::event_operations const
dimension_timeperiod_exclusion::operations = {
&new_dimension_timeperiod_exclusion};
&new_dimension_timeperiod_exclusion, nullptr, nullptr};
Original file line number Diff line number Diff line change
Expand Up @@ -40,4 +40,4 @@ static io::data* new_dimension_truncate_table_signal() {
}
io::event_info::event_operations const
dimension_truncate_table_signal::operations = {
&new_dimension_truncate_table_signal};
&new_dimension_truncate_table_signal, nullptr, nullptr};
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/inherited_downtime.cc
Original file line number Diff line number Diff line change
Expand Up @@ -83,4 +83,4 @@ static io::data* new_inherited_downtime() {
return new inherited_downtime;
}
io::event_info::event_operations const inherited_downtime::operations = {
&new_inherited_downtime, nullptr};
&new_inherited_downtime, nullptr, nullptr};
3 changes: 2 additions & 1 deletion centreon-broker/bam/src/kpi_event.cc
Original file line number Diff line number Diff line change
Expand Up @@ -115,4 +115,5 @@ static io::data* new_kpi_event() {
return new kpi_event(0, 0, 0);
}

io::event_info::event_operations const kpi_event::operations = {&new_kpi_event};
io::event_info::event_operations const kpi_event::operations = {
&new_kpi_event, nullptr, nullptr};
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/kpi_status.cc
Original file line number Diff line number Diff line change
Expand Up @@ -68,4 +68,4 @@ static io::data* new_kpi_status() {
return new kpi_status(0);
}
io::event_info::event_operations const kpi_status::operations = {
&new_kpi_status};
&new_kpi_status, nullptr, nullptr};
3 changes: 2 additions & 1 deletion centreon-broker/bam/src/rebuild.cc
Original file line number Diff line number Diff line change
Expand Up @@ -63,4 +63,5 @@ mapping::entry const rebuild::entries[] = {
static io::data* new_rebuild() {
return new rebuild;
}
io::event_info::event_operations const rebuild::operations = {&new_rebuild};
io::event_info::event_operations const rebuild::operations = {&new_rebuild,
nullptr, nullptr};
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ class event_info {
struct event_operations {
io::data* (*constructor)();
std::string (*serialize)(const io::data& e);
io::data* (*unserialize)(const char* buffer, size_t size);
};

private:
Expand Down
3 changes: 2 additions & 1 deletion centreon-broker/core/src/bbdo/ack.cc
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,5 @@ mapping::entry const ack::entries[]{
static io::data* new_ack() {
return new ack;
}
io::event_info::event_operations const ack::operations = {&new_ack};
io::event_info::event_operations const ack::operations = {&new_ack, nullptr,
nullptr};
3 changes: 2 additions & 1 deletion centreon-broker/core/src/bbdo/stop.cc
Original file line number Diff line number Diff line change
Expand Up @@ -33,4 +33,5 @@ mapping::entry const stop::entries[]{mapping::entry()};
static io::data* new_stop() {
return new stop;
}
io::event_info::event_operations const stop::operations = {&new_stop};
io::event_info::event_operations const stop::operations = {&new_stop, nullptr,
nullptr};
141 changes: 81 additions & 60 deletions centreon-broker/core/src/bbdo/stream.cc
Original file line number Diff line number Diff line change
Expand Up @@ -228,72 +228,93 @@ static uint32_t set_ulong(io::data& t,
static io::data* unserialize(uint32_t event_type,
uint32_t source_id,
uint32_t destination_id,
char const* buffer,
const char* buffer,
uint32_t size) {
// Get event info (operations and mapping).
io::event_info const* info(io::events::instance().get_event_info(event_type));
if (info) {
// Create object.
std::unique_ptr<io::data> t(info->get_operations().constructor());
if (t) {
t->source_id = source_id;
t->destination_id = destination_id;
// Browse all mapping to unserialize the object.
for (const mapping::entry* current_entry = info->get_mapping();
!current_entry->is_null(); ++current_entry)
// Skip entries that should not be serialized.
if (current_entry->get_serialize()) {
uint32_t rb;
switch (current_entry->get_type()) {
case mapping::source::BOOL:
rb = set_boolean(*t, *current_entry, buffer, size);
break;
case mapping::source::DOUBLE:
rb = set_double(*t, *current_entry, buffer, size);
break;
case mapping::source::INT:
rb = set_integer(*t, *current_entry, buffer, size);
break;
case mapping::source::SHORT:
rb = set_short(*t, *current_entry, buffer, size);
break;
case mapping::source::STRING:
rb = set_string(*t, *current_entry, buffer, size);
break;
case mapping::source::TIME:
rb = set_timestamp(*t, *current_entry, buffer, size);
break;
case mapping::source::UINT:
rb = set_uint(*t, *current_entry, buffer, size);
break;
case mapping::source::ULONG:
rb = set_ulong(*t, *current_entry, buffer, size);
break;

default:
log_v2::bbdo()->error(
"BBDO: invalid mapping for object of type '{0}': {1} is not "
"a known type ID",
info->get_name(), current_entry->get_type());
throw msg_fmt(
"BBDO: invalid mapping for "
"object of type '{}"
"': {}"
" is not a known type ID",
info->get_name(), current_entry->get_type());
if (info->get_mapping()) {
std::unique_ptr<io::data> t(info->get_operations().constructor());
if (t) {
t->source_id = source_id;
t->destination_id = destination_id;
// Browse all mapping to unserialize the object.
for (const mapping::entry* current_entry = info->get_mapping();
!current_entry->is_null(); ++current_entry)
// Skip entries that should not be serialized.
if (current_entry->get_serialize()) {
uint32_t rb;
switch (current_entry->get_type()) {
case mapping::source::BOOL:
rb = set_boolean(*t, *current_entry, buffer, size);
break;
case mapping::source::DOUBLE:
rb = set_double(*t, *current_entry, buffer, size);
break;
case mapping::source::INT:
rb = set_integer(*t, *current_entry, buffer, size);
break;
case mapping::source::SHORT:
rb = set_short(*t, *current_entry, buffer, size);
break;
case mapping::source::STRING:
rb = set_string(*t, *current_entry, buffer, size);
break;
case mapping::source::TIME:
rb = set_timestamp(*t, *current_entry, buffer, size);
break;
case mapping::source::UINT:
rb = set_uint(*t, *current_entry, buffer, size);
break;
case mapping::source::ULONG:
rb = set_ulong(*t, *current_entry, buffer, size);
break;

default:
log_v2::bbdo()->error(
"BBDO: invalid mapping for object of type '{0}': {1} is "
"not "
"a known type ID",
info->get_name(), current_entry->get_type());
throw msg_fmt(
"BBDO: invalid mapping for "
"object of type '{}"
"': {}"
" is not a known type ID",
info->get_name(), current_entry->get_type());
}
buffer += rb;
size -= rb;
}
buffer += rb;
size -= rb;
}
return t.release();
return t.release();
} else {
log_v2::bbdo()->error(
"BBDO: cannot create object of ID {} whereas it has been "
"registered",
event_type);
throw msg_fmt(
"BBDO: cannot create object of ID {}"
" whereas it has been registered",
event_type);
}
} else {
log_v2::bbdo()->error(
"BBDO: cannot create object of ID {} whereas it has been registered",
event_type);
throw msg_fmt(
"BBDO: cannot create object of ID {}"
" whereas it has been registered",
event_type);
std::unique_ptr<io::data> t(
info->get_operations().unserialize(buffer, size));
if (t) {
t->source_id = source_id;
t->destination_id = destination_id;
} else {
log_v2::bbdo()->error(
"BBDO: cannot create object of ID {} whereas it has been "
"registered",
event_type);
throw msg_fmt(
"BBDO: cannot create object of ID {} whereas it has been "
"registered",
event_type);
}
return t.release();
}
} else {
log_v2::bbdo()->info(
Expand Down Expand Up @@ -511,7 +532,7 @@ static io::raw* serialize(const io::data& e) {
while (size > 0) {
if (size < 0xffff) {
content->insert(content->end(), it, r.end());
*(reinterpret_cast<uint16_t*>(content->data() + 2)) = htonl(size);
*(reinterpret_cast<uint16_t*>(content->data() + 2)) = htons(size);
*(reinterpret_cast<uint32_t*>(content->data() + 4)) = htonl(e.type());
*(reinterpret_cast<uint32_t*>(content->data() + 8)) =
htonl(e.source_id);
Expand Down
2 changes: 1 addition & 1 deletion centreon-broker/core/src/bbdo/version_response.cc
Original file line number Diff line number Diff line change
Expand Up @@ -55,4 +55,4 @@ static auto new_version_response() -> io::data* {
return new version_response;
}
io::event_info::event_operations const version_response::operations = {
&new_version_response};
&new_version_response, nullptr, nullptr};
Loading