Browse Source

Adding submodule code

pull/32/head
Edwin.Avalos 8 years ago
parent
commit
352219f062
  1. 15
      main.go
  2. 42
      plugin.go

15
main.go

@ -2,6 +2,7 @@ package main
import ( import (
"encoding/json" "encoding/json"
"fmt"
"os" "os"
"github.com/Sirupsen/logrus" "github.com/Sirupsen/logrus"
@ -79,6 +80,12 @@ func main() {
Usage: "targets to run apply or plan on", Usage: "targets to run apply or plan on",
EnvVar: "PLUGIN_TARGETS", EnvVar: "PLUGIN_TARGETS",
}, },
cli.StringFlag{
Name: "submodules",
Usage: "submodules to override",
EnvVar: "PLUGIN_SUBMODULES",
},
} }
if err := app.Run(os.Args); err != nil { if err := app.Run(os.Args); err != nil {
@ -111,6 +118,13 @@ func run(c *cli.Context) error {
} }
} }
var submodules map[string]map[string]string
if c.String("submodules") != "" {
if err := json.Unmarshal([]byte(c.String("submodules")), &submodules); err != nil {
panic(err)
}
}
plugin := Plugin{ plugin := Plugin{
Config: Config{ Config: Config{
Remote: remote, Remote: remote,
@ -123,6 +137,7 @@ func run(c *cli.Context) error {
RootDir: c.String("root_dir"), RootDir: c.String("root_dir"),
Parallelism: c.Int("parallelism"), Parallelism: c.Int("parallelism"),
Targets: c.StringSlice("targets"), Targets: c.StringSlice("targets"),
Submodules: submodules,
}, },
} }

42
plugin.go

@ -1,6 +1,7 @@
package main package main
import ( import (
"encoding/hex"
"fmt" "fmt"
"github.com/Sirupsen/logrus" "github.com/Sirupsen/logrus"
"github.com/aws/aws-sdk-go/aws/credentials" "github.com/aws/aws-sdk-go/aws/credentials"
@ -8,6 +9,7 @@ import (
"github.com/aws/aws-sdk-go/aws/session" "github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/sts" "github.com/aws/aws-sdk-go/service/sts"
"io/ioutil" "io/ioutil"
"math/rand"
"os" "os"
"os/exec" "os/exec"
"strings" "strings"
@ -26,6 +28,7 @@ type (
RootDir string RootDir string
Parallelism int Parallelism int
Targets []string Targets []string
Submodules map[string]map[string]string
} }
Remote struct { Remote struct {
@ -45,6 +48,15 @@ func (p Plugin) Exec() error {
var commands []*exec.Cmd var commands []*exec.Cmd
remote := p.Config.Remote remote := p.Config.Remote
if len(p.Config.Secrets) != 0 {
exportSecrets(p.Config.Secrets)
}
if len(p.Config.Submodules) != 0 {
submoduleOverride(p.Config.Submodules)
}
if p.Config.Cacert != "" { if p.Config.Cacert != "" {
commands = append(commands, installCaCert(p.Config.Cacert)) commands = append(commands, installCaCert(p.Config.Cacert))
} }
@ -94,6 +106,36 @@ func installCaCert(cacert string) *exec.Cmd {
) )
} }
func submoduleOverride(submodules map[string]map[string]string) {
allOverrides := []string{}
for moduleName, override := range submodules {
overrideContents := []string{}
for k, v := range override {
overrideString := fmt.Sprintf(` %s = "%s"`, k, v)
overrideContents = append(overrideContents, overrideString)
}
moduleContents := fmt.Sprintf(`
module "%s" {
%s
}`, moduleName, strings.Join(overrideContents, "\n"))
allOverrides = append(allOverrides, moduleContents)
}
fileContents := []byte(strings.Join(allOverrides, "\n"))
randBytes := make([]byte, 16)
rand.Read(randBytes)
fileName := hex.EncodeToString(randBytes) + "_override.tf"
err := ioutil.WriteFile(fileName, fileContents, 0644)
if err != nil {
panic(err)
}
}
func exportSecrets(secrets map[string]string) {
for k, v := range secrets {
os.Setenv(fmt.Sprintf("%s", k), fmt.Sprintf("%s", os.Getenv(v)))
}
}
func deleteCache() *exec.Cmd { func deleteCache() *exec.Cmd {
return exec.Command( return exec.Command(
"rm", "rm",

Loading…
Cancel
Save