auth: add basic authentication filter framework
This leverages the new lua support. See filters/simple-authentication.lua for explaination of how this works. There is also additional documentation in cgitrc.5.txt. Though this is a cookie-based approach, cgit's caching mechanism is preserved for authenticated pages. Very plugable and extendable depending on user needs. The sample script uses an HMAC-SHA1 based cookie to store the currently logged in user, with an expiration date. Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
This commit is contained in:
7
cgit.h
7
cgit.h
@ -53,7 +53,7 @@ typedef void (*filepair_fn)(struct diff_filepair *pair);
|
||||
typedef void (*linediff_fn)(char *line, int len);
|
||||
|
||||
typedef enum {
|
||||
ABOUT, COMMIT, SOURCE, EMAIL
|
||||
ABOUT, COMMIT, SOURCE, EMAIL, AUTH
|
||||
} filter_type;
|
||||
|
||||
struct cgit_filter {
|
||||
@ -252,6 +252,7 @@ struct cgit_config {
|
||||
struct cgit_filter *commit_filter;
|
||||
struct cgit_filter *source_filter;
|
||||
struct cgit_filter *email_filter;
|
||||
struct cgit_filter *auth_filter;
|
||||
};
|
||||
|
||||
struct cgit_page {
|
||||
@ -278,6 +279,10 @@ struct cgit_environment {
|
||||
const char *script_name;
|
||||
const char *server_name;
|
||||
const char *server_port;
|
||||
const char *http_cookie;
|
||||
const char *http_referer;
|
||||
unsigned int content_length;
|
||||
int authenticated;
|
||||
};
|
||||
|
||||
struct cgit_context {
|
||||
|
Reference in New Issue
Block a user