Newsgrouper - a web interface to usenet newsgroups
This is the Tcl code used to run my site https://newsgrouper.org.uk.
It is not currently in a form where it would be very easy for someone else to install, but I'm making it available just in case anyone is interested. It has only been tested on Debian 12.
I have moved confidential parameters like login credentials for the usenet server into config files, and I supply only dummy sample versions here. But there are many other things hard-coded which ideally would be configurable.
Prerequisites
- Tcl 9.0
- Tk (only needed for the user_admin program)
- Tcllib
- Tclhttpd
- TclTls (if https support is wanted)
- Retcl (Tcl interface to Redis)
- Tclsqlite (Tcl interface to sqlite)
- Redis (any of the compatible forks should also work but I have not tested this)
- NNTP access to a usenet server
- X-Face support needs the
uncompface
program (for Debian this is part of thecompface
package)
Downloads
You can download the code from The Download Page.
Architecture
Newsgrouper loads news headers and articles on-demand from one or more usenet servers. These are then cached locally for configurable times. This allows it to offer the full range of groups available on the server without needing huge local resources.
The web server used here is Tclhttpd, which is itself implemented in Tcl. It is customised for this purpose by loading more Tcl code, principally server/news_code.tcl
which generates all the Newsgrouper web pages on demand.
Communication with the usenet server(s) is delegated to separate newsgetter
processes. Each of these opens one NNTP connection to a usenet server. Most servers will permit up to 4 concurrent connections per login, so up to 4 newsgetter
processes can be run per server.
There is also a newsutility
process, currently its only job is to generate PNG images from X-Face headers.
Coordination of these processes and caching of their results is done through Redis, using the DisTcl system - see https://wiki.tcl-lang.org/DisTcl for more info about this.
User login info, both for registered users and guests, is kept in a single sqlite table. A utility program user_admin
can be used to initialise the database and to add registered users.
Other user-specific info like their preferences and which groups they read is kept in Redis.
License
This software uses the ISC LICENSE:
Copyright (c) 2024 Colin G. Macleod
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.