Rivendellaudio/lib/rdsystem.cpp
Fred Gleason deb363f6eb 2020-11-22 Fred Gleason <fredg@paravelsystems.com>
* Added a 'SYSTEM.ORIGIN_EMAIL_ADDRESS' field to the database.
	* Added a 'GROUPS.NOTIFY_EMAIL_ADDRESS' field to the database.
	* Incremented the database version to 344.
	* Added an 'Origin E-Mail Address' control to the 'System-Wide
	Settings' dialog in rdadmin(1).
	* Added a 'Notification E-Mail Addresses' control to the 'Group'
	dialog in rdadmin(1).

Signed-off-by: Fred Gleason <fredg@paravelsystems.com>
2020-11-22 13:58:59 -05:00

267 lines
5.1 KiB
C++

// rdsystem.cpp
//
// System-wide Rivendell settings
//
// (C) Copyright 2009,2016 Fred Gleason <fredg@paravelsystems.com>
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License version 2 as
// published by the Free Software Foundation.
//
// 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 "rd.h"
#include "rddb.h"
#include "rdconf.h"
#include "rdescape_string.h"
#include "rdsystem.h"
#include "rdweb.h"
RDSystem::RDSystem()
{
}
unsigned RDSystem::sampleRate() const
{
return GetValue("SAMPLE_RATE").toUInt();
}
void RDSystem::setSampleRate(unsigned rate) const
{
SetRow("SAMPLE_RATE",rate);
}
bool RDSystem::allowDuplicateCartTitles() const
{
bool ret=false;
QString sql;
RDSqlQuery *q;
sql="select DUP_CART_TITLES from SYSTEM";
q=new RDSqlQuery(sql);
if(q->first()) {
ret=RDBool(q->value(0).toString());
}
delete q;
return ret;
}
void RDSystem::setAllowDuplicateCartTitles(bool state) const
{
QString sql;
RDSqlQuery *q;
sql=QString("update SYSTEM set ")+
"DUP_CART_TITLES=\""+RDYesNo(state)+"\"";
q=new RDSqlQuery(sql);
delete q;
}
bool RDSystem::fixDuplicateCartTitles() const
{
bool ret=false;
QString sql;
RDSqlQuery *q;
sql="select FIX_DUP_CART_TITLES from SYSTEM";
q=new RDSqlQuery(sql);
if(q->first()) {
ret=RDBool(q->value(0).toString());
}
delete q;
return ret;
}
void RDSystem::setFixDuplicateCartTitles(bool state) const
{
QString sql;
RDSqlQuery *q;
sql=QString("update SYSTEM set ")+
"FIX_DUP_CART_TITLES=\""+RDYesNo(state)+"\"";
q=new RDSqlQuery(sql);
delete q;
}
unsigned RDSystem::maxPostLength() const
{
unsigned ret;
QString sql="select MAX_POST_LENGTH from SYSTEM";
RDSqlQuery *q=new RDSqlQuery(sql);
if(q->first()) {
ret=q->value(0).toUInt();
}
else {
ret=RD_DEFAULT_MAX_POST_LENGTH;
}
delete q;
return ret;
}
void RDSystem::setMaxPostLength(unsigned bytes) const
{
QString sql=QString().sprintf("update SYSTEM set MAX_POST_LENGTH=%u",bytes);
RDSqlQuery *q=new RDSqlQuery(sql);
delete q;
}
QString RDSystem::isciXreferencePath() const
{
return GetValue("ISCI_XREFERENCE_PATH").toString();
}
void RDSystem::setIsciXreferencePath(const QString &str) const
{
SetRow("ISCI_XREFERENCE_PATH",str);
}
QString RDSystem::originEmailAddress() const
{
return GetValue("ORIGIN_EMAIL_ADDRESS").toString();
}
void RDSystem::setOriginEmailAddress(const QString &str) const
{
SetRow("ORIGIN_EMAIL_ADDRESS",str);
}
QString RDSystem::tempCartGroup() const
{
return GetValue("TEMP_CART_GROUP").toString();
}
void RDSystem::setTempCartGroup(const QString &str) const
{
SetRow("TEMP_CART_GROUP",str);
}
bool RDSystem::showUserList() const
{
bool ret=false;
QString sql;
RDSqlQuery *q;
sql="select SHOW_USER_LIST from SYSTEM";
q=new RDSqlQuery(sql);
if(q->first()) {
ret=RDBool(q->value(0).toString());
}
delete q;
return ret;
}
void RDSystem::setShowUserList(bool state) const
{
QString sql;
RDSqlQuery *q;
sql=QString("update SYSTEM set ")+
"SHOW_USER_LIST=\""+RDYesNo(state)+"\"";
q=new RDSqlQuery(sql);
delete q;
}
QHostAddress RDSystem::notificationAddress() const
{
return QHostAddress(GetValue("NOTIFICATION_ADDRESS").toString());
}
void RDSystem::setNotificationAddress(const QHostAddress &addr)
{
SetRow("NOTIFICATION_ADDRESS",addr.toString());
}
QString RDSystem::rssProcessorStation() const
{
return GetValue("RSS_PROCESSOR_STATION").toString();
}
void RDSystem::setRssProcessorStation(const QString &str) const
{
SetRow("RSS_PROCESSOR_STATION",str);
}
QString RDSystem::xml() const
{
QString xml="<systemSettings>\n";
xml+=RDXmlField("sampleRate",sampleRate());
xml+=RDXmlField("duplicateTitles",allowDuplicateCartTitles());
xml+=RDXmlField("fixDuplicateTitles",fixDuplicateCartTitles());
xml+=RDXmlField("maxPostLength",maxPostLength());
xml+=RDXmlField("isciXreferencePath",isciXreferencePath());
xml+=RDXmlField("tempCartGroup",tempCartGroup());
xml+="</systemSettings>\n";
return xml;
}
QVariant RDSystem::GetValue(const QString &field) const
{
QVariant ret;
QString sql=QString("select ")+
field+" from SYSTEM";
RDSqlQuery *q=new RDSqlQuery(sql);
if(q->first()) {
ret=q->value(0);
}
delete q;
return ret;
}
void RDSystem::SetRow(const QString &param,QString value) const
{
QString sql;
if(value.isNull()) {
sql=QString("update SYSTEM set ")+
param+"=NULL";
}
else {
sql=QString("update SYSTEM set ")+
param+"=\""+RDEscapeString(value)+"\"";
}
RDSqlQuery::apply(sql);
}
void RDSystem::SetRow(const QString &param,int value) const
{
QString sql;
sql=QString("update SYSTEM set ")+
param+QString().sprintf("=%d",value);
RDSqlQuery::apply(sql);
}