X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/becf6dfe4fe2ecd43792aa53a302c5866483f306..c0357e12bb0f1c4514956f61c1187059a656f94d:/projects/stargazer/admins_impl.h?ds=sidebyside diff --git a/projects/stargazer/admins_impl.h b/projects/stargazer/admins_impl.h index 09933230..03aa4ece 100644 --- a/projects/stargazer/admins_impl.h +++ b/projects/stargazer/admins_impl.h @@ -28,61 +28,65 @@ $Author: faust $ */ -#ifndef ADMINS_H -#define ADMINS_H +#ifndef ADMINS_IMPL_H +#define ADMINS_IMPL_H + +#include "admin_impl.h" + +#include "stg/admins.h" +#include "stg/admin.h" +#include "stg/locker.h" +#include "stg/store.h" +#include "stg/noncopyable.h" +#include "stg/logger.h" -#include <pthread.h> #include <list> #include <map> +#include <string> -#include "admin.h" -#include "stg_locker.h" -#include "base_store.h" -#include "noncopyable.h" - -using namespace std; +#include <pthread.h> -//----------------------------------------------------------------------------- -class ADMINS : private NONCOPYABLE -{ +class ADMINS_IMPL : private NONCOPYABLE, public ADMINS { public: - ADMINS(BASE_STORE * st); - ~ADMINS() {}; - - int Add(const string & login, const ADMIN & admin); - int Del(const string & login, const ADMIN & admin); - int Change(const ADMIN_CONF & ac, const ADMIN & admin); - void PrintAdmins() const; - const ADMIN GetSysAdmin() const { return stg; }; - const ADMIN GetNoAdmin() const { return noAdmin; }; - bool FindAdmin(const string & l, ADMIN * admin) const; - bool AdminExists(const std::string & login) const; - bool AdminCorrect(const std::string & login, - const std::string & password, - ADMIN * admin) const; - const string & GetStrError() const { return strError; }; + explicit ADMINS_IMPL(STORE * st); + virtual ~ADMINS_IMPL() {} + + int Add(const std::string & login, const ADMIN * admin); + int Del(const std::string & login, const ADMIN * admin); + int Change(const ADMIN_CONF & ac, const ADMIN * admin); + const ADMIN * GetSysAdmin() const { return &stg; } + const ADMIN * GetNoAdmin() const { return &noAdmin; } + bool Find(const std::string & l, ADMIN ** admin); + bool Exists(const std::string & login) const; + bool Correct(const std::string & login, + const std::string & password, + ADMIN ** admin); + const std::string & GetStrError() const { return strError; } + + size_t Count() const { return data.size(); } int OpenSearch() const; int SearchNext(int, ADMIN_CONF * ac) const; int CloseSearch(int) const; private: - typedef list<ADMIN>::iterator admin_iter; - typedef list<ADMIN>::const_iterator const_admin_iter; - - int ReadAdmins(); - - ADMIN stg; - ADMIN noAdmin; - list<ADMIN> data; - BASE_STORE * store; - STG_LOGGER & WriteServLog; - mutable map<int, const_admin_iter> searchDescriptors; - mutable unsigned int handle; + ADMINS_IMPL(const ADMINS_IMPL & rvalue); + ADMINS_IMPL & operator=(const ADMINS_IMPL & rvalue); + + typedef std::list<ADMIN_IMPL>::iterator admin_iter; + typedef std::list<ADMIN_IMPL>::const_iterator const_admin_iter; + + int Read(); + + ADMIN_IMPL stg; + ADMIN_IMPL noAdmin; + std::list<ADMIN_IMPL> data; + STORE * store; + STG_LOGGER & WriteServLog; + mutable std::map<int, const_admin_iter> searchDescriptors; + mutable unsigned int handle; mutable pthread_mutex_t mutex; - string strError; + std::string strError; }; -//----------------------------------------------------------------------------- -#endif - +#endif