kdeconnect-kde/core/backends/loopback/loopbackpairinghandler.cpp

72 lines
2.6 KiB
C++
Raw Normal View History

2015-09-14 12:06:04 +01:00
/**
* Copyright 2015 Vineet Garg <grg.vineet@gmail.com>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License or (at your option) version 3 or any later version
* accepted by the membership of KDE e.V. (or its successor approved
* by the membership of KDE e.V.), which shall act as a proxy
* defined in Section 14 of version 3 of the license.
*
* 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, see <http://www.gnu.org/licenses/>.
*/
#include <KLocalizedString>
#include "core_debug.h"
#include "daemon.h"
#include "kdeconnectconfig.h"
#include "loopbackdevicelink.h"
#include "loopbackpairinghandler.h"
#include "networkpackagetypes.h"
2015-11-30 18:36:01 +00:00
LoopbackPairingHandler::LoopbackPairingHandler(const QString& deviceId)
: LanPairingHandler(deviceId)
2015-09-14 12:06:04 +01:00
{
2015-11-30 18:36:01 +00:00
}
2015-09-14 12:06:04 +01:00
bool LoopbackPairingHandler::requestPairing()
{
2015-11-30 18:36:01 +00:00
switch (pairStatus()) {
2015-09-14 12:06:04 +01:00
case PairStatus::Paired:
2015-11-30 18:36:01 +00:00
Q_EMIT pairingFailed(deviceLink()->name().append(" : Already paired").toLatin1().data());
2015-09-14 12:06:04 +01:00
return false;
2015-12-01 18:45:14 +00:00
case PairStatus::Requested:
2015-11-30 18:36:01 +00:00
Q_EMIT pairingFailed(deviceLink()->name().append(" : Pairing already requested for this device").toLatin1().data());
2015-09-14 12:06:04 +01:00
return false;
2015-12-01 18:45:14 +00:00
case PairStatus::RequestedByPeer:
2015-11-30 18:36:01 +00:00
qCDebug(KDECONNECT_CORE) << deviceLink()->name() << " : Pairing already started by the other end, accepting their request.";
2015-09-14 12:06:04 +01:00
acceptPairing();
return false;
case PairStatus::NotPaired:
;
}
NetworkPackage np(PACKAGE_TYPE_PAIR);
createPairPackage(np);
2015-11-30 18:36:01 +00:00
setPairStatus(PairStatus::Requested);
2015-09-14 12:06:04 +01:00
m_pairingTimeout.start();
2015-11-30 18:36:01 +00:00
bool success = deviceLink()->sendPackage(np);
2015-09-14 12:06:04 +01:00
return success;
}
bool LoopbackPairingHandler::acceptPairing()
{
NetworkPackage np(PACKAGE_TYPE_PAIR);
createPairPackage(np);
2015-11-30 18:36:01 +00:00
setPairStatus(PairStatus::Paired);
bool success = deviceLink()->sendPackage(np);
KdeConnectConfig::instance()->setDeviceProperty(m_deviceId, "publicKey", QString::fromLatin1(KdeConnectConfig::instance()->certificate().toPem()));
KdeConnectConfig::instance()->setDeviceProperty(m_deviceId, "certificate", QString::fromLatin1(KdeConnectConfig::instance()->certificate().toPem()));
2015-09-14 12:06:04 +01:00
return success;
}