]> git.stg.codes - stg.git/blobdiff - projects/stargazer/admins_impl.h
Merge branch 'stg-2.409-radius'
[stg.git] / projects / stargazer / admins_impl.h
index 09933230b4fdc7bfd9b52a951ba32666073d99a9..03aa4ece97ed9a14463e9c511d66ed928635d6ea 100644 (file)
  $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