packer-cn/config.go

116 lines
2.9 KiB
Go
Raw Normal View History

package main
import (
"encoding/json"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer/plugin"
"io"
"log"
"os/exec"
)
2013-05-08 21:13:15 -04:00
// This is the default, built-in configuration that ships with
// Packer.
const defaultConfig = `
{
"plugin_min_port": 10000,
"plugin_max_port": 25000,
"builders": {
"amazon-ebs": "packer-builder-amazon-ebs",
"digital-ocean": "packer-builder-digital-ocean",
2013-06-11 18:12:45 -04:00
"virtualbox": "packer-builder-virtualbox",
"vmware": "packer-builder-vmware"
},
"commands": {
2013-06-13 13:03:44 -04:00
"build": "packer-command-build",
"validate": "packer-command-validate"
},
"provisioners": {
"shell": "packer-provisioner-shell"
}
}
2013-05-08 21:13:15 -04:00
`
type config struct {
PluginMinPort uint
PluginMaxPort uint
2013-05-24 00:59:03 -04:00
Builders map[string]string
Commands map[string]string
2013-05-24 00:39:00 -04:00
Provisioners map[string]string
}
// Decodes configuration in JSON format from the given io.Reader into
// the config object pointed to.
func decodeConfig(r io.Reader, c *config) error {
decoder := json.NewDecoder(r)
return decoder.Decode(c)
}
2013-05-08 21:13:15 -04:00
// Returns an array of defined command names.
func (c *config) CommandNames() (result []string) {
result = make([]string, 0, len(c.Commands))
for name, _ := range c.Commands {
result = append(result, name)
}
return
}
// This is a proper packer.BuilderFunc that can be used to load packer.Builder
// implementations from the defined plugins.
func (c *config) LoadBuilder(name string) (packer.Builder, error) {
log.Printf("Loading builder: %s\n", name)
bin, ok := c.Builders[name]
if !ok {
log.Printf("Builder not found: %s\n", name)
return nil, nil
}
2013-06-11 14:06:23 -04:00
return c.pluginClient(bin).Builder()
}
2013-05-08 21:13:15 -04:00
// This is a proper packer.CommandFunc that can be used to load packer.Command
// implementations from the defined plugins.
func (c *config) LoadCommand(name string) (packer.Command, error) {
log.Printf("Loading command: %s\n", name)
2013-06-11 14:06:23 -04:00
bin, ok := c.Commands[name]
if !ok {
log.Printf("Command not found: %s\n", name)
return nil, nil
}
2013-06-11 14:06:23 -04:00
return c.pluginClient(bin).Command()
}
2013-05-11 14:11:40 -04:00
// This is a proper implementation of packer.HookFunc that can be used
// to load packer.Hook implementations from the defined plugins.
2013-05-11 14:11:40 -04:00
func (c *config) LoadHook(name string) (packer.Hook, error) {
log.Printf("Loading hook: %s\n", name)
2013-06-11 14:06:23 -04:00
return c.pluginClient(name).Hook()
2013-05-11 14:11:40 -04:00
}
2013-05-24 00:39:00 -04:00
// This is a proper packer.ProvisionerFunc that can be used to load
// packer.Provisioner implementations from defined plugins.
2013-05-24 00:39:00 -04:00
func (c *config) LoadProvisioner(name string) (packer.Provisioner, error) {
log.Printf("Loading provisioner: %s\n", name)
2013-06-11 14:06:23 -04:00
bin, ok := c.Provisioners[name]
2013-05-24 00:39:00 -04:00
if !ok {
log.Printf("Provisioner not found: %s\n", name)
return nil, nil
}
2013-06-11 14:06:23 -04:00
return c.pluginClient(bin).Provisioner()
}
func (c *config) pluginClient(path string) *plugin.Client {
var config plugin.ClientConfig
config.Cmd = exec.Command(path)
config.Managed = true
2013-06-11 14:08:21 -04:00
config.MinPort = c.PluginMinPort
config.MaxPort = c.PluginMaxPort
2013-06-11 14:06:23 -04:00
return plugin.NewClient(&config)
2013-05-24 00:39:00 -04:00
}