Documentation ¶
Overview ¶
Package gcloudjuice provides utility functions for interacting with Google Cloud services.
Index ¶
- func AuthenticateOIDCToken(ctx context.Context, w http.ResponseWriter, r *http.Request, ...) (*structcup.AuthResponse, error)
- func AuthenticateOIDCTokenCustomPrefix(ctx context.Context, w http.ResponseWriter, r *http.Request, ...) (*structcup.AuthResponse, error)
- func CreateOIDCToken(ctx context.Context, FS embed.FS, credentialsPath string, audience string) (*oauth2.Token, error)
- func DecodePubSubMessage(r *http.Request, message *pubsub.Message) error
- func GetSecretValue(ctx context.Context, FS embed.FS, credentialsPath string, projectID string, ...) ([]byte, error)
- func GetTimezoneFromCoordinates(ctx context.Context, c *maps.Client, latitude float64, longitude float64) (string, error)
- func NewMapsClient(ctx context.Context, mapsApiKey string, qps int) (*maps.Client, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AuthenticateOIDCToken ¶
func AuthenticateOIDCToken(ctx context.Context, w http.ResponseWriter, r *http.Request, authTokenKey, expectedAudience, expectedIssuer string) (*structcup.AuthResponse, error)
AuthenticateOIDCToken verifies a JWT token's authenticity based on the provided audience and issuer.
It assumes the token is passed with the Bearer prefix.
It requires an HTTP response writer (w), an HTTP request (r), an authorization token key (authTokenKey), an expected audience (expectedAudience), and an expected issuer (expectedIssuer).
It returns a success response if the token is valid or an error if the token is invalid or does not match the expected audience and issuer.
func AuthenticateOIDCTokenCustomPrefix ¶ added in v1.7.1
func AuthenticateOIDCTokenCustomPrefix(ctx context.Context, w http.ResponseWriter, r *http.Request, authTokenKey, prefix, expectedAudience, expectedIssuer string) (*structcup.AuthResponse, error)
AuthenticateOIDCToken verifies a JWT token's authenticity based on the provided audience and issuer.
It allows to specify a custom prefix for the authorization token instead of the default 'Bearer'.
It requires an HTTP response writer (w), an HTTP request (r), an authorization token key (authTokenKey), an expected audience (expectedAudience), and an expected issuer (expectedIssuer).
It returns a success response if the token is valid or an error if the token is invalid or does not match the expected audience and issuer.
func CreateOIDCToken ¶
func CreateOIDCToken(ctx context.Context, FS embed.FS, credentialsPath string, audience string) (*oauth2.Token, error)
CreateOIDCToken creates an OIDC token with the given audience.
It requires an embedded filesystem (FS), a path to the credentials file (credentialsPath), and an audience (audience).
It returns the OIDC token or an error if the operation fails.
func DecodePubSubMessage ¶ added in v1.6.9
DecodePubSubMessage decodes a Google Cloud Pub/Sub message from the request body and maps it to the provided Pub/Sub Message struct.
func GetSecretValue ¶
func GetSecretValue(ctx context.Context, FS embed.FS, credentialsPath string, projectID string, secretID string, versionID string) ([]byte, error)
GetSecretValue retrieves a secret value from Google Cloud Secret Manager.
It requires an embedded filesystem (FS), a path to the credentials file (credentialsPath), a Google Cloud project ID (projectID), a secret ID (secretID), and a secret version ID (versionID).
It returns the secret value as a byte slice or an error if the operation fails.
Types ¶
This section is empty.