-rw-r--r-- | ui-clone.c | 10 |
1 files changed, 4 insertions, 6 deletions
@@ -39,63 +39,61 @@ static void print_pack_info(struct cgit_context *ctx) ctx->page.filename = "objects/info/packs"; cgit_print_http_headers(ctx); ofs = strlen(ctx->repo->path) + strlen("/objects/pack/"); prepare_packed_git(); for (pack = packed_git; pack; pack = pack->next) if (pack->pack_local) htmlf("P %s\n", pack->pack_name + ofs); } static void send_file(struct cgit_context *ctx, char *path) { struct stat st; - int err; if (stat(path, &st)) { switch (errno) { case ENOENT: - err = 404; + html_status(404, "Not found", 0); break; case EACCES: - err = 403; + html_status(403, "Forbidden", 0); break; default: - err = 400; + html_status(400, "Bad request", 0); } - html_status(err, 0); return; } ctx->page.mimetype = "application/octet-stream"; ctx->page.filename = path; if (prefixcmp(ctx->repo->path, path)) ctx->page.filename += strlen(ctx->repo->path) + 1; cgit_print_http_headers(ctx); html_include(path); } void cgit_clone_info(struct cgit_context *ctx) { if (!ctx->qry.path || strcmp(ctx->qry.path, "refs")) return; ctx->page.mimetype = "text/plain"; ctx->page.filename = "info/refs"; cgit_print_http_headers(ctx); for_each_ref(print_ref_info, ctx); } void cgit_clone_objects(struct cgit_context *ctx) { if (!ctx->qry.path) { - html_status(400, 0); + html_status(400, "Bad request", 0); return; } if (!strcmp(ctx->qry.path, "info/packs")) { print_pack_info(ctx); return; } send_file(ctx, git_path("objects/%s", ctx->qry.path)); } void cgit_clone_head(struct cgit_context *ctx) |