/*************************************************************************
* UrBackup - Client/Server backup system
* Copyright (C) 2011-2016 Martin Raiber
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see .
**************************************************************************/
#include "FileSettingsReader.h"
#include "stringtools.h"
#include "Server.h"
#include
#include
#include "Interface/File.h"
std::map* CFileSettingsReader::settings=new std::map;
IMutex* CFileSettingsReader::settings_mutex=NULL;
namespace
{
std::string readFile(const std::string& fn)
{
std::auto_ptr file(Server->openFile(fn));
if(file.get()==NULL)
{
return std::string();
}
std::string ret;
ret.resize(file->Size());
size_t read=0;
while(readRead(&ret[read], static_cast<_u32>(ret.size()-read));
}
return ret;
}
}
CFileSettingsReader::CFileSettingsReader(std::string pFile)
{
IScopedLock lock(settings_mutex);
std::map::iterator iter
= settings->find(pFile);
if( iter==settings->end() )
{
lock.relock(NULL);
std::auto_ptr f(Server->openFile(pFile, MODE_READ));
std::string fdata;
if (f.get() != NULL)
{
fdata = f->Read(static_cast<_u32>(f->Size()));
f.reset();
}
read(fdata, pFile);
}
else
{
cached_settings=iter->second;
++cached_settings->refcount;
}
}
CFileSettingsReader::~CFileSettingsReader()
{
IScopedLock lock(settings_mutex);
--cached_settings->refcount;
if(cached_settings->refcount<=0)
{
std::map::iterator it=settings->find(cached_settings->key);
if(it!=settings->end())
{
settings->erase(it);
}
Server->destroy(cached_settings->smutex);
delete cached_settings;
}
}
bool CFileSettingsReader::getValue(std::string key, std::string *value)
{
IScopedLock lock(cached_settings->smutex);
std::map::iterator i=cached_settings->mSettingsMap.find(key);
if( i!= cached_settings->mSettingsMap.end() )
{
*value=i->second;
return true;
}
return false;
}
void CFileSettingsReader::cleanup()
{
{
IScopedLock lock(settings_mutex);
for(std::map::iterator iter=settings->begin();iter!=settings->end();++iter)
{
Server->destroy(iter->second->smutex);
delete iter->second;
}
}
Server->destroy(settings_mutex);
delete settings;
}
void CFileSettingsReader::setup()
{
settings_mutex=Server->createMutex();
}
std::vector CFileSettingsReader::getKeys()
{
IScopedLock lock(cached_settings->smutex);
std::vector ret;
for(std::map::iterator i=cached_settings->mSettingsMap.begin();
i!=cached_settings->mSettingsMap.end();++i)
{
ret.push_back(i->first);
}
return ret;
}
void CFileSettingsReader::read( const std::string& fdata, const std::string& pFile )
{
std::vector mSettings;
int num_lines=linecount(fdata);
for(int i=0;ismutex=Server->createMutex();
for(size_t i=0;imSettingsMap[(mSettings[i].key)]=(mSettings[i].value);
}
cached_settings->refcount=1;
cached_settings->key=pFile;
IScopedLock lock(settings_mutex);
std::map::iterator iter = settings->find(pFile);
if (iter == settings->end())
{
settings->insert(std::pair(pFile, cached_settings));
}
else
{
Server->destroy(cached_settings->smutex);
delete cached_settings;
cached_settings = iter->second;
++cached_settings->refcount;
}
}