/*
* Copyright (c) 2001-2002 Packet Design, LLC.
* All rights reserved.
*
* Subject to the following obligations and disclaimer of warranty,
* use and redistribution of this software, in source or object code
* forms, with or without modifications are expressly permitted by
* Packet Design; provided, however, that:
*
* (i) Any and all reproductions of the source or object code
* must include the copyright notice above and the following
* disclaimer of warranties; and
* (ii) No rights are granted, in any manner or form, to use
* Packet Design trademarks, including the mark "PACKET DESIGN"
* on advertising, endorsements, or otherwise except as such
* appears in the above copyright notice or in the software.
*
* THIS SOFTWARE IS BEING PROVIDED BY PACKET DESIGN "AS IS", AND
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, PACKET DESIGN MAKES NO
* REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING
* THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY AND ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
* OR NON-INFRINGEMENT. PACKET DESIGN DOES NOT WARRANT, GUARANTEE,
* OR MAKE ANY REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS
* OF THE USE OF THIS SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY,
* RELIABILITY OR OTHERWISE. IN NO EVENT SHALL PACKET DESIGN BE
* LIABLE FOR ANY DAMAGES RESULTING FROM OR ARISING OUT OF ANY USE
* OF THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, PUNITIVE, OR CONSEQUENTIAL
* DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, LOSS OF
* USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
* THE USE OF THIS SOFTWARE, EVEN IF PACKET DESIGN IS ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*
* Author: Archie Cobbs <archie@freebsd.org>
*/
#ifndef _PDEL_HTTP_SERVLET_COOKIEAUTH_H_
#define _PDEL_HTTP_SERVLET_COOKIEAUTH_H_
/*
* Function that should return non-zero if access to
* the supplied URL path requires a valid login cookie.
*/
typedef int http_servlet_cookieauth_reqd_t(void *arg,
struct http_request *req);
__BEGIN_DECLS
/*
* Create a new cookieauth servlet that will redirect any requests
* not having a valid cookie to the "redirect" URL (presumably a
* login page); "append" functions as with http_servlet_redirect_create().
*
* "privkey" should point to the PEM-encoded RSA private key file.
*
* The opaque "id" must uniquely identify this server. Cookies created
* with different id's (e.g., different machines) are incompatible.
*/
extern struct http_servlet *http_servlet_cookieauth_create(
const char *redirect, int append,
http_servlet_cookieauth_reqd_t *authreqd,
void *arg, void (*destroy)(void *),
const char *privkey, const void *id, size_t idlen,
const char *cookiename);
/*
* Add a cookie that will cause the servlet to not redirect.
* That is, make the browser appear logged in as "username".
*
* The servlet returned by http_servlet_cookieauth_create() must be
* supplied.
*
* The cookie remains valid until time "expire". If "session_only"
* is set, the browser is instructed to delete the cookie when it
* exits (though from a security point of view you can't trust the
* browser to actually do that; use "expire" as a backup).
*
* If "linger" is non zero, force a re-login if the last time the servlet
* was run was longer than "linger" seconds ago.
*
* "path" and "domain" may be NULL to omit (i.e., leave as default).
*
* Returns zero if success, -1 if error.
*/
extern int http_servlet_cookieauth_login(struct http_response *resp,
const char *privkey, const char *username,
u_int max_linger, time_t expire, int session_only,
const u_char *id, size_t idlen, const char *cookiename,
const char *path, const char *domain, int secure);
/*
* Invalidate authorization cookie.
*/
extern int http_servlet_cookieauth_logout(const char *cookiename,
const char *path, const char *domain,
struct http_response *resp);
/*
* Get the username from the authorization cookie.
*
* Returns the username, or NULL if not logged in (EACCES) or error.
*/
extern char *http_servlet_cookieauth_user(const char *privkey,
const void *id, size_t idlen, const char *cookiename,
struct http_request *req, const char *mtype);
__END_DECLS
#endif /* _PDEL_HTTP_SERVLET_COOKIEAUTH_H_ */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>