diff options
author | bptato <nincsnevem662@gmail.com> | 2023-12-15 19:16:41 +0100 |
---|---|---|
committer | bptato <nincsnevem662@gmail.com> | 2023-12-15 19:18:32 +0100 |
commit | b8becdc0061eea161a6fbe11bc53032e7a0a4479 (patch) | |
tree | 55b53a4024d10ce66be15331bc2db25f0bf06840 | |
parent | fbae4ab9127dc4dd9a707c27f8c0bf25a8289e7d (diff) | |
download | chawan-b8becdc0061eea161a6fbe11bc53032e7a0a4479.tar.gz |
Add doc/protocols
-rw-r--r-- | Makefile | 4 | ||||
-rw-r--r-- | README.md | 3 | ||||
-rw-r--r-- | doc/protocols.md | 149 |
3 files changed, 154 insertions, 2 deletions
diff --git a/Makefile b/Makefile index ca9d67e3..84dd7612 100644 --- a/Makefile +++ b/Makefile @@ -153,7 +153,7 @@ clean: .PHONY: manpage manpage: $(OBJDIR)/man/cha-config.5 $(OBJDIR)/man/cha-mailcap.5 \ $(OBJDIR)/man/cha-mime.types.5 $(OBJDIR)/man/cha-localcgi.5 \ - $(OBJDIR)/man/cha-urimethodmap.5 \ + $(OBJDIR)/man/cha-urimethodmap.5 $(OBJDIR)/man/cha-protocols.5 \ $(OBJDIR)/man/cha.1 .PHONY: install @@ -180,6 +180,7 @@ install: install -m644 "$(OBJDIR)/man/cha-mime.types.5" "$(DESTDIR)$(MANPREFIX5)"; \ install -m644 "$(OBJDIR)/man/cha-localcgi.5" "$(DESTDIR)$(MANPREFIX5)"; \ install -m644 "$(OBJDIR)/man/cha-urimethodmap.5" "$(DESTDIR)$(MANPREFIX5)"; \ + install -m644 "$(OBJDIR)/man/cha-protocols.5" "$(DESTDIR)$(MANPREFIX5)"; \ install -m644 "$(OBJDIR)/man/cha.1" "$(DESTDIR)$(MANPREFIX1)"; \ fi @@ -203,6 +204,7 @@ uninstall: rm -f "$(DESTDIR)$(MANPREFIX5)/cha-mime.types.5" rm -f "$(DESTDIR)$(MANPREFIX5)/cha-localcgi.5" rm -f "$(DESTDIR)$(MANPREFIX5)/cha-urimethodmap.5" + rm -f "$(DESTDIR)$(MANPREFIX5)/cha-cha-protocols.5" rm -f "$(DESTDIR)$(MANPREFIX1)/cha.1" .PHONY: submodule diff --git a/README.md b/README.md index f2f56555..bd746c48 100644 --- a/README.md +++ b/README.md @@ -61,7 +61,7 @@ Currently implemented features are: implemented * cookies * Supports several protocols: HTTP(S), FTP, Gopher, Gemini, Finger -* Can load user-defined protocols/files using [local CGI](doc/localcgi.md), +* Can load user-defined protocols/file formats using [local CGI](doc/localcgi.md), [urimethodmap](doc/urimethodmap.md) and [mailcap](doc/mailcap.md) ...with a lot more [planned](todo). @@ -74,6 +74,7 @@ Currently implemented features are: * mime.types: [doc/mime.types.md](doc/mime.types.md) * urimethodmap: [doc/urimethodmap.md](doc/urimethodmap.md) * local CGI: [doc/localcgi.md](doc/localcgi.md) +* protocols: [doc/protocols.md](doc/protocols.md) ## Neighbors diff --git a/doc/protocols.md b/doc/protocols.md new file mode 100644 index 00000000..d2fe8804 --- /dev/null +++ b/doc/protocols.md @@ -0,0 +1,149 @@ +<!-- MANON +% cha-protocols(5) | Protocol support in Chawan +MANOFF --> + +# Protocols + +Chawan supports downloading resources from various protocols: HTTP, FTP, +Gopher, Gemini, and Finger. Details on these protocols, and information +on how users can add support to their preferred protocols is outlined in +this document. + +<!-- MANOFF --> +**Table of contents** + +* [HTTP](#http) +* [FTP](#ftp) +* [Gopher](#gopher) +* [Gemini](#gemini) +* [Finger](#finger) +* [Local schemes: file:, about:, data:-](#local-schemes-file-about-data) +* [Custom protocols](#custom-protocols) + +<!-- MANON --> + +## HTTP + +HTTP/s support is based on libcurl; supported features largely depend on +your libcurl version. The adapter is found at `adapter/protocol/http.nim`. + +The libcurl HTTP adapter can take arbitrary headers and POST data, is able +to use passed userinfo data (`https://username:password@example.org`), and +returns all headers and response body it receives from libcurl without +exception. + +It is possible to build these adapters using +[curl-impersonate](https://github.com/lwthiker/curl-impersonate) by setting +the compile-time variable CURLLIBNAME to `libcurl-impersonate.so`. Note that +for curl-impersonate to work, you must set `network.default-headers = {}` +in the Chawan config. (Otherwise, the libcurl adapter will happily override +curl-impersonate headers, which is probably not what you want.) + +The `bonus/libfetch` directory contains an alternative HTTP client, which is +based on FreeBSD libfetch. It is mostly a proof of concept, as FreeBSD +libfetch HTTP support is very limited; in particular, it does not support +HTTP headers (beyond some basic request headers), so e.g. cookies will +not work. + +## FTP + +Chawan supports FTP through the `adapter/protocol/ftp.nim` libcurl adapter. For +directory listings, it assumes UNIX output style, and will probably break +horribly on receiving anything else. Otherwise, the directory listing view +is identical to (and uses the same code path as) the file:// directory listing. + +In theory, SFTP and FTPS should be supported as well. In practice, SFTP does +not really work yet because there is no way to specify private keys, and I +have never seen an FTPS server in the wild so I assume it is broken too. + +## Gopher + +Gopher is supported through the `adapter/protocol/gopher.nim` libcurl +adapter. Gopher directories are passed as the `text/gopher` type, and +`adapter/format/gopher.nim` takes care of converting this to HTML. + +Gopher selector types are converted to MIME types when possible; note however, +that this is very limited, as most of them (like `s` sound, or `I` image) +cannot be unambiguously converted without some other sniffing method. Chawan +will fall back to extension-based detection in these cases, and in the worst +case may end up with `application/octet-stream`. + +## Gemini + +Chawan's gemini adapter (in `adapter/protocol/gmifetch.c`) is a C program. It +requires OpenSSL to work. + +Note that gmifetch was written as a candidate for the bonus/ directory when +Chawan's local CGI support was still in early stages of development, and +thus has some legacy issues. In particular: + +* It takes the URL through `$QUERY_STRING`, and re-parses it for its needs. In + all likelihood it breaks on IPv6 URLs. Needless to say this is a bad idea + and should not be imitated. +* Error messages are returned as full documents. +* It does not support proxies. +* It does not support private key authentication. + +`adapter/format/gmi2html.c` is its companion program to convert the +`text/gemini` file format to HTML. Note that the gemtext specification insists +on line breaks being visually significant, and forbids their collapsing onto +a single line; gmi2html respects this, with the unfortunate effect that the +generated HTML page is just a bunch of lines with lots of `<BR>` tags. + +## Finger + +Finger is supported through the `adapter/protocol/cha-finger` shell script. +It is implemented as a shell script because of the protocol's simplicity. +cha-finger uses the `curl` program's telnet:// protocol to make requests. +As such, it will not work if `curl` is not installed. + +Aspiring protocol adapter writers are encouraged to study cha-finger for +a simple example of how a custom protocol handler could be written. + +## Local schemes: file:, about:, data:, cgi-bin: + +While these are not necessarily *protocols*, they are implemented similarly +to the protocols listed above (and thus can also be replaced, if the user +wishes; see below). + +`file:` loads a file from the local filesystem. In case of directories, it +shows the directory listing like the FTP protocol does. + +`about:` contains informational pages about the browser. At the time of +writing, the following pages are available: `about:chawan`, `about:blank` +and `about:license`. + +`data:` decodes a data URL as defined in RFC 2397. + +Finally, `cgi-bin:` executes a local CGI script. This scheme is used for +the actual implementations of all supported protocols and can *not* +be replaced. + +## Custom protocols + +Chawan itself is protocol-agnostic. This means that the `cha` binary itself +does not know much about the protocols listed above; instead, it loads +these through a combination of local CGI, urimethodmap, and if conversion +to HTML or plain text is necessary, mailcap (using x-htmloutput and +copiousoutput). + +urimethodmap can also be used to override default handlers for the protocols +listed above. This is similar to how w3m allows you to override the default +directory listing display, but much more powerful; this way, any library +or program that can retrieve and output text through a certain protocol can +be combined with Chawan. + +For example, consider the urimethodmap definition of cha-finger: + +``` +finger: cgi-bin:cha-finger +``` + +This commands Chawan to load the cha-finger CGI script, setting the +`$MAPPED_URI_*` variables to the target URL's parts in the process. + +Then, cha-finger uses these passed parts to construct an appropriate curl +command that will retrieve the specified `finger:` URL; it prints the header +'Content-Type: text/plain' to the output, then an empty line, then the body +of the retrieved resource. If an error is encountered, it prints a +`Cha-Control` header with an error code and a specific error message instead. |