2016-09-14 03:45:49 +00:00
|
|
|
# Gopher protocol library for Golang
|
|
|
|
|
2018-12-30 13:29:30 +00:00
|
|
|
[![Build Status](https://cloud.drone.io/api/badges/prologic/go-gopher/status.svg)](https://cloud.drone.io/prologic/go-gopher)
|
2017-06-21 06:48:48 +00:00
|
|
|
[![CodeCov](https://codecov.io/gh/prologic/go-gopher/branch/master/graph/badge.svg)](https://codecov.io/gh/prologic/go-gopher)
|
2017-06-21 07:03:34 +00:00
|
|
|
[![Go Report Card](https://goreportcard.com/badge/prologic/go-gopher)](https://goreportcard.com/report/prologic/go-gopher)
|
2017-06-21 06:35:09 +00:00
|
|
|
[![GoDoc](https://godoc.org/github.com/prologic/go-gopher?status.svg)](https://godoc.org/github.com/prologic/go-gopher)
|
2018-12-30 13:29:30 +00:00
|
|
|
[![Sourcegraph](https://sourcegraph.com/github.com/prologic/go-gopher/-/badge.svg)](https://sourcegraph.com/github.com/prologic/go-gopher?badge)
|
2016-09-14 07:36:45 +00:00
|
|
|
|
2016-09-14 03:45:49 +00:00
|
|
|
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
|
2016-10-01 07:33:55 +00:00
|
|
|
|
|
|
|
```#!bash
|
2017-06-21 06:51:34 +00:00
|
|
|
$ go get github.com/prologic/go-gopher
|
2016-10-01 07:33:55 +00:00
|
|
|
```
|
2016-09-14 03:45:49 +00:00
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
```#!go
|
|
|
|
import "github.com/prologic/go-gopher"
|
|
|
|
```
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
|
|
|
### Client
|
|
|
|
|
|
|
|
```#!go
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/prologic/go-gopher"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
res, _ := gopher.Get("gopher://gopher.floodgap.com/")
|
|
|
|
bytes, _ = res.Dir.ToText()
|
|
|
|
fmt.Println(string(bytes))
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Server
|
|
|
|
|
|
|
|
```#!go
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"github.com/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))
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-10-01 07:33:55 +00:00
|
|
|
## Related
|
|
|
|
|
|
|
|
Related projects:
|
|
|
|
|
|
|
|
- [gopherproxy](https://github.com/prologic/gopherproxy)
|
|
|
|
gopherproxy is Gopher to HTTP proxy that uses go-gopher
|
|
|
|
for all of its core functionality.
|
|
|
|
|
|
|
|
- [gopherclient](https://github.com/prologic/gopherclient)
|
|
|
|
gopherclient is a cross-platform QT/QML GUI Gopher Client
|
|
|
|
using the gopherproxy library as its backend.
|
|
|
|
|
2016-09-14 03:45:49 +00:00
|
|
|
## License
|
|
|
|
|
|
|
|
MIT
|