Documentation ¶
Index ¶
- func CleanUpBlob(st *corestate.State, persist corestate.Persistence, storagePath string) error
- func DeployResources(applicationID string, chID charmstore.CharmID, csMac *macaroon.Macaroon, ...) (ids map[string]string, err error)
- func NewAPIClient(apiCaller base.APICallCloser) (*client.Client, error)
- func NewLatestCharmHandler(st *state.State) (charmrevisionupdater.LatestCharmHandler, error)
- func NewResourceOpener(st *corestate.State, unitName string) (opener resource.Opener, err error)
- func NewResourcePersistence(persist corestate.Persistence) corestate.ResourcesPersistence
- func NewResourceState(persist corestate.Persistence, base *corestate.State) corestate.Resources
- type CSRetryClient
- type DeployResourcesFunc
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CleanUpBlob ¶
CleanUpBlob is a cleanup handler that will be used in state cleanup.
func DeployResources ¶
func DeployResources( applicationID string, chID charmstore.CharmID, csMac *macaroon.Macaroon, filesAndRevisions map[string]string, resources map[string]charmresource.Meta, conn base.APICallCloser, ) (ids map[string]string, err error)
DeployResources uploads the bytes for the given files to the server and creates pending resource metadata for the all resource mentioned in the metadata. It returns a map of resource name to pending resource IDs.
func NewAPIClient ¶
func NewAPIClient(apiCaller base.APICallCloser) (*client.Client, error)
NewAPIClient is mostly a copy of the newClient code in component/all/resources.go. It lives here because it simplifies this code immensely.
func NewLatestCharmHandler ¶
func NewLatestCharmHandler(st *state.State) (charmrevisionupdater.LatestCharmHandler, error)
NewLatestCharmHandler returns a LatestCharmHandler that uses the given Juju state.
func NewResourceOpener ¶
NewResourceOpener returns a new resource.Opener for the given unit.
The caller owns the State provided. It is the caller's responsibility to close it.
TODO(mjs): This is the entry point for a whole lot of untested shim code in this package. At some point this should be sorted out.
func NewResourcePersistence ¶
func NewResourcePersistence(persist corestate.Persistence) corestate.ResourcesPersistence
NewResourcePersistence is a function that may be passed to state.SetResourcesPersistence(). It will be used in the core state package to produce the resource persistence.
func NewResourceState ¶
NewResourceState is a function that may be passed to state.SetResourcesComponent().
Types ¶
type CSRetryClient ¶
type CSRetryClient struct { charmstore.Client // contains filtered or unexported fields }
CSRetryClient is a wrapper around a Juju charm store client that retries GetResource() calls.
func (CSRetryClient) GetResource ¶
func (client CSRetryClient) GetResource(req charmstore.ResourceRequest) (charmstore.ResourceData, error)
GetResource returns a reader for the resource's data.
type DeployResourcesFunc ¶
type DeployResourcesFunc func( applicationID string, chID charmstore.CharmID, csMac *macaroon.Macaroon, filesAndRevisions map[string]string, resources map[string]charmresource.Meta, conn base.APICallCloser, ) (ids map[string]string, err error)
DeployResourcesFunc is the function type of DeployResources.