2  *    This program is free software; you can redistribute it and/or modify
 
   3  *    it under the terms of the GNU General Public License as published by
 
   4  *    the Free Software Foundation; either version 2 of the License, or
 
   5  *    (at your option) any later version.
 
   7  *    This program is distributed in the hope that it will be useful,
 
   8  *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
   9  *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  10  *    GNU General Public License for more details.
 
  12  *    You should have received a copy of the GNU General Public License
 
  13  *    along with this program; if not, write to the Free Software
 
  14  *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
  22  *    Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
 
  27  $Date: 2010/10/07 18:43:21 $
 
  35 #include "stg/locker.h"
 
  36 #include "stg/logger.h"
 
  37 #include "stg/store.h"
 
  38 #include "stg/admin.h"
 
  39 #include "tariffs_impl.h"
 
  41 //-----------------------------------------------------------------------------
 
  42 TARIFFS_IMPL::TARIFFS_IMPL(STORE * st)
 
  46       WriteServLog(GetStgLogger()),
 
  49       noTariff(NO_TARIFF_NAME),
 
  53 pthread_mutex_init(&mutex, NULL);
 
  56 //-----------------------------------------------------------------------------
 
  57 TARIFFS_IMPL::~TARIFFS_IMPL()
 
  59 pthread_mutex_destroy(&mutex);
 
  61 //-----------------------------------------------------------------------------
 
  62 int TARIFFS_IMPL::ReadTariffs()
 
  64 STG_LOCKER lock(&mutex);
 
  66 std::vector<std::string> tariffsList;
 
  67 if (store->GetTariffsList(&tariffsList))
 
  69     WriteServLog("Cannot get tariffs list.");
 
  70     WriteServLog("%s", store->GetStrError().c_str());
 
  73 Tariffs::size_type tariffsNum = tariffsList.size();
 
  75 for (Tariffs::size_type i = 0; i < tariffsNum; i++)
 
  78     if (store->RestoreTariff(&td, tariffsList[i]))
 
  80         WriteServLog("Cannot read tariff %s.", tariffsList[i].c_str());
 
  81         WriteServLog("%s", store->GetStrError().c_str());
 
  84     tariffs.push_back(TARIFF_IMPL(td));
 
  89 //-----------------------------------------------------------------------------
 
  90 size_t TARIFFS_IMPL::Count() const
 
  92 STG_LOCKER lock(&mutex);
 
  93 return tariffs.size();
 
  95 //-----------------------------------------------------------------------------
 
  96 const TARIFF * TARIFFS_IMPL::FindByName(const std::string & name) const
 
  98 if (name == NO_TARIFF_NAME)
 
 101 STG_LOCKER lock(&mutex);
 
 102 std::list<TARIFF_IMPL>::const_iterator ti;
 
 103 ti = find(tariffs.begin(), tariffs.end(), TARIFF_IMPL(name));
 
 105 if (ti != tariffs.end())
 
 110 //-----------------------------------------------------------------------------
 
 111 int TARIFFS_IMPL::Chg(const TARIFF_DATA & td, const ADMIN * admin)
 
 113 const PRIV * priv = admin->GetPriv();
 
 115 if (!priv->tariffChg)
 
 117     std::string s = admin->GetLogStr() + " Change tariff \'"
 
 118                + td.tariffConf.name + "\'. Access denied.";
 
 119     strError = "Access denied.";
 
 120     WriteServLog(s.c_str());
 
 124 STG_LOCKER lock(&mutex);
 
 126 std::list<TARIFF_IMPL>::iterator ti;
 
 127 ti = find(tariffs.begin(), tariffs.end(), TARIFF_IMPL(td.tariffConf.name));
 
 129 if (ti == tariffs.end())
 
 131     strError = "Tariff \'" + td.tariffConf.name + "\' cannot be changed. Tariff does not exist.";
 
 132     WriteServLog("%s %s", admin->GetLogStr().c_str(), strError.c_str());
 
 138 if (store->SaveTariff(td, td.tariffConf.name))
 
 140     std::string error = "Tariff " + td.tariffConf.name + " writing error. " + store->GetStrError();
 
 141     WriteServLog(error.c_str());
 
 145 WriteServLog("%s Tariff \'%s\' changed.",
 
 146              admin->GetLogStr().c_str(), td.tariffConf.name.c_str());
 
 150 //-----------------------------------------------------------------------------
 
 151 int TARIFFS_IMPL::Del(const std::string & name, const ADMIN * admin)
 
 153 const PRIV * priv = admin->GetPriv();
 
 155 if (!priv->tariffChg)
 
 157     std::string s = admin->GetLogStr() + " Delete tariff \'"
 
 158                + name + "\'. Access denied.";
 
 159     strError = "Access denied.";
 
 160     WriteServLog(s.c_str());
 
 167     STG_LOCKER lock(&mutex);
 
 169     std::list<TARIFF_IMPL>::iterator ti;
 
 170     ti = find(tariffs.begin(), tariffs.end(), TARIFF_IMPL(name));
 
 172     if (ti == tariffs.end())
 
 174         strError = "Tariff \'" + name + "\' cannot be deleted. Tariff does not exist.";
 
 175         WriteServLog("%s %s", admin->GetLogStr().c_str(), strError.c_str());
 
 179     if (store->DelTariff(name))
 
 181         WriteServLog("Cannot delete tariff %s.", name.c_str());
 
 182         WriteServLog("%s", store->GetStrError().c_str());
 
 186     td = ti->GetTariffData();
 
 191 std::set<NOTIFIER_BASE<TARIFF_DATA> *>::iterator ni = onDelNotifiers.begin();
 
 192 while (ni != onDelNotifiers.end())
 
 198 WriteServLog("%s Tariff \'%s\' deleted.",
 
 199              admin->GetLogStr().c_str(),
 
 203 //-----------------------------------------------------------------------------
 
 204 int TARIFFS_IMPL::Add(const std::string & name, const ADMIN * admin)
 
 206 const PRIV * priv = admin->GetPriv();
 
 208 if (!priv->tariffChg)
 
 210     std::string s = admin->GetLogStr() + " Add tariff \'"
 
 211                + name + "\'. Access denied.";
 
 212     strError = "Access denied.";
 
 213     WriteServLog(s.c_str());
 
 218     STG_LOCKER lock(&mutex);
 
 220     std::list<TARIFF_IMPL>::iterator ti;
 
 221     ti = find(tariffs.begin(), tariffs.end(), TARIFF_IMPL(name));
 
 223     if (ti != tariffs.end())
 
 225         strError = "Tariff \'" + name + "\' cannot be added. Tariff already exist.";
 
 226         WriteServLog("%s %s", admin->GetLogStr().c_str(), strError.c_str());
 
 230     tariffs.push_back(TARIFF_IMPL(name));
 
 233 if (store->AddTariff(name) < 0)
 
 235     strError = "Tariff " + name + " adding error. " + store->GetStrError();
 
 236     WriteServLog(strError.c_str());
 
 240 // Fire all "on add" notifiers
 
 241 std::set<NOTIFIER_BASE<TARIFF_DATA> *>::iterator ni = onAddNotifiers.begin();
 
 242 while (ni != onAddNotifiers.end())
 
 244     (*ni)->Notify(tariffs.back().GetTariffData());
 
 248 WriteServLog("%s Tariff \'%s\' added.",
 
 249                  admin->GetLogStr().c_str(), name.c_str());
 
 253 //-----------------------------------------------------------------------------
 
 254 void TARIFFS_IMPL::GetTariffsData(std::list<TARIFF_DATA> * tdl) const
 
 256 assert(tdl != NULL && "Tariffs data list is not null");
 
 257 STG_LOCKER lock(&mutex);
 
 259 Tariffs::const_iterator it = tariffs.begin();
 
 260 for (; it != tariffs.end(); ++it)
 
 262     tdl->push_back(it->GetTariffData());
 
 265 //-----------------------------------------------------------------------------
 
 266 void TARIFFS_IMPL::AddNotifierAdd(NOTIFIER_BASE<TARIFF_DATA> * n)
 
 268 STG_LOCKER lock(&mutex);
 
 269 onAddNotifiers.insert(n);
 
 271 //-----------------------------------------------------------------------------
 
 272 void TARIFFS_IMPL::DelNotifierAdd(NOTIFIER_BASE<TARIFF_DATA> * n)
 
 274 STG_LOCKER lock(&mutex);
 
 275 onAddNotifiers.erase(n);
 
 277 //-----------------------------------------------------------------------------
 
 278 void TARIFFS_IMPL::AddNotifierDel(NOTIFIER_BASE<TARIFF_DATA> * n)
 
 280 STG_LOCKER lock(&mutex);
 
 281 onDelNotifiers.insert(n);
 
 283 //-----------------------------------------------------------------------------
 
 284 void TARIFFS_IMPL::DelNotifierDel(NOTIFIER_BASE<TARIFF_DATA> * n)
 
 286 STG_LOCKER lock(&mutex);
 
 287 onDelNotifiers.erase(n);
 
 289 //-----------------------------------------------------------------------------