Rename example directory to examples
This commit is contained in:
2
examples/client/.gitignore
vendored
Normal file
2
examples/client/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
client.crt
|
||||
client.key
|
||||
73
examples/client/client.go
Normal file
73
examples/client/client.go
Normal file
@@ -0,0 +1,73 @@
|
||||
// +build example
|
||||
|
||||
package main
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"crypto/tls"
|
||||
"fmt"
|
||||
"log"
|
||||
"os"
|
||||
|
||||
"git.sr.ht/~adnano/go-gemini"
|
||||
)
|
||||
|
||||
var client gemini.Client
|
||||
|
||||
func init() {
|
||||
// Configure a client side certificate.
|
||||
// To generate a certificate, run:
|
||||
//
|
||||
// openssl genrsa -out client.key 2048
|
||||
// openssl ecparam -genkey -name secp384r1 -out client.key
|
||||
// openssl req -new -x509 -sha256 -key client.key -out client.crt -days 3650
|
||||
//
|
||||
config := tls.Config{}
|
||||
cert, err := tls.LoadX509KeyPair("examples/client/client.crt", "examples/client/client.key")
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
config.Certificates = append(config.Certificates, cert)
|
||||
client.TLSConfig = config
|
||||
}
|
||||
|
||||
func makeRequest(url string) {
|
||||
resp, err := client.Request(url)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
fmt.Println("Status code:", resp.Status)
|
||||
fmt.Println("Meta:", resp.Meta)
|
||||
|
||||
switch resp.Status / 10 {
|
||||
case gemini.StatusClassInput:
|
||||
scanner := bufio.NewScanner(os.Stdin)
|
||||
fmt.Printf("%s: ", resp.Meta)
|
||||
scanner.Scan()
|
||||
query := scanner.Text()
|
||||
makeRequest(url + "?" + query)
|
||||
return
|
||||
case gemini.StatusClassSuccess:
|
||||
fmt.Print("Body:\n", string(resp.Body))
|
||||
case gemini.StatusClassRedirect:
|
||||
log.Print("Redirecting to ", resp.Meta)
|
||||
makeRequest(resp.Meta)
|
||||
return
|
||||
case gemini.StatusClassTemporaryFailure:
|
||||
log.Fatal("Temporary failure")
|
||||
case gemini.StatusClassPermanentFailure:
|
||||
log.Fatal("Permanent failure")
|
||||
case gemini.StatusClassClientCertificateRequired:
|
||||
log.Fatal("Client Certificate Required")
|
||||
default:
|
||||
log.Fatal("Protocol Error")
|
||||
}
|
||||
}
|
||||
|
||||
func main() {
|
||||
if len(os.Args) < 2 {
|
||||
log.Fatalf("usage: %s gemini://...", os.Args[0])
|
||||
}
|
||||
makeRequest(os.Args[1])
|
||||
}
|
||||
2
examples/server/.gitignore
vendored
Normal file
2
examples/server/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
server.crt
|
||||
server.key
|
||||
41
examples/server/server.go
Normal file
41
examples/server/server.go
Normal file
@@ -0,0 +1,41 @@
|
||||
// +build example
|
||||
|
||||
package main
|
||||
|
||||
import (
|
||||
"crypto/tls"
|
||||
"git.sr.ht/~adnano/go-gemini"
|
||||
"log"
|
||||
"net/url"
|
||||
)
|
||||
|
||||
func main() {
|
||||
// Load a TLS key pair.
|
||||
// To generate a TLS key pair, run:
|
||||
//
|
||||
// openssl genrsa -out server.key 2048
|
||||
// openssl ecparam -genkey -name secp384r1 -out server.key
|
||||
// openssl req -new -x509 -sha256 -key server.key -out server.crt -days 3650
|
||||
//
|
||||
config := tls.Config{}
|
||||
cert, err := tls.LoadX509KeyPair("examples/server/server.crt", "examples/server/server.key")
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
config.Certificates = append(config.Certificates, cert)
|
||||
|
||||
mux := &gemini.Mux{}
|
||||
mux.HandleFunc("/", func(url *url.URL) *gemini.Response {
|
||||
return &gemini.Response{
|
||||
Status: gemini.StatusSuccess,
|
||||
Meta: "text/gemini",
|
||||
Body: []byte("You requested " + url.String()),
|
||||
}
|
||||
})
|
||||
|
||||
server := gemini.Server{
|
||||
TLSConfig: config,
|
||||
Handler: mux,
|
||||
}
|
||||
server.ListenAndServe()
|
||||
}
|
||||
Reference in New Issue
Block a user