Documentation ¶
Overview ¶
package trackedresource provides utility functionality for working with tracked resources. This functionality is shared between frontend and backend controllers for tracked resources.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func IDFor ¶
IDFor computes the resource ID of a tracked resource entry from the original resource ID.
func NameFor ¶
NameFor computes the resource name of a tracked resource from its ID.
This can be used to compute the name of a tracked resource based on the resource that it is tracking.
Names are computed by taking the name of the resource being tracked and appending a suffix to it based on the hash of the resource ID. This ensures that the name is unique and deterministic.
Types ¶
type InProgressErr ¶
type InProgressErr struct { }
InProgressErr signifies that the resource is currently in a non-terminal state.
func (*InProgressErr) Error ¶
func (e *InProgressErr) Error() string
Error returns the error message.
func (*InProgressErr) Is ¶
func (e *InProgressErr) Is(other error) bool
Is returns true if the other error is an InProgressErr.
type Updater ¶
type Updater struct { // DatabaseClient is the database client used to access the database. DatabaseClient database.Client // Client is the HTTP client used to make requests to the downstream API. Client *http.Client // AttemptCount is the number of times to attempt a request and database update. AttemptCount int // RetryDelay is the delay between retries. RetryDelay time.Duration // RequestTimeout is the timeout used for requests to the downstream API. RequestTimeout time.Duration }
Updater is a utility struct that can perform updates on tracked resources.
func NewUpdater ¶
NewUpdater creates a new Updater.
func (*Updater) Update ¶
func (u *Updater) Update(ctx context.Context, downstream string, id resources.ID, apiVersion string) error
Update updates a tracked resource.
This function return attempt to update the state using optimistic concurrency and will retry on the following conditions:
- Downstream failure or timeout - Database failure - Optimistic concurrency failure - Resource is still being provisioned (provisioning state is non-terminal)