2020-09-30 10:30:53 +02:00
|
|
|
package abaputils
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
"path/filepath"
|
2020-10-05 14:38:35 +02:00
|
|
|
"reflect"
|
2020-09-30 10:30:53 +02:00
|
|
|
|
|
|
|
"github.com/ghodss/yaml"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
2021-03-15 21:24:43 +02:00
|
|
|
/*
|
|
|
|
* The AddonDescriptor
|
|
|
|
* ===================
|
|
|
|
* contains information about the Add-on Product and the comprised Add-on Software Component Git Repositories
|
|
|
|
*
|
|
|
|
* Lifecycle
|
|
|
|
* =========
|
|
|
|
* addon.yml file is read by abapAddonAssemblyKitCheckPV|CheckCV
|
|
|
|
* addonDesriptor is stored in CPE [commonPipelineEnvironment]
|
|
|
|
* subsequent steps enrich and update the data in CPE
|
|
|
|
*/
|
|
|
|
|
2020-09-30 10:30:53 +02:00
|
|
|
// AddonDescriptor contains fields about the addonProduct
|
|
|
|
type AddonDescriptor struct {
|
2021-03-15 21:24:43 +02:00
|
|
|
AddonProduct string `json:"addonProduct"`
|
|
|
|
AddonVersionYAML string `json:"addonVersion"`
|
|
|
|
AddonVersion string `json:"addonVersionAAK"`
|
2020-09-30 10:30:53 +02:00
|
|
|
AddonSpsLevel string
|
|
|
|
AddonPatchLevel string
|
|
|
|
TargetVectorID string
|
|
|
|
Repositories []Repository `json:"repositories"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Repository contains fields for the repository/component version
|
|
|
|
type Repository struct {
|
|
|
|
Name string `json:"name"`
|
2022-04-12 14:39:42 +02:00
|
|
|
UseClassicCTS bool `json:"useClassicCTS"`
|
2020-09-30 10:30:53 +02:00
|
|
|
Tag string `json:"tag"`
|
|
|
|
Branch string `json:"branch"`
|
2020-11-02 15:17:13 +02:00
|
|
|
CommitID string `json:"commitID"`
|
2020-09-30 10:30:53 +02:00
|
|
|
VersionYAML string `json:"version"`
|
|
|
|
Version string `json:"versionAAK"`
|
2022-04-12 16:00:17 +02:00
|
|
|
AdditionalPiecelist string `json:"additionalPiecelist"`
|
2020-09-30 10:30:53 +02:00
|
|
|
PackageName string
|
|
|
|
PackageType string
|
|
|
|
SpLevel string
|
|
|
|
PatchLevel string
|
|
|
|
PredecessorCommitID string
|
|
|
|
Status string
|
|
|
|
Namespace string
|
|
|
|
SarXMLFilePath string
|
2021-03-15 21:24:43 +02:00
|
|
|
Languages []string `json:"languages"`
|
2021-10-28 11:01:16 +02:00
|
|
|
InBuildScope bool
|
2020-09-30 10:30:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ReadAddonDescriptorType is the type for ReadAddonDescriptor for mocking
|
|
|
|
type ReadAddonDescriptorType func(FileName string) (AddonDescriptor, error)
|
2021-03-15 21:24:43 +02:00
|
|
|
type readFileFunc func(FileName string) ([]byte, error)
|
2020-09-30 10:30:53 +02:00
|
|
|
|
|
|
|
// ReadAddonDescriptor parses AddonDescriptor YAML file
|
|
|
|
func ReadAddonDescriptor(FileName string) (AddonDescriptor, error) {
|
|
|
|
var addonDescriptor AddonDescriptor
|
2021-03-15 21:24:43 +02:00
|
|
|
err := addonDescriptor.initFromYmlFile(FileName, readFile)
|
2020-09-30 10:30:53 +02:00
|
|
|
return addonDescriptor, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConstructAddonDescriptorFromJSON : Create new AddonDescriptor filled with data from JSON
|
|
|
|
func ConstructAddonDescriptorFromJSON(JSON []byte) (AddonDescriptor, error) {
|
|
|
|
var addonDescriptor AddonDescriptor
|
|
|
|
err := addonDescriptor.initFromJSON(JSON)
|
|
|
|
return addonDescriptor, err
|
|
|
|
}
|
|
|
|
|
2021-03-15 21:24:43 +02:00
|
|
|
func readFile(FileName string) ([]byte, error) {
|
|
|
|
fileLocations, err := filepath.Glob(FileName)
|
|
|
|
if err != nil || len(fileLocations) != 1 {
|
|
|
|
return nil, errors.New(fmt.Sprintf("Could not find %v", FileName))
|
|
|
|
}
|
|
|
|
|
|
|
|
absoluteFilename, err := filepath.Abs(fileLocations[0])
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.New(fmt.Sprintf("Could not get path of %v", FileName))
|
2020-09-30 10:30:53 +02:00
|
|
|
}
|
|
|
|
|
2021-03-15 21:24:43 +02:00
|
|
|
var fileContent []byte
|
|
|
|
fileContent, err = ioutil.ReadFile(absoluteFilename)
|
2020-09-30 10:30:53 +02:00
|
|
|
if err != nil {
|
2021-03-15 21:24:43 +02:00
|
|
|
return nil, errors.New(fmt.Sprintf("Could not read %v", FileName))
|
2020-09-30 10:30:53 +02:00
|
|
|
}
|
|
|
|
|
2021-03-15 21:24:43 +02:00
|
|
|
return fileContent, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// initFromYmlFile : Reads from file
|
|
|
|
func (me *AddonDescriptor) initFromYmlFile(FileName string, readFile readFileFunc) error {
|
|
|
|
fileContent, err := readFile(FileName)
|
2020-09-30 10:30:53 +02:00
|
|
|
if err != nil {
|
2021-03-15 21:24:43 +02:00
|
|
|
return err
|
2020-09-30 10:30:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var jsonBytes []byte
|
2021-03-15 21:24:43 +02:00
|
|
|
jsonBytes, err = yaml.YAMLToJSON(fileContent)
|
2020-09-30 10:30:53 +02:00
|
|
|
if err != nil {
|
|
|
|
return errors.New(fmt.Sprintf("Could not parse %v", FileName))
|
|
|
|
}
|
|
|
|
|
|
|
|
err = me.initFromJSON(jsonBytes)
|
|
|
|
if err != nil {
|
|
|
|
return errors.New(fmt.Sprintf("Could not unmarshal %v", FileName))
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-10-05 14:38:35 +02:00
|
|
|
// CheckAddonDescriptorForRepositories checks AddonDescriptor struct if it contains any repositories. If not it will return an error
|
|
|
|
func CheckAddonDescriptorForRepositories(addonDescriptor AddonDescriptor) error {
|
|
|
|
//checking if parsing went wrong
|
|
|
|
if len(addonDescriptor.Repositories) == 0 {
|
2021-10-28 11:01:16 +02:00
|
|
|
return errors.New("AddonDescriptor doesn't contain any repositories")
|
2020-10-05 14:38:35 +02:00
|
|
|
}
|
|
|
|
//
|
|
|
|
emptyRepositoryCounter := 0
|
|
|
|
for counter, repo := range addonDescriptor.Repositories {
|
|
|
|
if reflect.DeepEqual(Repository{}, repo) {
|
|
|
|
emptyRepositoryCounter++
|
|
|
|
}
|
|
|
|
if counter+1 == len(addonDescriptor.Repositories) && emptyRepositoryCounter == len(addonDescriptor.Repositories) {
|
2021-10-28 11:01:16 +02:00
|
|
|
return errors.New("AddonDescriptor doesn't contain any repositories")
|
2020-10-05 14:38:35 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-09-30 10:30:53 +02:00
|
|
|
// initFromJSON : Init from json
|
|
|
|
func (me *AddonDescriptor) initFromJSON(JSON []byte) error {
|
|
|
|
return json.Unmarshal(JSON, me)
|
|
|
|
}
|
|
|
|
|
2021-11-02 12:00:01 +02:00
|
|
|
// initFromJSON : Init from json string
|
|
|
|
func (me *AddonDescriptor) InitFromJSONstring(JSONstring string) error {
|
|
|
|
return me.initFromJSON([]byte(JSONstring))
|
|
|
|
}
|
|
|
|
|
2020-09-30 10:30:53 +02:00
|
|
|
// AsJSON : dito
|
|
|
|
func (me *AddonDescriptor) AsJSON() []byte {
|
|
|
|
//hopefully no errors should happen here or they are covered by the users unit tests
|
|
|
|
jsonBytes, _ := json.Marshal(me)
|
|
|
|
return jsonBytes
|
|
|
|
}
|
|
|
|
|
2021-11-02 12:00:01 +02:00
|
|
|
// AsJSONstring : dito
|
|
|
|
func (me *AddonDescriptor) AsJSONstring() string {
|
|
|
|
return string(me.AsJSON())
|
|
|
|
}
|
|
|
|
|
2020-09-30 10:30:53 +02:00
|
|
|
// SetRepositories : dito
|
|
|
|
func (me *AddonDescriptor) SetRepositories(Repositories []Repository) {
|
|
|
|
me.Repositories = Repositories
|
|
|
|
}
|
2021-03-15 21:24:43 +02:00
|
|
|
|
|
|
|
// GetAakAasLanguageVector : dito
|
|
|
|
func (me *Repository) GetAakAasLanguageVector() string {
|
|
|
|
if len(me.Languages) <= 0 {
|
|
|
|
return `ISO-DEEN`
|
|
|
|
}
|
|
|
|
languageVector := `ISO-`
|
|
|
|
for _, language := range me.Languages {
|
|
|
|
languageVector = languageVector + language
|
|
|
|
}
|
|
|
|
return languageVector
|
|
|
|
}
|
2021-10-28 11:01:16 +02:00
|
|
|
|
|
|
|
func (me *AddonDescriptor) GetRepositoriesInBuildScope() []Repository {
|
|
|
|
var RepositoriesInBuildScope []Repository
|
|
|
|
for _, repo := range me.Repositories {
|
|
|
|
if repo.InBuildScope {
|
|
|
|
RepositoriesInBuildScope = append(RepositoriesInBuildScope, repo)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return RepositoriesInBuildScope
|
|
|
|
}
|