💾 Archived View for thelambdalab.xyz › phlog › 2020-05-13-Finger.txt captured on 2020-09-24 at 01:06:32.

View Raw

More Information

-=-=-=-=-=-=-

Finger
------

It's fun to see ideas flitter like leaves across distinct and highly
niche communities.  The last few days has seen Gemini hit the
front page of Hacker News twice, one of which was a post reporting the
existence of the Castor [1] client directed at the "small internet" and
hence additionally supports the old Finger protocol.  Of course this
immediately had me reminiscing.

One of my earliest interactions with this protocol is solidly etched
in my memory for all the wrong reasons.  Back in 1994 or so I was
a young teenager excitedly exploring the internet via various door software
made available by my local BBS.  One of these doors allowed you to send
finger requests, and for some reason I requested the finger directory
of AusCERT: an Australia anti computer-crime organization.  This led
to a then highly-terrifying and now highly-embarrassing series of emails between
some scary people at AusCERT, the poor SysOp of the BBS, and me, while
the whole thing was sorted out and explained away as a silly kid pressing
buttons he shouldn't have pressed.
Shaun: if you happen upon this, I'm so sorry - you should know that I
still feel terrible about this! :-(

Erm yeah, so Finger.  Turns out I wasn't the only one reminiscing:
Mozz took the hint [2] from Castor and added a new finger server to
his machine at finger://mozz.us/michael.  Furthermore, he listed several
other servers still running scattered around gopherspace/geminispace.

Now that there are finger:// URLs popping up with apparent regularity,
I had to go and add finger support to Elpher, so that these links
resolve.  (Which they now do, as of version 2.6.)  Stupidly, I only
realized/remembered after finishing this that finger and gopher fit together
quite neatly, meaning that I could have simply interpreted finger:// addresses
as gopher:// addresses with a selector type of 0 instead of implementing
a simple-yet-dedicated handler.  However, now that it's done, I think
the way I chose is semantically cleaner as it means that Elpher is always
able to distinguish between gopher and finger pages.

(One fun thing about elpher, and I suspect it shares this with many
other text browsers, is that because it turns any and all URLs in
plain text into clickable links, it's absolutely possible to have an
easily navigable web-like experience composed entirely of plain text
finger pages.)

Of course, I've also hacked together the worlds stupidest fingerd by
copying Michael's systemd socket approach in combination with a 4 line
bash script: finger://thelambdalab.xyz/plugd.  Don't get too excited
though, it lacks even the most basic ascii artistry.

Anyway, that's enough navel-gazing for one evening!

Okay, maybe just one final comment - I've started to notice people
taking the text flow parts of the text/gemini mimetype spec seriously.
To this point I've been completely ignoring this in Elpher as much of
this seemed to be in a constant state of flux.  For instance, I've
completely lost track of the numerous deep threads on the gemini list
discussing when/when not to re-flow text.  However it looks like things
are starting to settle in ways that make text rendered using Elpher's
default Gemini renderer difficult to read, as it produces long lines
with non-word-sensitive wrapping.  Enabling visual-line-mode can
alleviate this, but things go back to ugly when following links.

If you happen to be one of the courageous few who are using elpher as a tool
for gemini exploration, expect some improvements in this area shortly.

Tschüss!

---
[1]: https://git.sr.ht/~julienxx/castor
[2]: gemini://mozz.us/journal/2020-04-29.gmi