
* Update FSF address in license headers (Michael Biebl <biebl@debian.org>) git-svn-id: http://svn-archive.gnome.org/svn/NetworkManager/trunk@3775 4912f4e0-d625-0410-9fb7-b9a5a253dbdc
171 lines
7.5 KiB
C
171 lines
7.5 KiB
C
/* NetworkManager -- Network link manager
|
|
*
|
|
* Dan Williams <dcbw@redhat.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) any later version.
|
|
*
|
|
* 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, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* (C) Copyright 2008 Red Hat, Inc.
|
|
*/
|
|
|
|
#ifndef NM_VPN_PLUGIN_UI_INTERFACE_H
|
|
#define NM_VPN_PLUGIN_UI_INTERFACE_H
|
|
|
|
#include <glib.h>
|
|
#include <glib-object.h>
|
|
#include <nm-connection.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
typedef struct _NMVpnPluginUiInterface NMVpnPluginUiInterface;
|
|
typedef struct _NMVpnPluginUiWidgetInterface NMVpnPluginUiWidgetInterface;
|
|
|
|
/* Plugin's factory function that returns a GObject that implements
|
|
* NMVpnPluginUiInterface.
|
|
*/
|
|
typedef NMVpnPluginUiInterface * (*NMVpnPluginUiFactory) (GError **error);
|
|
NMVpnPluginUiInterface *nm_vpn_plugin_ui_factory (GError **error);
|
|
|
|
|
|
/**************************************************/
|
|
/* Plugin interface */
|
|
/**************************************************/
|
|
|
|
#define NM_TYPE_VPN_PLUGIN_UI_INTERFACE (nm_vpn_plugin_ui_interface_get_type ())
|
|
#define NM_VPN_PLUGIN_UI_INTERFACE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_VPN_PLUGIN_UI_INTERFACE, NMVpnPluginUiInterface))
|
|
#define NM_IS_VPN_PLUGIN_UI_INTERFACE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_VPN_PLUGIN_UI_INTERFACE))
|
|
#define NM_VPN_PLUGIN_UI_INTERFACE_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), NM_TYPE_VPN_PLUGIN_UI_INTERFACE, NMVpnPluginUiInterface))
|
|
|
|
#define NM_VPN_PLUGIN_UI_CAPABILITY_NONE 0x00
|
|
#define NM_VPN_PLUGIN_UI_CAPABILITY_IMPORT 0x01
|
|
#define NM_VPN_PLUGIN_UI_CAPABILITY_EXPORT 0x02
|
|
|
|
/* Short display name of the VPN plugin */
|
|
#define NM_VPN_PLUGIN_UI_INTERFACE_NAME "name"
|
|
|
|
/* Longer description of the the VPN plugin */
|
|
#define NM_VPN_PLUGIN_UI_INTERFACE_DESC "desc"
|
|
|
|
/* D-Bus service name of the plugin's VPN service */
|
|
#define NM_VPN_PLUGIN_UI_INTERFACE_SERVICE "service"
|
|
|
|
typedef enum {
|
|
NM_VPN_PLUGIN_UI_INTERFACE_PROP_FIRST = 0x1000,
|
|
|
|
NM_VPN_PLUGIN_UI_INTERFACE_PROP_NAME = NM_VPN_PLUGIN_UI_INTERFACE_PROP_FIRST,
|
|
NM_VPN_PLUGIN_UI_INTERFACE_PROP_DESC,
|
|
NM_VPN_PLUGIN_UI_INTERFACE_PROP_SERVICE
|
|
} NMVpnPluginUiInterfaceProp;
|
|
|
|
struct _NMVpnPluginUiInterface {
|
|
GTypeInterface g_iface;
|
|
|
|
/* Plugin's factory function that returns a GObject that implements
|
|
* NMVpnPluginUiWidgetInterface, pre-filled with values from 'connection'
|
|
* if non-NULL.
|
|
*/
|
|
NMVpnPluginUiWidgetInterface * (*ui_factory) (NMVpnPluginUiInterface *iface,
|
|
NMConnection *connection,
|
|
GError **error);
|
|
|
|
/* Plugin's capabiltity function that returns a bitmask of capabilities
|
|
* described by NM_VPN_PLUGIN_UI_CAPABILITY_* defines.
|
|
*/
|
|
guint32 (*get_capabilities) (NMVpnPluginUiInterface *iface);
|
|
|
|
/* Try to import a connection from the specified path. On success, return a
|
|
* partial NMConnection object. On error, return NULL and set 'error' with
|
|
* additional information. Note that 'error' can be NULL, in which case no
|
|
* additional error information should be provided.
|
|
*/
|
|
NMConnection * (*import) (NMVpnPluginUiInterface *iface, const char *path, GError **error);
|
|
|
|
/* Export the given connection to the specified path. Return TRUE on success.
|
|
* On error, return FALSE and set 'error' with additional error information.
|
|
* Note that 'error' can be NULL, in which case no additional error information
|
|
* should be provided.
|
|
*/
|
|
gboolean (*export) (NMVpnPluginUiInterface *iface, const char *path, NMConnection *connection, GError **error);
|
|
|
|
/* For a given connection, return a suggested file name. Returned value should
|
|
* be NULL or a suggested file name allocated via g_malloc/g_new/etc to be freed
|
|
* by the caller.
|
|
*/
|
|
char * (*get_suggested_name) (NMVpnPluginUiInterface *iface, NMConnection *connection);
|
|
};
|
|
|
|
GType nm_vpn_plugin_ui_interface_get_type (void);
|
|
|
|
NMVpnPluginUiWidgetInterface *nm_vpn_plugin_ui_interface_ui_factory (NMVpnPluginUiInterface *iface,
|
|
NMConnection *connection,
|
|
GError **error);
|
|
|
|
guint32 nm_vpn_plugin_ui_interface_get_capabilities (NMVpnPluginUiInterface *iface);
|
|
|
|
NMConnection *nm_vpn_plugin_ui_interface_import (NMVpnPluginUiInterface *iface,
|
|
const char *path,
|
|
GError **error);
|
|
|
|
gboolean nm_vpn_plugin_ui_interface_export (NMVpnPluginUiInterface *iface,
|
|
const char *path,
|
|
NMConnection *connection,
|
|
GError **error);
|
|
|
|
char *nm_vpn_plugin_ui_interface_get_suggested_name (NMVpnPluginUiInterface *iface,
|
|
NMConnection *connection);
|
|
|
|
|
|
/**************************************************/
|
|
/* UI widget interface */
|
|
/**************************************************/
|
|
|
|
#define NM_TYPE_VPN_PLUGIN_UI_WIDGET_INTERFACE (nm_vpn_plugin_ui_widget_interface_get_type ())
|
|
#define NM_VPN_PLUGIN_UI_WIDGET_INTERFACE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_VPN_PLUGIN_UI_WIDGET_INTERFACE, NMVpnPluginUiWidgetInterface))
|
|
#define NM_IS_VPN_PLUGIN_UI_WIDGET_INTERFACE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_VPN_PLUGIN_UI_WIDGET_INTERFACE))
|
|
#define NM_VPN_PLUGIN_UI_WIDGET_INTERFACE_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), NM_TYPE_VPN_PLUGIN_UI_WIDGET_INTERFACE, NMVpnPluginUiWidgetInterface))
|
|
|
|
struct _NMVpnPluginUiWidgetInterface {
|
|
GTypeInterface g_iface;
|
|
|
|
/* Return the GtkWidget for the VPN's UI */
|
|
GObject * (*get_widget) (NMVpnPluginUiWidgetInterface *iface);
|
|
|
|
/* Called to save the user-entered options to the connection object. Should
|
|
* return FALSE and set 'error' if the current options are invalid. 'error'
|
|
* should contain enough information for the plugin to determine which UI
|
|
* widget is invalid at a later point in time. For example, creating unique
|
|
* error codes for what error occurred and populating the message field
|
|
* of 'error' with the name of the invalid property.
|
|
*/
|
|
gboolean (*update_connection) (NMVpnPluginUiWidgetInterface *iface,
|
|
NMConnection *connection,
|
|
GError **error);
|
|
|
|
/* Emitted when the value of a UI widget changes. May trigger a validity
|
|
* check via update_connection() to write values to the connection */
|
|
void (*changed) (NMVpnPluginUiWidgetInterface *iface);
|
|
};
|
|
|
|
GType nm_vpn_plugin_ui_widget_interface_get_type (void);
|
|
|
|
GObject * nm_vpn_plugin_ui_widget_interface_get_widget (NMVpnPluginUiWidgetInterface *iface);
|
|
|
|
gboolean nm_vpn_plugin_ui_widget_interface_update_connection (NMVpnPluginUiWidgetInterface *iface,
|
|
NMConnection *connection,
|
|
GError **error);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* NM_VPN_PLUGIN_UI_INTERFACE_H */
|