scorecard/dependencydiff/mapping.go
Spencer Schrock 92470deac3
🌱 enable nolintlint linter and fix violations (#3650)
* enable nolintlint

Signed-off-by: Spencer Schrock <sschrock@google.com>

* first chunk of fixing nolintlint

Signed-off-by: Spencer Schrock <sschrock@google.com>

* second chunk of fixing nolintlint

Signed-off-by: Spencer Schrock <sschrock@google.com>

* third chunk of fixing nolintlint

Signed-off-by: Spencer Schrock <sschrock@google.com>

* fourth chunk of fixing nolintlint

Signed-off-by: Spencer Schrock <sschrock@google.com>

* include reason for the specific linter config

Signed-off-by: Spencer Schrock <sschrock@google.com>

* fifth chunk of fixing nolintlint

Signed-off-by: Spencer Schrock <sschrock@google.com>

* fix linter errors that are somehow still triggering

Signed-off-by: Spencer Schrock <sschrock@google.com>

---------

Signed-off-by: Spencer Schrock <sschrock@google.com>
2023-11-15 11:44:28 -08:00

121 lines
4.2 KiB
Go

// Copyright 2022 OpenSSF Scorecard Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package dependencydiff
import (
"fmt"
)
// Ecosystem is a package ecosystem supported by OSV, GitHub, etc.
type ecosystem string
// OSV ecosystem naming data source: https://ossf.github.io/osv-schema/#affectedpackage-field
const (
// The Go ecosystem.
ecosystemGo ecosystem = "Go"
// The NPM ecosystem.
ecosystemNpm ecosystem = "npm"
// The Android ecosystem.
ecosystemAndroid ecosystem = "Android" //nolint:unused
// The crates.io ecosystem for RUST.
ecosystemCrates ecosystem = "crates.io"
// For reports from the OSS-Fuzz project that have no more appropriate ecosystem.
ecosystemOssFuzz ecosystem = "OSS-Fuzz" //nolint:unused
// The Python PyPI ecosystem. PyPI is the main package source of pip.
ecosystemPyPI ecosystem = "PyPI"
// The RubyGems ecosystem.
ecosystemRubyGems ecosystem = "RubyGems"
// The PHP package manager ecosystem. Packagist is the main Composer repository.
ecosystemPackagist ecosystem = "Packagist"
// The Maven Java package ecosystem.
ecosystemMaven ecosystem = "Maven"
// The NuGet package ecosystem.
ecosystemNuGet ecosystem = "NuGet"
// The Linux kernel.
ecosystemLinux ecosystem = "Linux" //nolint:unused
// The Debian package ecosystem.
ecosystemDebian ecosystem = "Debian" //nolint:unused
// Hex is the package manager of Erlang.
// TODO: GitHub doesn't support hex as the ecosystem for Erlang yet. Add this to the map in the future.
ecosystemHex ecosystem = "Hex" //nolint:unused
// GitHub Actions is an ecosystem for the GitHub Actions.
ecosystemActions ecosystem = "GitHub Actions"
// Pub is the official package repository for Dart and Flutter apps.
ecosystemPub ecosystem = "Pub" //nolint:unused
// Ecosystems with a "nolint" tag suggests GitHub hasn't gotten them supported yet.
// We need to add them to the below hashmap in a timely manner once GitHub adds supports.
)
// gitHubToOSV defines the ecosystem naming mapping relationship between GitHub and others.
var gitHubToOSV = map[string]ecosystem{
// GitHub ecosystem naming data source: https://docs.github.com/en/code-security/supply-chain-security/
// understanding-your-software-supply-chain/about-the-dependency-graph#supported-package-ecosystems
"gomod": ecosystemGo, /* go.mod and go.sum */
"cargo": ecosystemCrates,
"pip": ecosystemPyPI, /* pip and poetry */
"npm": ecosystemNpm, /* npm and yarn */
"maven": ecosystemMaven,
"composer": ecosystemPackagist,
"rubygems": ecosystemRubyGems,
"nuget": ecosystemNuGet,
"actions": ecosystemActions,
}
func mapDependencyEcosystemNaming(deps []dependency) error {
for i := range deps {
// Since we allow a dependency's ecosystem to be nil, so skip those nil ones and only map
// those valid ones.
if deps[i].Ecosystem == nil {
continue
}
mappedEcosys, err := toEcosystem(*deps[i].Ecosystem)
if err != nil {
// Iff. the ecosystem is not empty and the mapping entry is not found, we will return an error.
return fmt.Errorf("error mapping dependency ecosystem: %w", err)
}
deps[i].Ecosystem = asPointer(string(mappedEcosys))
}
return nil
}
// Note: the current implementation directly returns an error if the mapping entry is not found in the above hashmap.
// GitHub might update their ecosystem names frequently, so we might also need to update the above map in a timely
// manner for the dependency-diff feature not to fail because of the "mapping not found" error.
func toEcosystem(e string) (ecosystem, error) {
if ecosystemOSV, found := gitHubToOSV[e]; found {
return ecosystemOSV, nil
}
return "", fmt.Errorf("%w for github entry %s", errMappingNotFound, e)
}
func asPointer(s string) *string {
return &s
}