1 cc1c8f54 2021-01-01 op 2021-12-29 Omar Polo <op@omarpolo.com>
3 cc1c8f54 2021-01-01 op * proxy.c (proxy_init): add proxying support via `proxy relay-to'
5 fe903d30 2021-12-11 op 2021-12-11 Max <vdrummer@posteo.net>
7 fe903d30 2021-12-11 op * sandbox.c (filter): [seccomp]: allow ugetrlimit(2), needed by glibc on armv7l
9 34c4ca6e 2021-12-09 op 2021-12-09 Omar Polo <op@omarpolo.com>
11 52c92ef6 2021-12-09 op * server.c (client_read): don't check if the port in the request is the same we're listening on. Suggested by Allen Sobot, thanks!
12 34c4ca6e 2021-12-09 op * configure: add --prefix=... long argument.
14 aa76c675 2021-11-16 op 2021-11-16 Omar Polo <op@omarpolo.com>
16 aa76c675 2021-11-16 op * configure (singletest): fix the cross-compilation: don't run the test binaries just built
18 eaa02ac8 2021-10-24 op 2021-10-24 Omar Polo <op@omarpolo.com>
20 eaa02ac8 2021-10-24 op * log.c (log_request): fix "double slash" in logs: gmid ended up printing two slashes between the hostname and the path when logging the request IRI.
22 818d6aee 2021-10-15 op 2021-10-15 Stephen Gregoratto <dev@sgregoratto.me>
24 818d6aee 2021-10-15 op * gmid.c (add_keypair): implement OCSP stapling support
26 2ae10bb4 2021-10-13 op 2021-10-13 Omar Polo <op@omarpolo.com>
28 2ae10bb4 2021-10-13 op * server.c (do_accept): don't die on ECONNABORTED (``Software caused connection abort'')
30 536026c5 2021-10-11 op 2021-10-11 Omar Polo <op@omarpolo.com>
32 536026c5 2021-10-11 op * contrib/renew-certs: add script to automatically renew self-signed certificates
34 d7e2e22c 2021-10-09 op 2021-10-09 Omar Polo <op@omarpolo.com>
36 f0a01fc7 2021-10-09 op * parse.y (print_conf): multiple -n to dump the parsed configuration
38 d7e2e22c 2021-10-09 op * contrib/gencert: add gencert, a simple script to generate self-signed certs
40 c1272f63 2021-10-04 op 2021-10-04 Omar Polo <op@omarpolo.com>
42 2072343d 2021-10-04 op * regress/lib.sh (raw): reduced the timeout time for single checks from 30 to 10 seconds
44 c1272f63 2021-10-04 op * regress/runtime: regression test restructured. still implemented as a set of POSIX-scripts
46 a49800c8 2021-10-02 op 2021-10-02 Omar Polo <op@omarpolo.com>
48 a49800c8 2021-10-02 op * server.c (client_read): reworked the internal structure. Now we leverage libevent' bufferevents more.
49 a49800c8 2021-10-02 op (cgi_read): be more strict with CGI scripts: don't pass through illegal CGI responses.
51 2a44a2ab 2021-09-26 op 2021-09-26 Omar Polo <op@omarpolo.com>
53 2a44a2ab 2021-09-26 op * fcgi.c (fcgi_req): the FastCGI implementation is fully asynchronous
55 0d9a5b7a 2021-09-24 op 2021-09-24 Omar Polo <op@omarpolo.com>
57 0d9a5b7a 2021-09-24 op * configure (VERSION): 1.7.4 tagged
59 775ef04f 2021-09-24 op * server.c (check_for_cgi): fix out-of-bound access, found with lots of help from cage, thanks!
61 fba809b5 2021-09-19 op 2021-09-19 Omar Polo <op@omarpolo.com>
63 36d2d7b4 2021-09-19 op * sandbox.c (gmid_create_landlock_rs): [linux] use landlock on the server and logger process to reduce the fs access
65 fba809b5 2021-09-19 op * configure (VERSION): 1.7.3 tagged
67 b03b7d5b 2021-09-17 op 2021-09-17 Omar Polo <op@omarpolo.com>
69 b03b7d5b 2021-09-17 op * log.c (logger_main): fix syslog logging on FreeBSD
71 39c5bfd6 2021-09-18 op 2021-08-24 Omar Polo <op@omarpolo.com>
73 f2478b33 2021-08-23 op * gmid.c (main): don't crash on -n without -c
75 03747a6c 2021-07-29 op 2021-07-29 Anna “CyberTailor”
77 03747a6c 2021-07-29 op * gmid.1: document logging, openssl key generation example, spelling/grammar and crosslinks
79 2887c631 2021-07-27 op 2021-07-27 Omar Polo <op@omarpolo.com>
81 2887c631 2021-07-27 op * server.c (check_path): allow symlinks
83 ca3d8bfd 2021-09-18 op 2021-07-23 Omar Polo <op@omarpolo.com>
85 ca3d8bfd 2021-09-18 op * sandbox.c: seccomp allow fstat64 (used by glibc an aarch64). Reported by pine, thanks!
87 735336b2 2021-07-19 op 2021-07-19 Omar Polo <op@omarpolo.com>
89 735336b2 2021-07-19 op * gmid.c (setup_configless): unbreak configless mode
91 a7da5571 2021-07-13 op 2021-07-13 Anna “CyberTailor”
93 a7da5571 2021-07-13 op * parse.y (yyerror): error and warning messages are prefixed with "error:" and "warning:"
94 a7da5571 2021-07-13 op (yywarn): fix off-by-one line number in warnings
96 8068d2ff 2021-07-11 op 2021-07-11 Omar Polo <op@omarpolo.com>
98 8068d2ff 2021-07-11 op * configure (VERSION): 1.7.1 tagged
100 094bdacd 2021-07-11 op 2021-07-11 Anna “CyberTailor”
102 094bdacd 2021-07-11 op * gmid.1 (common): fix misleading example in man page: macros names may not be reserved words
104 b79b2d81 2021-07-10 op 2021-07-10 Omar Polo <op@omarpolo.com>
106 b79b2d81 2021-07-10 op * configure (VERSION): 1.7 tagged
108 c39be742 2021-07-09 op 2021-07-09 Omar Polo <op@omarpolo.com>
110 c39be742 2021-07-09 op * parse.y (STRING): add `include' directive
111 9f075bd6 2021-07-09 op (yylex): add @-macros (real macros)
113 d19951cf 2021-07-09 op 2021-07-08 Omar Polo <op@omarpolo.com>
115 d19951cf 2021-07-09 op * parse.y (option): rename `mime MIME EXT' to `map MIME to-ext EXT', but retain the old `mime' for compatibility.
117 6edcfca9 2021-07-06 op 2021-07-06 Omar Polo <op@omarpolo.com>
119 321341f6 2021-07-06 op * regress/gg.c (main): add -T timeout
121 6edcfca9 2021-07-06 op * configure (guessing_cflags): try to preserve CFLAGS/LDFLAGS
123 137def5f 2021-07-02 op 2021-07-02 Omar Polo <op@omarpolo.com>
125 137def5f 2021-07-02 op * sandbox.c (filter): seccomp filter reworked: now it should work on x86 and possibly other arches too!
127 5777923b 2021-06-29 op 2021-06-29 Omar Polo <op@omarpolo.com>
129 6b86655a 2021-06-29 op * parse.y (conf): don't require the strict order macro > options > servers
130 98f52178 2021-06-29 op c-like strings: when two or more strings are next to each others, concat them
132 f98e9045 2021-06-29 op * gmid.c (main): add -D to define macros from the cmd line
134 3b21cca3 2021-06-29 op * parse.y (yylex): allow to define macros in the config file
136 5777923b 2021-06-29 op * gmid.c (main): use getopt_long, add --help as synonym of -h and -V/--version
138 2c43dcce 2021-06-17 op 2021-06-17 Omar Polo <op@omarpolo.com>
140 2c43dcce 2021-06-17 op * gmid.1: document `log' option
142 74f0778b 2021-06-16 op 2021-06-16 Omar Polo <op@omarpolo.com>
144 74f0778b 2021-06-16 op * parse.y (yylex): drop the dependency on lex by implementing
145 74f0778b 2021-06-16 op yylex by ourselves (the actual implementation is based off doas'
146 74f0778b 2021-06-16 op parse.y). This gave us various benefits, like cleaner code, \ to
147 74f0778b 2021-06-16 op break long lines, better handling of quotes etc...
149 f740b61b 2021-06-11 op 2021-06-11 Omar Polo <op@omarpolo.com>
151 c92b802b 2021-06-11 op * parse.y (servopt): add `param' keyword
153 f740b61b 2021-06-11 op * fcgi.c (send_fcgi_req): send GATEWAY_INTERFACE, AUTH_TYPE,
154 f740b61b 2021-06-11 op REMOTE_USER, TLS_CLIENT_ISSUER, TLS_CLIENT_HASH, TLS_VERSION,
155 f740b61b 2021-06-11 op TLS_CIPHER, TLS_CIPHER_STRENGTH and TLS_CLIENT_NOT_BEFORE/AFTER.
156 f740b61b 2021-06-11 op (send_fcgi_req): support a custom list of params
158 3a1bd9ab 2021-05-27 op 2021-05-24 Omar Polo <op@omarpolo.com>
160 3a1bd9ab 2021-05-27 op * gg.c: move `gg' to regress, as it's only used for the tests
162 1eb3631d 2021-05-12 op 2021-05-12 Omar Polo <op@omarpolo.com>
164 1eb3631d 2021-05-12 op * utils.c (gen_certificate): don't add gmid as organisation when generating the certificate, and now it set the version 3, so it's compatible with java/android
166 84821dc0 2021-05-09 op 2021-05-09 Omar Polo <op@omarpolo.com>
168 84821dc0 2021-05-09 op * server.c (apply_fastcgi): added fastcgi support!
170 419e32b0 2021-05-03 op 2021-05-03 Omar Polo <op@omarpolo.com>
172 419e32b0 2021-05-03 op * parse.y: errors on duplicate values instead of silently using only the last value.
174 fdea6aa0 2021-04-30 op 2021-04-30 Omar Polo <op@omarpolo.com>
176 737a6b50 2021-04-30 op * server.c (fmt_sbuf): ensure %p (path) is always absolute
178 fdea6aa0 2021-04-30 op * gmid.c (load_vhosts): allow ``root'' rule to be specified per-location block
180 cc8c2901 2021-04-29 op 2021-04-29 Omar Polo <op@omarpolo.com>
182 cc8c2901 2021-04-29 op * parse.y (servopt): added ``alias'' option to define hostname aliases for a server
184 8e8b2e25 2021-04-28 op 2021-04-28 Omar Polo <op@omarpolo.com>
186 8e8b2e25 2021-04-28 op * gmid.c (main): pidfile support with `-P pidfile'
188 e6ca8eb1 2021-04-28 op 2021-04-27 Omar Polo <op@omarpolo.com>
190 9cc630aa 2021-04-28 op * parse.y (servopt): added ``env'' option to define environment vars for CGI scripts
192 e6ca8eb1 2021-04-28 op * log.c (fatal): lower the log priority for fatal errors from CRIT to ERR
194 11c98667 2021-04-25 op 2021-04-25 Omar Polo <op@omarpolo.com>
196 11c98667 2021-04-25 op * server.c (open_dir): sort the auto index alphabetically
198 4d820b6c 2021-04-21 op 2021-04-21 Omar Polo <op@omarpolo.com>
200 4d820b6c 2021-04-21 op * mime.c (load_default_mime): use `text/x-patch' for .patch and .diff files
202 b3342582 2021-04-14 op 2021-04-14 Omar Polo <op@omarpolo.com>
204 b3342582 2021-04-14 op * log.c (handle_imsg_log): print the datetime when logging to stderr
206 89541eee 2021-04-13 op 2021-04-13 Omar Polo <op@omarpolo.com>
208 89541eee 2021-04-13 op * ex.c (launch_cgi): define TLS_VERSION, TLS_CIPHER and TLS_CIPHER_STRENGTH for CGI scripts
210 b211d0f7 2021-04-12 op 2021-04-12 Omar Polo <op@omarpolo.com>
212 b211d0f7 2021-04-12 op * 1.6.1 tagged
214 b211d0f7 2021-04-12 op * iri.c (path_clean): fix possible infinite loop in the IRI parsing code.
216 e0ebdf2d 2021-03-31 op 2021-03-31 Omar Polo <op@omarpolo.com>
218 b8e64ccd 2021-03-31 op * gmid.h (struct vhost): remove limits on the number of vhosts and location blocks
220 e0ebdf2d 2021-03-31 op * gmid.c (mkdirs): fix recursive mkdirs for configless mode
222 33b455ad 2021-03-31 op 2021-03-29 Omar Polo <op@omarpolo.com>
224 33b455ad 2021-03-31 op * Makefile (static): fixed `static' target
226 33b455ad 2021-03-31 op 2021-03-29 kornellapacz @ github
228 33b455ad 2021-03-31 op * Dockerfile: add missing libevent-dev dependency, thanks!
230 c836cdfa 2021-03-29 op 2021-03-27 Omar Polo <op@omarpolo.com>
232 c836cdfa 2021-03-29 op * gmid.h (struct client): correctly handle CGI scripts that replies with the maximum header length allowed
234 7e3aaf37 2021-03-20 op 2021-03-20 Omar Polo <op@omarpolo.com>
238 7e3aaf37 2021-03-20 op * sandbox.c (sandbox_logger_process): add capsicum to the logger process
240 ad5301d1 2021-03-20 op 2021-03-19 Omar Polo <op@omarpolo.com>
242 ad5301d1 2021-03-20 op * gmid.c (main): use imsg for all IPC; only the main process
243 ad5301d1 2021-03-20 op listens for SIGHUP: this means that finally the config reload will
244 ad5301d1 2021-03-20 op work with OpenBSD' rc (and probably other service manager too)
246 793835cb 2021-02-23 op 2021-02-22 Omar Polo <op@omarpolo.com>
248 793835cb 2021-02-23 op * log.c (log_request): add `log on/off' to enable/disable logs per-server or per-location
250 02be96c6 2021-02-09 op 2021-02-09 Omar Polo <op@omarpolo.com>
252 02be96c6 2021-02-09 op * parse.y (locopt): add `require client ca' rule to require client certs signed by a specified CA
254 a709ddf5 2021-02-07 op 2021-02-07 Omar Polo <op@omarpolo.com>
256 9f006a21 2021-02-07 op * ex.c (do_exec): [cgi] split the query in words if needed and add them to the argv
257 b63e30ff 2021-02-07 op (launch_cgi): define TLS_CLIENT_NOT_BEFORE/NOT_AFTER in CGI scripts
259 a709ddf5 2021-02-07 op * parse.y (option): added prefork option
261 6abda252 2021-02-06 op 2021-02-06 Omar Polo <op@omarpolo.com>
263 6abda252 2021-02-06 op * parse.y (locopt): added ``block return'' and ``strip'' options
264 e3ddf390 2021-02-06 op (servopt): add the ``entrypoint'' option
266 8404ec30 2021-02-05 op 2021-02-05 Omar Polo <op@omarpolo.com>
268 8404ec30 2021-02-05 op * iri.c (parse_query): don't %-decode the query part. This affects the value of QUERY_STRING for CGI scripts too, since that must be %-encoded and we're currently shipping it decoded.
270 ca21e100 2021-02-04 op 2021-02-04 Omar Polo <op@omarpolo.com>
272 ca21e100 2021-02-04 op * gmid.c (main): reload configuration on SIGHUP, without disconnecting the clients
274 5f715ce4 2021-02-02 op 2021-02-02 Omar Polo <op@omarpolo.com>
276 5f715ce4 2021-02-02 op * server.c (handle_dirlist_head): print the header in the directory listing
277 87f2b68b 2021-02-02 op (open_file): cgi follows globbing rules, just like location and hostname matching
279 e17642a7 2021-02-01 op 2021-02-01 Omar Polo <op@omarpolo.com>
281 e17642a7 2021-02-01 op * parse.y (servopt): require absolute paths in config file
283 ee29b5a6 2021-01-31 op 2021-01-31 Omar Polo <op@omarpolo.com>
285 ee29b5a6 2021-01-31 op * gmid.c (main): cgi scripts now have only std{in,out,err} open
287 e9992347 2021-01-30 op 2021-01-30 Omar Polo <op@omarpolo.com>
290 e9992347 2021-01-30 op * server.c: change precedence of location rules
292 dceca3b6 2021-01-29 op 2021-01-29 Omar Polo <op@omarpolo.com>
294 dceca3b6 2021-01-29 op * iri.c (parse_authority): accept a wider range of unicode
295 dceca3b6 2021-01-29 op codepoints while parsing the host name.
297 3300cbe0 2021-01-27 op 2021-01-26 Omar Polo <op@omarpolo.com>
299 3300cbe0 2021-01-27 op * puny.c (puny_decode): initial punycode support!
301 145ba43e 2021-01-25 op 2021-01-25 Omar Polo <op@omarpolo.com>
303 a5d04ea0 2021-01-25 op * gmid.1: manpage improvements (example and usage)
305 a5d04ea0 2021-01-25 op * gmid.c (main): Dropping -C, -K, -f, changing the meaning of -d:
306 a5d04ea0 2021-01-25 op now it's the certificate directory. Serve the directory given as
307 a5d04ea0 2021-01-25 op positional argument (or the current one) when running in
308 a5d04ea0 2021-01-25 op config-less mode.
309 a5d04ea0 2021-01-25 op (gen_certificate): automatically generate a certificate
311 145ba43e 2021-01-25 op * parse.y (option): added chroot and user options
313 ba7b2faa 2021-01-24 op 2021-01-24 Omar Polo <op@omarpolo.com>
315 252908e6 2021-01-24 op * server.c (open_dir): add directory listing (disabled by default)
317 c8b74339 2021-01-24 op * parse.y (vhost): added support for location blocks
319 ba7b2faa 2021-01-24 op * server.c (send_dir): make the directory index customizable
321 ba7b2faa 2021-01-24 op 2021-01-23 Omar Polo <op@omarpolo.com>
323 ba7b2faa 2021-01-24 op * gg.c (main): added gg, a barebone gemini client. used by the
324 ba7b2faa 2021-01-24 op regress suite
326 1213c735 2021-01-21 op 2021-01-21 Omar Polo <op@omarpolo.com>
328 0ac2dcec 2021-01-21 op * configure: added a configure script
330 1213c735 2021-01-21 op * server.c (handle_handshake): glob for vhost domain
332 1213c735 2021-01-21 op * gmid.c (log_request): logs the full IRI and the response code (even for CGI)
334 17b09e3c 2021-01-18 op 2021-01-19 Omar Polo <op@omarpolo.com>
336 05c23a54 2021-01-19 op * parse.y (servopt): add "lang" server option
337 6119e13e 2021-01-19 op (servopt): moving "default type" from global options to server options
339 17b09e3c 2021-01-18 op * Dockerfile: add a dockerfile
341 e7ecf9a5 2021-01-18 op 2021-01-18 Omar Polo <op@omarpolo.com>
343 d89aa763 2021-01-18 op * parse.y (option): add mime and "default type" options for media types.
345 7a11e8a5 2021-01-17 op 2021-01-17 Omar Polo <op@omarpolo.com>
347 7a11e8a5 2021-01-17 op * sandbox.c (sandbox): added initial seccomp(2) support
349 15902770 2021-01-15 op 2021-01-15 Omar Polo <op@omarpolo.com>
351 bd726b55 2021-01-15 op * cgi.c (start_cgi): set SERVER_NAME to the vhost when executing CGI scripts
353 5bc3c98e 2021-01-15 op * parse.y (option): add ability to specify the tls versions with "protocols"
355 8696c5ea 2021-01-15 op * gmid.c (handle_open_conn): ensure the port number of the request matches
357 dafb57b8 2021-01-15 op * sandbox.c (sandbox): sandbox on OpenBSD (pledge/unveil, as before) and on FreeBSD (capsicum) too
359 6214c127 2021-01-15 op * sample.conf: added sample configuration
361 15902770 2021-01-15 op * gmid.c (main): changed behaviour: daemon off by default
362 15902770 2021-01-15 op (main): changed -c in -C (cert option)
363 15902770 2021-01-15 op (main): changed -k in -K (key option, for consistency with -C)
364 15902770 2021-01-15 op (main): added -c to load a configuration
365 15902770 2021-01-15 op (main): certs, key and doc (-C -K and -d) doesn't have a default value anymore
366 15902770 2021-01-15 op (handle_handshake): add vhosts support
368 9939ddcf 2021-01-13 op 2021-01-13 Omar Polo <op@omarpolo.com>
370 9939ddcf 2021-01-13 op * iri.c (parse_scheme): normalize scheme while parsing, so we're
371 9939ddcf 2021-01-13 op RFC3986 compliant.
373 85dff1f9 2021-01-11 op 2021-01-11 Omar Polo <op@omarpolo.com>
375 9939ddcf 2021-01-13 op * 1.4 and 1.4.1 tagged
377 85dff1f9 2021-01-11 op * gmid.c (main): ipv6 disabled by default and -6 flag to enable it
378 7b1d9790 2021-01-11 op (handle): reject non-gemini protocols with 53
380 709d6e5e 2021-01-10 op 2021-01-10 Omar Polo <op@omarpolo.com>
382 709d6e5e 2021-01-10 op * gmid.c (logs): log also the port of the client
383 33756bd2 2021-01-10 op (loop): accept both ipv4 and ipv6
385 60ff0355 2020-12-26 op 2020-12-26 Omar Polo <op@omarpolo.com>
387 60ff0355 2020-12-26 op * uri.c (parse_uri): IRI support
389 4f12842d 2020-12-21 op 2020-12-21 Omar Polo <op@omarpolo.com>
391 4f12842d 2020-12-21 op * gmid.c (main): -d supports relative paths
393 d7802bb4 2020-12-02 op 2020-12-02 Omar Polo <op@omarpolo.com>
395 d7802bb4 2020-12-02 op * gmid.c: logging reworked and daemonize. The -l option was
396 d7802bb4 2020-12-02 op removed: now it logs on syslog if -f (foreground) is not passed.
398 ae2ad03e 2020-11-18 op 2020-11-18 Omar Polo <op@omarpolo.com>
400 c603f126 2020-11-18 op * 1.3.2 tagged
402 c603f126 2020-11-18 op * gmid.c (url_after_proto): fix bug introduced in last version
403 c603f126 2020-11-18 op regarding full URLs with explicit gemini protocol.
405 dd389558 2020-11-18 op * 1.3.1 tagged
407 ae2ad03e 2020-11-18 op * gmid.c (url_after_proto): correct url parsing: accept URLs
408 ae2ad03e 2020-11-18 op without explicit protocol
409 dd389558 2020-11-18 op (url_start_of_request): correct handling of relative URLs
411 721e2325 2020-11-18 op 2020-11-17 Omar Polo <op@omarpolo.com>
413 721e2325 2020-11-18 op * gmid.c (main): add flag -p to change the port
415 a5d310bc 2020-11-10 op 2020-11-10 Omar Polo <op@omarpolo.com>
417 d431188c 2020-11-10 op * ChangeLog: 1.3 tagged, fixed ChangeLog format
419 a5d310bc 2020-11-10 op * gmid.c (open_file): added support for path parameters for CGI
422 3c19febb 2020-11-06 op 2020-11-06 Omar Polo <op@omarpolo.com>
424 0ed56567 2020-11-06 op * gmid.1: great improvements to the documentation
426 3c19febb 2020-11-06 op * gmid.c (url_after_proto): ensure that the requested protocol is
427 3c19febb 2020-11-06 op “gemini” and not something else that’s long 6 bytes.
429 aff8d190 2020-11-06 op * gmid.c (loop): added support for cgi scripts (can handle multiple
430 aff8d190 2020-11-06 op concurrently)
432 2c3a40fa 2020-11-06 op 2020-11-06 Omar Polo <op@venera>
434 2c3a40fa 2020-11-06 op * gmid.1: added option to log to a file
436 dd080e1f 2020-11-05 op 2020-11-05 Omar Polo <op@omarpolo.com>
438 dd080e1f 2020-11-05 op * gmid.c (filetypes): add MIME type for xml files
440 19f68393 2020-11-03 op 2020-11-03 Omar Polo <op@omarpolo.com>
444 d431188c 2020-11-10 op * gmid.c (main): ignore SIGPIPE
446 2b897a2c 2020-10-14 op 2020-10-14 Omar Polo <op@omarpolo.com>
450 d431188c 2020-11-10 op * switching to mmap() based file handling
452 2b897a2c 2020-10-14 op 2020-10-07 Omar Polo <op@omarpolo.com>