kdeconnect-kde/kded/plugins/kdeconnectplugin.h

69 lines
2.1 KiB
C
Raw Normal View History

2013-06-06 04:57:06 +01:00
/**
* Copyright 2013 Albert Vaca <albertvaka@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/>.
*/
2013-08-13 04:14:46 +01:00
#ifndef KDECONNECTPLUGIN_H
#define KDECONNECTPLUGIN_H
2013-06-06 04:57:06 +01:00
#include <QObject>
#include <QVariantList>
2013-06-06 04:57:06 +01:00
#include <kdemacros.h>
#include <KPluginFactory>
#include <KPluginLoader>
2013-06-06 04:57:06 +01:00
#include "../networkpackage.h"
#include "../device.h"
2013-08-13 04:14:46 +01:00
class KDE_EXPORT KdeConnectPlugin
2013-06-06 04:57:06 +01:00
: public QObject
{
Q_OBJECT
public:
2013-08-13 04:14:46 +01:00
KdeConnectPlugin(QObject* parent, const QVariantList& args);
virtual ~KdeConnectPlugin();
Device* device();
Device const* device() const;
2013-06-06 04:57:06 +01:00
public Q_SLOTS:
/**
* Returns true if it has handled the package in some way
* device.sendPackage can be used to send an answer back to the device
*/
virtual bool receivePackage(const NetworkPackage& np) = 0;
/**
* This method will be called when a device is connected to this computer.
* The plugin could be loaded already, but there is no guarantee we will be able to reach the device until this is called.
*/
virtual void connected() = 0;
private:
Device* mDevice;
// The Initializer object sets things up, and also does cleanup when it goes out of scope
// Since the plugins use their own memory, they need their own initializer in order to send encrypted packages
QCA::Initializer init;
2013-06-06 04:57:06 +01:00
};
#endif