-
Notifications
You must be signed in to change notification settings - Fork 2.1k
/
dependabot_alerts.go
128 lines (110 loc) · 4.67 KB
/
dependabot_alerts.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
// Copyright 2022 The go-github AUTHORS. All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package github
import (
"context"
"fmt"
)
type Dependency struct {
Package VulnerabilityPackage `json:"package"`
ManifestPath string `json:"manifest_path"`
Scope string `json:"scope"`
}
type AdvisoryCvss struct {
Score float64 `json:"score"`
VectorString string `json:"vector_string"`
}
type AdvisoryCwes struct {
CweID string `json:"cwe_id"`
Name string `json:"name"`
}
type DependabotSecurityAdvisory struct {
GHSAID string `json:"ghsa_id"`
CVEID string `json:"cve_id"`
Summary string `json:"summary"`
Description string `json:"description"`
Vulnerabilities []AdvisoryVulnerability `json:"vulnerabilities"`
Severity string `json:"severity"`
Cvss AdvisoryCvss `json:"cvss"`
Cwes []AdvisoryCwes `json:"cwes"`
Identifiers []AdvisoryIdentifier `json:"identifiers"`
References []AdvisoryReference `json:"references"`
PublishedAt Timestamp `json:"published_at"`
UpdatedAt Timestamp `json:"updated_at"`
WithdrawnAt *Timestamp `json:"withdrawn_at"`
}
// DependabotAlert represents a dependabot alert
type DependabotAlert struct {
Number int `json:"number"`
State string `json:"state"`
Dependency Dependency `json:"dependency"`
SecurityAdvisory DependabotSecurityAdvisory `json:"security_advisory"`
SecurityVulnerability AdvisoryVulnerability `json:"security_vulnerability"`
URL string `json:"url"`
HtmlURL string `json:"html_url"`
CreatedAt Timestamp `json:"created_at"`
UpdatedAt Timestamp `json:"updated_at"`
DismissedAt *Timestamp `json:"dismissed_at"`
DismissedBy *User `json:"dismissed_by"`
DismissedReason string `json:"dismissed_reason"`
DismissedComment string `json:"dismissed_comment"`
FixedAt *Timestamp `json:"fixed_at"`
}
type ListAlertsOptions struct {
State string `url:"state,omitempty"`
Severity string `url:"severity,omitempty"`
Ecosystem string `url:"ecosystem,omitempty"`
Package string `url:"package,omitempty"`
Scope string `url:"scope,omitempty"`
Sort string `url:"sort,omitempty"`
Direction string `url:"direction,omitempty"`
ListCursorOptions
}
func (s *DependabotService) listAlerts(ctx context.Context, url string, opts *ListAlertsOptions) ([]*DependabotAlert, *Response, error) {
u, err := addOptions(url, opts)
if err != nil {
return nil, nil, err
}
req, err := s.client.NewRequest("GET", u, nil)
if err != nil {
return nil, nil, err
}
var alerts []*DependabotAlert
resp, err := s.client.Do(ctx, req, &alerts)
if err != nil {
return nil, resp, err
}
return alerts, resp, nil
}
// ListRepoAlerts lists all Dependabot alerts of a repository
//
// GitHub API docs: https://docs.github.com/en/rest/dependabot/alerts#list-dependabot-alerts-for-a-repository
func (s *DependabotService) ListRepoAlerts(ctx context.Context, owner, repo string, opts *ListAlertsOptions) ([]*DependabotAlert, *Response, error) {
url := fmt.Sprintf("repos/%v/%v/dependabot/alerts", owner, repo)
return s.listAlerts(ctx, url, opts)
}
// ListOrgAlerts lists all Dependabot alerts of an organization
//
// GitHub API docs: https://docs.github.com/en/rest/dependabot/alerts#list-dependabot-alerts-for-an-organization
func (s *DependabotService) ListOrgAlerts(ctx context.Context, org string, opts *ListAlertsOptions) ([]*DependabotAlert, *Response, error) {
url := fmt.Sprintf("orgs/%v/dependabot/alerts", org)
return s.listAlerts(ctx, url, opts)
}
// GetRepoAlert gets a single repository Dependabot alert
//
// GitHub API docs: https://docs.github.com/en/rest/dependabot/alerts#get-a-dependabot-alert
func (s *DependabotService) GetRepoAlert(ctx context.Context, owner string, repo string, number int) (*DependabotAlert, *Response, error) {
url := fmt.Sprintf("repos/%v/%v/dependabot/alerts/%v", owner, repo, number)
req, err := s.client.NewRequest("GET", url, nil)
if err != nil {
return nil, nil, err
}
alert := new(DependabotAlert)
resp, err := s.client.Do(ctx, req, alert)
if err != nil {
return nil, resp, err
}
return alert, resp, nil
}