aboutsummaryrefslogtreecommitdiff
path: root/Makefile
AgeCommit message (Collapse)Author
2022-04-07install gmid.conf.5 tooOmar Polo
2022-03-29fix `make static': compile `gg' too!Omar Polo
2022-03-26add target `test' alias for `regress'Omar Polo
2022-02-03add gg to `make regress` dependenciesAnna “CyberTailor”
2022-01-30install gg tooOmar Polo
2022-01-30typoOmar Polo
2022-01-03track file dependency using -MMD if availableOmar Polo
While here, move the SRCS variable to the configure and add the -includes in Makefile.local; it de-clutters the Makefile a bit.
2022-01-03add `gg' to the list of things to cleanOmar Polo
2022-01-03remove TAGS and compile_flags.txt from the list of default actionsOmar Polo
2022-01-02fix regress when TESTS is more than one wordOmar Polo
2022-01-02make clean: don't clean regress, add cleanall for thatOmar Polo
2021-12-29add ability to proxy requestsOmar Polo
Add to gmid the ability to forwad a request to another gemini server and thus acting like a reverse proxy. The current syntax for the config file is server "example.com" { ... proxy relay-to host:port } Further options (like the use of custom certificates) are planned. cf. github issue #7
2021-12-29reimplement ggOmar Polo
This is a better version of gg. Initially it grew with flags directly needed to the specific test cases I wanted to write, so it's ugly to use but handy for tests. This is a new and re-thought implementation that it is (hopefully) easier to use both and "curl-like for gemini" but also for scripts and tests cases. One completely new feature is the proxying support with -P to send the request to the given host.
2021-10-07allow to run only a subset of the runtime testsOmar Polo
with make TESTS='test_1 test_2 ...' regress now it's possible to run only that specified subset of tests. It's really useful during debugging :)
2021-07-11fix "warning: jobserver unavailable: using -j1"Anna “CyberTailor”
https://www.gnu.org/software/make/manual/html_node/Error-Messages.html
2021-06-16remove last occurrences of lexOmar Polo
2021-06-16drop the dependency on lex by implementing yylex by ourselvesOmar Polo
The actual implementation is based off doas' parse.y. This gave us various benefits, like cleaner code, \ to break long lines, better handling of quotes etc...
2021-05-24move gg to regressOmar Polo
2021-05-09fastcgi: a first implementationOmar Polo
Not production-ready yet, but it's a start. This adds a third ``backend'' for gmid: until now there it served local files or CGI scripts, now FastCGI applications too. FastCGI is meant to be an improvement over CGI: instead of exec'ing a script for every request, it allows to open a single connection to an ``application'' and send the requests/receive the responses over that socket using a simple binary protocol. At the moment gmid supports three different methods of opening a fastcgi connection: - local unix sockets, with: fastcgi "/path/to/sock" - network sockets, with: fastcgi tcp "host" [port] port defaults to 9000 and can be either a string or a number - subprocess, with: fastcgi spawn "/path/to/program" the fastcgi protocol is done over the executed program stdin of these, the last is only for testing and may be removed in the future. P.S.: the fastcgi rule is per-location of course :)
2021-04-25sort the auto index alphabeticallyOmar Polo
2021-04-14hide output of etagsOmar Polo
even the message "sh: etags: not such file or directory" or whatever seems to be confusing for users, so silent it. (maybe it would be better not to automatically generate the TAGS, but it's so handy...)
2021-03-29fix static targetOmar Polo
2021-02-23make sure -o is passed to ${CC} in suffix ruleOmar Polo
2021-02-23clean objects in compat dirOmar Polo
2021-02-07improve logs managementOmar Polo
2021-02-01drop unused target iri_testOmar Polo
2021-02-01generate compile_flags for clangdOmar Polo
2021-01-30typoOmar Polo
2021-01-30remove unused targetOmar Polo
"test" was replaced by "regress" a while ago
2021-01-27use starts_with in puny.cOmar Polo
2021-01-27initial punycode supportOmar Polo
2021-01-23gg may need some compatOmar Polo
2021-01-23use gg instead of gg.py for the regression suiteOmar Polo
2021-01-23add gg, a barebones Gemini clientOmar Polo
2021-01-22brand new regress suiteOmar Polo
2021-01-21improve install targetOmar Polo
2021-01-21add a configure script and some compatOmar Polo
tested on openbsd, alpine and void
2021-01-18remove README.md targetOmar Polo
leftover from when README.md was generated by gmid.1
2021-01-18improve mime handlingOmar Polo
we still have an hardcoded list, but this implements the API needed to modify the mappings.
2021-01-17reorganize: move bunch of functions to server.cOmar Polo
cgi.c wasn't really needed; it better to group all the server related functions together, cgi or not. Now gmid.c contains only startup and utility code.
2021-01-17build docs + install and static targetsOmar Polo
2021-01-17add runtime tests for the serverOmar Polo
2021-01-16split into two processes: listener and executorOmar Polo
this way, we can sandbox the listener with seccomp (todo) or capsicum (already done) and still have CGI scripts. When we want to exec, we tell the executor what to do, the executor executes the scripts and send the fd backt to the listener.
2021-01-15move cgi stuff to its own fileOmar Polo
2021-01-15sandbox also on FreeBSD with capsicumOmar Polo
2021-01-15conf & vhostsOmar Polo
* gmid.c (main): changed behaviour: daemon off by default (main): changed -c in -C (cert option) (main): changed -k in -K (key option, for consistency with -C) (main): added -c to load a configuration (main): certs, key and doc (-C -K and -d) doesn't have a default value anymore (handle_handshake): add vhosts support
2021-01-11s/uri/iri since we accept IRIsOmar Polo
2021-01-11new README + wording in manpageOmar Polo
2021-01-09switch to Bjoern Hoehrmann UTF-8 decoderOmar Polo
It's correct, while my hacked valid_multibyte_utf8 would allow things that aren't technically UTF8.
2020-12-25implement a valid RFC3986 (URI) parserOmar Polo
Up until now I used a "poor man" approach: the uri parser is barely a parser, it tries to extract the path from the request, with some minor checking, and that's all. This obviously is not RFC3986-compliant. The new RFC3986 (URI) parser should be fully compliant. It may accept some invalid URI, but shouldn't reject or mis-parse valid URI. (in particular, the rule for the path is way more relaxed in this parser than it is in the RFC text). A difference with RFC3986 is that we don't even try to parse the (optional) userinfo part of a URI: following the Gemini spec we treat it as an error. A further caveats is that %2F in the path part of the URI is indistinguishable from a literal '/': this is NOT conforming, but due to the scope and use of gmid, I don't see how treat a %2F sequence in the path (reject the URI?).