func mapToAppSet(basePath string, data generic.Map) (appSet []models.AppParams, errs ManifestErrors) { if data.Has("applications") { appMaps, ok := data.Get("applications").([]interface{}) if !ok { errs = append(errs, errors.New("Expected applications to be a list")) return } // we delete applications so that we may merge top level app params into each app data.Delete("applications") for _, appData := range appMaps { if !generic.IsMappable(appData) { errs = append(errs, errors.New("Expected application to be a dictionary")) continue } appMap := generic.DeepMerge(data, generic.NewMap(appData)) appParams, appErrs := mapToAppParams(basePath, appMap) if !appErrs.Empty() { errs = append(errs, appErrs) continue } appSet = append(appSet, appParams) } } return }
func envVarOrEmptyMap(yamlMap generic.Map, errs *ManifestErrors) *map[string]string { key := "env" switch envVars := yamlMap.Get(key).(type) { case nil: aMap := make(map[string]string, 0) return &aMap case map[string]interface{}: yamlMap.Set(key, generic.NewMap(yamlMap.Get(key))) return envVarOrEmptyMap(yamlMap, errs) case generic.Map: merrs := validateEnvVars(envVars) if merrs != nil { *errs = append(*errs, merrs) return nil } result := make(map[string]string, envVars.Count()) generic.Each(envVars, func(key, value interface{}) { result[key.(string)] = value.(string) }) return &result default: *errs = append(*errs, errors.New(fmt.Sprintf("Expected %s to be a set of key => value.", key))) return nil } }
func (m Manifest) getAppMaps(data generic.Map) (apps []generic.Map, errs []error) { globalProperties := data.Except([]interface{}{"applications"}) if data.Has("applications") { appMaps, ok := data.Get("applications").([]interface{}) if !ok { errs = append(errs, errors.New("Expected applications to be a list")) return } for _, appData := range appMaps { if !generic.IsMappable(appData) { errs = append(errs, errors.New(fmt.Sprintf("Expected application to be a list of key/value pairs\nError occurred in manifest near:\n'%s'", appData))) continue } appMap := generic.DeepMerge(globalProperties, generic.NewMap(appData)) apps = append(apps, appMap) } } else { apps = append(apps, globalProperties) } return }
func setBytesVal(appMap, yamlMap generic.Map, key string, errs *ManifestErrors) { value, err := formatters.ToMegabytes(yamlMap.Get(key).(string)) if err != nil { *errs = append(*errs, errors.New(fmt.Sprintf("Unexpected value for %s :\n%s", key, err.Error()))) return } appMap.Set(key, value) }
func setStringVal(appMap generic.Map, yamlMap generic.Map, key string, errs *ManifestErrors) { val := yamlMap.Get(key) stringVal, ok := val.(string) if !ok { *errs = append(*errs, errors.New(fmt.Sprintf("%s must be a string value", key))) return } appMap.Set(key, stringVal) }
func formatDescription(metadata generic.Map, keys []string) string { parts := []string{} for _, key := range keys { value := metadata.Get(key) if value != nil { parts = append(parts, fmt.Sprintf("%s: %s", key, formatDescriptionPart(value))) } } return strings.Join(parts, ", ") }
func stringVal(yamlMap generic.Map, key string, errs *[]error) *string { val := yamlMap.Get(key) if val == nil { return nil } result, ok := val.(string) if !ok { *errs = append(*errs, errors.NewWithFmt("%s must be a string value", key)) return nil } return &result }
func bytesVal(yamlMap generic.Map, key string, errs *ManifestErrors) *uint64 { yamlVal := yamlMap.Get(key) if yamlVal == nil { return nil } value, err := formatters.ToMegabytes(yamlVal.(string)) if err != nil { *errs = append(*errs, errors.New(fmt.Sprintf("Unexpected value for %s :\n%s", key, err.Error()))) return nil } return &value }
func stringVal(yamlMap generic.Map, key string, errs *ManifestErrors) *string { val := yamlMap.Get(key) if val == nil { return nil } result, ok := val.(string) if !ok { *errs = append(*errs, errors.New(fmt.Sprintf("%s must be a string value", key))) return nil } return &result }
func sliceOrEmptyVal(yamlMap generic.Map, key string, errs *ManifestErrors) *[]string { if !yamlMap.Has(key) { return new([]string) } var ( stringSlice []string err error ) errMsg := fmt.Sprintf("Expected %s to be a list of strings.", key) switch input := yamlMap.Get(key).(type) { case []interface{}: for _, value := range input { stringValue, ok := value.(string) if !ok { err = errors.New(errMsg) break } stringSlice = append(stringSlice, stringValue) } default: err = errors.New(errMsg) } if err != nil { *errs = append(*errs, err) return nil } return &stringSlice }
func intVal(yamlMap generic.Map, key string, errs *ManifestErrors) *int { var ( intVal int err error ) switch val := yamlMap.Get(key).(type) { case string: intVal, err = strconv.Atoi(val) case int: intVal = val case int64: intVal = int(val) case nil: return nil default: err = errors.New(fmt.Sprintf("Expected %s to be a number, but it was a %T.", key, val)) } if err != nil { *errs = append(*errs, err) return nil } return &intVal }
func setStringOrNullVal(appMap, yamlMap generic.Map, key string, errs *ManifestErrors) { switch val := yamlMap.Get(key).(type) { case string: appMap.Set(key, val) case nil: appMap.Set(key, "") default: *errs = append(*errs, errors.New(fmt.Sprintf("%s must be a string or null value", key))) } }
func setEnvVarOrEmptyMap(appMap, yamlMap generic.Map, key string, errs *ManifestErrors) { if !yamlMap.Has(key) { appMap.Set(key, generic.NewMap()) return } envVars := yamlMap.Get(key) if !generic.IsMappable(envVars) { *errs = append(*errs, errors.New(fmt.Sprintf("Expected %s to be a set of key => value.", key))) return } merrs := validateEnvVars(envVars) if merrs != nil { *errs = append(*errs, merrs) return } appMap.Set(key, generic.NewMap(envVars)) }
func envVarOrEmptyMap(yamlMap generic.Map, errs *ManifestErrors) *map[string]string { key := "env" switch envVars := yamlMap.Get(key).(type) { case nil: aMap := make(map[string]string, 0) return &aMap case map[string]interface{}: yamlMap.Set(key, generic.NewMap(yamlMap.Get(key))) return envVarOrEmptyMap(yamlMap, errs) case map[interface{}]interface{}: yamlMap.Set(key, generic.NewMap(yamlMap.Get(key))) return envVarOrEmptyMap(yamlMap, errs) case generic.Map: merrs := validateEnvVars(envVars) if merrs != nil { *errs = append(*errs, merrs) return nil } result := make(map[string]string, envVars.Count()) generic.Each(envVars, func(key, value interface{}) { switch value.(type) { case string: result[key.(string)] = value.(string) case int64, int, int32: result[key.(string)] = fmt.Sprintf("%d", value) case float32, float64: result[key.(string)] = fmt.Sprintf("%f", value) default: *errs = append(*errs, errors.New(fmt.Sprintf("Expected environment variable %s to have a string value, but it was a %T.", key, value))) } }) return &result default: *errs = append(*errs, errors.New(fmt.Sprintf("Expected %s to be a set of key => value, but it was a %T.", key, envVars))) return nil } }
func setBoolVal(appMap, yamlMap generic.Map, key string, errs *ManifestErrors) { switch val := yamlMap.Get(key).(type) { case bool: appMap.Set(key, val) case string: boolVal := val == "true" appMap.Set(key, boolVal) default: *errs = append(*errs, errors.New(fmt.Sprintf("Expected %s to be a boolean.", key))) } return }
func boolVal(yamlMap generic.Map, key string, errs *ManifestErrors) bool { switch val := yamlMap.Get(key).(type) { case nil: return false case bool: return val case string: return val == "true" default: *errs = append(*errs, errors.New(fmt.Sprintf("Expected %s to be a boolean.", key))) return false } }
func stringOrNullVal(yamlMap generic.Map, key string, errs *ManifestErrors) *string { if !yamlMap.Has(key) { return nil } switch val := yamlMap.Get(key).(type) { case string: return &val case nil: empty := "" return &empty default: *errs = append(*errs, errors.New(fmt.Sprintf("%s must be a string or null value", key))) return nil } }
func stringValOrDefault(yamlMap generic.Map, key string, errs *[]error) *string { if !yamlMap.Has(key) { return nil } empty := "" switch val := yamlMap.Get(key).(type) { case string: if val == "default" { return &empty } else { return &val } case nil: return &empty default: *errs = append(*errs, errors.NewWithFmt("%s must be a string or null value", key)) return nil } }
func servicesOrEmptyVal(yamlMap generic.Map, key string, errs *ManifestErrors) (*[]string, *[]map[string]string) { if !yamlMap.Has(key) { return new([]string), new([]map[string]string) } var ( stringSlice []string mapSlice []map[string]string err error ) errMsg := fmt.Sprintf("Expected %s to be a list of strings.", key) switch input := yamlMap.Get(key).(type) { case []map[interface{}]interface{}: for _, mapValue := range input { stringMap := map[string]string{} for key, value := range mapValue { stringMap[key.(string)] = value.(string) } mapSlice = append(mapSlice, stringMap) } case []interface{}: for _, value := range input { stringValue, ok := value.(string) if !ok { err = errors.New(errMsg) break } stringSlice = append(stringSlice, stringValue) } default: err = errors.New(errMsg) } if err != nil { *errs = append(*errs, err) return nil, nil } return &stringSlice, &mapSlice }
func setTimeoutVal(appMap, yamlMap generic.Map, key string, errs *ManifestErrors) { var ( intVal int err error ) switch val := yamlMap.Get(key).(type) { case string: intVal, err = strconv.Atoi(val) case int: intVal = val default: err = errors.New("Expected health_check_timeout to be a number.") } if err != nil { *errs = append(*errs, err) return } appMap.Set("health_check_timeout", intVal) }
func setIntVal(appMap, yamlMap generic.Map, key string, errs *ManifestErrors) { var ( intVal int err error ) switch val := yamlMap.Get(key).(type) { case string: intVal, err = strconv.Atoi(val) case int: intVal = val default: err = errors.New(fmt.Sprintf("Expected %s to be a number.", key)) } if err != nil { *errs = append(*errs, err) return } appMap.Set(key, intVal) }
func mapToAppParams(yamlMap generic.Map) (appParams cf.AppParams, errs ManifestErrors) { appParams = cf.NewEmptyAppParams() errs = checkForNulls(yamlMap) if !errs.Empty() { return } for _, key := range []string{"buildpack", "command", "disk_quota", "domain", "host", "name", "path", "stack", "no-route"} { if yamlMap.Has(key) { setStringVal(appParams, key, yamlMap.Get(key), &errs) } } if yamlMap.Has("memory") { memory, err := formatters.ToMegabytes(yamlMap.Get("memory").(string)) if err != nil { errs = append(errs, errors.New(fmt.Sprintf("Unexpected value for app memory:\n%s", err.Error()))) return } appParams.Set("memory", memory) } if yamlMap.Has("timeout") { setIntVal(appParams, "health_check_timeout", yamlMap.Get("timeout"), &errs) } if yamlMap.Has("instances") { setIntVal(appParams, "instances", yamlMap.Get("instances"), &errs) } if yamlMap.Has("services") { setStringSlice(appParams, "services", yamlMap.Get("services"), &errs) } else { appParams.Set("services", []string{}) } if yamlMap.Has("env") { setEnvVar(appParams, yamlMap.Get("env"), &errs) } else { appParams.Set("env", generic.NewMap()) } return }