aboutsummaryrefslogtreecommitdiffstats
path: root/subsurface-core/isocialnetworkintegration.h
blob: 778a171b39a12b0798100655f23b3408163f427c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#ifndef ISOCIALNETWORKINTEGRATION_H
#define ISOCIALNETWORKINTEGRATION_H

#include <QtPlugin>

/* This Interface represents a Plugin for Social Network integration,
 * with it you may be able to create plugins for facebook, instagram,
 * twitpic, google plus and any other thing you may imagine.
 *
 * We bundle facebook integration as an example.
 */

class ISocialNetworkIntegration {
public:
	/*!
	 * @name socialNetworkName
	 * @brief The name of this social network
	 * @return The name of this social network
	 *
	 * The name of this social network will be used to populate the Menu to toggle states
	 * between connected/disconnected, and also submit stuff to it.
	 */
	virtual QString socialNetworkName() const = 0;

	/*!
	 * @name socialNetworkIcon
	 * @brief The icon of this social network
	 * @return The icon of this social network
	 *
	 * The icon of this social network will be used to populate the menu, and can also be
	 * used on a toolbar if requested.
	 */
	virtual QString socialNetworkIcon() const = 0;

	/*!
	 * @name isConnected
	 * @brief returns true if connected to this social network, false otherwise
	 * @return true if connected to this social network, false otherwise
	 */
	virtual bool isConnected() = 0;

	/*!
	 * @name requestLogin
	 * @brief try to login on this social network.
	 *
	 * Try to login on this social network. All widget implementation that
	 * manages login should be done inside this function.
	 */
	virtual void requestLogin() = 0;

	/*!
	 * @name requestLogoff
	 * @brief tries to logoff from this social network
	 *
	 * Try to logoff from this social network.
	 */
	virtual void requestLogoff() = 0;

	/*!
	 * @name uploadCurrentDive
	 * @brief send the current dive info to the Social Network
	 *
	 * Should format all the options and pixmaps from the current dive
	 * to update to the social network. All widget stuff related to sendint
	 * dive information should be executed inside this function.
	 */
	virtual void uploadCurrentDive() = 0;
};

Q_DECLARE_INTERFACE(ISocialNetworkIntegration, "org.subsurface.ISocialNetworkIntegration.v1")
Q_DECLARE_METATYPE(ISocialNetworkIntegration*);
#endif