aboutsummaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
authoradnano <[email protected]>2020-09-27 20:34:59 -0400
committeradnano <[email protected]>2020-09-27 20:34:59 -0400
commitf6be76f8b80b0f2e76e3fb7b61ca48785ac0d7c6 (patch)
tree5e5acf1e03d83e7c73c7d70ab83b28b09b2c820f /examples
parentChange package name to gmi (diff)
downloadgo-gemini-f6be76f8b80b0f2e76e3fb7b61ca48785ac0d7c6.tar.xz
go-gemini-f6be76f8b80b0f2e76e3fb7b61ca48785ac0d7c6.zip
examples/client: Handle relative redirects
Diffstat (limited to 'examples')
-rw-r--r--examples/auth/auth.go6
-rw-r--r--examples/client/client.go10
2 files changed, 9 insertions, 7 deletions
diff --git a/examples/auth/auth.go b/examples/auth/auth.go
index 6abd0c8..8567e90 100644
--- a/examples/auth/auth.go
+++ b/examples/auth/auth.go
@@ -82,8 +82,7 @@ func login(rw *gmi.ResponseWriter, req *gmi.Request) {
sessions[fingerprint] = &session{
username: username,
}
- // TODO: Remove scheme and host once example client can handle relative redirects
- rw.WriteHeader(gmi.StatusRedirect, "gemini://localhost/login/password")
+ rw.WriteHeader(gmi.StatusRedirect, "/login/password")
}
} else {
rw.WriteHeader(gmi.StatusClientCertificateRequired, "Certificate required")
@@ -103,9 +102,8 @@ func loginPassword(rw *gmi.ResponseWriter, req *gmi.Request) {
} else {
expected := logins[session.username].password
if password == expected {
- // TODO: Remove scheme and host once example client can handle relative redirects
session.authorized = true
- rw.WriteHeader(gmi.StatusRedirect, "gemini://localhost/profile")
+ rw.WriteHeader(gmi.StatusRedirect, "/profile")
} else {
rw.WriteHeader(gmi.StatusInput, "Wrong password. Please try again")
}
diff --git a/examples/client/client.go b/examples/client/client.go
index b209d0e..c83fb88 100644
--- a/examples/client/client.go
+++ b/examples/client/client.go
@@ -64,12 +64,16 @@ func sendRequest(req *gmi.Request) error {
fmt.Print(string(resp.Body))
return nil
case gmi.StatusClassRedirect:
- fmt.Println("Redirecting to ", resp.Meta)
- req, err := gmi.NewRequest(resp.Meta)
+ fmt.Println("Redirecting to", resp.Meta)
+ // Make the request to the same host
+ red, err := gmi.NewProxyRequest(req.Host, resp.Meta)
if err != nil {
return err
}
- return sendRequest(req)
+ // Handle relative redirects
+ red.URL = req.URL.ResolveReference(red.URL)
+ fmt.Println(red.URL, red.Host)
+ return sendRequest(red)
case gmi.StatusClassTemporaryFailure:
return fmt.Errorf("Temporary failure: %s", resp.Meta)
case gmi.StatusClassPermanentFailure: