Browse Source

Merge pull request 'env: introduce Env() factory and `jpictl env -e` to export variables' (#2)

Reviewed-on: #2
pull/4/head v0.4.13
Alejandro Mery 10 months ago
parent
commit
9c4f6d987d
  1. 11
      cmd/jpictl/env.go
  2. 46
      pkg/zones/env.go

11
cmd/jpictl/env.go

@ -16,10 +16,19 @@ var envCmd = &cobra.Command{
return err return err
} }
return m.WriteEnv(os.Stdout) _, err = m.Env(*envExport).WriteTo(os.Stdout)
return err
}, },
} }
// Command Flags
var (
envExport *bool
)
func init() { func init() {
rootCmd.AddCommand(envCmd) rootCmd.AddCommand(envCmd)
envExport = envCmd.PersistentFlags().BoolP("export", "e", false,
"export generated variables")
} }

46
pkg/zones/env.go

@ -7,8 +7,23 @@ import (
"strings" "strings"
) )
// WriteEnv generates environment variables for shell scripts // Env is a shell environment factory for this cluster
func (m *Zones) WriteEnv(w io.Writer) error { type Env struct {
ZoneIterator
export bool
}
// Env returns a shell environment factory
func (m *Zones) Env(export bool) *Env {
return &Env{
ZoneIterator: m,
export: export,
}
}
// WriteTo generates environment variables for shell scripts
func (m *Env) WriteTo(w io.Writer) (int64, error) {
var buf bytes.Buffer var buf bytes.Buffer
m.writeEnvVarFn(&buf, genEnvZones, "ZONES") m.writeEnvVarFn(&buf, genEnvZones, "ZONES")
@ -17,11 +32,10 @@ func (m *Zones) WriteEnv(w io.Writer) error {
return false return false
}) })
_, err := buf.WriteTo(w) return buf.WriteTo(w)
return err
} }
func (m *Zones) writeEnvZone(w io.Writer, z *Zone) { func (m *Env) writeEnvZone(w io.Writer, z *Zone) {
zoneID := z.ID zoneID := z.ID
// ZONE{zoneID} // ZONE{zoneID}
@ -42,7 +56,7 @@ func (m *Zones) writeEnvZone(w io.Writer, z *Zone) {
} }
} }
func (m *Zones) writeEnvVarFn(w io.Writer, fn func(*Zones) string, name string, args ...any) { func (m *Env) writeEnvVarFn(w io.Writer, fn func(*Env) string, name string, args ...any) {
var value string var value string
if fn != nil { if fn != nil {
@ -52,7 +66,13 @@ func (m *Zones) writeEnvVarFn(w io.Writer, fn func(*Zones) string, name string,
m.writeEnvVar(w, value, name, args...) m.writeEnvVar(w, value, name, args...)
} }
func (*Zones) writeEnvVar(w io.Writer, value string, name string, args ...any) { func (m *Env) writeEnvVar(w io.Writer, value string, name string, args ...any) {
var prefix string
if m.export {
prefix = "export "
}
if len(args) > 0 { if len(args) > 0 {
name = fmt.Sprintf(name, args...) name = fmt.Sprintf(name, args...)
} }
@ -60,15 +80,17 @@ func (*Zones) writeEnvVar(w io.Writer, value string, name string, args ...any) {
if name != "" { if name != "" {
value = strings.TrimSpace(value) value = strings.TrimSpace(value)
_, _ = fmt.Fprintf(w, "%s=%q\n", name, value) _, _ = fmt.Fprintf(w, "%s%s=%q\n", prefix, name, value)
} }
} }
func genEnvZones(m *Zones) string { func genEnvZones(m *Env) string {
s := make([]string, 0, len(m.Zones)) var s []string
for _, z := range m.Zones {
m.ForEachZone(func(z *Zone) bool {
s = append(s, fmt.Sprintf("%v", z.ID)) s = append(s, fmt.Sprintf("%v", z.ID))
} return false
})
return strings.Join(s, " ") return strings.Join(s, " ")
} }

Loading…
Cancel
Save