Gopher (RFC 1436) protocol library for the Go (Golang) programming language supporting both client and server
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
James Mills c5e856b800
Remove some large files
6 months ago
.github Upgrade to GitHub-native Dependabot (#18) 7 months ago
examples Remove some large files 6 months ago
testdata Fix tests (#12) 2 years ago
.gitignore Remove some large files 6 months ago
LICENSE Added LICENSE 5 years ago
Makefile Migrate to Drone CI 3 years ago
README.md Fix import paths 7 months ago
_config.yml Set theme jekyll-theme-hacker 3 years ago
go.mod Moved to git.mills.io 7 months ago
go.sum Bump github.com/stretchr/testify from 1.6.1 to 1.7.0 (#16) 1 year ago
gopher.go Fix import paths 7 months ago
gopher_test.go Fix import paths 7 months ago

README.md

Gopher protocol library for Golang

Build Status CodeCov Go Report Card GoDoc Sourcegraph

This is a standards compliant Gopher library for the Go programming language implementing the RFC 1436 specification. The library includes both client and server handling and examples of each.

Installation

$ go get git.mills.io/prologic/go-gopher

Usage

import "git.mills.io/prologic/go-gopher"

Example

Client

package main

import (
	"fmt"

	"git.mills.io/prologic/go-gopher"
)

func main() {
	res, _ := gopher.Get("gopher://gopher.floodgap.com/")
	bytes, _ := res.Dir.ToText()
	fmt.Println(string(bytes))
}

Server

package main

import (
	"log"

	"git.mills.io/prologic/go-gopher"
)

func hello(w gopher.ResponseWriter, r *gopher.Request) {
	w.WriteInfo("Hello World!")
}

func main() {
	gopher.HandleFunc("/hello", hello)
	log.Fatal(gopher.ListenAndServe("localhost:70", nil))
}

Related projects:

  • gopherproxy gopherproxy is Gopher to HTTP proxy that uses go-gopher for all of its core functionality.

  • gopherclient gopherclient is a cross-platform QT/QML GUI Gopher Client using the gopherproxy library as its backend.

License

MIT