|  |  |  | GUPnP Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | Signals | ||||
struct GUPnPServiceProxy; GUPnPServiceProxyAction; void (*GUPnPServiceProxyActionCallback) (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,gpointer user_data); void (*GUPnPServiceProxyNotifyCallback) (GUPnPServiceProxy *proxy,const char *variable,GValue *value,gpointer user_data); gboolean gupnp_service_proxy_send_action (GUPnPServiceProxy *proxy,const char *action,GError **error,...); gboolean gupnp_service_proxy_send_action_valist (GUPnPServiceProxy *proxy,const char *action,GError **error,va_list var_args); gboolean gupnp_service_proxy_send_action_hash (GUPnPServiceProxy *proxy,const char *action,GError **error,GHashTable *in_hash,GHashTable *out_hash); gboolean gupnp_service_proxy_send_action_list (GUPnPServiceProxy *proxy,const char *action,GError **error,GList *in_names,GList *in_values,GList *out_names,GList *out_types,GList **out_values); GUPnPServiceProxyAction * gupnp_service_proxy_begin_action (GUPnPServiceProxy *proxy,const char *action,GUPnPServiceProxyActionCallback callback,gpointer user_data,...); GUPnPServiceProxyAction * gupnp_service_proxy_begin_action_valist (GUPnPServiceProxy *proxy,const char *action,GUPnPServiceProxyActionCallback callback,gpointer user_data,va_list var_args); GUPnPServiceProxyAction * gupnp_service_proxy_begin_action_hash (GUPnPServiceProxy *proxy,const char *action,GUPnPServiceProxyActionCallback callback,gpointer user_data,GHashTable *hash); GUPnPServiceProxyAction * gupnp_service_proxy_begin_action_list (GUPnPServiceProxy *proxy,const char *action,GList *in_names,GList *in_values,GUPnPServiceProxyActionCallback callback,gpointer user_data); gboolean gupnp_service_proxy_end_action (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,...); gboolean gupnp_service_proxy_end_action_valist (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,va_list var_args); gboolean gupnp_service_proxy_end_action_hash (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,GHashTable *hash); gboolean gupnp_service_proxy_end_action_list (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,GList *out_names,GList *out_types,GList **out_values); void gupnp_service_proxy_cancel_action (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action); gboolean gupnp_service_proxy_add_notify (GUPnPServiceProxy *proxy,const char *variable,GType type,GUPnPServiceProxyNotifyCallback callback,gpointer user_data); gboolean gupnp_service_proxy_remove_notify (GUPnPServiceProxy *proxy,const char *variable,GUPnPServiceProxyNotifyCallback callback,gpointer user_data); void gupnp_service_proxy_set_subscribed (GUPnPServiceProxy *proxy,gboolean subscribed); gboolean gupnp_service_proxy_get_subscribed (GUPnPServiceProxy *proxy);
GUPnPServiceProxy sends commands to a remote UPnP service and handles incoming event notifications. GUPnPServiceProxy implements the GUPnPServiceInfo interface.
struct GUPnPServiceProxy;
This struct contains private data only, and should be accessed using the functions below.
typedef struct _GUPnPServiceProxyAction GUPnPServiceProxyAction;
Opaque structure for holding in-progress action data.
void (*GUPnPServiceProxyActionCallback) (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,gpointer user_data);
Callback notifying that action on proxy has returned and
gupnp_service_proxy_end_action() etc can be called.
| 
 | The GUPnPServiceProxy actionis called from | 
| 
 | The GUPnPServiceProxyAction in progress | 
| 
 | User data | 
void (*GUPnPServiceProxyNotifyCallback) (GUPnPServiceProxy *proxy,const char *variable,GValue *value,gpointer user_data);
Callback notifying that the state variable variable on proxy has changed to
value.
| 
 | The GUPnPServiceProxy the notification originates from | 
| 
 | The name of the variable being notified | 
| 
 | The GValue of the variable being notified | 
| 
 | User data | 
gboolean gupnp_service_proxy_send_action (GUPnPServiceProxy *proxy,const char *action,GError **error,...);
Sends action action with parameters Varargs to the service exposed by
proxy synchronously. If an error occurred, error will be set. In case of
a UPnPError the error code will be the same in error.
| 
 | A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | The location where to store any error, or NULL | 
| 
 | tuples of in parameter name, in parameter type, and in parameter
value, followed by NULL, and then tuples of out parameter name,
out parameter type, and out parameter value location, terminated withNULL | 
| Returns : | TRUEif sending the action was succesful. | 
gboolean gupnp_service_proxy_send_action_valist (GUPnPServiceProxy *proxy,const char *action,GError **error,va_list var_args);
See gupnp_service_proxy_send_action().
| 
 | A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | The location where to store any error, or NULL | 
| 
 | va_list of tuples of in parameter name, in parameter type, and in
parameter value, followed by NULL, and then tuples of out parameter name,
out parameter type, and out parameter value location | 
| Returns : | TRUEif sending the action was succesful. | 
gboolean gupnp_service_proxy_send_action_hash (GUPnPServiceProxy *proxy,const char *action,GError **error,GHashTable *in_hash,GHashTable *out_hash);
gupnp_service_proxy_send_action_hash has been deprecated since version 0.20.9 and should not be used in newly-written code. Use gupnp_service_proxy_send_action() or
gupnp_service_proxy_send_action_list()
See gupnp_service_proxy_send_action(); this version takes a pair of
GHashTables for runtime determined parameter lists.
Do not use this function in newly written code; it cannot guarantee the order of arguments and thus breaks interaction with many devices.
| 
 | A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | The location where to store any error, or NULL | 
| 
 | A GHashTable of in parameter name and GValue pairs. [element-type utf8 GValue][transfer none] | 
| 
 | A GHashTable of out parameter name and initialized GValue pairs. [inout][element-type utf8 GValue][transfer full] | 
| Returns : | TRUEif sending the action was succesful. | 
gboolean gupnp_service_proxy_send_action_list (GUPnPServiceProxy *proxy,const char *action,GError **error,GList *in_names,GList *in_values,GList *out_names,GList *out_types,GList **out_values);
The synchronous variant of gupnp_service_proxy_begin_action_list and gupnp_service_proxy_end_action_list.
| 
 | (transfer none) : A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | The location where to store any error, or NULL | 
| 
 | GList of 'in' parameter names (as strings). [element-type utf8][transfer none] | 
| 
 | GList of values (as
GValue) that line up with in_names. [element-type GValue][transfer none] | 
| 
 | GList of 'out' parameter names (as strings). [element-type utf8][transfer none] | 
| 
 | GList of types (as GType)
that line up with out_names. [element-type GType][transfer none] | 
| 
 | GList of values
(as GValue) that line up with out_namesandout_types. [element-type GValue][transfer full][out] | 
| Returns : | TRUEif sending the action was succesful. | 
GUPnPServiceProxyAction * gupnp_service_proxy_begin_action (GUPnPServiceProxy *proxy,const char *action,GUPnPServiceProxyActionCallback callback,gpointer user_data,...);
Sends action action with parameters Varargs to the service exposed by
proxy asynchronously, calling callback on completion. From callback, call
gupnp_service_proxy_end_action() to check for errors, to retrieve return
values, and to free the GUPnPServiceProxyAction.
| 
 | A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | The callback to call when sending the action has succeeded or failed. [scope async] | 
| 
 | User data for callback | 
| 
 | tuples of in parameter name, in parameter type, and in parameter
value, terminated with NULL | 
| Returns : | A GUPnPServiceProxyAction handle. This will be freed when gupnp_service_proxy_cancel_action()orgupnp_service_proxy_end_action_valist(). [transfer none] | 
GUPnPServiceProxyAction * gupnp_service_proxy_begin_action_valist (GUPnPServiceProxy *proxy,const char *action,GUPnPServiceProxyActionCallback callback,gpointer user_data,va_list var_args);
See gupnp_service_proxy_begin_action().
| 
 | A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | (scope async) : The callback to call when sending the action has succeeded or failed | 
| 
 | User data for callback | 
| 
 | A va_list of tuples of in parameter name, in parameter type, and in parameter value | 
| Returns : | A GUPnPServiceProxyAction handle. This will
be freed when calling gupnp_service_proxy_cancel_action()orgupnp_service_proxy_end_action_valist(). [transfer none] | 
GUPnPServiceProxyAction * gupnp_service_proxy_begin_action_hash (GUPnPServiceProxy *proxy,const char *action,GUPnPServiceProxyActionCallback callback,gpointer user_data,GHashTable *hash);
gupnp_service_proxy_begin_action_hash has been deprecated since version 0.20.9 and should not be used in newly-written code. Use gupnp_service_proxy_send_action() or
gupnp_service_proxy_send_action_list()
See gupnp_service_proxy_begin_action(); this version takes a GHashTable
for runtime generated parameter lists.
Do not use this function in newly written code; it cannot guarantee the order of arguments and thus breaks interaction with many devices.
| 
 | A GUPnPServiceProxy | 
| 
 | An action | 
| 
 | The callback to call when sending the action has succeeded or failed. [scope async] | 
| 
 | User data for callback | 
| 
 | A GHashTable of in parameter name and GValue pairs. [element-type utf8 GValue] | 
| Returns : | A GUPnPServiceProxyAction handle. This will
be freed when calling gupnp_service_proxy_cancel_action()orgupnp_service_proxy_end_action_hash(). [transfer none] | 
GUPnPServiceProxyAction * gupnp_service_proxy_begin_action_list (GUPnPServiceProxy *proxy,const char *action,GList *in_names,GList *in_values,GUPnPServiceProxyActionCallback callback,gpointer user_data);
A variant of gupnp_service_proxy_begin_action that takes lists of in-parameter names, types and values.
| 
 | A GUPnPServiceProxy. [transfer none] | 
| 
 | An action | 
| 
 | GList of 'in' parameter names (as strings). [element-type utf8][transfer none] | 
| 
 | GList of values (as
GValue) that line up with in_names. [element-type GValue][transfer none] | 
| 
 | (scope async) : The callback to call when sending the action has succeeded or failed | 
| 
 | User data for callback | 
| Returns : | A GUPnPServiceProxyAction handle. This will be freed when calling gupnp_service_proxy_cancel_action or gupnp_service_proxy_end_action_list. [transfer none] | 
gboolean gupnp_service_proxy_end_action (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,...);
Retrieves the result of action. The out parameters in Varargs will be
filled in, and if an error occurred, error will be set. In case of
a UPnPError the error code will be the same in error.
| 
 | A GUPnPServiceProxy | 
| 
 | A GUPnPServiceProxyAction handle | 
| 
 | The location where to store any error, or NULL | 
| 
 | tuples of out parameter name, out parameter type, and out parameter
value location, terminated with NULL. The out parameter values should be
freed after use | 
| Returns : | TRUEon success. | 
gboolean gupnp_service_proxy_end_action_valist (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,va_list var_args);
See gupnp_service_proxy_end_action().
| 
 | A GUPnPServiceProxy | 
| 
 | A GUPnPServiceProxyAction handle | 
| 
 | The location where to store any error, or NULL | 
| 
 | A va_list of tuples of out parameter name, out parameter type, and out parameter value location. The out parameter values should be freed after use | 
| Returns : | TRUEon success. | 
gboolean gupnp_service_proxy_end_action_hash (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,GHashTable *hash);
See gupnp_service_proxy_end_action(); this version takes a GHashTable for
runtime generated parameter lists.
| 
 | A GUPnPServiceProxy | 
| 
 | A GUPnPServiceProxyAction handle | 
| 
 | The location where to store any error, or NULL | 
| 
 | A GHashTable of out parameter name and initialised GValue pairs. [element-type utf8 GValue][inout][transfer none] | 
| Returns : | TRUEon success. | 
gboolean gupnp_service_proxy_end_action_list (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action,GError **error,GList *out_names,GList *out_types,GList **out_values);
A variant of gupnp_service_proxy_end_action that takes lists of
out-parameter names, types and place-holders for values. The returned list
in out_values must be freed using g_list_free and each element in it using
g_value_unset and g_slice_free.
| 
 | A GUPnPServiceProxy | 
| 
 | A GUPnPServiceProxyAction handle | 
| 
 | The location where to store any error, or NULL | 
| 
 | GList of 'out' parameter names (as strings). [element-type utf8][transfer none] | 
| 
 | GList of types (as GType)
that line up with out_names. [element-type GType][transfer none] | 
| 
 | GList of values
(as GValue) that line up with out_namesandout_types. [element-type GValue][transfer full][out] | 
| Returns : | TRUEon success. | 
void gupnp_service_proxy_cancel_action (GUPnPServiceProxy *proxy,GUPnPServiceProxyAction *action);
Cancels action, freeing the action handle.
| 
 | A GUPnPServiceProxy | 
| 
 | A GUPnPServiceProxyAction handle | 
gboolean gupnp_service_proxy_add_notify (GUPnPServiceProxy *proxy,const char *variable,GType type,GUPnPServiceProxyNotifyCallback callback,gpointer user_data);
Sets up callback to be called whenever a change notification for
variable is recieved.
| 
 | A GUPnPServiceProxy | 
| 
 | The variable to add notification for | 
| 
 | The type of the variable | 
| 
 | The callback to call when variablechanges. [scope async] | 
| 
 | User data for callback | 
| Returns : | TRUEon success. | 
gboolean gupnp_service_proxy_remove_notify (GUPnPServiceProxy *proxy,const char *variable,GUPnPServiceProxyNotifyCallback callback,gpointer user_data);
Cancels the variable change notification for callback and user_data.
In version 20.9 and earlier this function must not be called directly or indirectly from a GUPnPServiceProxyNotifyCallback associated with this service proxy, even if it is for another variable. In later versions such calls are allowed.
| 
 | A GUPnPServiceProxy | 
| 
 | The variable to add notification for | 
| 
 | The callback to call when variablechanges. [scope call] | 
| 
 | User data for callback | 
| Returns : | TRUEon success. | 
void gupnp_service_proxy_set_subscribed (GUPnPServiceProxy *proxy,gboolean subscribed);
(Un)subscribes to this service.
Note that the relevant messages are not immediately sent but queued. If you want to unsubcribe from this service because the application is quitting, rely on automatic synchronised unsubscription on object destruction instead.
| 
 | A GUPnPServiceProxy | 
| 
 | TRUEto subscribe to this service | 
gboolean            gupnp_service_proxy_get_subscribed  (GUPnPServiceProxy *proxy);
Returns if we are subscribed to this service.
| 
 | A GUPnPServiceProxy | 
| Returns : | TRUEif we are subscribed to this service, otherwiseFALSE. | 
"subscribed" property"subscribed" gboolean : Read / Write
Whether we are subscribed to this service.
Default value: FALSE
"subscription-lost" signalvoid                user_function                      (GUPnPServiceProxy *proxy,
                                                        gpointer           error,
                                                        gpointer           user_data)      : Run Last
Emitted whenever the subscription to this service has been lost due to an error condition.
| 
 | The GUPnPServiceProxy that received the signal | 
| 
 | A pointer to a GError describing why the subscription has been lost. [type GError] | 
| 
 | user data set when the signal handler was connected. |