2019-12-28 20:45:20 +00:00
<!--
2019-12-19 18:27:15 +00:00
/ |
___ (___ ___|
| )| )| )
2019-12-23 02:05:48 +00:00
|__/ | / |__/
|
2019-12-28 20:45:20 +00:00
--> < p align = "center" > < img src = "./img/logo2.png" > < / p >
2019-12-19 18:27:15 +00:00
2019-12-28 20:45:20 +00:00
`phd` is an esoteric gopher server for small gopher sites.
2019-12-19 18:27:15 +00:00
2019-12-28 20:45:20 +00:00
point it at a directory and it'll serve up all its text files, sub-directories, and binary files over gopher. executable files will be run, like cgi!
2019-12-28 05:06:33 +00:00
2019-12-28 05:50:28 +00:00
special files:
2019-12-19 18:27:15 +00:00
2019-12-28 06:17:42 +00:00
- **header.gph**: if it exists in a directory, its content will be shown above the directory's content. put ascii art in it.
2019-12-28 05:50:28 +00:00
- **footer.gph**: same, but will be shown below a directory's content.
- **index.gph**: completely replaces a directory's content with what's in this file.
2019-12-28 06:27:56 +00:00
- **??.gph**: visiting gopher://yoursite/1/dog/ will try to render `dog.gph` from disk.
2019-12-28 06:17:42 +00:00
- **.reverse**: if this exists, the directory contents will be listed in reverse alphanumeric order. useful for phloggin'.
2019-12-28 05:50:28 +00:00
2019-12-28 20:45:20 +00:00
any line in a `.gph` file that doesn't contain tabs (`\t`) and doesn't start with an ` i` will get an `i` automatically prefixed, turning it into a gopher information item.
2019-12-19 18:27:15 +00:00
2019-12-28 20:45:20 +00:00
any `.gph` file that is marked **executable** with be run as if it were a shell script and its output will be sent to the client. it will be passed three arguments: the query string (if any, the host, and the port. do with them what you will.
2019-12-28 07:46:27 +00:00
2019-12-28 20:45:20 +00:00
for example:
2019-12-28 07:46:27 +00:00
$ cat echo.gph
#!/bin/sh
2019-12-28 09:27:29 +00:00
echo "Hi, world! You said:" $1
2019-12-28 20:45:20 +00:00
echo "1Visit Gopherpedia / gopherpedia.com 70"
2019-12-28 07:46:27 +00:00
2019-12-28 20:45:20 +00:00
then:
2019-12-28 07:46:27 +00:00
2019-12-28 09:27:29 +00:00
$ gopher-client gopher://localhost/1/echo?something
2019-12-28 20:45:20 +00:00
[INFO] Hi, world! You said: something
[LINK] Visit Gopherpedia
or more seriously:
$ cat figlet.gph
#!/bin/sh
figlet $1
then:
$ gopher-client gopher://localhost/1/figlet?hi gopher
[INFO] _ _ _
[INFO] | |__ (_) __ _ ___ _ __ | |__ ___ _ __
[INFO] | '_ \| | / _` |/ _ \| '_ \| '_ \ / _ \ '__|
[INFO] | | | | | | (_| | (_) | |_) | | | | __ / |
[INFO] |_| |_|_| \__, |\___/| .__/|_| |_|\___|_|
[INFO] |___/ |_|
2019-12-28 07:46:27 +00:00
2019-12-19 18:27:15 +00:00
## usage
2019-12-23 02:05:48 +00:00
phd [options] < directory >
2019-12-19 18:27:15 +00:00
phd ./path/to/gopher/root # Serve directory over port 70.
2019-12-23 02:05:48 +00:00
phd -p 7070 docs # Serve 'docs' directory on port 7070
phd -h localhost # Serve cwd using hostname "localhost".
2019-12-19 18:27:15 +00:00
## development
cargo run -- ./path/to/gopher/site
## resources
- https://github.com/gophernicus/gophernicus/blob/master/README.Gophermap
- https://gopher.zone/posts/how-to-gophermap/
2019-12-28 00:53:36 +00:00
- [rfc 1436 ](https://tools.ietf.org/html/rfc1436 )
2019-12-19 18:27:15 +00:00
2019-12-28 06:27:56 +00:00
## todo
- [ ] script mode
- [ ] log options
2019-12-28 06:28:13 +00:00
- [ ] 404 message