Top |
char * | soup_xmlrpc_build_request () |
SoupMessage * | soup_xmlrpc_message_new () |
GVariant * | soup_xmlrpc_parse_response () |
GVariant * | soup_xmlrpc_variant_new_datetime () |
SoupDate * | soup_xmlrpc_variant_get_datetime () |
void | soup_xmlrpc_params_free () |
GVariant * | soup_xmlrpc_params_parse () |
char * | soup_xmlrpc_parse_request () |
char * | soup_xmlrpc_build_response () |
char * | soup_xmlrpc_build_fault () |
gboolean | soup_xmlrpc_message_set_response () |
void | soup_xmlrpc_message_set_fault () |
#define | SOUP_XMLRPC_ERROR |
enum | SoupXMLRPCError |
#define | SOUP_XMLRPC_FAULT |
enum | SoupXMLRPCFault |
SoupXMLRPCParams |
char * soup_xmlrpc_build_request (const char *method_name
,GVariant *params
,GError **error
);
This creates an XML-RPC methodCall and returns it as a string.
This is the low-level method that soup_xmlrpc_message_new()
is
built on.
params
is a GVariant tuple representing the method parameters.
Serialization details:
"a{s*}" and "{s*}" are serialized as <struct>
"ay" is serialized as <base64>
Other arrays and tuples are serialized as <array>
booleans are serialized as <boolean>
byte, int16, uint16 and int32 are serialized as <int>
uint32 and int64 are serialized as the nonstandard <i8> type
doubles are serialized as <double>
Strings are serialized as <string>
Variants (i.e. "v" type) are unwrapped and their child is serialized.
GVariants created by soup_xmlrpc_variant_new_datetime()
are serialized as
<dateTime.iso8601>
Other types are not supported and will return NULL
and set error
.
This notably includes: object-paths, signatures, uint64, handles, maybes
and dictionaries with non-string keys.
If params
is floating, it is consumed.
Since: 2.52
SoupMessage * soup_xmlrpc_message_new (const char *uri
,const char *method_name
,GVariant *params
,GError **error
);
Creates an XML-RPC methodCall and returns a SoupMessage, ready to send, for that method call.
See soup_xmlrpc_build_request()
for serialization details.
If params
is floating, it is consumed.
Since: 2.52
GVariant * soup_xmlrpc_parse_response (const char *method_response
,int length
,const char *signature
,GError **error
);
Parses method_response
and returns the return value. If
method_response
is a fault, NULL
is returned, and error
will be set to an error in the SOUP_XMLRPC_FAULT
domain, with the error
code containing the fault code, and the error message containing
the fault string. If method_response
cannot be parsed, NULL
is returned,
and error
will be set to an error in the SOUP_XMLRPC_ERROR
domain.
See soup_xmlrpc_params_parse()
for deserialization details.
Since: 2.52
GVariant *
soup_xmlrpc_variant_new_datetime (SoupDate *date
);
Construct a special GVariant used to serialize a <dateTime.iso8601>
node. See soup_xmlrpc_build_request()
.
The actual type of the returned GVariant is unspecified and "v" or "*" should be used in variant format strings. For example:
1 |
args = g_variant_new ("(v)", soup_xmlrpc_variant_new_datetime (date)); |
Since: 2.52
SoupDate * soup_xmlrpc_variant_get_datetime (GVariant *variant
,GError **error
);
Get the SoupDate from special GVariant created by
soup_xmlrpc_variant_new_datetime()
or by parsing a <dateTime.iso8601>
node. See soup_xmlrpc_params_parse()
.
If variant
does not contain a datetime it will return an error but it is not
considered a programmer error because it generally means parameters received
are not in the expected type.
Since: 2.52
void
soup_xmlrpc_params_free (SoupXMLRPCParams *self
);
Free a SoupXMLRPCParams returned by soup_xmlrpc_parse_request()
.
Since: 2.52
GVariant * soup_xmlrpc_params_parse (SoupXMLRPCParams *self
,const char *signature
,GError **error
);
Parse method parameters returned by soup_xmlrpc_parse_request()
.
Deserialization details:
If signature
is provided, <int> and <i4> can be deserialized
to byte, int16, uint16, int32, uint32, int64 or uint64. Otherwise
it will be deserialized to int32. If the value is out of range
for the target type it will return an error.
<struct> will be deserialized to "a{sv}". signature
could define
another value type (e.g. "a{ss}").
<array> will be deserialized to "av". signature
could define
another element type (e.g. "as") or could be a tuple (e.g. "(ss)").
<base64> will be deserialized to "ay".
<string> will be deserialized to "s".
<dateTime.iso8601> will be deserialized to an unspecified variant
type. If signature
is provided it must have the generic "v" type, which
means there is no guarantee that it's actually a datetime that has been
received. soup_xmlrpc_variant_get_datetime()
must be used to parse and
type check this special variant.
signature
must not have maybes, otherwise an error is returned.
Dictionaries must have string keys, otherwise an error is returned.
Since: 2.52
char * soup_xmlrpc_parse_request (const char *method_call
,int length
,SoupXMLRPCParams **params
,GError **error
);
Parses method_call
and return the method name. Method parameters can be
parsed later using soup_xmlrpc_params_parse()
.
method_call |
the XML-RPC methodCall string |
|
length |
the length of |
|
params |
on success, a new SoupXMLRPCParams. |
[out] |
error |
Since: 2.52
char * soup_xmlrpc_build_response (GVariant *value
,GError **error
);
This creates a (successful) XML-RPC methodResponse and returns it
as a string. To create a fault response, use soup_xmlrpc_build_fault()
. This
is the low-level method that soup_xmlrpc_message_set_response()
is built on.
See soup_xmlrpc_build_request()
for serialization details, but note
that since a method can only have a single return value, value
should not be a tuple here (unless the return value is an array).
If value
is floating, it is consumed.
Since: 2.52
char * soup_xmlrpc_build_fault (int fault_code
,const char *fault_format
,...
);
This creates an XML-RPC fault response and returns it as a string.
(To create a successful response, use
soup_xmlrpc_build_method_response()
.)
gboolean soup_xmlrpc_message_set_response (SoupMessage *msg
,GVariant *value
,GError **error
);
Sets the status code and response body of msg
to indicate a
successful XML-RPC call, with a return value given by value
. To set a
fault response, use soup_xmlrpc_message_set_fault()
.
See soup_xmlrpc_build_request()
for serialization details.
If value
is floating, it is consumed.
Since: 2.52
void soup_xmlrpc_message_set_fault (SoupMessage *msg
,int fault_code
,const char *fault_format
,...
);
Sets the status code and response body of msg
to indicate an
unsuccessful XML-RPC call, with the error described by fault_code
and fault_format
.
msg |
an XML-RPC request |
|
fault_code |
the fault code |
|
fault_format |
a |
|
... |
the parameters to |
Since: 2.52
#define SOUP_XMLRPC_FAULT soup_xmlrpc_fault_quark()
A GError domain representing an XML-RPC fault code. Used with SoupXMLRPCFault (although servers may also return fault codes not in that enumeration).
Pre-defined XML-RPC fault codes from http://xmlrpc-epi.sourceforge.net/specs/rfc.fault_codes.php. These are an extension, not part of the XML-RPC spec; you can't assume servers will use them.
typedef struct _SoupXMLRPCParams SoupXMLRPCParams;
Opaque structure containing XML-RPC methodCall parameter values.
Can be parsed using soup_xmlrpc_params_parse()
and freed with
soup_xmlrpc_params_free()
.
Since: 2.52