photoprism/docker/oidc/server.go
2021-09-20 20:08:28 +02:00

55 lines
1.1 KiB
Go

package main
import (
"context"
"crypto/rand"
"crypto/sha256"
"log"
"net/http"
"github.com/gorilla/mux"
"caos-test-op/mock"
"github.com/caos/oidc/pkg/op"
)
func main() {
ctx := context.Background()
b := make([]byte, 32)
rand.Read(b)
port := "9998"
config := &op.Config{
Issuer: "http://oidc-test-op:9998",
CryptoKey: sha256.Sum256(b),
CodeMethodS256: true,
}
storage := mock.NewAuthStorage()
handler, err := op.NewOpenIDProvider(ctx, config, storage)
if err != nil {
log.Fatal(err)
}
router := handler.HttpHandler().(*mux.Router)
router.Methods("GET").Path("/login").HandlerFunc(HandleLogin)
server := &http.Server{
Addr: ":" + port,
Handler: router,
}
err = server.ListenAndServe()
if err != nil {
log.Fatal(err)
}
<-ctx.Done()
}
func HandleLogin(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
requestId := r.Form.Get("id")
// simulate user login and retrieve a token that indicates a successfully logged-in user
usertoken := requestId + ":usertoken"
http.Redirect(w, r, "/authorize/callback?id="+usertoken, http.StatusFound)
}