diff --git a/html.c b/html.c index 27596a2..810502e 100644 --- a/html.c +++ b/html.c @@ -2168,6 +2168,7 @@ xs_str *html_timeline(snac *user, const xs_list *list, int read_only, xs_list *p = (xs_list *)list; const char *v; double t = ftime(); + int hide_children = xs_is_true(xs_dict_get(srv_config, "strict_public_timelines")); xs *desc = NULL; xs *alternate = NULL; @@ -2329,7 +2330,7 @@ xs_str *html_timeline(snac *user, const xs_list *list, int read_only, } } - xs_html *entry = html_entry(user, msg, read_only, 0, v, user ? 0 : 1); + xs_html *entry = html_entry(user, msg, read_only, 0, v, (user && !hide_children) ? 0 : 1); if (entry != NULL) xs_html_add(posts, @@ -2844,8 +2845,17 @@ int html_get_handler(const xs_dict *req, const char *q_path, xs_dict_get(req, "if-none-match"), etag); } else { - xs *list = timeline_list(&snac, "public", skip, show); - xs *next = timeline_list(&snac, "public", skip + show, 1); + xs *list = NULL; + xs *next = NULL; + + if (xs_is_true(xs_dict_get(srv_config, "strict_public_timelines"))) { + list = timeline_simple_list(&snac, "public", skip, show); + next = timeline_simple_list(&snac, "public", skip + show, 1); + } + else { + list = timeline_list(&snac, "public", skip, show); + next = timeline_list(&snac, "public", skip + show, 1); + } xs *pins = pinned_list(&snac); pins = xs_list_cat(pins, list);