Skip to content

Commit

Permalink
feat: add support for alternative Snyk API URLs
Browse files Browse the repository at this point in the history
  • Loading branch information
mcombuechen committed Nov 11, 2024
1 parent acc6bd2 commit ccc205d
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 5 deletions.
6 changes: 6 additions & 0 deletions doc/providers/snyk.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,12 @@ bomber scan --provider snyk --token xxx sbom.json

Note rather than passing the API token explicitly, you can also set this as an environment variable, either as `SNYK_TOKEN` or the generic `BOMBER_PROVIDER_TOKEN`.

By default, `bomber` will use Snyk's global API (https://api.snyk.io). To use a different Snyk API, you can specify its base URL on the `SNYK_API` environment variable.

```
SNYK_API=https://api.eu.snyk.io bomber scan --provider snyk sbom.json
```


## Supported ecosystems

Expand Down
3 changes: 1 addition & 2 deletions providers/snyk/orgid.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,14 +25,13 @@ type selfDocument struct {
}

func getOrgID(token string) (orgID string, err error) {

client := resty.New()
client.Debug = true

resp, err := client.R().
SetHeader("User-Agent", "bomber").
SetAuthToken(token).
Get(SnykURL + "/self" + SnykAPIVersion)
Get(getSnykAPIURL() + "/rest/self" + SnykAPIVersion)

if err != nil {
log.Print(err)
Expand Down
10 changes: 9 additions & 1 deletion providers/snyk/snyk.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import (
)

const (
SnykURL = "https://api.snyk.io/rest"
SnykURL = "https://api.snyk.io"
SnykAPIVersion = "?version=2022-09-15~experimental"
Concurrency = 10
)
Expand Down Expand Up @@ -102,3 +102,11 @@ func validateCredentials(credentials *models.Credentials) error {

return nil
}

func getSnykAPIURL() string {
u := os.Getenv("SNYK_API")
if u != "" {
return u
}
return SnykURL
}
10 changes: 10 additions & 0 deletions providers/snyk/snyk_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,16 @@ func Test_validateCredentials(t *testing.T) {
os.Setenv("SNYK_TOKEN", snykToken)
}

func Test_getSnykAPIURL_default(t *testing.T) {
assert.Equal(t, "https://api.snyk.io", getSnykAPIURL())
}

func Test_getSnykAPIURL_override(t *testing.T) {
os.Setenv("SNYK_API", "http://example.com")
defer os.Unsetenv("SNYK_API")
assert.Equal(t, "http://example.com", getSnykAPIURL())
}

// func TestProvider_Scan_FakeCredentials(t *testing.T) {
// httpmock.Activate()
// defer httpmock.DeactivateAndReset()
Expand Down
4 changes: 2 additions & 2 deletions providers/snyk/vulns.go
Original file line number Diff line number Diff line change
Expand Up @@ -150,8 +150,8 @@ func getVulnsForPurl(
}

issuesURL := fmt.Sprintf(
"%s/orgs/%s/packages/%s/issues%s",
SnykURL, orgID, url.QueryEscape(purl), SnykAPIVersion,
"%s/rest/orgs/%s/packages/%s/issues%s",
getSnykAPIURL(), orgID, url.QueryEscape(purl), SnykAPIVersion,
)

client := resty.New()
Expand Down

0 comments on commit ccc205d

Please sign in to comment.