Skip to content

An implementation of the Gemini protocol for GNU Guile

License

LGPL-3.0, GPL-3.0 licenses found

Licenses found

LGPL-3.0
COPYING.LESSER
GPL-3.0
COPYING
Notifications You must be signed in to change notification settings

flatwhatson/guile-gemini

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

guile-gemini

An implementation of the Gemini protocol for GNU Guile, using fibers and gnutls.

Installation

This project provides a package definition for GNU Guix, making it easy to install from a cloned repository:

guix package -f path/to/guile-gemini/guix.scm

Development

This project provides a .envrc for direnv to simplify setting up a development environment, using the Guix package definition to automatically set up dependencies and paths when working in the project directory.

To enable direnv for this project (after installing direnv itself):

cd guile-gemini
direnv allow

If you would prefer to do things manually, the following will set up an equivalent environment:

cd guile-gemini
guix shell -Df guix.scm
export GUILE_LOAD_PATH="$PWD/src:$GUILE_LOAD_PATH"

Documentation

Coming soon!

Examples

Run the example server:

# Generate a self-signed certificate for host "localhost"
openssl req -x509 -newkey rsa:4096 \
 -keyout server-key.pem \
 -out server-cert.pem \
 -nodes -days 365 -subj /CN=localhost

# Run the server, listening on localhost:1965 by default
example/hello-world.scm --cert server-cert.pem --key server-key.pem

Make a request to the local server using the example client:

example/gem-fetch.scm localhost

The example client works on real-world Gemini URIs:

# Short URIs are supported
example/gem-fetch.scm gemini.circumlunar.space

# Full URIs are also supported
example/gem-fetch.scm gemini://gemini.circumlunar.space:1965/

The example client supports client certificates:

# Generate a self-signed certificate for user "Anonymous"
openssl req -x509 -newkey rsa:4096 \
 -keyout client-key.pem \
 -out client-cert.pem \
 -nodes -days 365 -subj /CN=Anonymous

# Request localhost using these credentials
example/gem-fetch.scm localhost -c client-cert.pem -k client-key.pem

License

This library is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with this program. If not, see http://www.gnu.org/licenses/.

See COPYING and COPYING.LESSER for details.

About

An implementation of the Gemini protocol for GNU Guile

Resources

License

LGPL-3.0, GPL-3.0 licenses found

Licenses found

LGPL-3.0
COPYING.LESSER
GPL-3.0
COPYING

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published