2014-06-18 11:58:18 -07:00
|
|
|
package initialize
|
|
|
|
|
2014-06-24 17:46:06 -07:00
|
|
|
import "encoding/json"
|
2014-06-18 11:58:18 -07:00
|
|
|
|
2014-06-24 17:46:06 -07:00
|
|
|
// ParseMetaData parses a JSON blob in the OpenStack metadata service format, and
|
2014-06-26 17:17:58 -07:00
|
|
|
// converts it to a partially hydrated CloudConfig
|
2014-06-27 18:31:55 -07:00
|
|
|
func ParseMetaData(contents string) (*CloudConfig, error) {
|
|
|
|
if len(contents) == 0 {
|
|
|
|
return nil, nil
|
|
|
|
}
|
2014-06-18 11:58:18 -07:00
|
|
|
var metadata struct {
|
|
|
|
SSHAuthorizedKeyMap map[string]string `json:"public_keys"`
|
|
|
|
Hostname string `json:"hostname"`
|
|
|
|
NetworkConfig struct {
|
|
|
|
ContentPath string `json:"content_path"`
|
|
|
|
} `json:"network_config"`
|
|
|
|
}
|
2014-06-27 18:31:55 -07:00
|
|
|
if err := json.Unmarshal([]byte(contents), &metadata); err != nil {
|
|
|
|
return nil, err
|
2014-06-18 11:58:18 -07:00
|
|
|
}
|
|
|
|
|
2014-06-27 18:31:55 -07:00
|
|
|
var cfg CloudConfig
|
|
|
|
if len(metadata.SSHAuthorizedKeyMap) > 0 {
|
|
|
|
cfg.SSHAuthorizedKeys = make([]string, 0, len(metadata.SSHAuthorizedKeyMap))
|
|
|
|
for _, key := range metadata.SSHAuthorizedKeyMap {
|
|
|
|
cfg.SSHAuthorizedKeys = append(cfg.SSHAuthorizedKeys, key)
|
|
|
|
}
|
2014-06-18 11:58:18 -07:00
|
|
|
}
|
|
|
|
cfg.Hostname = metadata.Hostname
|
|
|
|
cfg.NetworkConfigPath = metadata.NetworkConfig.ContentPath
|
2014-06-27 18:31:55 -07:00
|
|
|
return &cfg, nil
|
2014-06-18 11:58:18 -07:00
|
|
|
}
|
2014-06-24 17:46:06 -07:00
|
|
|
|
|
|
|
// ExtractIPsFromMetaData parses a JSON blob in the OpenStack metadata service format,
|
|
|
|
// and returns a substitution map possibly containing private_ipv4 and public_ipv4 addresses
|
|
|
|
func ExtractIPsFromMetadata(contents []byte) (map[string]string, error) {
|
|
|
|
var ips struct {
|
|
|
|
Public string `json:"public-ipv4"`
|
|
|
|
Private string `json:"local-ipv4"`
|
|
|
|
}
|
|
|
|
if err := json.Unmarshal(contents, &ips); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
m := make(map[string]string)
|
|
|
|
if ips.Private != "" {
|
|
|
|
m["$private_ipv4"] = ips.Private
|
|
|
|
}
|
|
|
|
if ips.Public != "" {
|
|
|
|
m["$public_ipv4"] = ips.Public
|
|
|
|
}
|
|
|
|
return m, nil
|
|
|
|
}
|