Documentation ¶
Overview ¶
Package cloudruntime provides primitives for loading data from the cloud runtime.
Index ¶
- func Configuration() (string, bool)
- func Execution() (string, bool)
- func Job() (string, bool)
- func Port() (int, bool)
- func ProjectID() (string, bool)
- func ResolveProjectID(ctx context.Context) (string, bool)
- func ResolveServiceAccount(ctx context.Context) (string, bool)
- func Revision() (string, bool)
- func Service() (string, bool)
- func ServiceAccount() (string, bool)
- func ServiceVersion() (string, bool)
- func ServiceVersionFromBuildInfo() (string, bool)
- func ServiceVersionFromLinkerFlags() string
- func TaskAttempt() (int, bool)
- func TaskCount() (int, bool)
- func TaskIndex() (int, bool)
- func WithConfig(ctx context.Context, config Config) context.Context
- type Config
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Configuration ¶
Configuration returns the service configuration of the current runtime.
func Execution ¶ added in v0.45.0
Execution returns the name of the Cloud Run job execution being run.
func ProjectID ¶
ProjectID returns the Google Cloud Project ID of the current runtime. Deprecated: Use the context-based ResolveProjectID function.
func ResolveProjectID ¶ added in v0.63.0
ResolveProjectID resolves the Google Cloud Project ID of the current runtime.
func ResolveServiceAccount ¶ added in v0.63.0
ResolveServiceAccount resolves the default service account of the current runtime.
func ServiceAccount ¶
ServiceAccount returns the default service account of the current runtime. Deprecated: Use the context-based ResolveServiceAccount function.
func ServiceVersion ¶
ServiceVersion returns the service version of the current runtime. The service version is taken from, in order of precedence: - the "SERVICE_VERSION" environment variable - the go.einride.tech/cloudrunner/cloudruntime.serviceVersion variable (must be set at build-time) - the "K_REVISION" environment variable - no version.
func ServiceVersionFromBuildInfo ¶ added in v0.23.0
ServiceVersionFromBuildInfo returns the VCS revision from the embedded build info.
func ServiceVersionFromLinkerFlags ¶
func ServiceVersionFromLinkerFlags() string
ServiceVersionFromLinkerFlags returns the exact value of the variable:
go.einride.tech/cloudrunner/cloudruntime.serviceVersion
This variable can be set during build-time to provide a default value for the service version.
Example:
go build -ldflags="-X 'go.einride.tech/cloudrunner/cloudruntime.serviceVersion=v1.0.0'"
func TaskAttempt ¶ added in v0.45.0
TaskAttempt returns the number of time this Cloud Run job task tas been retried. Starts at 0 for the first attempt and increments by 1 for every successive retry, up to the maximum retries value.
func TaskCount ¶ added in v0.45.0
TaskCount returns the number of tasks in the current Cloud Run job.
Types ¶
type Config ¶
type Config struct { // Port is the port the service is listening on. Port int `env:"PORT" default:"8080"` // Service is the name of the service. Service string `env:"K_SERVICE"` // Revision of the service, as assigned by a Knative runtime. Revision string `env:"K_REVISION"` // Configuration of the service, as assigned by a Knative runtime. Configuration string `env:"K_CONFIGURATION"` // Job name, if running as a Cloud Run job. Job string `env:"CLOUD_RUN_JOB"` // Execution name, if running as a Cloud Run job. Execution string `env:"CLOUD_RUN_EXECUTION"` // TaskIndex of the current task, if running as a Cloud Run job. TaskIndex int `env:"CLOUD_RUN_TASK_INDEX"` // TaskAttempt of the current task, if running as a Cloud Run job. TaskAttempt int `env:"CLOUD_RUN_TASK_ATTEMPT"` // TaskCount of the job, if running as a Cloud Run job. TaskCount int `env:"CLOUD_RUN_TASK_COUNT"` // ProjectID is the GCP project ID the service is running in. // In production, defaults to the project where the service is deployed. ProjectID string `env:"GOOGLE_CLOUD_PROJECT"` // ServiceAccount is the service account used by the service. // In production, defaults to the default service account of the running service. ServiceAccount string // ServiceVersion is the version of the service. ServiceVersion string `env:"SERVICE_VERSION"` }
Config is the runtime config for the service.
func (*Config) Autodetect ¶
Autodetect the runtime config. Deprecated: Use the context-based Config.Resolve method instead.