2023-01-23 08:11:40 +01:00
|
|
|
package idp
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2025-05-02 13:44:24 +02:00
|
|
|
"time"
|
2023-01-23 08:11:40 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Session is the minimal implementation for a session of a 3rd party authentication [Provider]
|
|
|
|
type Session interface {
|
2025-06-30 11:07:33 -04:00
|
|
|
GetAuth(ctx context.Context) (Auth, error)
|
2025-02-26 13:20:47 +01:00
|
|
|
PersistentParameters() map[string]any
|
2023-01-23 08:11:40 +01:00
|
|
|
FetchUser(ctx context.Context) (User, error)
|
2025-05-02 13:44:24 +02:00
|
|
|
ExpiresAt() time.Time
|
2023-01-23 08:11:40 +01:00
|
|
|
}
|
2023-08-04 11:35:36 +02:00
|
|
|
|
2025-06-30 11:07:33 -04:00
|
|
|
type Auth interface {
|
|
|
|
auth()
|
|
|
|
}
|
|
|
|
|
|
|
|
type RedirectAuth struct {
|
|
|
|
RedirectURL string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *RedirectAuth) auth() {}
|
|
|
|
|
|
|
|
type FormAuth struct {
|
|
|
|
URL string
|
|
|
|
Fields map[string]string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FormAuth) auth() {}
|
|
|
|
|
2023-08-04 11:35:36 +02:00
|
|
|
// SessionSupportsMigration is an optional extension to the Session interface.
|
|
|
|
// It can be implemented to support migrating users, were the initial external id has changed because of a migration of the Provider type.
|
|
|
|
// E.g. when a user was linked on a generic OIDC provider and this provider has now been migrated to an AzureAD provider.
|
|
|
|
// In this case OIDC used the `sub` claim and Azure now uses the id of the user endpoint, which differ.
|
|
|
|
// The RetrievePreviousID will return the `sub` claim again, so that the user can be matched and safely migrated to the new id.
|
|
|
|
type SessionSupportsMigration interface {
|
|
|
|
RetrievePreviousID() (previousID string, err error)
|
|
|
|
}
|
2023-09-29 11:26:14 +02:00
|
|
|
|
2025-06-30 11:07:33 -04:00
|
|
|
func Redirect(redirectURL string) (*RedirectAuth, error) {
|
|
|
|
return &RedirectAuth{RedirectURL: redirectURL}, nil
|
2023-09-29 11:26:14 +02:00
|
|
|
}
|
|
|
|
|
2025-06-30 11:07:33 -04:00
|
|
|
func Form(url string, fields map[string]string) (*FormAuth, error) {
|
|
|
|
return &FormAuth{
|
|
|
|
URL: url,
|
|
|
|
Fields: fields,
|
|
|
|
}, nil
|
2023-09-29 11:26:14 +02:00
|
|
|
}
|