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
cleanup(various): coding style reapplied
  • Loading branch information
bouda1 committed Dec 3, 2021
commit 35706f33b8866049d6eef5f9276fdb84e4ceb5e7
1 change: 0 additions & 1 deletion centreon-broker/bam/src/availability_thread.cc
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@

#include "com/centreon/broker/database/mysql_error.hh"
#include "com/centreon/broker/log_v2.hh"
#include "com/centreon/broker/misc/global_lock.hh"
#include "com/centreon/exceptions/msg_fmt.hh"

using namespace com::centreon::exceptions;
Expand Down
10 changes: 6 additions & 4 deletions centreon-broker/bam/src/ba.cc
Original file line number Diff line number Diff line change
Expand Up @@ -72,10 +72,12 @@ ba::ba(uint32_t id,
_host_id(host_id),
_service_id(service_id),
_generate_virtual_status(generate_virtual_status),
_computed_soft_state(source == configuration::ba::state_source_best ?
ba::state::state_critical : ba::state::state_ok),
_computed_hard_state(source == configuration::ba::state_source_best ?
ba::state::state_critical : ba::state::state_ok),
_computed_soft_state(source == configuration::ba::state_source_best
? ba::state::state_critical
: ba::state::state_ok),
_computed_hard_state(source == configuration::ba::state_source_best
? ba::state::state_critical
: ba::state::state_ok),
_num_soft_critical_childs{0.f},
_num_hard_critical_childs{0.f},
_acknowledgement_hard(0.0),
Expand Down
8 changes: 4 additions & 4 deletions centreon-broker/bam/src/bool_expression.cc
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ using namespace com::centreon::broker;
*/
bool_expression::bool_expression() : _id(0), _impact_if(true) {}


/**
* Base boolean expression got updated.
*
Expand All @@ -47,7 +46,8 @@ bool bool_expression::child_has_update(computable* child, io::stream* visitor) {
// class, as the bool_* classes already cache most of them.
if (child == _expression.get()) {
// Logging.
log_v2::bam()->debug("BAM: boolean expression {} is getting notified of child update", _id);
log_v2::bam()->debug(
"BAM: boolean expression {} is getting notified of child update", _id);
}
return true;
}
Expand All @@ -59,8 +59,8 @@ bool bool_expression::child_has_update(computable* child, io::stream* visitor) {
*/
impact_values::state bool_expression::get_state() const {
return (_expression->value_hard() == _impact_if)
? bool_expression::state::state_critical
: bool_expression::state::state_ok;
? bool_expression::state::state_critical
: bool_expression::state::state_ok;
}

/**
Expand Down
24 changes: 11 additions & 13 deletions centreon-broker/bam/src/configuration/kpi.cc
Original file line number Diff line number Diff line change
Expand Up @@ -129,19 +129,17 @@ kpi& kpi::operator=(kpi const& other) {
*/
bool kpi::operator==(kpi const& other) const {
return _id == other._id && _state_type == other._state_type &&
_host_id == other._host_id && _service_id == other._service_id &&
_ba_id == other._ba_id &&
_indicator_ba_id == other._indicator_ba_id &&
_meta_id == other._meta_id && _boolexp_id == other._boolexp_id &&
_status == other._status && _last_level == other._last_level &&
_downtimed == other._downtimed &&
_acknowledged == other._acknowledged &&
_ignore_downtime == other._ignore_downtime &&
_ignore_acknowledgement == other._ignore_acknowledgement &&
_impact_warning == other._impact_warning &&
_impact_critical == other._impact_critical &&
_impact_unknown == other._impact_unknown &&
_event == other._event;
_host_id == other._host_id && _service_id == other._service_id &&
_ba_id == other._ba_id && _indicator_ba_id == other._indicator_ba_id &&
_meta_id == other._meta_id && _boolexp_id == other._boolexp_id &&
_status == other._status && _last_level == other._last_level &&
_downtimed == other._downtimed &&
_acknowledged == other._acknowledged &&
_ignore_downtime == other._ignore_downtime &&
_ignore_acknowledgement == other._ignore_acknowledgement &&
_impact_warning == other._impact_warning &&
_impact_critical == other._impact_critical &&
_impact_unknown == other._impact_unknown && _event == other._event;
}

/**
Expand Down
2 changes: 1 addition & 1 deletion centreon-broker/bam/src/exp_parser.cc
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,8 @@
#include <stack>

#include "com/centreon/broker/bam/exp_tokenizer.hh"
#include "com/centreon/exceptions/msg_fmt.hh"
#include "com/centreon/broker/log_v2.hh"
#include "com/centreon/exceptions/msg_fmt.hh"

using namespace com::centreon::exceptions;
using namespace com::centreon::broker;
Expand Down
4 changes: 2 additions & 2 deletions centreon-broker/bam/src/monitoring_stream.cc
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@
#include "com/centreon/broker/exceptions/shutdown.hh"
#include "com/centreon/broker/io/events.hh"
#include "com/centreon/broker/log_v2.hh"
#include "com/centreon/broker/misc/global_lock.hh"
#include "com/centreon/broker/multiplexing/publisher.hh"
#include "com/centreon/broker/neb/acknowledgement.hh"
#include "com/centreon/broker/neb/downtime.hh"
Expand Down Expand Up @@ -200,7 +199,8 @@ int monitoring_stream::write(std::shared_ptr<io::data> const& data) {
std::shared_ptr<neb::service_status> ss(
std::static_pointer_cast<neb::service_status>(data));
log_v2::bam()->trace(
"BAM: processing service status (host: {}, service: {}, hard state {}, "
"BAM: processing service status (host: {}, service: {}, hard state "
"{}, "
"current state {})",
ss->host_id, ss->service_id, ss->last_hard_state, ss->current_state);
multiplexing::publisher pblshr;
Expand Down
1 change: 0 additions & 1 deletion centreon-broker/bam/src/reporting_stream.cc
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@
#include "com/centreon/broker/exceptions/shutdown.hh"
#include "com/centreon/broker/io/events.hh"
#include "com/centreon/broker/log_v2.hh"
#include "com/centreon/broker/misc/global_lock.hh"
#include "com/centreon/broker/misc/string.hh"
#include "com/centreon/broker/time/timezone_manager.hh"
#include "com/centreon/exceptions/msg_fmt.hh"
Expand Down
4 changes: 2 additions & 2 deletions centreon-broker/core/src/brokerrpc.cc
Original file line number Diff line number Diff line change
Expand Up @@ -18,15 +18,15 @@
*/

#include "com/centreon/broker/brokerrpc.hh"
#include <grpcpp/server_builder.h>
#include <fmt/format.h>
#include <grpcpp/server_builder.h>

using namespace com::centreon::broker;

brokerrpc::brokerrpc(const std::string& address,
uint16_t port,
std::string const& broker_name) {
//broker_impl* service = new broker_impl;
// broker_impl* service = new broker_impl;
_service.set_broker_name(broker_name);
std::string server_address{fmt::format("{}:{}", address, port)};
grpc::ServerBuilder builder;
Expand Down
2 changes: 1 addition & 1 deletion centreon-broker/core/src/config/applier/modules.cc
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ bool modules::load_file(const std::string& filename, const void* arg) {
void* h = dlopen(filename.c_str(), RTLD_LAZY | RTLD_GLOBAL);
if (!h)
log_v2::config()->error("modules: could not load module '{}': {}",
filename, dlerror());
filename, dlerror());

if (_check_module(filename, h)) {
void* parents = dlsym(h, handle::parents_list);
Expand Down
2 changes: 1 addition & 1 deletion centreon-broker/core/src/io/events.cc
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ void events::unload() {
* @param category_id Category ID.
*/
void events::unregister_category(uint16_t category_id) {
for (auto it = _elements.begin(), end = _elements.end(); it != end; ) {
for (auto it = _elements.begin(), end = _elements.end(); it != end;) {
if (category_of_type(it->first) == category_id)
it = _elements.erase(it);
else
Expand Down
1 change: 0 additions & 1 deletion centreon-broker/core/src/misc/string.cc
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,6 @@ std::list<fmt::string_view> string::split_sv(std::string const& str, char sep) {
return retval;
}


std::string string::base64_encode(const std::string& str) {
static const std::string b =
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
Expand Down
5 changes: 2 additions & 3 deletions centreon-broker/core/src/mysql_connection.cc
Original file line number Diff line number Diff line change
Expand Up @@ -617,8 +617,8 @@ void mysql_connection::_run() {
/* We are waiting for some activity, nothing to do for now it is time
* to make some ping */
while (!_tasks_condition.wait_for(
lock, std::chrono::seconds(30),
[this] { return _finish_asked || !_tasks_list.empty(); })) {
lock, std::chrono::seconds(30),
[this] { return _finish_asked || !_tasks_list.empty(); })) {
lock.unlock();
log_v2::sql()->trace("SQL: performing mysql_ping.");
if (mysql_ping(_conn)) {
Expand All @@ -629,7 +629,6 @@ void mysql_connection::_run() {
lock.lock();
}


if (_tasks_list.empty()) {
_state = finished;
}
Expand Down
2 changes: 1 addition & 1 deletion centreon-broker/core/src/mysql_manager.cc
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ void mysql_manager::clear() {
conn->finish();
} catch (const std::exception& e) {
log_v2::sql()->info("mysql_manager: Unable to stop a connection: {}",
e.what());
e.what());
}
}
log_v2::sql()->debug("mysql_manager: clear finished");
Expand Down
16 changes: 10 additions & 6 deletions centreon-broker/core/src/processing/failover.cc
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,8 @@ void failover::exit() {
_should_exit = true;
log_v2::processing()->trace("Waiting for {} to be stopped", _name);

_state_cv.wait(lck, [this] { return _state == stopped || _state == not_started; });
_state_cv.wait(
lck, [this] { return _state == stopped || _state == not_started; });
}
if (_thread.joinable())
_thread.join();
Expand Down Expand Up @@ -358,7 +359,8 @@ void failover::_run() {
try {
ack_events = _stream->stop();
} catch (const std::exception& e) {
log_v2::core()->error("Failed to send stop event to stream: {}", e.what());
log_v2::core()->error("Failed to send stop event to stream: {}",
e.what());
}
_subscriber->get_muxer().ack_events(ack_events);
std::lock_guard<std::timed_mutex> stream_lock(_stream_m);
Expand All @@ -379,9 +381,10 @@ void failover::_run() {
{
int32_t ack_events;
try {
ack_events = _stream->stop();
ack_events = _stream->stop();
} catch (const std::exception& e) {
log_v2::core()->error("Failed to send stop event to stream: {}", e.what());
log_v2::core()->error("Failed to send stop event to stream: {}",
e.what());
}
_subscriber->get_muxer().ack_events(ack_events);
std::lock_guard<std::timed_mutex> stream_lock(_stream_m);
Expand All @@ -401,9 +404,10 @@ void failover::_run() {
// If ack_events is not zero, then we will store data twice
int32_t ack_events;
try {
ack_events = _stream->stop();
ack_events = _stream->stop();
} catch (const std::exception& e) {
log_v2::core()->error("Failed to send stop event to stream: {}", e.what());
log_v2::core()->error("Failed to send stop event to stream: {}",
e.what());
}
_subscriber->get_muxer().ack_events(ack_events);
_stream.reset();
Expand Down
51 changes: 24 additions & 27 deletions centreon-broker/core/src/stats/center.cc
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@

#include "com/centreon/broker/config/applier/modules.hh"
#include "com/centreon/broker/config/applier/state.hh"
#include "com/centreon/broker/log_v2.hh"
#include "com/centreon/broker/misc/filesystem.hh"
#include "com/centreon/broker/version.hh"
#include "com/centreon/broker/log_v2.hh"

using namespace com::centreon::broker;
using namespace com::centreon::broker::stats;
Expand Down Expand Up @@ -83,9 +83,7 @@ center::~center() {
* a last action and wait it is over. */
std::promise<bool> p;
std::future<bool> f{p.get_future()};
_strand.post([&p] {
p.set_value(true);
});
_strand.post([&p] { p.set_value(true); });
f.get();
pool::instance().stop_stats();
}
Expand Down Expand Up @@ -124,10 +122,9 @@ bool center::unregister_mysql_connection(SqlConnectionStats* connection) {
std::promise<bool> p;
std::future<bool> retval = p.get_future();
_strand.post([this, &p, connection] {
for (auto
it = _stats.mutable_connections()->begin(),
end = _stats.mutable_connections()->end();
it != end; ++it) {
for (auto it = _stats.mutable_connections()->begin(),
end = _stats.mutable_connections()->end();
it != end; ++it) {
if (&(*it) == connection) {
_stats.mutable_connections()->erase(it);
break;
Expand All @@ -137,7 +134,6 @@ bool center::unregister_mysql_connection(SqlConnectionStats* connection) {
return retval.get();
}


/**
* @brief When a feeder needs to write statistics, it primarily has to
* call this function to be registered in the statistic center and to get
Expand Down Expand Up @@ -251,7 +247,7 @@ bool center::unregister_mysql_connection(SqlConnectionStats* connection) {
*
* @return A pointer to the conflict_manager statistics.
*/
ConflictManagerStats* center::register_conflict_manager() {
ConflictManagerStats* center::register_conflict_manager() {
std::promise<ConflictManagerStats*> p;
std::future<ConflictManagerStats*> retval = p.get_future();
_strand.post([this, &p] {
Expand Down Expand Up @@ -320,24 +316,25 @@ std::string center::to_string() {
// done.get();
//}

void center::get_sql_connection_stats(uint32_t index, SqlConnectionStats* response) {
void center::get_sql_connection_stats(uint32_t index,
SqlConnectionStats* response) {
std::promise<bool> p;
std::future<bool> done = p.get_future();
_strand.post([&s = this->_stats, &p, &index, response] {
uint32_t i = 0;
for (auto it = s.connections().begin(),
end = s.connections().end();
it != end; ++it, ++i) {
if (index == i) {
*response = (*it);
}
uint32_t i = 0;
for (auto it = s.connections().begin(), end = s.connections().end();
it != end; ++it, ++i) {
if (index == i) {
*response = (*it);
}
}

if (i > index) {
log_v2::sql()->info("mysql_connection: index out of range in get sql "
"connection stats");
}
p.set_value(true);
if (i > index) {
log_v2::sql()->info(
"mysql_connection: index out of range in get sql "
"connection stats");
}
p.set_value(true);
});

// We wait for the response.
Expand All @@ -348,8 +345,8 @@ void center::get_sql_connection_size(GenericSize* response) {
std::promise<bool> p;
std::future<bool> done = p.get_future();
_strand.post([&s = this->_stats, &p, response] {
response->set_size(s.connections().size());
p.set_value(true);
response->set_size(s.connections().size());
p.set_value(true);
});

// We wait for the response.
Expand All @@ -360,8 +357,8 @@ void center::get_conflict_manager_stats(ConflictManagerStats* response) {
std::promise<bool> p;
std::future<bool> done = p.get_future();
_strand.post([&s = this->_stats, &p, response] {
*response = s.conflict_manager();
p.set_value(true);
*response = s.conflict_manager();
p.set_value(true);
});

// We wait for the response.
Expand Down
Loading