feat: use errgroup
parent
2092b9cfde
commit
fe6f810769
1
go.mod
1
go.mod
|
@ -8,6 +8,7 @@ require (
|
||||||
github.com/make-go-great/copy-go v0.9.0
|
github.com/make-go-great/copy-go v0.9.0
|
||||||
github.com/make-go-great/diff-go v0.0.5
|
github.com/make-go-great/diff-go v0.0.5
|
||||||
github.com/urfave/cli/v2 v2.24.4
|
github.com/urfave/cli/v2 v2.24.4
|
||||||
|
golang.org/x/sync v0.1.0
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
|
|
2
go.sum
2
go.sum
|
@ -24,6 +24,8 @@ github.com/urfave/cli/v2 v2.24.4 h1:0gyJJEBYtCV87zI/x2nZCPyDxD51K6xM8SkwjHFCNEU=
|
||||||
github.com/urfave/cli/v2 v2.24.4/go.mod h1:GHupkWPMM0M/sj1a2b4wUrWBPzazNrIjouW6fmdJLxc=
|
github.com/urfave/cli/v2 v2.24.4/go.mod h1:GHupkWPMM0M/sj1a2b4wUrWBPzazNrIjouW6fmdJLxc=
|
||||||
github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 h1:bAn7/zixMGCfxrRTfdpNzjtPYqr8smhKouy9mxVdGPU=
|
github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 h1:bAn7/zixMGCfxrRTfdpNzjtPYqr8smhKouy9mxVdGPU=
|
||||||
github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673/go.mod h1:N3UwUGtsrSj3ccvlPHLoLsHnpR27oXr4ZE984MbSER8=
|
github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673/go.mod h1:N3UwUGtsrSj3ccvlPHLoLsHnpR27oXr4ZE984MbSER8=
|
||||||
|
golang.org/x/sync v0.1.0 h1:wsuoTGHzEhffawBOhz5CYhcrV4IdKZbEyZjBMuTp12o=
|
||||||
|
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
|
|
@ -8,6 +8,8 @@ import (
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
|
"golang.org/x/sync/errgroup"
|
||||||
|
|
||||||
"github.com/make-go-great/copy-go"
|
"github.com/make-go-great/copy-go"
|
||||||
"github.com/make-go-great/diff-go"
|
"github.com/make-go-great/diff-go"
|
||||||
)
|
)
|
||||||
|
@ -23,67 +25,112 @@ var _ Config = (*ConfigReal)(nil)
|
||||||
|
|
||||||
// Install internal -> external
|
// Install internal -> external
|
||||||
func (c *ConfigReal) Install() error {
|
func (c *ConfigReal) Install() error {
|
||||||
|
eg := new(errgroup.Group)
|
||||||
|
|
||||||
for _, app := range c.Apps {
|
for _, app := range c.Apps {
|
||||||
for _, p := range app.Paths {
|
for _, p := range app.Paths {
|
||||||
if p.External == "" {
|
if p.External == "" {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := copy.Replace(p.Internal, p.External); err != nil {
|
p := Path{
|
||||||
return fmt.Errorf("copy: failed to replace [%s] -> [%s]: %w", p.Internal, p.External, err)
|
Internal: p.Internal,
|
||||||
|
External: p.External,
|
||||||
|
URL: p.URL,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
eg.Go(func() error {
|
||||||
|
if err := copy.Replace(p.Internal, p.External); err != nil {
|
||||||
|
return fmt.Errorf("copy: failed to replace [%s] -> [%s]: %w", p.Internal, p.External, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := eg.Wait(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update external -> internal
|
// Update external -> internal
|
||||||
func (c *ConfigReal) Update() error {
|
func (c *ConfigReal) Update() error {
|
||||||
|
eg := new(errgroup.Group)
|
||||||
|
|
||||||
for _, app := range c.Apps {
|
for _, app := range c.Apps {
|
||||||
for _, p := range app.Paths {
|
for _, p := range app.Paths {
|
||||||
if p.External == "" {
|
if p.External == "" {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := copy.Replace(p.External, p.Internal); err != nil {
|
p := Path{
|
||||||
return fmt.Errorf("copy: failed to replace [%s] -> [%s]: %w", p.External, p.Internal, err)
|
Internal: p.Internal,
|
||||||
|
External: p.External,
|
||||||
|
URL: p.URL,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
eg.Go(func() error {
|
||||||
|
if err := copy.Replace(p.External, p.Internal); err != nil {
|
||||||
|
return fmt.Errorf("copy: failed to replace [%s] -> [%s]: %w", p.External, p.Internal, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := eg.Wait(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ConfigReal) Download() error {
|
func (c *ConfigReal) Download() error {
|
||||||
|
eg := new(errgroup.Group)
|
||||||
|
|
||||||
for _, app := range c.Apps {
|
for _, app := range c.Apps {
|
||||||
for _, p := range app.Paths {
|
for _, p := range app.Paths {
|
||||||
if p.URL == "" {
|
if p.URL == "" {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
httpRsp, err := c.httpClient.Get(p.URL)
|
p := Path{
|
||||||
if err != nil {
|
Internal: p.Internal,
|
||||||
return fmt.Errorf("http client: failed to get: %w", err)
|
External: p.External,
|
||||||
|
URL: p.URL,
|
||||||
}
|
}
|
||||||
|
|
||||||
data, err := io.ReadAll(httpRsp.Body)
|
eg.Go(func() error {
|
||||||
if err != nil {
|
httpRsp, err := c.httpClient.Get(p.URL)
|
||||||
return fmt.Errorf("io: failed to read all: %w", err)
|
if err != nil {
|
||||||
}
|
return fmt.Errorf("http client: failed to get: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
// Copy from github.com/make-go-great/copy-go
|
data, err := io.ReadAll(httpRsp.Body)
|
||||||
// Make sure nested dir is exist before copying file
|
if err != nil {
|
||||||
dstDir := filepath.Dir(p.Internal)
|
return fmt.Errorf("io: failed to read all: %w", err)
|
||||||
if err := os.MkdirAll(dstDir, os.ModePerm); err != nil {
|
}
|
||||||
return fmt.Errorf("os: failed to mkdir all [%s]: %w", dstDir, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := os.WriteFile(p.Internal, data, 0o600); err != nil {
|
// Copy from github.com/make-go-great/copy-go
|
||||||
return fmt.Errorf("os: failed to write file: %w", err)
|
// Make sure nested dir is exist before copying file
|
||||||
}
|
dstDir := filepath.Dir(p.Internal)
|
||||||
|
if err := os.MkdirAll(dstDir, os.ModePerm); err != nil {
|
||||||
|
return fmt.Errorf("os: failed to mkdir all [%s]: %w", dstDir, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := os.WriteFile(p.Internal, data, 0o600); err != nil {
|
||||||
|
return fmt.Errorf("os: failed to write file: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
httpRsp.Body.Close()
|
||||||
|
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
|
||||||
httpRsp.Body.Close()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -150,17 +197,34 @@ func (c *ConfigReal) Diff() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ConfigReal) Validate() error {
|
func (c *ConfigReal) Validate() error {
|
||||||
|
eg := new(errgroup.Group)
|
||||||
|
|
||||||
for _, app := range c.Apps {
|
for _, app := range c.Apps {
|
||||||
for _, p := range app.Paths {
|
for _, p := range app.Paths {
|
||||||
if p.Internal == "" {
|
app := app
|
||||||
return fmt.Errorf("empty internal app [%s]: %w", app, ErrConfigInvalid)
|
p := Path{
|
||||||
|
Internal: p.Internal,
|
||||||
|
External: p.External,
|
||||||
|
URL: p.URL,
|
||||||
}
|
}
|
||||||
|
|
||||||
if p.External == "" && p.URL == "" {
|
eg.Go(func() error {
|
||||||
return fmt.Errorf("empty external and url app [%s]: %w", app, ErrConfigInvalid)
|
if p.Internal == "" {
|
||||||
}
|
return fmt.Errorf("empty internal app [%s]: %w", app, ErrConfigInvalid)
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.External == "" && p.URL == "" {
|
||||||
|
return fmt.Errorf("empty external and url app [%s]: %w", app, ErrConfigInvalid)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := eg.Wait(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue