Python 3 library for building Gopher clients and servers
Pituophis, at the moment, requires nine modules: os, re, sockets, asyncio, ssl, mimetypes, glob, and urllib, which are standard in most Python 3.7 installations, and natsort. Pituophis can simply be loaded as a module like this:
Pituophis can act as a powerful Gopher server, with full Bucktooth-style gophermap and globbing support. Scripting is also supported through alt handlers (used in the event of a 404) or fully custom handlers (replaces Pituophis' handler entirely).
The simplest method of getting a server up and running is with the
pituophis.serve() function. See the examples and docs for more information. If you'd like to see a server built with Pituophis that can search an index, try Gophew.
Pituophis can also grab files and parse menus from Gopher servers. Simple fetching is done with
Request().stream() can be used for lower-level access as a BufferedReader. The
get functions return a Response type. See the docs for more information.
An interactive demo of Pituophis' client features is provided in the form of TreeGopher, a graphical Gopher client in <250 lines of code. It uses Pituophis, PySimpleGUI, and Pyperclip. It can browse Gopher in a hierarchical structure (similarly to WSGopher32, Cyberdog, and Little Gopher Client), cache menus, read text files, download and save binary files (writing in chunks using
Request().stream(), and running on another thread), recognize URL: links and use search services.
Getting menus and files as plain text:
pituophis.get('gopher.floodgap.com').text() pituophis.get('gopher://gopher.floodgap.com/1/').text() pituophis.get('gopher://gopher.floodgap.com:70/0/gopher/proxy').text() pituophis.get('gophers://khzae.net:105/1/').text() # gophers:// URL support
Getting a menu, parsed:
menu = pituophis.get('gopher.floodgap.com').menu() for item in menu: print(item.type) print(item.text) print(item.path) print(item.host) print(item.port)
Using search services:
Downloading a binary:
Requests can also be created from a URL:
import pituophis req = pituophis.parse_url('gopher://gopher.floodgap.com/7/v2/vs%09food') print('Getting', req.url()) rsp = req.get() print(rsp.text())