| Ximian Connector for Microsoft Exchange Programmer’s Reference Manual |
|---|
E2kUriE2kUri — URI utility routines |
E2kUri;
E2kUri* e2k_uri_new (const char *uri_string);
void e2k_uri_free (E2kUri *uri);
const char* e2k_uri_get_param (E2kUri *uri,
const char *name);
void e2k_uri_decode (char *part);
char* e2k_uri_encode (const char *in,
gboolean wss_encode,
const char *extra_enc_chars);
void e2k_uri_append_encoded (GString *str,
const char *in,
gboolean wss_encode,
const char *extra_enc_chars);
const char* e2k_uri_path (const char *uri_string);
char* e2k_uri_concat (const char *uri_prefix,
const char *tail);
const char* e2k_uri_relative (const char *uri_prefix,
const char *uri);
typedef struct {
char *protocol;
char *user;
char *domain;
char *authmech;
char *passwd;
char *host;
int port;
char *path;
GData *params;
char *query;
char *fragment;
} E2kUri;
A URI.
char *protocol; |
the URI protocol |
char *user; |
the username to authenticate with |
char *domain; |
the Windows NT domain of user
|
char *authmech; |
the HTTP authentication mechanism to use |
char *passwd; |
user's password
|
char *host; |
the host to connect to |
int port; |
the port to connect to |
char *path; |
the path on host
|
GData *params; |
additional parameters |
char *query; |
query string |
char *fragment; |
URI fragment |
E2kUri* e2k_uri_new (const char *uri_string);
Parses uri_string.
uri_string : |
the URI |
| Returns : | a parsed E2kUri
|
const char* e2k_uri_get_param (E2kUri *uri, const char *name);
Fetches a parameter from uri
uri : |
an E2kUri
|
name : |
name of the parameter |
| Returns : | the value of name, or NULL if it is not set
|
void e2k_uri_decode (char *part);
Undoes URI-escaping in part in-place.
part : |
a piece of a URI |
char* e2k_uri_encode (const char *in,
gboolean wss_encode,
const char *extra_enc_chars);
Encodes URI-unsafe characters as in e2k_uri_append_encoded()
in : |
data to encode |
wss_encode : |
whether or not to use the special Web Storage System encoding rules |
extra_enc_chars : |
additional characters beyond the normal URI-reserved
characters to encode when appending to str
|
| Returns : | the encoded string |
void e2k_uri_append_encoded (GString *str, const char *in, gboolean wss_encode, const char *extra_enc_chars);
Appends in to str, encoding URI-unsafe characters as needed
(optionally including some Exchange-specific encodings).
When appending a path, you must append each segment separately;
e2k_uri_append_encoded() will encode any "/"s passed in.
str : |
a GString containing part of a URI
|
in : |
data to append to str
|
wss_encode : |
whether or not to use the special Web Storage System encoding rules |
extra_enc_chars : |
additional characters beyond the normal URI-reserved
characters to encode when appending to str
|
const char* e2k_uri_path (const char *uri_string);
Returns the path component of uri_string, including the initial
"/". (The return value is actually a pointer into the passed-in
string, meaning this will only really work if the URI has no
query/fragment/etc.)
uri_string : |
a well-formed absolute URI |
| Returns : | the path component of uri_string.
|
char* e2k_uri_concat (const char *uri_prefix,
const char *tail);
Constructs a new URI consisting of the concatenation of
uri_prefix and tail. If uri_prefix does not end with a "/",
one will be inserted between uri_prefix and tail.
uri_prefix : |
an absolute URI |
tail : |
a relative path |
| Returns : | the new URI |
const char* e2k_uri_relative (const char *uri_prefix,
const char *uri);
Returns a URI describing uri's relation to uri_prefix; either a
relative URI consisting of the subpath of uri underneath
uri_prefix, or all of uri if it is not a sub-uri of uri_prefix.
uri_prefix : |
an absolute URI |
uri : |
another URI, presumably a child of uri_prefix
|
| Returns : | the relative URI |
| << E2kSid | E2kUserDialog >> |