X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/27cbf9efdb75590ada1c734e68bd74a78730ad20..58024dfd7ad59626cc0c4beaf82f5c27c93ea0e3:/projects/stargazer/plugins/other/smux/smux.cpp?ds=sidebyside diff --git a/projects/stargazer/plugins/other/smux/smux.cpp b/projects/stargazer/plugins/other/smux/smux.cpp index 23d5f05f..cc69aa81 100644 --- a/projects/stargazer/plugins/other/smux/smux.cpp +++ b/projects/stargazer/plugins/other/smux/smux.cpp @@ -108,7 +108,9 @@ SMUX::SMUX() sensors(), tables(), notifiers(), - addDelNotifier(*this) + addUserNotifier(*this), + delUserNotifier(*this), + addDelTariffNotifier(*this) { pthread_mutex_init(&mutex, NULL); @@ -183,8 +185,6 @@ tables[".1.3.6.1.4.1.38313.1.1.6"] = new TariffUsersTable(".1.3.6.1.4.1.38313.1. UpdateTables(); SetNotifiers(); -users->AddNotifierUserAdd(&addDelNotifier); -users->AddNotifierUserDel(&addDelNotifier); #ifdef DEBUG Sensors::const_iterator it(sensors.begin()); @@ -215,8 +215,6 @@ int SMUX::Stop() printfd(__FILE__, "SMUX::Stop() - Before\n"); running = false; -users->DelNotifierUserDel(&addDelNotifier); -users->DelNotifierUserAdd(&addDelNotifier); ResetNotifiers(); if (!stopped) @@ -395,23 +393,53 @@ sensors.insert(newSensors.begin(), newSensors.end()); return true; } +void SMUX::SetNotifier(USER_PTR userPtr) +{ +notifiers.push_back(CHG_AFTER_NOTIFIER(*this, userPtr)); +userPtr->GetProperty().tariffName.AddAfterNotifier(¬ifiers.back()); +} + +void SMUX::UnsetNotifier(USER_PTR userPtr) +{ +std::list::iterator it = notifiers.begin(); +while (it != notifiers.end()) + { + if (it->GetUserPtr() == userPtr) + { + userPtr->GetProperty().tariffName.DelAfterNotifier(&(*it)); + notifiers.erase(it); + break; + } + ++it; + } +} + void SMUX::SetNotifiers() { -USER_PTR u; int h = users->OpenSearch(); assert(h && "USERS::OpenSearch is always correct"); +USER_PTR u; while (!users->SearchNext(h, &u)) - { - notifiers.push_back(CHG_AFTER_NOTIFIER(*this, u)); - u->GetProperty().tariffName.AddAfterNotifier(¬ifiers.back()); - } + SetNotifier(u); users->CloseSearch(h); + +users->AddNotifierUserAdd(&addUserNotifier); +users->AddNotifierUserDel(&delUserNotifier); + +tariffs->AddNotifierAdd(&addDelTariffNotifier); +tariffs->AddNotifierDel(&addDelTariffNotifier); } void SMUX::ResetNotifiers() { +tariffs->DelNotifierDel(&addDelTariffNotifier); +tariffs->DelNotifierAdd(&addDelTariffNotifier); + +users->DelNotifierUserDel(&delUserNotifier); +users->DelNotifierUserAdd(&addUserNotifier); + std::list::iterator it = notifiers.begin(); while (it != notifiers.end()) { @@ -424,8 +452,3 @@ void CHG_AFTER_NOTIFIER::Notify(const std::string &, const std::string &) { smux.UpdateTables(); } - -void ADD_DEL_USER_NOTIFIER::Notify(const USER_PTR &) -{ -smux.UpdateTables(); -}