2010-01-04 15:49:22 -05: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>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "call.h"
|
2010-01-20 21:48:53 -05:00
|
|
|
#include <QtGui>
|
2010-01-14 22:30:11 -05:00
|
|
|
#include <fshost.h>
|
2010-01-04 15:49:22 -05:00
|
|
|
|
|
|
|
Call::Call()
|
2010-04-05 21:03:20 -04:00
|
|
|
{
|
|
|
|
_answeredEpoch = 0;
|
|
|
|
}
|
2010-01-17 21:43:48 -05:00
|
|
|
|
|
|
|
switch_status_t Call::toggleRecord(bool startRecord)
|
|
|
|
{
|
|
|
|
QDir conf_dir = QDir::home();
|
|
|
|
QString result;
|
|
|
|
switch_status_t status;
|
|
|
|
|
|
|
|
if (startRecord)
|
|
|
|
{
|
|
|
|
_recording_filename = QString("%1/.fscomm/recordings/%2_%3.wav").arg(
|
|
|
|
conf_dir.absolutePath(),
|
|
|
|
QDateTime::currentDateTime().toString("yyyyMMddhhmmss"),
|
2010-04-05 02:03:06 -04:00
|
|
|
getCidNumber());
|
|
|
|
status = g_FSHost.sendCmd("uuid_record", QString("%1 start %2").arg(getUuid(), _recording_filename).toAscii().data(),&result);
|
2010-01-17 21:43:48 -05:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Stopping call recording on call [%s]\n",
|
2010-04-05 02:03:06 -04:00
|
|
|
getUuid().toAscii().data());
|
|
|
|
status = g_FSHost.sendCmd("uuid_record", QString("%1 stop %2").arg(getUuid(), _recording_filename).toAscii().data(),&result);
|
2010-01-17 21:43:48 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
return status;
|
2010-01-04 15:49:22 -05:00
|
|
|
}
|
2010-01-20 21:48:53 -05:00
|
|
|
|
|
|
|
void Call::sendDTMF(QString digit)
|
|
|
|
{
|
|
|
|
QString result;
|
|
|
|
QString dtmf_string = QString("dtmf %1").arg(digit);
|
|
|
|
if (g_FSHost.sendCmd("pa", dtmf_string.toAscii(), &result) == SWITCH_STATUS_FALSE) {
|
2010-04-05 02:03:06 -04:00
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Could not send DTMF digit %s on call[%s]", digit.toAscii().data(), getUuid().toAscii().data());
|
2010-01-20 21:48:53 -05:00
|
|
|
QMessageBox::critical(0, QWidget::tr("DTMF Error"), QWidget::tr("There was an error sending DTMF, please report this bug."), QMessageBox::Ok);
|
|
|
|
}
|
|
|
|
}
|
2010-01-27 20:12:34 -05:00
|
|
|
|
|
|
|
QTime Call::getCurrentStateTime()
|
|
|
|
{
|
2010-04-05 21:03:20 -04:00
|
|
|
qulonglong time = 0;
|
|
|
|
|
|
|
|
if (_state == FSCOMM_CALL_STATE_ANSWERED)
|
|
|
|
{
|
|
|
|
time = _answeredEpoch;
|
|
|
|
}
|
|
|
|
else if(_state == FSCOMM_CALL_STATE_RINGING)
|
|
|
|
{
|
|
|
|
if (_direction == FSCOMM_CALL_DIRECTION_INBOUND)
|
|
|
|
{
|
|
|
|
/* TODO: DOESNT WORK - How do I get what time it started to ring? */
|
|
|
|
_channel.data()->getProgressEpoch() == 0 ? time = _channel.data()->getProgressMediaEpoch() : time = _channel.data()->getProgressEpoch();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
_otherLegChannel.data()->getProgressEpoch() == 0 ? time = _otherLegChannel.data()->getProgressMediaEpoch() : time = _otherLegChannel.data()->getProgressEpoch();
|
|
|
|
}
|
|
|
|
|
|
|
|
int now = QDateTime::fromTime_t(time).secsTo(QDateTime::currentDateTime());
|
2010-01-27 20:12:34 -05:00
|
|
|
return QTime::fromString(QString::number(now), "s");
|
|
|
|
}
|