mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-22 05:15:04 +00:00
The WWW-Authenticate real also includes the user.
This commit is contained in:
parent
3da32bd327
commit
2f3ed55790
2 changed files with 13 additions and 4 deletions
13
html.c
13
html.c
|
@ -1565,8 +1565,10 @@ int html_get_handler(const xs_dict *req, const char *q_path,
|
|||
}
|
||||
else
|
||||
if (strcmp(p_path, "admin") == 0) { /** private timeline **/
|
||||
if (!login(&snac, req))
|
||||
if (!login(&snac, req)) {
|
||||
*body = xs_dup(uid);
|
||||
status = 401;
|
||||
}
|
||||
else {
|
||||
if (cache && history_mtime(&snac, "timeline.html_") > timeline_mtime(&snac)) {
|
||||
snac_debug(&snac, 1, xs_fmt("serving cached timeline"));
|
||||
|
@ -1593,8 +1595,10 @@ int html_get_handler(const xs_dict *req, const char *q_path,
|
|||
}
|
||||
else
|
||||
if (strcmp(p_path, "people") == 0) { /** the list of people **/
|
||||
if (!login(&snac, req))
|
||||
if (!login(&snac, req)) {
|
||||
*body = xs_dup(uid);
|
||||
status = 401;
|
||||
}
|
||||
else {
|
||||
*body = html_people(&snac);
|
||||
*b_size = strlen(*body);
|
||||
|
@ -1603,8 +1607,10 @@ int html_get_handler(const xs_dict *req, const char *q_path,
|
|||
}
|
||||
else
|
||||
if (strcmp(p_path, "notifications") == 0) { /** the list of notifications **/
|
||||
if (!login(&snac, req))
|
||||
if (!login(&snac, req)) {
|
||||
*body = xs_dup(uid);
|
||||
status = 401;
|
||||
}
|
||||
else {
|
||||
*body = html_notifications(&snac);
|
||||
*b_size = strlen(*body);
|
||||
|
@ -1758,6 +1764,7 @@ int html_post_handler(const xs_dict *req, const char *q_path,
|
|||
/* all posts must be authenticated */
|
||||
if (!login(&snac, req)) {
|
||||
user_free(&snac);
|
||||
*body = xs_dup(uid);
|
||||
return 401;
|
||||
}
|
||||
|
||||
|
|
4
httpd.c
4
httpd.c
|
@ -251,7 +251,9 @@ void httpd_connection(FILE *f)
|
|||
headers = xs_dict_append(headers, "location", body);
|
||||
|
||||
if (status == 401) {
|
||||
xs *www_auth = xs_fmt("Basic realm=\"%s snac login\"", xs_dict_get(srv_config, "host"));
|
||||
xs *www_auth = xs_fmt("Basic realm=\"@%s@%s snac login\"",
|
||||
body, xs_dict_get(srv_config, "host"));
|
||||
|
||||
headers = xs_dict_append(headers, "WWW-Authenticate", www_auth);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue