// appendArchives collects all matching Juju GUI archive metadata information. func appendArchives( source simplestreams.DataSource, matchingItems []interface{}, items map[string]interface{}, cons simplestreams.LookupConstraint, ) ([]interface{}, error) { var majorVersion int if guiConstraint, ok := cons.(*constraint); ok { majorVersion = guiConstraint.majorVersion } for _, item := range items { meta := item.(*Metadata) if majorVersion != 0 && majorVersion != meta.JujuMajorVersion { continue } fullPath, err := source.URL(meta.Path) if err != nil { return nil, errors.Annotate(err, "cannot retrieve metadata full path") } meta.FullPath = fullPath vers, err := version.Parse(meta.StringVersion) if err != nil { return nil, errors.Annotate(err, "cannot parse metadata version") } meta.Version = vers meta.Source = source matchingItems = append(matchingItems, meta) } return matchingItems, nil }
func appendMatchingFunc(source simplestreams.DataSource, matchingImages []interface{}, images map[string]interface{}, cons simplestreams.LookupConstraint) ([]interface{}, error) { for _, val := range images { file := val.(*OvaFileMetadata) if file.FileType == "ova" { //ignore error for url data source url, _ := source.URL(file.Path) file.Url = url matchingImages = append(matchingImages, file) } } return matchingImages, nil }
// appendMatchingTools updates matchingTools with tools metadata records from tools which belong to the // specified series. If a tools record already exists in matchingTools, it is not overwritten. func appendMatchingTools(source simplestreams.DataSource, matchingTools []interface{}, tools map[string]interface{}, cons simplestreams.LookupConstraint) ([]interface{}, error) { toolsMap := make(map[version.Binary]*ToolsMetadata, len(matchingTools)) for _, val := range matchingTools { tm := val.(*ToolsMetadata) binary, err := tm.binary() if err != nil { return nil, errors.Trace(err) } toolsMap[binary] = tm } for _, val := range tools { tm := val.(*ToolsMetadata) if !set.NewStrings(cons.Params().Series...).Contains(tm.Release) { continue } if toolsConstraint, ok := cons.(*ToolsConstraint); ok { tmNumber := version.MustParse(tm.Version) if toolsConstraint.Version == version.Zero { if toolsConstraint.MajorVersion >= 0 && toolsConstraint.MajorVersion != tmNumber.Major { continue } if toolsConstraint.MinorVersion >= 0 && toolsConstraint.MinorVersion != tmNumber.Minor { continue } } else { if toolsConstraint.Version != tmNumber { continue } } } binary, err := tm.binary() if err != nil { return nil, errors.Trace(err) } if _, ok := toolsMap[binary]; !ok { tm.FullPath, _ = source.URL(tm.Path) matchingTools = append(matchingTools, tm) } } return matchingTools, nil }