mirror of
https://github.com/pomerium/pomerium.git
synced 2025-04-29 18:36:30 +02:00
* core/identity: add data store for thread-safe storage of sessions and users * wip * add test * wip * clean up context * fix nil session error * add stop message * remove log * use origin context * use base context for manager calls * use manager context for syncers too * add runtime flag * rename legacy lease * add comment * use NotSame * add comment * Update internal/identity/manager/manager.go Co-authored-by: Kenneth Jenkins <51246568+kenjenkins@users.noreply.github.com> * lint --------- Co-authored-by: Kenneth Jenkins <51246568+kenjenkins@users.noreply.github.com>
46 lines
1.1 KiB
Go
46 lines
1.1 KiB
Go
package manager
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
|
|
"golang.org/x/oauth2"
|
|
"google.golang.org/protobuf/types/known/timestamppb"
|
|
|
|
"github.com/pomerium/pomerium/pkg/grpc/session"
|
|
)
|
|
|
|
// FromOAuthToken converts a session oauth token to oauth2.Token.
|
|
func FromOAuthToken(token *session.OAuthToken) *oauth2.Token {
|
|
return &oauth2.Token{
|
|
AccessToken: token.GetAccessToken(),
|
|
TokenType: token.GetTokenType(),
|
|
RefreshToken: token.GetRefreshToken(),
|
|
Expiry: token.GetExpiresAt().AsTime(),
|
|
}
|
|
}
|
|
|
|
// ToOAuthToken converts an oauth2.Token to a session oauth token.
|
|
func ToOAuthToken(token *oauth2.Token) *session.OAuthToken {
|
|
expiry := timestamppb.New(token.Expiry)
|
|
return &session.OAuthToken{
|
|
AccessToken: token.AccessToken,
|
|
TokenType: token.TokenType,
|
|
RefreshToken: token.RefreshToken,
|
|
ExpiresAt: expiry,
|
|
}
|
|
}
|
|
|
|
func isTemporaryError(err error) bool {
|
|
if err == nil {
|
|
return false
|
|
}
|
|
if errors.Is(err, context.DeadlineExceeded) || errors.Is(err, context.Canceled) {
|
|
return true
|
|
}
|
|
var hasTemporary interface{ Temporary() bool }
|
|
if errors.As(err, &hasTemporary) && hasTemporary.Temporary() {
|
|
return true
|
|
}
|
|
return false
|
|
}
|