|
1 | 1 | package git
|
2 | 2 |
|
3 | 3 | import (
|
4 |
| - "errors" |
5 |
| - |
6 | 4 | "github.com/wavesoftware/go-ensure"
|
7 | 5 | "github.com/wavesoftware/go-magetasks/config"
|
8 | 6 | "github.com/wavesoftware/go-magetasks/pkg/cache"
|
9 | 7 | "github.com/wavesoftware/go-magetasks/pkg/version"
|
10 | 8 | )
|
11 | 9 |
|
12 |
| -// IsLatestStrategy is used to determine if current version is latest one. |
13 |
| -type IsLatestStrategy func(Resolver) func(versionRange string) (bool, error) |
| 10 | +type VersionResolverOption func(*VersionResolver) |
14 | 11 |
|
15 |
| -// Remote represents a remote repository name and address. |
16 |
| -type Remote struct { |
17 |
| - Name string |
18 |
| - URL string |
| 12 | +func NewVersionResolver(options ...VersionResolverOption) VersionResolver { |
| 13 | + r := VersionResolver{} |
| 14 | + |
| 15 | + for _, option := range options { |
| 16 | + option(&r) |
| 17 | + } |
| 18 | + |
| 19 | + return r |
| 20 | +} |
| 21 | + |
| 22 | +func WithCache(cache cache.Cache) VersionResolverOption { |
| 23 | + return func(r *VersionResolver) { |
| 24 | + r.Cache = cache |
| 25 | + } |
19 | 26 | }
|
20 | 27 |
|
21 |
| -// Resolver implements version.Resolver for git SCM. |
22 |
| -type Resolver struct { |
| 28 | +func WithIsLatestStrategy(strategy IsLatestStrategy) VersionResolverOption { |
| 29 | + return func(r *VersionResolver) { |
| 30 | + r.IsLatestStrategy = strategy |
| 31 | + } |
| 32 | +} |
| 33 | + |
| 34 | +func WithRepository(repository Repository) VersionResolverOption { |
| 35 | + return func(r *VersionResolver) { |
| 36 | + r.Repository = repository |
| 37 | + } |
| 38 | +} |
| 39 | + |
| 40 | +func WithRemote(remote Remote) VersionResolverOption { |
| 41 | + return func(r *VersionResolver) { |
| 42 | + r.Remote = &remote |
| 43 | + } |
| 44 | +} |
| 45 | + |
| 46 | +// VersionResolver implements version.Resolver for git SCM. |
| 47 | +type VersionResolver struct { |
23 | 48 | Cache cache.Cache
|
24 | 49 | IsLatestStrategy
|
25 | 50 | Repository
|
26 | 51 | *Remote
|
27 | 52 | }
|
28 | 53 |
|
| 54 | +// Remote represents a remote repository name and address. |
| 55 | +type Remote struct { |
| 56 | + Name string |
| 57 | + URL string |
| 58 | +} |
| 59 | + |
| 60 | +// IsLatestStrategy is used to determine if current version is latest one. |
| 61 | +type IsLatestStrategy func(version.Resolver) func(string) (bool, error) |
| 62 | + |
29 | 63 | type cacheKey struct {
|
30 | 64 | typee string
|
31 | 65 | }
|
32 | 66 |
|
33 |
| -func (r Resolver) Version() string { |
| 67 | +func (r VersionResolver) Version() string { |
34 | 68 | ver, err := r.cache().Compute(cacheKey{"version"}, func() (interface{}, error) {
|
35 | 69 | return r.repository().Describe()
|
36 | 70 | })
|
37 | 71 | ensure.NoError(err)
|
38 | 72 | return ver.(string)
|
39 | 73 | }
|
40 | 74 |
|
41 |
| -func (r Resolver) IsLatest(versionRange string) (bool, error) { |
42 |
| - strategy := TagBasedIsLatestStrategy |
43 |
| - if r.IsLatestStrategy != nil { |
44 |
| - strategy = r.IsLatestStrategy |
45 |
| - } |
46 |
| - fn := strategy(r) |
47 |
| - latest, err := fn(versionRange) |
48 |
| - if err != nil { |
49 |
| - if !errors.Is(err, version.ErrVersionIsNotValid) { |
50 |
| - return false, err |
51 |
| - } |
52 |
| - return false, nil |
53 |
| - } |
54 |
| - return latest, nil |
| 75 | +func (r VersionResolver) IsLatest(versionRange string) (bool, error) { |
| 76 | + return ResolveIsLatest(r, r, versionRange) |
55 | 77 | }
|
56 | 78 |
|
57 |
| -func (r Resolver) cache() cache.Cache { |
| 79 | +func (r VersionResolver) cache() cache.Cache { |
58 | 80 | if r.Cache == nil {
|
59 | 81 | return config.Cache()
|
60 | 82 | }
|
61 | 83 | return r.Cache
|
62 | 84 | }
|
63 | 85 |
|
64 |
| -func (r Resolver) repository() Repository { |
| 86 | +func (r VersionResolver) repository() Repository { |
65 | 87 | if r.Repository == nil {
|
66 | 88 | return installedGitBinaryRepo{r.remote()}
|
67 | 89 | }
|
68 | 90 | return r.Repository
|
69 | 91 | }
|
70 | 92 |
|
71 |
| -func (r Resolver) remote() Remote { |
| 93 | +func (r VersionResolver) remote() Remote { |
72 | 94 | remote := Remote{Name: "origin"}
|
73 | 95 | if r.Remote != nil {
|
74 | 96 | remote = *r.Remote
|
75 | 97 | }
|
76 | 98 | return remote
|
77 | 99 | }
|
78 | 100 |
|
79 |
| -func (r Resolver) resolveTags() []string { |
| 101 | +func (r VersionResolver) resolveTags() []string { |
80 | 102 | tt, err := r.cache().Compute(cacheKey{"tags"}, func() (interface{}, error) {
|
81 | 103 | return r.repository().Tags()
|
82 | 104 | })
|
|
0 commit comments