Start of indieauth for backend
This commit is contained in:
parent
8083f50f6a
commit
1b5c029c7b
|
@ -22,12 +22,15 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"regexp"
|
"regexp"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/garyburd/redigo/redis"
|
"github.com/garyburd/redigo/redis"
|
||||||
|
"github.com/pstuifzand/ekster/pkg/indieauth"
|
||||||
"github.com/pstuifzand/ekster/pkg/microsub"
|
"github.com/pstuifzand/ekster/pkg/microsub"
|
||||||
|
"github.com/pstuifzand/ekster/pkg/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -51,10 +54,58 @@ type mainHandler struct {
|
||||||
|
|
||||||
func (h *mainHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
func (h *mainHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.Method == http.MethodGet {
|
if r.Method == http.MethodGet {
|
||||||
fmt.Fprintln(w, "<h1>Ekster - Microsub server</h1>")
|
if r.URL.Path == "/" {
|
||||||
fmt.Fprintln(w, `<p><a href="/settings">Settings</a></p>`)
|
fmt.Fprintln(w, "<h1>Ekster - Microsub server</h1>")
|
||||||
|
fmt.Fprintln(w, `<p><a href="/settings">Settings</a></p>`)
|
||||||
|
fmt.Fprintln(w, `
|
||||||
|
<h2>Sign in to Ekster</h2>
|
||||||
|
<form action="/auth" method="post">
|
||||||
|
<input type="text" name="url" placeholder="https://example.com/">
|
||||||
|
<button type="submit">Login</button>
|
||||||
|
</form>
|
||||||
|
`)
|
||||||
|
} else if r.URL.Path == "/auth/callback" {
|
||||||
|
}
|
||||||
|
} else if r.Method == http.MethodPost {
|
||||||
|
if r.URL.Path == "/auth" {
|
||||||
|
// redirect to endpoint
|
||||||
|
me := r.Form.Get("url")
|
||||||
|
meURL, err := url.Parse(me)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, fmt.Sprintf("Bad Request: %s", err.Error()), 400)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
endpoints, err := indieauth.GetEndpoints(meURL)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, fmt.Sprintf("Bad Request: %s", err.Error()), 400)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
authURL, err := url.Parse(endpoints.AuthorizationEndpoint)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, fmt.Sprintf("Bad Request: %s", err.Error()), 400)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
state := util.RandStringBytes(16)
|
||||||
|
clientID := "https://p83.nl/microsub-client"
|
||||||
|
|
||||||
|
redirectURI := fmt.Sprintf("%s/auth/callback", os.Getenv("EKSTER_BASEURL"))
|
||||||
|
|
||||||
|
q := authURL.Query()
|
||||||
|
q.Add("response_type", "id")
|
||||||
|
q.Add("me", meURL.String())
|
||||||
|
q.Add("client_id", clientID)
|
||||||
|
q.Add("redirect_uri", redirectURI)
|
||||||
|
q.Add("state", state)
|
||||||
|
authURL.RawQuery = q.Encode()
|
||||||
|
|
||||||
|
http.Redirect(w, r, authURL.String(), 302)
|
||||||
|
return
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
http.NotFound(w, r)
|
http.NotFound(w, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user