|  |  |  | libsoup Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | Signals | ||||
#include <libsoup/soup.h>
                    SoupAuth;
SoupAuth *          soup_auth_new                       (GType type,
                                                         SoupMessage *msg,
                                                         const char *auth_header);
gboolean            soup_auth_update                    (SoupAuth *auth,
                                                         SoupMessage *msg,
                                                         const char *auth_header);
#define             SOUP_TYPE_AUTH_BASIC
#define             SOUP_TYPE_AUTH_DIGEST
#define             SOUP_TYPE_AUTH_NTLM
gboolean            soup_auth_is_for_proxy              (SoupAuth *auth);
const char *        soup_auth_get_scheme_name           (SoupAuth *auth);
const char *        soup_auth_get_host                  (SoupAuth *auth);
const char *        soup_auth_get_realm                 (SoupAuth *auth);
char *              soup_auth_get_info                  (SoupAuth *auth);
void                soup_auth_authenticate              (SoupAuth *auth,
                                                         const char *username,
                                                         const char *password);
gboolean            soup_auth_is_authenticated          (SoupAuth *auth);
char *              soup_auth_get_authorization         (SoupAuth *auth,
                                                         SoupMessage *msg);
GSList *            soup_auth_get_protection_space      (SoupAuth *auth,
                                                         SoupURI *source_uri);
void                soup_auth_free_protection_space     (SoupAuth *auth,
                                                         GSList *space);
#define             SOUP_AUTH_SCHEME_NAME
#define             SOUP_AUTH_REALM
#define             SOUP_AUTH_HOST
#define             SOUP_AUTH_IS_FOR_PROXY
#define             SOUP_AUTH_IS_AUTHENTICATED
"host" gchar* : Read / Write / Construct Only "is-authenticated" gboolean : Read "is-for-proxy" gboolean : Read / Write / Construct Only "realm" gchar* : Read / Write / Construct Only "scheme-name" gchar* : Read
SoupAuth objects store the authentication data associated with a given bit of web space. They are created automatically by SoupSession.
typedef struct _SoupAuth SoupAuth;
The abstract base class for handling authentication. Specific HTTP Authentication mechanisms are implemented by its subclasses, but applications never need to be aware of the specific subclasses being used.
SoupAuth * soup_auth_new (GType type,SoupMessage *msg,const char *auth_header);
Creates a new SoupAuth of type type with the information from
msg and auth_header.
This is called by SoupSession; you will normally not create auths yourself.
| 
 | the type of auth to create (a subtype of SoupAuth) | 
| 
 | the SoupMessage the auth is being created for | 
| 
 | the WWW-Authenticate/Proxy-Authenticate header | 
| Returns : | the new SoupAuth, or NULLif it could not be
created | 
gboolean soup_auth_update (SoupAuth *auth,SoupMessage *msg,const char *auth_header);
Updates auth with the information from msg and auth_header,
possibly un-authenticating it. As with soup_auth_new(), this is
normally only used by SoupSession.
| 
 | a SoupAuth | 
| 
 | the SoupMessage authis being updated for | 
| 
 | the WWW-Authenticate/Proxy-Authenticate header | 
| Returns : | TRUEifauthis still a valid (but potentially
unauthenticated) SoupAuth.FALSEif something aboutauth_paramscould not be parsed or incorporated intoauthat all. | 
gboolean            soup_auth_is_for_proxy              (SoupAuth *auth);
Tests whether or not auth is associated with a proxy server rather
than an "origin" server.
| 
 | a SoupAuth | 
| Returns : | TRUEorFALSE | 
const char *        soup_auth_get_scheme_name           (SoupAuth *auth);
Returns auth's scheme name. (Eg, "Basic", "Digest", or "NTLM")
| 
 | a SoupAuth | 
| Returns : | the scheme name | 
const char *        soup_auth_get_host                  (SoupAuth *auth);
Returns the host that auth is associated with.
| 
 | a SoupAuth | 
| Returns : | the hostname | 
const char *        soup_auth_get_realm                 (SoupAuth *auth);
Returns auth's realm. This is an identifier that distinguishes
separate authentication spaces on a given server, and may be some
string that is meaningful to the user. (Although it is probably not
localized.)
| 
 | a SoupAuth | 
| Returns : | the realm name | 
char *              soup_auth_get_info                  (SoupAuth *auth);
Gets an opaque identifier for auth, for use as a hash key or the
like. SoupAuth objects from the same server with the same
identifier refer to the same authentication domain (eg, the URLs
associated with them take the same usernames and passwords).
| 
 | a SoupAuth | 
| Returns : | the identifier | 
void soup_auth_authenticate (SoupAuth *auth,const char *username,const char *password);
Call this on an auth to authenticate it; normally this will cause the auth's message to be requeued with the new authentication info.
This does not cause the password to be saved to persistent storage;
see soup_auth_save_password() for that.
| 
 | a SoupAuth | 
| 
 | the username provided by the user or client | 
| 
 | the password provided by the user or client | 
gboolean            soup_auth_is_authenticated          (SoupAuth *auth);
Tests if auth has been given a username and password
| 
 | a SoupAuth | 
| Returns : | TRUEifauthhas been given a username and password | 
char * soup_auth_get_authorization (SoupAuth *auth,SoupMessage *msg);
Generates an appropriate "Authorization" header for msg. (The
session will only call this if soup_auth_is_authenticated()
returned TRUE.)
| 
 | a SoupAuth | 
| 
 | the SoupMessage to be authorized | 
| Returns : | the "Authorization" header, which must be freed. | 
GSList * soup_auth_get_protection_space (SoupAuth *auth,SoupURI *source_uri);
Returns a list of paths on the server which auth extends over.
(All subdirectories of these paths are also assumed to be part
of auth's protection space, unless otherwise discovered not to
be.)
| 
 | a SoupAuth | 
| 
 | the URI of the request that authwas generated in
response to. | 
| Returns : | the list of
paths, which can be freed with soup_auth_free_protection_space(). [element-type utf8][transfer full] | 
void soup_auth_free_protection_space (SoupAuth *auth,GSList *space);
Frees space.
| 
 | a SoupAuth | 
| 
 | the return value from soup_auth_get_protection_space() | 
#define SOUP_AUTH_SCHEME_NAME "scheme-name"
An alias for the "scheme-name" property. (The authentication scheme name.)
#define SOUP_AUTH_REALM "realm"
An alias for the "realm" property. (The authentication realm.)
#define SOUP_AUTH_HOST "host"
An alias for the "host" property. (The host being authenticated to.)
#define SOUP_AUTH_IS_FOR_PROXY "is-for-proxy"
An alias for the "is-for-proxy" property. (Whether or not the auth is for a proxy server.)
#define SOUP_AUTH_IS_AUTHENTICATED "is-authenticated"
An alias for the "is-authenticated" property. (Whether or not the auth has been authenticated.)
"host" property  "host"                     gchar*                : Read / Write / Construct Only
Authentication host.
Default value: NULL
"is-authenticated" property  "is-authenticated"         gboolean              : Read
Whether or not the auth is authenticated.
Default value: FALSE
"is-for-proxy" property  "is-for-proxy"             gboolean              : Read / Write / Construct Only
Whether or not the auth is for a proxy server.
Default value: FALSE
"realm" property  "realm"                    gchar*                : Read / Write / Construct Only
Authentication realm.
Default value: NULL
"save-password" signalvoid                user_function                      (SoupAuth *auth,
                                                        gchar    *username,
                                                        gchar    *password,
                                                        gpointer  user_data)      : Run First
Emitted to request that the username/password pair be
saved. If the session supports password-saving, it will
connect to this signal before emitting
"authenticate", so that it record the password
if requested by the caller.
| 
 | the auth | 
| 
 | the username to save | 
| 
 | the password to save | 
| 
 | user data set when the signal handler was connected. | 
Since 2.28