2010-01-04 20:49:22 +00:00
|
|
|
/*
|
|
|
|
* FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
|
|
|
* Copyright (C) 2005-2009, Anthony Minessale II <anthm@freeswitch.org>
|
|
|
|
*
|
|
|
|
* Version: MPL 1.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Anthony Minessale II <anthm@freeswitch.org>
|
|
|
|
* Portions created by the Initial Developer are Copyright (C)
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Joao Mesquita <jmesquita@freeswitch.org>
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Module to load configurations from Qt preference system QSettings
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#include <QString>
|
|
|
|
#include <QtGui>
|
|
|
|
#include <QDir>
|
2010-01-14 02:32:20 +00:00
|
|
|
#include <QXmlStreamWriter>
|
2010-01-04 20:49:22 +00:00
|
|
|
#include "mod_qsettings/mod_qsettings.h"
|
|
|
|
|
|
|
|
switch_xml_t XMLBinding::getConfigXML(QString tmpl)
|
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->beginGroup("FreeSWITCH/conf");
|
|
|
|
if (!_settings->childGroups().contains(tmpl))
|
2010-01-04 20:49:22 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->endGroup();
|
2010-01-04 20:49:22 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->beginGroup(tmpl);
|
2010-01-04 20:49:22 +00:00
|
|
|
|
2010-01-14 02:32:20 +00:00
|
|
|
QByteArray *finalXML = new QByteArray();
|
|
|
|
QXmlStreamWriter streamWriter(finalXML);
|
2010-01-05 22:16:46 +00:00
|
|
|
|
2010-01-14 02:32:20 +00:00
|
|
|
streamWriter.setAutoFormatting(true);
|
|
|
|
streamWriter.writeStartElement("document");
|
|
|
|
streamWriter.writeAttribute("type", "freeswitch/xml");
|
|
|
|
|
|
|
|
streamWriter.writeStartElement("section");
|
|
|
|
streamWriter.writeAttribute("name", "configuration");
|
|
|
|
|
|
|
|
streamWriter.writeStartElement("configuration");
|
|
|
|
streamWriter.writeAttribute("name", tmpl);
|
|
|
|
streamWriter.writeAttribute("description", "Configuration generated by QSettings");
|
|
|
|
|
|
|
|
foreach (QString group, _settings->childGroups())
|
2010-01-04 20:49:22 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
parseGroup(&streamWriter, group);
|
2010-01-04 20:49:22 +00:00
|
|
|
}
|
2010-01-14 02:32:20 +00:00
|
|
|
|
|
|
|
streamWriter.writeEndElement();
|
|
|
|
streamWriter.writeEndElement();
|
|
|
|
streamWriter.writeEndElement();
|
|
|
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Config for %s requested. Providing the following XML:\n%s\n",
|
|
|
|
tmpl.toAscii().constData(), finalXML->data());
|
|
|
|
|
2010-01-05 22:16:46 +00:00
|
|
|
_settings->endGroup();
|
|
|
|
_settings->endGroup();
|
2010-01-04 20:49:22 +00:00
|
|
|
|
2010-01-14 02:32:20 +00:00
|
|
|
return switch_xml_parse_str(finalXML->data(), strlen(finalXML->data()));
|
2010-01-04 20:49:22 +00:00
|
|
|
}
|
|
|
|
|
2010-01-14 02:32:20 +00:00
|
|
|
void XMLBinding::parseGroup(QXmlStreamWriter *streamWriter, QString group)
|
2010-01-11 04:40:39 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
if (group == "attrs")
|
2010-01-11 04:40:39 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->beginGroup(group);
|
|
|
|
foreach (QString k, _settings->childKeys())
|
2010-01-11 04:40:39 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
streamWriter->writeAttribute(k, _settings->value(k).toString());
|
2010-01-11 04:40:39 +00:00
|
|
|
}
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->endGroup();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2010-01-14 03:25:27 +00:00
|
|
|
if (group == "params" || group == "customParams")
|
2010-01-14 02:32:20 +00:00
|
|
|
{
|
|
|
|
_settings->beginGroup(group);
|
|
|
|
foreach(QString param, _settings->childKeys())
|
2010-01-11 04:40:39 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
streamWriter->writeStartElement("param");
|
|
|
|
streamWriter->writeAttribute("name", param);
|
|
|
|
streamWriter->writeAttribute("value", _settings->value(param).toString());
|
|
|
|
streamWriter->writeEndElement();
|
2010-01-11 04:40:39 +00:00
|
|
|
}
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->endGroup();
|
|
|
|
return;
|
|
|
|
}
|
2010-01-11 04:40:39 +00:00
|
|
|
|
2010-01-14 02:32:20 +00:00
|
|
|
if (group == "gateways")
|
|
|
|
{
|
|
|
|
streamWriter->writeStartElement(group);
|
|
|
|
_settings->beginGroup(group);
|
|
|
|
foreach (QString gw, _settings->childGroups())
|
2010-01-11 04:40:39 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->beginGroup(gw);
|
|
|
|
foreach(QString g, _settings->childGroups())
|
2010-01-11 04:40:39 +00:00
|
|
|
{
|
2010-01-14 02:32:20 +00:00
|
|
|
parseGroup(streamWriter, g);
|
2010-01-11 04:40:39 +00:00
|
|
|
}
|
|
|
|
_settings->endGroup();
|
|
|
|
}
|
|
|
|
_settings->endGroup();
|
2010-01-14 02:32:20 +00:00
|
|
|
streamWriter->writeEndElement();
|
|
|
|
return;
|
2010-01-11 04:40:39 +00:00
|
|
|
}
|
|
|
|
|
2010-01-14 02:32:20 +00:00
|
|
|
_settings->beginGroup(group);
|
|
|
|
streamWriter->writeStartElement(group);
|
|
|
|
|
|
|
|
foreach (QString group2, _settings->childGroups())
|
|
|
|
{
|
|
|
|
parseGroup(streamWriter, group2);
|
|
|
|
}
|
|
|
|
|
|
|
|
streamWriter->writeEndElement();
|
|
|
|
_settings->endGroup();
|
2010-01-11 04:40:39 +00:00
|
|
|
}
|
|
|
|
|
2010-01-04 20:49:22 +00:00
|
|
|
static switch_xml_t xml_url_fetch(const char *section, const char *tag_name, const char *key_name, const char *key_value, switch_event_t *params,
|
|
|
|
void *user_data)
|
|
|
|
{
|
|
|
|
XMLBinding *binding = (XMLBinding *) user_data;
|
|
|
|
|
2010-01-05 04:57:25 +00:00
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "We are being requested -> section: %s | tag_name: %s | key_name: %s | key_value: %s!\n",
|
|
|
|
section, tag_name, key_name, key_value);
|
2010-01-04 20:49:22 +00:00
|
|
|
if (!binding) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return binding->getConfigXML(key_value);
|
|
|
|
}
|
|
|
|
|
|
|
|
static switch_status_t do_config(void)
|
|
|
|
{
|
|
|
|
char *cf = "qsettings.conf";
|
|
|
|
switch_xml_t cfg, xml, bindings_tag;
|
|
|
|
XMLBinding *binding = NULL;
|
|
|
|
|
|
|
|
if (!(xml = switch_xml_open_cfg(cf, &cfg, NULL))) {
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "open of %s failed\n", cf);
|
|
|
|
return SWITCH_STATUS_TERM;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(bindings_tag = switch_xml_child(cfg, "bindings"))) {
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Missing <bindings> tag!\n");
|
|
|
|
switch_xml_free(xml);
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
QString bind_mask = switch_xml_attr_soft(bindings_tag, "value");
|
|
|
|
if (!bind_mask.isEmpty())
|
|
|
|
{
|
|
|
|
binding = new XMLBinding(bind_mask);
|
|
|
|
}
|
|
|
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "Binding XML Fetch Function [%s]\n",
|
|
|
|
binding->getBinding().isEmpty() ? "all" : binding->getBinding().toAscii().constData());
|
|
|
|
switch_xml_bind_search_function(xml_url_fetch, switch_xml_parse_section_string(binding->getBinding().toAscii().constData()), binding);
|
|
|
|
binding = NULL;
|
|
|
|
|
|
|
|
switch_xml_free(xml);
|
2010-01-18 04:21:46 +00:00
|
|
|
|
|
|
|
QSettings settings;
|
|
|
|
if (!settings.allKeys().contains("FreeSWITCH/conf"))
|
|
|
|
setQSettingsDefaults();
|
|
|
|
setGlobals();
|
|
|
|
|
2010-01-04 20:49:22 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2010-01-18 04:21:46 +00:00
|
|
|
void setQSettingsDefaults()
|
|
|
|
{
|
|
|
|
QSettings settings;
|
|
|
|
settings.beginGroup("FreeSWITCH/conf");
|
|
|
|
|
|
|
|
/* Globals config */
|
|
|
|
/* Sofia config */
|
|
|
|
settings.beginGroup("sofia.conf");
|
|
|
|
|
|
|
|
/* General Settings */
|
|
|
|
settings.beginGroup("global_settings/params");
|
|
|
|
settings.setValue("log-level", 0);
|
|
|
|
settings.setValue("auto-restart", "true");
|
|
|
|
settings.setValue("debug-presence", 0);
|
|
|
|
settings.endGroup();
|
|
|
|
|
|
|
|
/* Profile settings */
|
|
|
|
settings.beginGroup("profiles");
|
|
|
|
settings.beginGroup("profile");
|
|
|
|
|
|
|
|
settings.beginGroup("attrs");
|
|
|
|
settings.setValue("name", "softphone");
|
|
|
|
settings.endGroup();
|
|
|
|
|
|
|
|
settings.beginGroup("settings/params");
|
|
|
|
settings.setValue("user-agent-string", "FreeSWITCH/FSComm");
|
|
|
|
settings.setValue("debug", 0);
|
|
|
|
settings.setValue("sip-trace", "no");
|
|
|
|
settings.setValue("context", "public");
|
|
|
|
settings.setValue("rfc2833-pt", 101);
|
|
|
|
settings.setValue("sip-port", 12345);
|
|
|
|
settings.setValue("dialplan", "XML");
|
|
|
|
settings.setValue("dtmf-duration", 100);
|
|
|
|
settings.setValue("codec-prefs", "CELT@48000h,G7221@32000h,G7221@16000h,G722,PCMU,PCMA,GSM");
|
|
|
|
settings.setValue("use-rtp-timer", "true");
|
|
|
|
settings.setValue("rtp-timer-name", "soft");
|
|
|
|
settings.setValue("rtp-ip", "auto");
|
|
|
|
settings.setValue("sip-ip", "auto");
|
|
|
|
settings.setValue("hold-music", "local_stream://moh");
|
|
|
|
settings.setValue("apply-nat-acl", "rfc1918");
|
|
|
|
settings.setValue("manage-presence", "false");
|
|
|
|
settings.setValue("max-proceeding", 3);
|
|
|
|
settings.setValue("inbound-codec-negotiation", "generous");
|
|
|
|
settings.setValue("nonce-ttl", 60);
|
|
|
|
settings.setValue("auth-calls", "false");
|
|
|
|
settings.setValue("auth-all-packets", "false");
|
|
|
|
settings.setValue("ext-rtp-ip", "stun:stun.freeswitch.org");
|
|
|
|
settings.setValue("ext-sip-ip", "stun:stun.freeswitch.org");
|
|
|
|
settings.setValue("rtp-timeout-sec", 300);
|
|
|
|
settings.setValue("rtp-hold-timeout-sec", 1800);
|
|
|
|
settings.setValue("disable-register", "true");
|
|
|
|
settings.setValue("challenge-realm", "auto_from");
|
|
|
|
settings.endGroup();
|
|
|
|
|
|
|
|
settings.endGroup();
|
|
|
|
settings.endGroup();
|
|
|
|
settings.endGroup();
|
|
|
|
|
|
|
|
/* PortAudio config */
|
|
|
|
settings.beginGroup("portaudio.conf/settings/params");
|
|
|
|
settings.setValue("cid-name", "FSComm");
|
|
|
|
settings.setValue("cid-num", "00000000");
|
|
|
|
settings.setValue("ring-file", "tone_stream://%(2000,4000,440.0,480.0);loops=20");
|
|
|
|
settings.setValue("dialplan", "XML");
|
|
|
|
settings.setValue("ring-interval", 5);
|
|
|
|
settings.setValue("hold-file", "local_stream://moh");
|
|
|
|
settings.setValue("sample-rate", 48000);
|
|
|
|
settings.setValue("codec-ms", 10);
|
|
|
|
settings.setValue("indev", "");
|
|
|
|
settings.setValue("outdev", "");
|
|
|
|
settings.setValue("ringdev", "");
|
|
|
|
settings.endGroup();
|
|
|
|
|
|
|
|
/* Finish configs */
|
|
|
|
settings.endGroup();
|
|
|
|
}
|
|
|
|
|
|
|
|
void setGlobals()
|
|
|
|
{
|
|
|
|
QSettings settings;
|
|
|
|
settings.beginGroup("FreeSWITCH/conf/globals");
|
|
|
|
foreach (QString k, settings.childKeys())
|
|
|
|
{
|
|
|
|
switch_core_set_variable(k.toAscii().data(), settings.value(k).toByteArray().data());
|
|
|
|
}
|
|
|
|
settings.endGroup();
|
|
|
|
}
|
|
|
|
|
2010-01-05 18:49:08 +00:00
|
|
|
switch_status_t mod_qsettings_load(void)
|
2010-01-04 20:49:22 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
if (do_config() == SWITCH_STATUS_SUCCESS) {
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "Sucessfully configured.\n");
|
|
|
|
} else {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "We loaded mod_qsettings.\n");
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|