2009-09-02 02:21:41 +00:00
|
|
|
/*
|
|
|
|
* Copyright © 2009 Rob Scheepmaker <r.scheepmaker@student.utwente.nl>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Library 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 Library General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2009-09-02 02:27:16 +00:00
|
|
|
#include "remoteservicejob_p.h"
|
|
|
|
|
2009-10-20 19:15:32 +00:00
|
|
|
#include <kconfiggroup.h>
|
2009-09-02 06:28:32 +00:00
|
|
|
#include <kurl.h>
|
2009-09-02 02:21:41 +00:00
|
|
|
|
2009-09-02 02:27:16 +00:00
|
|
|
#include <QtCore/QBuffer>
|
2009-09-02 02:21:41 +00:00
|
|
|
#include <QtJolie/Client>
|
2009-09-02 02:27:16 +00:00
|
|
|
#include <QtJolie/Message>
|
|
|
|
#include <QtJolie/PendingCallWatcher>
|
|
|
|
#include <QtJolie/PendingReply>
|
2009-09-02 02:21:41 +00:00
|
|
|
|
|
|
|
#include "../servicejob.h"
|
2009-09-03 21:10:33 +00:00
|
|
|
#include "../remote/accessmanager.h"
|
|
|
|
#include "../remote/authorizationmanager.h"
|
2009-09-02 02:27:16 +00:00
|
|
|
#include "authorizationmanager_p.h"
|
|
|
|
#include "remoteservice_p.h"
|
2009-10-20 19:15:32 +00:00
|
|
|
#include "servicejob_p.h"
|
2009-09-02 02:27:16 +00:00
|
|
|
#include "joliemessagehelper_p.h"
|
|
|
|
#include <qtimer.h>
|
2009-09-02 02:21:41 +00:00
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
|
|
|
|
|
|
|
RemoteServiceJob::RemoteServiceJob(KUrl location,
|
2009-09-02 02:27:16 +00:00
|
|
|
const QString& destination,
|
2009-09-02 02:21:41 +00:00
|
|
|
const QString& operation,
|
2011-05-26 19:01:44 +02:00
|
|
|
QHash<QString,QVariant>& parameters,
|
2009-09-02 02:27:16 +00:00
|
|
|
QByteArray initialToken,
|
|
|
|
RemoteService* parent)
|
|
|
|
: ServiceJob(destination, operation, parameters, parent),
|
|
|
|
m_token(initialToken),
|
|
|
|
m_location(location),
|
2009-10-20 19:15:32 +00:00
|
|
|
m_service(parent),
|
|
|
|
m_delayedDesc(0)
|
2009-09-02 02:21:41 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-10-20 19:15:32 +00:00
|
|
|
RemoteServiceJob::~RemoteServiceJob()
|
|
|
|
{
|
|
|
|
delete m_delayedDesc;
|
|
|
|
m_delayedDesc = 0;
|
|
|
|
}
|
|
|
|
|
2009-09-02 02:21:41 +00:00
|
|
|
void RemoteServiceJob::start()
|
|
|
|
{
|
2009-09-02 02:27:16 +00:00
|
|
|
QTimer::singleShot(30000, this, SLOT(timeout()));
|
|
|
|
|
2009-10-20 18:23:32 +00:00
|
|
|
if (m_service->m_busy || !m_service->m_ready) {
|
2009-09-02 02:27:16 +00:00
|
|
|
//enqueue and wait
|
|
|
|
m_service->m_queue.enqueue(this);
|
2011-07-29 15:46:52 +02:00
|
|
|
#ifndef NDEBUG
|
2009-09-02 02:27:16 +00:00
|
|
|
kDebug() << "already busy... enqueue, queue contains " << m_service->m_queue.count();
|
2011-07-29 15:46:52 +02:00
|
|
|
#endif
|
2009-09-02 02:27:16 +00:00
|
|
|
return;
|
2009-10-20 18:23:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// the service is now busy ... with us!
|
|
|
|
m_service->m_busy = true;
|
|
|
|
|
|
|
|
// while waiting in the queue, our validity may have changed; it's all async
|
|
|
|
// so don't assume anything
|
|
|
|
checkValidity();
|
|
|
|
if (error()) {
|
|
|
|
emitResult();
|
|
|
|
return;
|
2009-09-02 02:27:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//serialize the parameters
|
|
|
|
QByteArray params;
|
|
|
|
QBuffer buffer(¶ms);
|
|
|
|
buffer.open(QIODevice::WriteOnly);
|
|
|
|
QDataStream out(&buffer);
|
|
|
|
out << parameters();
|
|
|
|
|
|
|
|
Jolie::Message message(m_location.path(KUrl::RemoveTrailingSlash).remove(0, 1).toUtf8(),
|
|
|
|
"startOperationCall");
|
|
|
|
Jolie::Value data;
|
2012-12-13 11:57:36 +01:00
|
|
|
data.children(JolieMessage::Field::OPERATION) << (Jolie::Value(operationName().toLatin1()));
|
2009-11-17 01:48:12 +00:00
|
|
|
data.children(JolieMessage::Field::PARAMETERS) << Jolie::Value(params);
|
2012-12-13 11:57:36 +01:00
|
|
|
data.children(JolieMessage::Field::DESTINATION) << Jolie::Value(destination().toLatin1());
|
2009-09-02 02:27:16 +00:00
|
|
|
message.setData(data);
|
|
|
|
|
2009-10-20 18:23:32 +00:00
|
|
|
Jolie::Client *client = m_service->m_client;
|
2009-09-02 02:27:16 +00:00
|
|
|
Jolie::PendingCall pendingReply = client->asyncCall(m_service->signMessage(message));
|
|
|
|
Jolie::PendingCallWatcher *watcher = new Jolie::PendingCallWatcher(pendingReply, this);
|
|
|
|
connect(watcher, SIGNAL(finished(Jolie::PendingCallWatcher*)),
|
|
|
|
this, SLOT(callCompleted(Jolie::PendingCallWatcher*)));
|
|
|
|
}
|
|
|
|
|
2009-10-20 19:15:32 +00:00
|
|
|
void RemoteServiceJob::setDelayedDescription(const KConfigGroup &desc)
|
|
|
|
{
|
|
|
|
if (!m_delayedDesc) {
|
|
|
|
m_delayedDesc = new KConfigGroup(desc);
|
|
|
|
} else {
|
|
|
|
*m_delayedDesc = desc;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-10-20 18:23:32 +00:00
|
|
|
void RemoteServiceJob::checkValidity()
|
|
|
|
{
|
|
|
|
if (!m_service->isOperationEnabled(operationName())) {
|
|
|
|
setError(-1);
|
2009-10-22 20:48:59 +00:00
|
|
|
setErrorText(i18n("Job no longer valid, operation is not enabled."));
|
2009-10-20 19:15:32 +00:00
|
|
|
} else if (m_delayedDesc) {
|
|
|
|
d->parameters = m_service->parametersFromDescription(*m_delayedDesc);
|
2009-10-20 18:23:32 +00:00
|
|
|
} else {
|
|
|
|
KConfigGroup description = m_service->operationDescription(operationName());
|
2011-05-26 19:01:44 +02:00
|
|
|
QHashIterator<QString, QVariant> param(parameters());
|
2009-10-20 18:23:32 +00:00
|
|
|
while (param.hasNext()) {
|
|
|
|
param.next();
|
|
|
|
if (!description.hasKey(param.key())) {
|
|
|
|
setError(-1);
|
|
|
|
setErrorText(i18n("Job no longer valid, invalid parameters."));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-10-20 19:15:32 +00:00
|
|
|
|
|
|
|
delete m_delayedDesc;
|
|
|
|
m_delayedDesc = 0;
|
2009-10-20 18:23:32 +00:00
|
|
|
}
|
|
|
|
|
2009-09-02 02:27:16 +00:00
|
|
|
void RemoteServiceJob::callCompleted(Jolie::PendingCallWatcher *watcher)
|
|
|
|
{
|
|
|
|
m_service->m_busy = false;
|
|
|
|
|
|
|
|
Jolie::PendingReply reply = *watcher;
|
|
|
|
Jolie::Message response = reply.reply();
|
|
|
|
|
2009-09-02 02:21:41 +00:00
|
|
|
//TODO:async
|
|
|
|
if (response.fault().isValid()) {
|
2011-07-29 15:46:52 +02:00
|
|
|
#ifndef NDEBUG
|
2009-09-02 02:27:16 +00:00
|
|
|
kDebug() << "fault: " << response.fault().name();
|
2011-07-29 15:46:52 +02:00
|
|
|
#endif
|
2009-09-02 02:27:16 +00:00
|
|
|
setError(-1);
|
2009-11-17 01:48:12 +00:00
|
|
|
setErrorText(JolieMessage::errorMessage(response.fault().name()));
|
2009-09-02 02:27:16 +00:00
|
|
|
emitResult();
|
2009-09-02 02:21:41 +00:00
|
|
|
return;
|
|
|
|
}
|
2009-09-02 02:27:16 +00:00
|
|
|
|
2009-11-17 01:48:12 +00:00
|
|
|
m_service->m_token = JolieMessage::field(JolieMessage::Field::TOKEN, response);
|
2009-09-02 02:27:16 +00:00
|
|
|
|
|
|
|
QVariant variantResult;
|
2009-11-17 01:48:12 +00:00
|
|
|
QByteArray byteArrayResult = JolieMessage::field(JolieMessage::Field::RESULT, response);
|
2009-09-02 02:27:16 +00:00
|
|
|
QBuffer buffer(&byteArrayResult);
|
|
|
|
buffer.open(QIODevice::ReadOnly);
|
|
|
|
QDataStream in(&buffer);
|
|
|
|
in >> variantResult;
|
|
|
|
|
|
|
|
setResult(variantResult);
|
2009-09-02 02:21:41 +00:00
|
|
|
}
|
|
|
|
|
2009-09-02 02:27:16 +00:00
|
|
|
void RemoteServiceJob::timeout()
|
|
|
|
{
|
|
|
|
m_service->m_busy = false;
|
2011-07-29 15:46:52 +02:00
|
|
|
#ifndef NDEBUG
|
2009-09-02 02:27:16 +00:00
|
|
|
kDebug() << "Service job timed out.";
|
2011-07-29 15:46:52 +02:00
|
|
|
#endif
|
2009-09-02 02:27:16 +00:00
|
|
|
setError(-1);
|
|
|
|
setErrorText(i18n("Timeout."));
|
2009-09-03 23:04:10 +00:00
|
|
|
m_service->m_queue.removeAll(this);
|
2009-09-02 02:27:16 +00:00
|
|
|
emitResult();
|
|
|
|
}
|
2009-09-02 02:21:41 +00:00
|
|
|
|
2009-09-02 02:27:16 +00:00
|
|
|
} // namespace Plasma
|