2022-03-30 10:42:47 +02:00
|
|
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
2022-11-27 19:20:29 +01:00
|
|
|
// SPDX-License-Identifier: MIT
|
2022-03-30 10:42:47 +02:00
|
|
|
|
|
|
|
package maven
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/xml"
|
|
|
|
"io"
|
|
|
|
|
2024-12-19 12:30:06 +01:00
|
|
|
"code.gitea.io/gitea/modules/util"
|
2022-03-30 10:42:47 +02:00
|
|
|
"code.gitea.io/gitea/modules/validation"
|
2023-07-14 11:39:15 +02:00
|
|
|
|
|
|
|
"golang.org/x/net/html/charset"
|
2022-03-30 10:42:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Metadata represents the metadata of a Maven package
|
|
|
|
type Metadata struct {
|
|
|
|
GroupID string `json:"group_id,omitempty"`
|
|
|
|
ArtifactID string `json:"artifact_id,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
Description string `json:"description,omitempty"`
|
|
|
|
ProjectURL string `json:"project_url,omitempty"`
|
|
|
|
Licenses []string `json:"licenses,omitempty"`
|
|
|
|
Dependencies []*Dependency `json:"dependencies,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dependency represents a dependency of a Maven package
|
|
|
|
type Dependency struct {
|
|
|
|
GroupID string `json:"group_id,omitempty"`
|
|
|
|
ArtifactID string `json:"artifact_id,omitempty"`
|
|
|
|
Version string `json:"version,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type pomStruct struct {
|
|
|
|
XMLName xml.Name `xml:"project"`
|
|
|
|
GroupID string `xml:"groupId"`
|
|
|
|
ArtifactID string `xml:"artifactId"`
|
|
|
|
Version string `xml:"version"`
|
|
|
|
Name string `xml:"name"`
|
|
|
|
Description string `xml:"description"`
|
|
|
|
URL string `xml:"url"`
|
|
|
|
Licenses []struct {
|
|
|
|
Name string `xml:"name"`
|
|
|
|
URL string `xml:"url"`
|
|
|
|
Distribution string `xml:"distribution"`
|
|
|
|
} `xml:"licenses>license"`
|
|
|
|
Dependencies []struct {
|
|
|
|
GroupID string `xml:"groupId"`
|
|
|
|
ArtifactID string `xml:"artifactId"`
|
|
|
|
Version string `xml:"version"`
|
|
|
|
Scope string `xml:"scope"`
|
|
|
|
} `xml:"dependencies>dependency"`
|
2024-12-19 12:30:06 +01:00
|
|
|
Parent struct {
|
|
|
|
GroupID string `xml:"groupId"`
|
|
|
|
ArtifactID string `xml:"artifactId"`
|
|
|
|
Version string `xml:"version"`
|
|
|
|
RelativePath string `xml:"relativePath"`
|
|
|
|
} `xml:"parent"`
|
2022-03-30 10:42:47 +02:00
|
|
|
}
|
|
|
|
|
2024-12-19 12:30:06 +01:00
|
|
|
var ErrNoGroupID = util.NewInvalidArgumentErrorf("group ID is missing")
|
|
|
|
|
2022-03-30 10:42:47 +02:00
|
|
|
// ParsePackageMetaData parses the metadata of a pom file
|
|
|
|
func ParsePackageMetaData(r io.Reader) (*Metadata, error) {
|
|
|
|
var pom pomStruct
|
2023-07-14 11:39:15 +02:00
|
|
|
|
|
|
|
dec := xml.NewDecoder(r)
|
|
|
|
dec.CharsetReader = charset.NewReaderLabel
|
|
|
|
if err := dec.Decode(&pom); err != nil {
|
2022-03-30 10:42:47 +02:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if !validation.IsValidURL(pom.URL) {
|
|
|
|
pom.URL = ""
|
|
|
|
}
|
|
|
|
|
2024-12-19 12:30:06 +01:00
|
|
|
groupID := pom.GroupID
|
|
|
|
|
|
|
|
if groupID == "" {
|
|
|
|
// If a project inherits from a parent project, the groupId element is optional.
|
|
|
|
// Refer to: https://maven.apache.org/pom.html#Inheritance
|
|
|
|
if pom.Parent.GroupID == "" {
|
|
|
|
return nil, ErrNoGroupID
|
|
|
|
}
|
|
|
|
groupID = pom.Parent.GroupID
|
|
|
|
}
|
|
|
|
|
2022-03-30 10:42:47 +02:00
|
|
|
licenses := make([]string, 0, len(pom.Licenses))
|
|
|
|
for _, l := range pom.Licenses {
|
|
|
|
if l.Name != "" {
|
|
|
|
licenses = append(licenses, l.Name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
dependencies := make([]*Dependency, 0, len(pom.Dependencies))
|
|
|
|
for _, d := range pom.Dependencies {
|
|
|
|
dependencies = append(dependencies, &Dependency{
|
|
|
|
GroupID: d.GroupID,
|
|
|
|
ArtifactID: d.ArtifactID,
|
|
|
|
Version: d.Version,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return &Metadata{
|
2024-12-19 12:30:06 +01:00
|
|
|
GroupID: groupID,
|
2022-03-30 10:42:47 +02:00
|
|
|
ArtifactID: pom.ArtifactID,
|
|
|
|
Name: pom.Name,
|
|
|
|
Description: pom.Description,
|
|
|
|
ProjectURL: pom.URL,
|
|
|
|
Licenses: licenses,
|
|
|
|
Dependencies: dependencies,
|
|
|
|
}, nil
|
|
|
|
}
|