From 4bd7ab1bd5095c891a9a9d064d0a9892ac0ac1d4 Mon Sep 17 00:00:00 2001 From: Ori Talmor Date: Wed, 16 Jun 2021 11:31:25 -0400 Subject: [PATCH 1/6] Added missing fields (ghsa_id, severity, created_at) to RepositoryVulnerabilityAlert struct --- github/event_types.go | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/github/event_types.go b/github/event_types.go index 48347f37d04..7a8ea572741 100644 --- a/github/event_types.go +++ b/github/event_types.go @@ -891,15 +891,18 @@ type RepositoryVulnerabilityAlertEvent struct { //The security alert of the vulnerable dependency. Alert *struct { - ID *int64 `json:"id,omitempty"` - AffectedRange *string `json:"affected_range,omitempty"` - AffectedPackageName *string `json:"affected_package_name,omitempty"` - ExternalReference *string `json:"external_reference,omitempty"` - ExternalIdentifier *string `json:"external_identifier,omitempty"` - FixedIn *string `json:"fixed_in,omitempty"` - Dismisser *User `json:"dismisser,omitempty"` - DismissReason *string `json:"dismiss_reason,omitempty"` - DismissedAt *Timestamp `json:"dismissed_at,omitempty"` + ID *int64 `json:"id,omitempty"` + AffectedRange *string `json:"affected_range,omitempty"` + AffectedPackageName *string `json:"affected_package_name,omitempty"` + ExternalReference *string `json:"external_reference,omitempty"` + ExternalIdentifier *string `json:"external_identifier,omitempty"` + GithubSecurityAdvisoryID *string `json:"ghsa_id,omitempty"` + Severity *string `json:"severity,omitempty"` + CreatedAt *Timestamp `json:"created_at,omitempty"` + FixedIn *string `json:"fixed_in,omitempty"` + Dismisser *User `json:"dismisser,omitempty"` + DismissReason *string `json:"dismiss_reason,omitempty"` + DismissedAt *Timestamp `json:"dismissed_at,omitempty"` } `json:"alert,omitempty"` //The repository of the vulnerable dependency. From b42229e261de7f12928178aa490c92f39db9906c Mon Sep 17 00:00:00 2001 From: Ori Talmor Date: Wed, 16 Jun 2021 11:31:53 -0400 Subject: [PATCH 2/6] Added missing fields (open_issues, watchers) to Repository struct --- github/repos.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/github/repos.go b/github/repos.go index 8f34cf8b6d3..1cde35cf67c 100644 --- a/github/repos.go +++ b/github/repos.go @@ -44,9 +44,11 @@ type Repository struct { ForksCount *int `json:"forks_count,omitempty"` NetworkCount *int `json:"network_count,omitempty"` OpenIssuesCount *int `json:"open_issues_count,omitempty"` + OpenIssues *int `json:"open_issues,omitempty"` StargazersCount *int `json:"stargazers_count,omitempty"` SubscribersCount *int `json:"subscribers_count,omitempty"` WatchersCount *int `json:"watchers_count,omitempty"` + Watchers *int `json:"watchers,omitempty"` Size *int `json:"size,omitempty"` AutoInit *bool `json:"auto_init,omitempty"` Parent *Repository `json:"parent,omitempty"` From cac4d270b9250fcbc444d414ce208ca348178273 Mon Sep 17 00:00:00 2001 From: Ori Talmor Date: Wed, 16 Jun 2021 11:33:44 -0400 Subject: [PATCH 3/6] Accessors for Repository struct (GetOpenIssues() and GetWatchers()) created --- github/github-accessors.go | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/github/github-accessors.go b/github/github-accessors.go index 1c17384eac0..03493a742e8 100644 --- a/github/github-accessors.go +++ b/github/github-accessors.go @@ -12468,6 +12468,14 @@ func (r *Repository) GetOpenIssuesCount() int { return *r.OpenIssuesCount } +// GetOpenIssues returns the OpenIssues field if it's non-nil, zero value otherwise. +func (r *Repository) GetOpenIssues() int { + if r == nil || r.OpenIssues == nil { + return 0 + } + return *r.OpenIssues +} + // GetOrganization returns the Organization field. func (r *Repository) GetOrganization() *Organization { if r == nil { @@ -12684,6 +12692,14 @@ func (r *Repository) GetWatchersCount() int { return *r.WatchersCount } +// GetWatchers returns the Watchers field if it's non-nil, zero value otherwise. +func (r *Repository) GetWatchers() int { + if r == nil || r.Watchers == nil { + return 0 + } + return *r.Watchers +} + // GetBody returns the Body field if it's non-nil, zero value otherwise. func (r *RepositoryComment) GetBody() string { if r == nil || r.Body == nil { From 2b774e68dfb164795296325c23bdf139ef295479 Mon Sep 17 00:00:00 2001 From: Ori Talmor Date: Wed, 16 Jun 2021 11:35:53 -0400 Subject: [PATCH 4/6] Created tests for Repository struct relating to new fields (OpenIssues and Watchers) --- github/github-accessors_test.go | 20 ++++++++++++++++++++ github/github-stringify_test.go | 2 ++ 2 files changed, 22 insertions(+) diff --git a/github/github-accessors_test.go b/github/github-accessors_test.go index 750c6a40f8f..2ea2b1e3a71 100644 --- a/github/github-accessors_test.go +++ b/github/github-accessors_test.go @@ -14602,6 +14602,16 @@ func TestRepository_GetOpenIssuesCount(tt *testing.T) { r.GetOpenIssuesCount() } +func TestRepository_GetOpenIssues(tt *testing.T) { + var zeroValue int + r := &Repository{OpenIssues: &zeroValue} + r.GetOpenIssues() + r = &Repository{} + r.GetOpenIssues() + r = nil + r.GetOpenIssues() +} + func TestRepository_GetOrganization(tt *testing.T) { r := &Repository{} r.GetOrganization() @@ -14857,6 +14867,16 @@ func TestRepository_GetWatchersCount(tt *testing.T) { r.GetWatchersCount() } +func TestRepository_GetWatchers(tt *testing.T) { + var zeroValue int + r := &Repository{Watchers: &zeroValue} + r.GetWatchers() + r = &Repository{} + r.GetWatchers() + r = nil + r.GetWatchers() +} + func TestRepositoryComment_GetBody(tt *testing.T) { var zeroValue string r := &RepositoryComment{Body: &zeroValue} diff --git a/github/github-stringify_test.go b/github/github-stringify_test.go index cf0c7ebe817..e37652566cd 100644 --- a/github/github-stringify_test.go +++ b/github/github-stringify_test.go @@ -1381,9 +1381,11 @@ func TestRepository_String(t *testing.T) { ForksCount: Int(0), NetworkCount: Int(0), OpenIssuesCount: Int(0), + OpenIssues: Int(0), StargazersCount: Int(0), SubscribersCount: Int(0), WatchersCount: Int(0), + Watchers: Int(0), Size: Int(0), AutoInit: Bool(false), Parent: &Repository{}, From 4eb2a2a1008a5c918b1d880e22d44c2534528ee1 Mon Sep 17 00:00:00 2001 From: Ori Talmor Date: Wed, 16 Jun 2021 11:43:58 -0400 Subject: [PATCH 5/6] execute `go generate` to make necessory accessor methods. --- github/github-accessors.go | 32 +++++++++++++------------- github/github-accessors_test.go | 40 ++++++++++++++++----------------- github/github-stringify_test.go | 2 +- 3 files changed, 37 insertions(+), 37 deletions(-) diff --git a/github/github-accessors.go b/github/github-accessors.go index 03493a742e8..0a1b282c0d1 100644 --- a/github/github-accessors.go +++ b/github/github-accessors.go @@ -12460,14 +12460,6 @@ func (r *Repository) GetNotificationsURL() string { return *r.NotificationsURL } -// GetOpenIssuesCount returns the OpenIssuesCount field if it's non-nil, zero value otherwise. -func (r *Repository) GetOpenIssuesCount() int { - if r == nil || r.OpenIssuesCount == nil { - return 0 - } - return *r.OpenIssuesCount -} - // GetOpenIssues returns the OpenIssues field if it's non-nil, zero value otherwise. func (r *Repository) GetOpenIssues() int { if r == nil || r.OpenIssues == nil { @@ -12476,6 +12468,14 @@ func (r *Repository) GetOpenIssues() int { return *r.OpenIssues } +// GetOpenIssuesCount returns the OpenIssuesCount field if it's non-nil, zero value otherwise. +func (r *Repository) GetOpenIssuesCount() int { + if r == nil || r.OpenIssuesCount == nil { + return 0 + } + return *r.OpenIssuesCount +} + // GetOrganization returns the Organization field. func (r *Repository) GetOrganization() *Organization { if r == nil { @@ -12684,14 +12684,6 @@ func (r *Repository) GetVisibility() string { return *r.Visibility } -// GetWatchersCount returns the WatchersCount field if it's non-nil, zero value otherwise. -func (r *Repository) GetWatchersCount() int { - if r == nil || r.WatchersCount == nil { - return 0 - } - return *r.WatchersCount -} - // GetWatchers returns the Watchers field if it's non-nil, zero value otherwise. func (r *Repository) GetWatchers() int { if r == nil || r.Watchers == nil { @@ -12700,6 +12692,14 @@ func (r *Repository) GetWatchers() int { return *r.Watchers } +// GetWatchersCount returns the WatchersCount field if it's non-nil, zero value otherwise. +func (r *Repository) GetWatchersCount() int { + if r == nil || r.WatchersCount == nil { + return 0 + } + return *r.WatchersCount +} + // GetBody returns the Body field if it's non-nil, zero value otherwise. func (r *RepositoryComment) GetBody() string { if r == nil || r.Body == nil { diff --git a/github/github-accessors_test.go b/github/github-accessors_test.go index 2ea2b1e3a71..0317a5801c5 100644 --- a/github/github-accessors_test.go +++ b/github/github-accessors_test.go @@ -14592,16 +14592,6 @@ func TestRepository_GetNotificationsURL(tt *testing.T) { r.GetNotificationsURL() } -func TestRepository_GetOpenIssuesCount(tt *testing.T) { - var zeroValue int - r := &Repository{OpenIssuesCount: &zeroValue} - r.GetOpenIssuesCount() - r = &Repository{} - r.GetOpenIssuesCount() - r = nil - r.GetOpenIssuesCount() -} - func TestRepository_GetOpenIssues(tt *testing.T) { var zeroValue int r := &Repository{OpenIssues: &zeroValue} @@ -14612,6 +14602,16 @@ func TestRepository_GetOpenIssues(tt *testing.T) { r.GetOpenIssues() } +func TestRepository_GetOpenIssuesCount(tt *testing.T) { + var zeroValue int + r := &Repository{OpenIssuesCount: &zeroValue} + r.GetOpenIssuesCount() + r = &Repository{} + r.GetOpenIssuesCount() + r = nil + r.GetOpenIssuesCount() +} + func TestRepository_GetOrganization(tt *testing.T) { r := &Repository{} r.GetOrganization() @@ -14857,16 +14857,6 @@ func TestRepository_GetVisibility(tt *testing.T) { r.GetVisibility() } -func TestRepository_GetWatchersCount(tt *testing.T) { - var zeroValue int - r := &Repository{WatchersCount: &zeroValue} - r.GetWatchersCount() - r = &Repository{} - r.GetWatchersCount() - r = nil - r.GetWatchersCount() -} - func TestRepository_GetWatchers(tt *testing.T) { var zeroValue int r := &Repository{Watchers: &zeroValue} @@ -14877,6 +14867,16 @@ func TestRepository_GetWatchers(tt *testing.T) { r.GetWatchers() } +func TestRepository_GetWatchersCount(tt *testing.T) { + var zeroValue int + r := &Repository{WatchersCount: &zeroValue} + r.GetWatchersCount() + r = &Repository{} + r.GetWatchersCount() + r = nil + r.GetWatchersCount() +} + func TestRepositoryComment_GetBody(tt *testing.T) { var zeroValue string r := &RepositoryComment{Body: &zeroValue} diff --git a/github/github-stringify_test.go b/github/github-stringify_test.go index e37652566cd..dc4eee6fdfc 100644 --- a/github/github-stringify_test.go +++ b/github/github-stringify_test.go @@ -1448,7 +1448,7 @@ func TestRepository_String(t *testing.T) { TeamsURL: String(""), Visibility: String(""), } - want := `github.Repository{ID:0, NodeID:"", Owner:github.User{}, Name:"", FullName:"", Description:"", Homepage:"", CodeOfConduct:github.CodeOfConduct{}, DefaultBranch:"", MasterBranch:"", CreatedAt:github.Timestamp{0001-01-01 00:00:00 +0000 UTC}, PushedAt:github.Timestamp{0001-01-01 00:00:00 +0000 UTC}, UpdatedAt:github.Timestamp{0001-01-01 00:00:00 +0000 UTC}, HTMLURL:"", CloneURL:"", GitURL:"", MirrorURL:"", SSHURL:"", SVNURL:"", Language:"", Fork:false, ForksCount:0, NetworkCount:0, OpenIssuesCount:0, StargazersCount:0, SubscribersCount:0, WatchersCount:0, Size:0, AutoInit:false, Parent:github.Repository{}, Source:github.Repository{}, TemplateRepository:github.Repository{}, Organization:github.Organization{}, AllowRebaseMerge:false, AllowSquashMerge:false, AllowMergeCommit:false, DeleteBranchOnMerge:false, Archived:false, Disabled:false, License:github.License{}, Private:false, HasIssues:false, HasWiki:false, HasPages:false, HasProjects:false, HasDownloads:false, IsTemplate:false, LicenseTemplate:"", GitignoreTemplate:"", TeamID:0, URL:"", ArchiveURL:"", AssigneesURL:"", BlobsURL:"", BranchesURL:"", CollaboratorsURL:"", CommentsURL:"", CommitsURL:"", CompareURL:"", ContentsURL:"", ContributorsURL:"", DeploymentsURL:"", DownloadsURL:"", EventsURL:"", ForksURL:"", GitCommitsURL:"", GitRefsURL:"", GitTagsURL:"", HooksURL:"", IssueCommentURL:"", IssueEventsURL:"", IssuesURL:"", KeysURL:"", LabelsURL:"", LanguagesURL:"", MergesURL:"", MilestonesURL:"", NotificationsURL:"", PullsURL:"", ReleasesURL:"", StargazersURL:"", StatusesURL:"", SubscribersURL:"", SubscriptionURL:"", TagsURL:"", TreesURL:"", TeamsURL:"", Visibility:""}` + want := `github.Repository{ID:0, NodeID:"", Owner:github.User{}, Name:"", FullName:"", Description:"", Homepage:"", CodeOfConduct:github.CodeOfConduct{}, DefaultBranch:"", MasterBranch:"", CreatedAt:github.Timestamp{0001-01-01 00:00:00 +0000 UTC}, PushedAt:github.Timestamp{0001-01-01 00:00:00 +0000 UTC}, UpdatedAt:github.Timestamp{0001-01-01 00:00:00 +0000 UTC}, HTMLURL:"", CloneURL:"", GitURL:"", MirrorURL:"", SSHURL:"", SVNURL:"", Language:"", Fork:false, ForksCount:0, NetworkCount:0, OpenIssuesCount:0, OpenIssues:0, StargazersCount:0, SubscribersCount:0, WatchersCount:0, Watchers:0, Size:0, AutoInit:false, Parent:github.Repository{}, Source:github.Repository{}, TemplateRepository:github.Repository{}, Organization:github.Organization{}, AllowRebaseMerge:false, AllowSquashMerge:false, AllowMergeCommit:false, DeleteBranchOnMerge:false, Archived:false, Disabled:false, License:github.License{}, Private:false, HasIssues:false, HasWiki:false, HasPages:false, HasProjects:false, HasDownloads:false, IsTemplate:false, LicenseTemplate:"", GitignoreTemplate:"", TeamID:0, URL:"", ArchiveURL:"", AssigneesURL:"", BlobsURL:"", BranchesURL:"", CollaboratorsURL:"", CommentsURL:"", CommitsURL:"", CompareURL:"", ContentsURL:"", ContributorsURL:"", DeploymentsURL:"", DownloadsURL:"", EventsURL:"", ForksURL:"", GitCommitsURL:"", GitRefsURL:"", GitTagsURL:"", HooksURL:"", IssueCommentURL:"", IssueEventsURL:"", IssuesURL:"", KeysURL:"", LabelsURL:"", LanguagesURL:"", MergesURL:"", MilestonesURL:"", NotificationsURL:"", PullsURL:"", ReleasesURL:"", StargazersURL:"", StatusesURL:"", SubscribersURL:"", SubscriptionURL:"", TagsURL:"", TreesURL:"", TeamsURL:"", Visibility:""}` if got := v.String(); got != want { t.Errorf("Repository.String = %v, want %v", got, want) } From 7a85d1f0c1c9b60bf2070a2ec1815530142aee53 Mon Sep 17 00:00:00 2001 From: Ori Talmor Date: Wed, 16 Jun 2021 12:06:53 -0400 Subject: [PATCH 6/6] Rename Repository Vulnerability Alert Field - GitHubSecurityAdvisoryID Capitalization of GitHub rather than Github Co-authored-by: Glenn Lewis <6598971+gmlewis@users.noreply.github.com> --- github/event_types.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/github/event_types.go b/github/event_types.go index 7a8ea572741..b5a00bdc9da 100644 --- a/github/event_types.go +++ b/github/event_types.go @@ -896,7 +896,7 @@ type RepositoryVulnerabilityAlertEvent struct { AffectedPackageName *string `json:"affected_package_name,omitempty"` ExternalReference *string `json:"external_reference,omitempty"` ExternalIdentifier *string `json:"external_identifier,omitempty"` - GithubSecurityAdvisoryID *string `json:"ghsa_id,omitempty"` + GitHubSecurityAdvisoryID *string `json:"ghsa_id,omitempty"` Severity *string `json:"severity,omitempty"` CreatedAt *Timestamp `json:"created_at,omitempty"` FixedIn *string `json:"fixed_in,omitempty"`