all repos — homestead @ c0f110119e434f188f5959c48570df12121cc663

Code for my website

domain/identity/oidc/service.go (view raw)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package oidc

import (
	"net/http"

	"alin.ovh/homestead/shared/config"
	sharedhttp "alin.ovh/homestead/shared/http"
	"alin.ovh/x/log"

	"github.com/benpate/digit"
)

type Service struct {
	config       *config.Config
	log          *log.Logger
	acctResource string
	resource     digit.Resource
}

func New(cfg *config.Config, logger *log.Logger) *Service {
	acctResource := "acct:" + cfg.OIDCEmail
	resource := digit.NewResource(acctResource).
		Link("http://openid.net/specs/connect/1.0/issuer", "", cfg.OIDCHost.String())

	return &Service{
		config:       cfg,
		log:          logger,
		acctResource: acctResource,
		resource:     resource,
	}
}

func (s *Service) RegisterHandlers(mux *sharedhttp.ServeMux) {
	const oidcPath = "/.well-known/openid-configuration"
	mux.ServeMux.Handle(oidcPath,
		sharedhttp.RedirectHandler(s.config.OIDCHost.JoinPath(oidcPath), http.StatusFound))
}

func (s *Service) GetResource() string {
	return s.acctResource
}

func (s *Service) GetIdentityResource() digit.Resource {
	return s.resource
}