Project

gack

0.0
No release in over 3 years
Low commit activity in last 3 years
Gack helps you build Gemini protocol applications with Ruby.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 2.1
~> 3.10
~> 1.2
~> 0.19
 Project Readme

Gack

Gack helps you build Gemini protocol applications with Ruby.

Usage

Install gem:

gem install gack

Build an app:

require 'gack'

class App < Gack::Application
  route '/' do
    'Hello, World!'
  end
end

App.run!

TLS

Gemini requires TLS handshakes. Gack does not do TLS handshakes. You need to setup a TLS terminator. I use Nginx. Below is some quick information on how you might begin to use Nginx to terminate TLS.

Certs

Generate a self-signed .crt and .key. Example:

openssl req -newkey rsa:2048 -nodes -keyout localhost.key -nodes -x509 -out localhost.crt -subj "/CN=localhost"

Nginx

Nginx will be used for the TLS handshake and termination:

stream {

  upstream backend {
    # change this to reflect what port your Gack server is running on (default is 6565)
    server localhost:6565;
  }

  server {
    # 1965 is the default Gemini protocol port
    listen 1965 ssl;
    proxy_pass backend;

    # change these to match the directory and filename of your crt and key
    ssl_certificate     /your/localtion/to/certs/localhost.crt;
    ssl_certificate_key /your/localtion/to/localhost.key;

    ssl_protocols TLSv1.1 TLSv1.2;

    ssl_prefer_server_ciphers on;
    ssl_ciphers ECDH+AESGCM:ECDH+AES256:ECDH+AES128:DH+3DES:!ADH:!AECDH:!MD5;

    ssl_session_cache    shared:SSL:20m;
    ssl_session_timeout  4h;

    ssl_handshake_timeout 20s;
  }
}