aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/cgi.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2017-03-15 10:17:29 +0000
committerIngo Schwarze <schwarze@openbsd.org>2017-03-15 10:17:29 +0000
commit7820a26ea52032d0330456ae02d4044b357144de (patch)
tree72770118c081a99496b5c8d7e35a16e3f17da130 /cgi.c
parent2c9e399563f0727410bbcdf0e023f956634dccf4 (diff)
downloadmandoc-7820a26ea52032d0330456ae02d4044b357144de.tar.gz
mandoc-7820a26ea52032d0330456ae02d4044b357144de.tar.zst
mandoc-7820a26ea52032d0330456ae02d4044b357144de.zip
It's annoying that people keep writing URIs including redundant parts
like "/OpenBSD-current/manN/". To discourage that, let man.cgi(8) redirect search form results to nice, concise URIs.
Diffstat (limited to 'cgi.c')
-rw-r--r--cgi.c28
1 files changed, 25 insertions, 3 deletions
diff --git a/cgi.c b/cgi.c
index af56da27..05a861d4 100644
--- a/cgi.c
+++ b/cgi.c
@@ -1,4 +1,4 @@
-/* $Id: cgi.c,v 1.148 2017/02/22 16:20:01 schwarze Exp $ */
+/* $Id: cgi.c,v 1.149 2017/03/15 10:17:29 schwarze Exp $ */
/*
* Copyright (c) 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2014, 2015, 2016, 2017 Ingo Schwarze <schwarze@usta.de>
@@ -76,6 +76,7 @@ static void pg_error_badrequest(const char *);
static void pg_error_internal(void);
static void pg_index(const struct req *);
static void pg_noresult(const struct req *, const char *);
+static void pg_redirect(const struct req *, const char *);
static void pg_search(const struct req *);
static void pg_searchres(const struct req *,
struct manpage *, size_t);
@@ -540,6 +541,23 @@ pg_error_internal(void)
}
static void
+pg_redirect(const struct req *req, const char *name)
+{
+ printf("Status: 303 See Other\r\n");
+ printf("Location: http://%s/", HTTP_HOST);
+ if (*scriptname != '\0')
+ printf("%s/", scriptname);
+ if (strcmp(req->q.manpath, req->p[0]))
+ printf("%s/", req->q.manpath);
+ if (req->q.arch != NULL)
+ printf("%s/", req->q.arch);
+ printf("%s", name);
+ if (req->q.sec != NULL)
+ printf(".%s", req->q.sec);
+ printf("\r\nContent-Type: text/html; charset=utf-8\r\n\r\n");
+}
+
+static void
pg_searchres(const struct req *req, struct manpage *r, size_t sz)
{
char *arch, *archend;
@@ -956,9 +974,13 @@ pg_search(const struct req *req)
}
}
- if (0 == mansearch(&search, &paths, argc, argv, &res, &ressz))
+ res = NULL;
+ ressz = 0;
+ if (req->isquery && req->q.equal && argc == 1)
+ pg_redirect(req, argv[0]);
+ else if (mansearch(&search, &paths, argc, argv, &res, &ressz) == 0)
pg_noresult(req, "You entered an invalid query.");
- else if (0 == ressz)
+ else if (ressz == 0)
pg_noresult(req, "No results found.");
else
pg_searchres(req, res, ressz);