|  |  |  | 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, orNULLif 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 GStringcontaining 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 >> |