X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/0aa5d347a234d6a636ae481564ac537c8f32a917..1e8eb98d30459399902534082c88b94bb26bb2e3:/stargazer/plugins/authorization/ao/ao.cpp diff --git a/stargazer/plugins/authorization/ao/ao.cpp b/stargazer/plugins/authorization/ao/ao.cpp index 853df2a4..d17eeb6d 100644 --- a/stargazer/plugins/authorization/ao/ao.cpp +++ b/stargazer/plugins/authorization/ao/ao.cpp @@ -52,18 +52,6 @@ return aoc.GetPlugin(); //----------------------------------------------------------------------------- //----------------------------------------------------------------------------- //----------------------------------------------------------------------------- -template -class IS_CONTAINS_USER: public std::binary_function -{ -public: - bool operator()(const varType& notifier, USER_PTR user) const - { - return notifier.GetUser() == user; - } -}; -//----------------------------------------------------------------------------- -//----------------------------------------------------------------------------- -//----------------------------------------------------------------------------- std::string AUTH_AO::GetVersion() const { return "Always Online authorizator v.1.0"; @@ -86,7 +74,7 @@ GetUsers(); users->AddNotifierUserAdd(&onAddUserNotifier); users->AddNotifierUserDel(&onDelUserNotifier); -std::for_each(usersList.begin(), usersList.end(), std::bind1st(std::mem_fun(&AUTH_AO::UpdateUserAuthorization), this)); +std::for_each(usersList.begin(), usersList.end(), [this](auto user){ UpdateUserAuthorization(user); }); isRunning = true; @@ -143,15 +131,12 @@ u->GetProperty().ips.AddAfterNotifier(&AfterChgIPNotifierList.front()); void AUTH_AO::UnSetUserNotifiers(USER_PTR u) { // --- AlwaysOnline --- -IS_CONTAINS_USER > IsContainsUserAOB; -IS_CONTAINS_USER > IsContainsUserAOA; - std::list >::iterator aoBIter; std::list >::iterator aoAIter; aoBIter = find_if(BeforeChgAONotifierList.begin(), BeforeChgAONotifierList.end(), - bind2nd(IsContainsUserAOB, u)); + [u](auto notifier){ return notifier.GetUser() == u; }); if (aoBIter != BeforeChgAONotifierList.end()) { @@ -161,7 +146,7 @@ if (aoBIter != BeforeChgAONotifierList.end()) aoAIter = find_if(AfterChgAONotifierList.begin(), AfterChgAONotifierList.end(), - bind2nd(IsContainsUserAOA, u)); + [u](auto notifier){ return notifier.GetUser() == u; }); if (aoAIter != AfterChgAONotifierList.end()) { @@ -171,15 +156,12 @@ if (aoAIter != AfterChgAONotifierList.end()) // --- AlwaysOnline end --- // --- IP --- -IS_CONTAINS_USER > IsContainsUserIPB; -IS_CONTAINS_USER > IsContainsUserIPA; - std::list >::iterator ipBIter; std::list >::iterator ipAIter; ipBIter = std::find_if(BeforeChgIPNotifierList.begin(), BeforeChgIPNotifierList.end(), - bind2nd(IsContainsUserIPB, u)); + [u](auto notifier){ return notifier.GetUser() == u; }); if (ipBIter != BeforeChgIPNotifierList.end()) { @@ -189,7 +171,7 @@ if (ipBIter != BeforeChgIPNotifierList.end()) ipAIter = find_if(AfterChgIPNotifierList.begin(), AfterChgIPNotifierList.end(), - bind2nd(IsContainsUserIPA, u)); + [u](auto notifier){ return notifier.GetUser() == u; }); if (ipAIter != AfterChgIPNotifierList.end()) {