/
manifold.go
80 lines (68 loc) · 2.33 KB
/
manifold.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// Copyright 2015 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package charmrevision
import (
"time"
"github.com/juju/clock"
"github.com/juju/errors"
"github.com/juju/worker/v3"
"github.com/juju/worker/v3/dependency"
"github.com/juju/juju/api/base"
"github.com/juju/juju/api/controller/charmrevisionupdater"
)
// ManifoldConfig describes how to create a worker that checks for updates
// available to deployed charms in an environment.
type ManifoldConfig struct {
// The named dependencies will be exposed to the start func as resources.
APICallerName string
Clock clock.Clock
// The remaining dependencies will be used with the resources to configure
// and create the worker. The period must be greater than 0; the NewFacade
// and NewWorker fields must not be nil. charmrevision.NewWorker, and
// NewAPIFacade, are suitable implementations for most clients.
Period time.Duration
NewFacade func(base.APICaller) (Facade, error)
NewWorker func(Config) (worker.Worker, error)
Logger Logger
}
// Manifold returns a dependency.Manifold that runs a charm revision worker
// according to the supplied configuration.
func Manifold(config ManifoldConfig) dependency.Manifold {
return dependency.Manifold{
Inputs: []string{
config.APICallerName,
},
Start: func(context dependency.Context) (worker.Worker, error) {
if config.Clock == nil {
return nil, errors.NotValidf("nil Clock")
}
var apiCaller base.APICaller
if err := context.Get(config.APICallerName, &apiCaller); err != nil {
return nil, errors.Trace(err)
}
facade, err := config.NewFacade(apiCaller)
if err != nil {
return nil, errors.Annotatef(err, "cannot create facade")
}
worker, err := config.NewWorker(Config{
RevisionUpdater: facade,
Clock: config.Clock,
Period: config.Period,
Logger: config.Logger,
})
if err != nil {
return nil, errors.Annotatef(err, "cannot create worker")
}
return worker, nil
},
}
}
// NewAPIFacade returns a Facade backed by the supplied APICaller.
var NewAPIFacade = newAPIFacade
func newAPIFacade(apiCaller base.APICaller) (Facade, error) {
return charmrevisionupdater.NewClient(apiCaller), nil
}
// Facade has all the controller methods used by the charm revision worker.
type Facade interface {
RevisionUpdater
}