#include <QtCore/QDebug>
#include <QtCore/QTimer>
+#include <QtCore/QDateTime>
#include "calllistener.h"
#include "settings.h"
#include "cache.h"
const QString CALL_SIGNAL_INCOMING = "Coming";
const QString CALL_SIGNAL_RELEASE = "Release";
const QString CALL_SIGNAL_TERMINATED = "Terminated";
+ const QString CALL_SIGNAL_ANSWERED = "AudioConnect";
}
QDBusConnection CallListener::systemBus_ = QDBusConnection::systemBus();
CallListener::CallListener(): source_(0),
closeConnection_(false), initialized_(false), box_(0), label_(0),
-retries_(-1), timer_(0)
+retries_(-1), timer_(0), currentCall_(0), ignoreFirstZero_(false)
{
}
CallListener::~CallListener()
{
end();
+ DB::removeDatabase();
}
bool CallListener::begin()
}
sourceId_ = Source::stringToId(Settings::instance()->get("source"));
+ QMap<QString, QString> tmpConfig;
SourceCoreConfig* config = SourceCoreConfig::getCoreConfig(sourceId_);
- config->getConfig(sourceConfig_);
+ config->getConfig(tmpConfig);
+ sourceConfig_ = tmpConfig;
delete config;
+ ignoreFirstZero_ = (Settings::instance()->get("ignore_first_zero") == "1");
+
systemBus_.connect(CALL_SERVICE_NAME,
CALL_SERVICE_PATH,
CALL_SERVICE_INTERFACE,
void CallListener::search(Source::SearchDetails const& details)
{
- qDebug() << "Search called";
+ if(currentCall_)
+ {
+ delete currentCall_;
+ }
+
+ currentCall_ = new CallDetails;
+ currentCall_->number = details.query;
+ currentCall_->time = QDateTime::currentDateTime().toTime_t();
+ currentCall_->answered = false;
searchInit();
showDelayedResult(createResult(result.name,
result.street,
result.city), BANNER_DELAY);
+
+ currentCall_->result = result;
}
else
{
retries_ = 0;
- currentSearch_ = details.query;
if(!handleConnection())
{
showDelayedResult(tr("Searching..."), BANNER_DELAY);
- qDebug() << "Starting to search...";
-
source_->search(details);
}
Source::SearchDetails const& details,
bool error)
{
- if(closeConnection_)
+ /*if(closeConnection_)
{
closeConnection_ = false;
ConnectionManager cm;
cm.disconnect(true);
- }
+ }*/
+
+ qDebug() << "Request finished";
// If box is not visible, the call must have been terminated already
- if(!initialized_ || !box_->isVisible())
+ if(!initialized_ || !box_->isVisible() || !currentCall_)
{
return;
}
if(retries_ < SEARCH_RETRIES && retries_ >= 0)
{
retries_++;
- source_->search(Source::SearchDetails(currentSearch_));
+ source_->search(Source::SearchDetails(currentCall_->number, "", Source::BOTH));
return;
}
else
Source::Result result = results.at(0);
result.number = details.query;
Cache::instance().addItem(result);
+ currentCall_->result = results.at(0);
}
}
retries_ = -1;
- currentSearch_ = "";
}
QString CallListener::createResult(QString const& name, QString const& street, QString const& city)
void CallListener::incomingCall(QDBusObjectPath path, QString number)
{
+ if(number.isEmpty())
+ {
+ qDebug() << "Unknown caller without number";
+ return;
+ }
+
+ // If the call has come through some kind of switch board
+ // there might be a leading zero added
+ if(ignoreFirstZero_)
+ {
+ number = number.replace(QRegExp("^00"), "0");
+ }
+
ContactManager cm;
if(!cm.numberExists(number))
{
- qDebug() << "Number doesn't exist";
+ qDebug() << "Number doesn't exist: " << number;
systemBus_.connect(CALL_SERVICE_NAME,
path.path(),
this,
SLOT(callTerminate()));
- search(Source::SearchDetails(number));
+ systemBus_.connect(CALL_SERVICE_NAME,
+ path.path(),
+ CALL_SERVICE_INSTANCE_NAME,
+ CALL_SIGNAL_ANSWERED,
+ this,
+ SLOT(handleAnswer()));
+
+ search(Source::SearchDetails(number, "", Source::BOTH));
}
else
{
- qDebug() << "Number exists";
+ qDebug() << "Number exists: " << number;
}
}
{
if(box_ && box_->isVisible())
{
- box_->close();
+ box_->hide();
+ }
+
+ if(currentCall_)
+ {
+ currentCall_->result.number = currentCall_->number;
+ Cache::instance().logItem(currentCall_->result, !currentCall_->answered, currentCall_->time);
+ delete currentCall_;
+ currentCall_ = 0;
}
searchClose();
}
+void CallListener::handleAnswer()
+{
+ qDebug() << "Answered";
+
+ if(currentCall_)
+ {
+ currentCall_->answered = true;
+ }
+}
+
void CallListener::showDelayedResult(QString const& text, int delay)
{
timedMessage_ = text;
void CallListener::searchClose()
{
+ if(!initialized_)
+ {
+ return;
+ }
+
initialized_ = false;
qDebug() << "Closing search...";
if(closeConnection_)
{
+ QTimer::singleShot(500, this, SLOT(closeConnection()));
+ }
+}
+
+void CallListener::closeConnection()
+{
+ if(closeConnection_)
+ {
closeConnection_ = false;
ConnectionManager cm;
cm.disconnect(true);
if(cm.isConnected())
{
+ cm.connect();
closeConnection_ = false;
return true;
}
return false;
}
- qDebug() << "Connecting to " << best.name;
+ qDebug() << "Connecting to " << best.name << " (" << best.id << ")";
if(cm.connect(best.id))
{
if(retries < CONNECT_RETRIES)
{
- sendRetrySignal(best.id, initialized_);
+ sendRetrySignal(best.id, false);
+ sleep(WAIT_BETWEEN_RETRIES);
}
}
void CallListener::sendRetrySignal(QString const& iap, bool retry)
{
- QDBusMessage msg = QDBusMessage::createSignal("/com/nokia/icd_ui",
+ QDBusMessage msg = QDBusMessage::createSignal("/com/nokia/icd_ui",
"com.nokia.icd_ui",
"retry");