2015-07-05 14:23:53 +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/>.
*/
# ifndef KDECONNECT_PAIRINGHANDLER_H
# define KDECONNECT_PAIRINGHANDLER_H
2015-07-25 12:45:19 +01:00
# include "networkpackage.h"
# include "devicelink.h"
2015-07-05 14:23:53 +01:00
2015-07-27 16:28:58 +01:00
# include <QTimer>
2015-08-11 04:34:02 +01:00
/*
* This class separates the pairing interface for each type of link .
* Since different links can pair via different methods , like for LanLink certificate and public key should be shared ,
* for Bluetooth link they should be paired via bluetooth etc .
* Each " Device " instance maintains a hash map for these pairing handlers so that there can be single pairing handler per
* per link type per device .
* Pairing handler keeps information about device , latest link , and pair status of the link
* During first pairing process , the pairing process is nearly same as old process .
* After that if any one of the link is paired , then we can say that device is paired , so new link will pair automatically
*/
2015-07-25 12:45:19 +01:00
class PairingHandler : public QObject
{
Q_OBJECT
2015-07-27 16:28:58 +01:00
2015-11-30 18:36:01 +00:00
public :
//TODO: Can we simplify this to just Paired/NotPaired, and leave the detailed status as an backend-specific thing?
2015-07-27 16:28:58 +01:00
enum PairStatus {
NotPaired ,
Requested ,
RequestedByPeer ,
Paired ,
} ;
2015-11-30 18:36:01 +00:00
PairingHandler ( ) ;
2015-07-05 14:23:53 +01:00
virtual ~ PairingHandler ( ) { }
2015-07-27 16:28:58 +01:00
void setLink ( DeviceLink * dl ) ;
2015-11-30 18:36:01 +00:00
bool isPaired ( ) const { return m_pairStatus = = PairStatus : : Paired ; }
bool isPairRequested ( ) const { return m_pairStatus = = PairStatus : : Requested ; }
2015-07-27 16:28:58 +01:00
2015-07-14 13:04:04 +01:00
virtual void createPairPackage ( NetworkPackage & np ) = 0 ;
2015-07-27 16:28:58 +01:00
virtual void packageReceived ( const NetworkPackage & np ) = 0 ;
2015-07-25 12:45:19 +01:00
virtual bool requestPairing ( ) = 0 ;
virtual bool acceptPairing ( ) = 0 ;
virtual void rejectPairing ( ) = 0 ;
virtual void unpair ( ) = 0 ;
2015-11-30 18:36:01 +00:00
protected :
DeviceLink * deviceLink ( ) const ;
void setPairStatus ( PairStatus status ) ;
PairStatus pairStatus ( ) const ;
2015-07-25 12:45:19 +01:00
public Q_SLOTS :
void linkDestroyed ( QObject * ) ;
2015-07-27 16:28:58 +01:00
virtual void pairingTimeout ( ) = 0 ;
2015-11-30 18:36:01 +00:00
Q_SIGNALS :
void pairStatusChanged ( PairStatus status , PairStatus previousStatus ) ;
2015-07-27 16:28:58 +01:00
private :
2015-11-30 18:36:01 +00:00
DeviceLink * m_deviceLink ; // We keep the latest link here, if this is destroyed without new link, linkDestroyed is emitted and device will destroy pairing handler
PairStatus m_pairStatus ;
2015-07-25 12:45:19 +01:00
Q_SIGNALS :
2015-07-27 16:28:58 +01:00
void pairingDone ( ) ;
void unpairingDone ( ) ;
void pairingFailed ( const QString & error ) ;
void linkNull ( ) ;
2015-07-05 14:23:53 +01:00
} ;
# endif //KDECONNECT_PAIRINGHANDLER_H