diff options
Diffstat (limited to 'ui-plain.c')
| -rw-r--r-- | ui-plain.c | 10 |
1 files changed, 10 insertions, 0 deletions
| @@ -37,6 +37,16 @@ static int print_object(const unsigned char *sha1, const char *path) | |||
| 37 | mimetype = get_mimetype_for_filename(path); | 37 | mimetype = get_mimetype_for_filename(path); |
| 38 | ctx.page.mimetype = mimetype; | 38 | ctx.page.mimetype = mimetype; |
| 39 | 39 | ||
| 40 | if (!ctx.repo->enable_html_serving) { | ||
| 41 | html("X-Content-Type-Options: nosniff\n"); | ||
| 42 | html("Content-Security-Policy: default-src 'none'\n"); | ||
| 43 | if (mimetype) { | ||
| 44 | /* Built-in white list allows PDF and everything that isn't text/ and application/ */ | ||
| 45 | if ((!strncmp(mimetype, "text/", 5) || !strncmp(mimetype, "application/", 12)) && strcmp(mimetype, "application/pdf")) | ||
| 46 | ctx.page.mimetype = NULL; | ||
| 47 | } | ||
| 48 | } | ||
| 49 | |||
| 40 | if (!ctx.page.mimetype) { | 50 | if (!ctx.page.mimetype) { |
| 41 | if (buffer_is_binary(buf, size)) { | 51 | if (buffer_is_binary(buf, size)) { |
| 42 | ctx.page.mimetype = "application/octet-stream"; | 52 | ctx.page.mimetype = "application/octet-stream"; |
