2011-06-17 04:30:12 -04:00
|
|
|
/*
|
|
|
|
* "$Id: rsiface.h,v 1.9 2007-04-21 19:08:51 rmf24 Exp $"
|
|
|
|
*
|
|
|
|
* RetroShare C++ Interface.
|
|
|
|
*
|
|
|
|
* Copyright 2011-2011 by Cyril Soler
|
|
|
|
*
|
|
|
|
* This library 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 library 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
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
|
|
* USA.
|
|
|
|
*
|
|
|
|
* Please report all bugs and problems to "retroshare@lunamutt.com".
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <time.h>
|
2013-12-15 14:35:14 -05:00
|
|
|
#include <string.h>
|
2011-06-17 04:30:12 -04:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <string>
|
2011-06-17 15:59:01 -04:00
|
|
|
#include <vector>
|
2011-10-08 13:47:36 -04:00
|
|
|
#include "retroshare/rspeers.h"
|
|
|
|
#include "retroshare/rsfiles.h"
|
2012-09-12 10:42:24 -04:00
|
|
|
#include "util/rsversion.h"
|
2011-06-17 04:30:12 -04:00
|
|
|
|
|
|
|
class RsPluginHandler ;
|
|
|
|
extern RsPluginHandler *rsPlugins ;
|
|
|
|
|
|
|
|
class p3Service ;
|
2013-12-15 14:35:14 -05:00
|
|
|
class RsTurtle ;
|
|
|
|
class RsDht ;
|
|
|
|
class RsDisc ;
|
|
|
|
class RsMsgs ;
|
2014-01-03 10:05:48 -05:00
|
|
|
class RsForums;
|
2011-07-09 20:41:39 -04:00
|
|
|
class p3LinkMgr ;
|
2011-06-17 04:30:12 -04:00
|
|
|
class MainPage ;
|
|
|
|
class QIcon ;
|
2011-07-05 16:29:07 -04:00
|
|
|
class QString ;
|
2012-09-04 17:59:49 -04:00
|
|
|
class QDialog ;
|
2011-07-05 16:29:07 -04:00
|
|
|
class QWidget ;
|
2011-11-17 16:17:24 -05:00
|
|
|
class QTranslator;
|
|
|
|
class QApplication;
|
2011-06-17 04:30:12 -04:00
|
|
|
class RsCacheService ;
|
|
|
|
class ftServer ;
|
2012-02-18 09:55:50 -05:00
|
|
|
class ConfigPage ;
|
2012-02-18 15:29:03 -05:00
|
|
|
class RsPQIService ;
|
2012-02-21 16:53:25 -05:00
|
|
|
class RsAutoUpdatePage ;
|
2012-10-21 17:38:55 -04:00
|
|
|
class SoundEvents;
|
2013-01-08 17:07:52 -05:00
|
|
|
class FeedNotify;
|
2014-01-01 19:56:46 -05:00
|
|
|
class ChatWidget;
|
|
|
|
class ChatWidgetHolder;
|
2011-06-17 04:30:12 -04:00
|
|
|
|
2012-09-09 09:59:21 -04:00
|
|
|
// Plugin API version. Not used yet, but will be in the future the
|
|
|
|
// main value that decides for compatibility.
|
|
|
|
//
|
|
|
|
#define RS_PLUGIN_API_VERSION 0x000101
|
|
|
|
|
2011-07-05 16:29:07 -04:00
|
|
|
// Used for the status of plugins.
|
|
|
|
//
|
|
|
|
#define PLUGIN_STATUS_NO_STATUS 0x0000
|
2012-09-09 09:59:21 -04:00
|
|
|
#define PLUGIN_STATUS_REJECTED_HASH 0x0001
|
2011-07-05 16:29:07 -04:00
|
|
|
#define PLUGIN_STATUS_DLOPEN_ERROR 0x0002
|
|
|
|
#define PLUGIN_STATUS_MISSING_SYMBOL 0x0003
|
|
|
|
#define PLUGIN_STATUS_NULL_PLUGIN 0x0004
|
|
|
|
#define PLUGIN_STATUS_LOADED 0x0005
|
2012-09-09 09:59:21 -04:00
|
|
|
#define PLUGIN_STATUS_WRONG_API 0x0006
|
|
|
|
#define PLUGIN_STATUS_MISSING_API 0x0007
|
|
|
|
#define PLUGIN_STATUS_MISSING_SVN 0x0008
|
2011-07-05 16:29:07 -04:00
|
|
|
|
2011-10-08 13:47:36 -04:00
|
|
|
class RsPluginHandler;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
*
|
|
|
|
* convenience class to store gui interfaces
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
class RsPlugInInterfaces {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
2013-12-15 14:35:14 -05:00
|
|
|
RsPlugInInterfaces()
|
|
|
|
{
|
|
|
|
memset(this,0,sizeof(RsPlugInInterfaces)) ; // zero all pointers.
|
|
|
|
}
|
|
|
|
RsPeers *mPeers;
|
|
|
|
RsFiles *mFiles;
|
|
|
|
RsMsgs *mMsgs;
|
|
|
|
RsTurtle *mTurtle;
|
|
|
|
RsDisc *mDisc;
|
|
|
|
RsDht *mDht;
|
2014-01-03 10:05:48 -05:00
|
|
|
RsForums *mForums;
|
2011-10-08 13:47:36 -04:00
|
|
|
};
|
|
|
|
|
2011-06-17 04:30:12 -04:00
|
|
|
class RsPlugin
|
|
|
|
{
|
|
|
|
public:
|
2012-02-21 16:53:25 -05:00
|
|
|
//
|
|
|
|
//================================ Services ==================================//
|
|
|
|
//
|
|
|
|
// Cache service. Use this for providing cache-based services, such as channels, forums.
|
2013-01-08 17:07:52 -05:00
|
|
|
// Example plugin: LinksCloud
|
2012-02-21 16:53:25 -05:00
|
|
|
//
|
2013-01-08 17:07:52 -05:00
|
|
|
virtual RsCacheService *rs_cache_service() const { return NULL ; }
|
2012-02-21 16:53:25 -05:00
|
|
|
|
|
|
|
// Peer-to-Peer service. Use this for providing a service based to friend to friend
|
2013-01-08 17:07:52 -05:00
|
|
|
// exchange of data, such as chat, messages, etc.
|
2012-02-21 16:53:25 -05:00
|
|
|
// Example plugin: VOIP
|
|
|
|
//
|
2012-02-18 15:29:03 -05:00
|
|
|
virtual RsPQIService *rs_pqi_service() const { return NULL ; }
|
2011-06-17 04:30:12 -04:00
|
|
|
virtual uint16_t rs_service_id() const { return 0 ; }
|
2011-07-05 16:29:07 -04:00
|
|
|
|
2012-08-02 09:17:53 -04:00
|
|
|
// Shutdown
|
|
|
|
virtual void stop() {}
|
|
|
|
|
2012-02-21 16:53:25 -05:00
|
|
|
// Filename used for saving the specific plugin configuration. Both RsCacheService and RsPQIService
|
|
|
|
// derive from p3Config, which means that the service provided by the plugin can load/save its own
|
|
|
|
// config by deriving loadList() and saveList() from p3Config.
|
|
|
|
//
|
|
|
|
virtual std::string configurationFileName() const { return std::string() ; }
|
|
|
|
|
|
|
|
//
|
|
|
|
//=================================== GUI ====================================//
|
|
|
|
//
|
|
|
|
// Derive the following methods to provide GUI additions to RetroShare's GUI.
|
|
|
|
//
|
|
|
|
// Main page: like Transfers, Channels, Forums, etc.
|
|
|
|
//
|
|
|
|
virtual MainPage *qt_page() const { return NULL ; } // The page itself
|
|
|
|
virtual QIcon *qt_icon() const { return NULL ; } // the page icon. Todo: put icon as virtual in MainPage
|
|
|
|
|
|
|
|
virtual QWidget *qt_config_panel() const { return NULL ; } // Config panel, to appear config->plugins->[]->
|
2012-09-04 17:59:49 -04:00
|
|
|
virtual QDialog *qt_about_page() const { return NULL ; } // About/Help button in plugin entry will show this up
|
2012-02-21 16:53:25 -05:00
|
|
|
virtual ConfigPage *qt_config_page() const { return NULL ; } // Config tab to add in config panel.
|
|
|
|
virtual RsAutoUpdatePage *qt_transfers_tab() const { return NULL ; } // Tab to add in transfers, after turtle statistics.
|
|
|
|
virtual std::string qt_transfers_tab_name()const { return "Tab" ; } // Tab name
|
2012-10-21 17:38:55 -04:00
|
|
|
virtual void qt_sound_events(SoundEvents &/*events*/) const { } // Sound events
|
2012-02-18 09:55:50 -05:00
|
|
|
|
2014-01-01 19:56:46 -05:00
|
|
|
// Provide buttons for the ChatWidget
|
|
|
|
virtual ChatWidgetHolder *qt_get_chat_widget_holder(ChatWidget */*chatWidget*/) const { return NULL ; }
|
2012-02-25 07:17:36 -05:00
|
|
|
|
2012-10-12 14:44:02 -04:00
|
|
|
virtual QTranslator *qt_translator(QApplication * /* app */, const QString& /* languageCode */, const QString& /* externalDir */ ) const { return NULL ; }
|
2011-06-17 04:30:12 -04:00
|
|
|
|
2013-01-08 17:07:52 -05:00
|
|
|
//
|
|
|
|
//================================== Notify ==================================//
|
|
|
|
//
|
|
|
|
virtual FeedNotify *qt_feedNotify() { return NULL; }
|
|
|
|
|
|
|
|
//
|
2012-02-21 16:53:25 -05:00
|
|
|
//========================== Plugin Description ==============================//
|
2013-01-08 17:07:52 -05:00
|
|
|
//
|
2012-02-21 16:53:25 -05:00
|
|
|
// All these items appear in the config->plugins tab, as a description of the plugin.
|
|
|
|
//
|
2013-11-05 18:14:30 -05:00
|
|
|
uint32_t getSvnRevision() const { return SVN_REVISION_NUMBER ; } // This is read from libretroshare/util/rsversion.h
|
2012-09-04 17:59:49 -04:00
|
|
|
|
2011-06-17 04:30:12 -04:00
|
|
|
virtual std::string getShortPluginDescription() const = 0 ;
|
|
|
|
virtual std::string getPluginName() const = 0 ;
|
2011-07-05 16:29:07 -04:00
|
|
|
virtual void getPluginVersion(int& major,int& minor,int& svn_rev) const = 0 ;
|
2012-02-21 16:53:25 -05:00
|
|
|
|
2013-01-08 17:07:52 -05:00
|
|
|
//
|
2012-02-21 16:53:25 -05:00
|
|
|
//========================== Plugin Interface ================================//
|
2013-01-08 17:07:52 -05:00
|
|
|
//
|
2012-02-21 16:53:25 -05:00
|
|
|
// Use these methods to access main objects from RetroShare.
|
|
|
|
//
|
2011-11-17 16:17:24 -05:00
|
|
|
virtual void setInterfaces(RsPlugInInterfaces& interfaces) = 0;
|
2012-02-21 16:53:25 -05:00
|
|
|
virtual void setPlugInHandler(RsPluginHandler* pgHandler) = 0;
|
2011-06-17 04:30:12 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
class RsPluginHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// Returns the number of loaded plugins.
|
|
|
|
//
|
|
|
|
virtual int nbPlugins() const = 0 ;
|
|
|
|
virtual RsPlugin *plugin(int i) = 0 ;
|
2011-06-17 15:59:01 -04:00
|
|
|
virtual const std::vector<std::string>& getPluginDirectories() const = 0;
|
2012-09-04 17:59:49 -04:00
|
|
|
virtual void getPluginStatus(int i,uint32_t& status,std::string& file_name,std::string& file_hash,uint32_t& svn_revision,std::string& error_string) const = 0 ;
|
2011-07-05 16:29:07 -04:00
|
|
|
virtual void enablePlugin(const std::string& hash) = 0;
|
|
|
|
virtual void disablePlugin(const std::string& hash) = 0;
|
2011-06-17 15:59:01 -04:00
|
|
|
|
2012-02-18 09:55:50 -05:00
|
|
|
virtual void allowAllPlugins(bool b) = 0 ;
|
|
|
|
virtual bool getAllowAllPlugins() const = 0 ;
|
|
|
|
|
2011-06-17 04:30:12 -04:00
|
|
|
virtual void slowTickPlugins(time_t sec) = 0 ;
|
|
|
|
|
|
|
|
virtual const std::string& getLocalCacheDir() const =0;
|
|
|
|
virtual const std::string& getRemoteCacheDir() const =0;
|
|
|
|
virtual ftServer *getFileServer() const = 0;
|
2011-07-09 20:41:39 -04:00
|
|
|
virtual p3LinkMgr *getLinkMgr() const = 0;
|
2011-06-17 04:30:12 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|