DMRGateway/Conf.cpp

287 lines
6.3 KiB
C++
Raw Normal View History

2017-04-20 21:51:30 +02:00
/*
* Copyright (C) 2015,2016,2017 by Jonathan Naylor G4KLX
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include "Conf.h"
#include "Log.h"
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cctype>
const int BUFFER_SIZE = 500;
enum SECTION {
SECTION_NONE,
SECTION_GENERAL,
SECTION_LOG,
SECTION_DMR_NETWORK,
2017-04-23 21:17:25 +02:00
SECTION_XLX_NETWORK
2017-04-20 21:51:30 +02:00
};
CConf::CConf(const std::string& file) :
m_file(file),
m_daemon(false),
m_xlxSlot(2U),
2017-04-28 17:45:05 +02:00
m_xlxTG(9U),
2017-04-23 21:17:25 +02:00
m_rptAddress("127.0.0.1"),
m_rptPort(62032U),
m_localAddress("127.0.0.1"),
m_localPort(62031U),
2017-04-20 21:51:30 +02:00
m_timeout(10U),
2017-04-23 21:17:25 +02:00
m_debug(false),
2017-04-20 21:51:30 +02:00
m_logDisplayLevel(0U),
m_logFileLevel(0U),
m_logFilePath(),
m_logFileRoot(),
2017-04-23 21:17:25 +02:00
m_dmrNetworkAddress(),
m_dmrNetworkPort(0U),
m_dmrNetworkLocal(0U),
m_dmrNetworkPassword(),
m_dmrNetworkDebug(false),
2017-04-20 21:51:30 +02:00
m_xlxNetworkAddress(),
m_xlxNetworkPort(0U),
m_xlxNetworkLocal(0U),
m_xlxNetworkPassword(),
m_xlxNetworkOptions(),
2017-04-23 21:17:25 +02:00
m_xlxNetworkDebug(false)
2017-04-20 21:51:30 +02:00
{
}
CConf::~CConf()
{
}
bool CConf::read()
{
FILE* fp = ::fopen(m_file.c_str(), "rt");
if (fp == NULL) {
::fprintf(stderr, "Couldn't open the .ini file - %s\n", m_file.c_str());
return false;
}
SECTION section = SECTION_NONE;
char buffer[BUFFER_SIZE];
while (::fgets(buffer, BUFFER_SIZE, fp) != NULL) {
if (buffer[0U] == '#')
continue;
if (buffer[0U] == '[') {
if (::strncmp(buffer, "[General]", 9U) == 0)
section = SECTION_GENERAL;
else if (::strncmp(buffer, "[Log]", 5U) == 0)
section = SECTION_LOG;
2017-04-23 21:17:25 +02:00
else if (::strncmp(buffer, "[XLX Network]", 13U) == 0)
section = SECTION_XLX_NETWORK;
else if (::strncmp(buffer, "[DMR Network]", 13U) == 0)
section = SECTION_DMR_NETWORK;
else
2017-04-20 21:51:30 +02:00
section = SECTION_NONE;
continue;
}
char* key = ::strtok(buffer, " \t=\r\n");
if (key == NULL)
continue;
char* value = ::strtok(NULL, "\r\n");
if (value == NULL)
continue;
if (section == SECTION_GENERAL) {
if (::strcmp(key, "Daemon") == 0)
m_daemon = ::atoi(value) == 1;
else if (::strcmp(key, "XLSSlot") == 0)
m_xlxSlot = (unsigned int)::atoi(value);
2017-04-28 17:45:05 +02:00
else if (::strcmp(key, "XLXTG") == 0)
m_xlxTG = (unsigned int)::atoi(value);
2017-04-20 21:51:30 +02:00
else if (::strcmp(key, "Timeout") == 0)
m_timeout = (unsigned int)::atoi(value);
2017-04-23 21:17:25 +02:00
else if (::strcmp(key, "RptAddress") == 0)
m_rptAddress = value;
else if (::strcmp(key, "RptPort") == 0)
m_rptPort = (unsigned int)::atoi(value);
else if (::strcmp(key, "LocalAddress") == 0)
m_localAddress = value;
else if (::strcmp(key, "LocalPort") == 0)
m_localPort = (unsigned int)::atoi(value);
else if (::strcmp(key, "Debug") == 0)
m_debug = ::atoi(value) == 1;
2017-04-20 21:51:30 +02:00
} else if (section == SECTION_LOG) {
2017-04-28 17:45:05 +02:00
if (::strcmp(key, "FilePath") == 0)
m_logFilePath = value;
else if (::strcmp(key, "FileRoot") == 0)
m_logFileRoot = value;
else if (::strcmp(key, "FileLevel") == 0)
m_logFileLevel = (unsigned int)::atoi(value);
else if (::strcmp(key, "DisplayLevel") == 0)
m_logDisplayLevel = (unsigned int)::atoi(value);
2017-04-20 21:51:30 +02:00
} else if (section == SECTION_XLX_NETWORK) {
if (::strcmp(key, "Address") == 0)
m_xlxNetworkAddress = value;
else if (::strcmp(key, "Port") == 0)
m_xlxNetworkPort = (unsigned int)::atoi(value);
else if (::strcmp(key, "Local") == 0)
m_xlxNetworkLocal = (unsigned int)::atoi(value);
else if (::strcmp(key, "Password") == 0)
m_xlxNetworkPassword = value;
else if (::strcmp(key, "Options") == 0)
m_xlxNetworkOptions = value;
else if (::strcmp(key, "Debug") == 0)
m_xlxNetworkDebug = ::atoi(value) == 1;
} else if (section == SECTION_DMR_NETWORK) {
2017-04-28 17:45:05 +02:00
if (::strcmp(key, "Address") == 0)
m_dmrNetworkAddress = value;
else if (::strcmp(key, "Port") == 0)
m_dmrNetworkPort = (unsigned int)::atoi(value);
else if (::strcmp(key, "Local") == 0)
m_dmrNetworkLocal = (unsigned int)::atoi(value);
else if (::strcmp(key, "Password") == 0)
m_dmrNetworkPassword = value;
else if (::strcmp(key, "Debug") == 0)
m_dmrNetworkDebug = ::atoi(value) == 1;
}
}
2017-04-20 21:51:30 +02:00
2017-04-28 17:45:05 +02:00
::fclose(fp);
2017-04-20 21:51:30 +02:00
2017-04-28 17:45:05 +02:00
return true;
2017-04-20 21:51:30 +02:00
}
bool CConf::getDaemon() const
{
return m_daemon;
}
unsigned int CConf::getXLXSlot() const
{
return m_xlxSlot;
}
2017-04-28 17:45:05 +02:00
unsigned int CConf::getXLXTG() const
{
return m_xlxTG;
}
2017-04-23 21:17:25 +02:00
std::string CConf::getRptAddress() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_rptAddress;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
unsigned int CConf::getRptPort() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_rptPort;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
std::string CConf::getLocalAddress() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_localAddress;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
unsigned int CConf::getLocalPort() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_localPort;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
unsigned int CConf::getTimeout() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_timeout;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
bool CConf::getDebug() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_debug;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
unsigned int CConf::getLogDisplayLevel() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_logDisplayLevel;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
unsigned int CConf::getLogFileLevel() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_logFileLevel;
2017-04-20 21:51:30 +02:00
}
2017-04-23 21:17:25 +02:00
std::string CConf::getLogFilePath() const
2017-04-20 21:51:30 +02:00
{
2017-04-23 21:17:25 +02:00
return m_logFilePath;
}
std::string CConf::getLogFileRoot() const
{
return m_logFileRoot;
2017-04-20 21:51:30 +02:00
}
std::string CConf::getXLXNetworkAddress() const
{
return m_xlxNetworkAddress;
}
unsigned int CConf::getXLXNetworkPort() const
{
return m_xlxNetworkPort;
}
unsigned int CConf::getXLXNetworkLocal() const
{
return m_xlxNetworkLocal;
}
std::string CConf::getXLXNetworkPassword() const
{
return m_xlxNetworkPassword;
}
std::string CConf::getXLXNetworkOptions() const
{
return m_xlxNetworkOptions;
}
bool CConf::getXLXNetworkDebug() const
{
return m_xlxNetworkDebug;
}
std::string CConf::getDMRNetworkAddress() const
{
return m_dmrNetworkAddress;
}
unsigned int CConf::getDMRNetworkPort() const
{
return m_dmrNetworkPort;
}
unsigned int CConf::getDMRNetworkLocal() const
{
return m_dmrNetworkLocal;
}
std::string CConf::getDMRNetworkPassword() const
{
return m_dmrNetworkPassword;
}
bool CConf::getDMRNetworkDebug() const
{
return m_dmrNetworkDebug;
}