diff --git a/README.md b/README.md
index 321af2a..35330a1 100644
--- a/README.md
+++ b/README.md
@@ -1,9 +1,10 @@
Gotcha Bot :robot:
A app to automate engineers tasks
-data:image/s3,"s3://crabby-images/7efbf/7efbf65ab43ceb3e5264f8bd5045116363227b84" alt="License"
-data:image/s3,"s3://crabby-images/1207f/1207fe1a7c4062186740b3ca32894811cb9ac36e" alt="go-version"
-[data:image/s3,"s3://crabby-images/b1052/b10520e9d66b51a656594a85fdd45eea37d362ab" alt="gotcha release (latest)"](https://github.com/diegolnasc/gotcha/releases)
+[data:image/s3,"s3://crabby-images/36062/360628899161c2ff9f23e9526d70ddd9e32ead1b" alt="go-doc"](https://godoc.org/github.com/diegolnasc/gotcha)
+[data:image/s3,"s3://crabby-images/71ae3/71ae3c434041c23c9720457cb7fa98b6fb884d72" alt="go-report"](https://goreportcard.com/report/github.com/diegolnasc/gotcha)
+data:image/s3,"s3://crabby-images/7efbf/7efbf65ab43ceb3e5264f8bd5045116363227b84" alt="license"
+[data:image/s3,"s3://crabby-images/b1052/b10520e9d66b51a656594a85fdd45eea37d362ab" alt="gotcha-release(latest)"](https://github.com/diegolnasc/gotcha/releases)
---
## What can :robot: do?
diff --git a/cmd/main.go b/cmd/main.go
index 8e19356..c6f8b49 100644
--- a/cmd/main.go
+++ b/cmd/main.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package main
import (
@@ -5,29 +9,29 @@ import (
"log"
"net/http"
- config "github.com/diegolnasc/gotcha/pkg/config"
+ "github.com/diegolnasc/gotcha/pkg/config"
github "github.com/diegolnasc/gotcha/pkg/github"
)
-type Provider string
+type provider string
const (
- GitHub Provider = "github"
+ gitHub provider = "github"
)
func main() {
- provider := flag.String("provider", "github", "Provider to run")
+ p := flag.String("provider", "github", "Provider to run")
flag.Parse()
- startProvider(Provider(*provider))
+ startProvider(provider(*p))
err := http.ListenAndServe(":3000", nil)
if err != nil {
log.Panic(err)
}
}
-func startProvider(provider Provider) {
- switch provider {
- case GitHub:
+func startProvider(p provider) {
+ switch p {
+ case gitHub:
config := &config.Settings{}
config.ReadConf()
worker := github.New(config)
diff --git a/pkg/config/config.go b/pkg/config/config.go
index 559d3cb..1804ebe 100644
--- a/pkg/config/config.go
+++ b/pkg/config/config.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package config
import (
@@ -7,34 +11,41 @@ import (
"gopkg.in/yaml.v3"
)
+// Settings represents the configuration and authorization aspects.
type Settings struct {
Layout Layout `yaml:"layout"`
Github Github `yaml:"github"`
}
+// Layout represents permissions level and pull request functionalities.
type Layout struct {
Administration Administration `yaml:"administration"`
PullRequest PullRequest `yaml:"pullRequest"`
}
+// Administration represents general permissions.
type Administration struct {
Permission Permission `yaml:"permission"`
}
+// Permission represents high level user's and repository permissions.
type Permission struct {
Users []string `yaml:"users"`
Repositories []Repositories `yaml:"repositories"`
}
+// Repositories represents low level permissions in repositories.
type Repositories struct {
Repository Repository `yaml:"repository"`
}
+// Repository represents user permission in a single repository.
type Repository struct {
Name string `yaml:"name"`
Users []string `yaml:"users"`
}
+// PullRequest represents commands and functionalities.
type PullRequest struct {
EnableOverview bool `yaml:"enableOverview"`
OverViewCommand string `yaml:"overViewCommand"`
@@ -45,6 +56,7 @@ type PullRequest struct {
TestSuite TestSuite `yaml:"testSuite"`
}
+// TestSuite represents configuration for the test cases.
type TestSuite struct {
NamePattern string `yaml:"namePattern"`
Reviewers bool `yaml:"reviewers"`
@@ -52,6 +64,7 @@ type TestSuite struct {
Labels bool `yaml:"labels"`
}
+// Github represents github app owner configuration.
type Github struct {
AppID int `yaml:"appId"`
Organization string `yaml:"organization"`
@@ -62,6 +75,7 @@ type Github struct {
Events []string `yaml:"events"`
}
+// ReadConf initialize the configuration.
func (c *Settings) ReadConf() {
yamlFile, err := ioutil.ReadFile("build/config-local.yaml")
if err != nil {
diff --git a/pkg/github/check.go b/pkg/github/check.go
index ad6cf3b..e916b04 100644
--- a/pkg/github/check.go
+++ b/pkg/github/check.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -9,14 +13,17 @@ import (
v41 "github.com/google/go-github/v41/github"
)
+// CheckService handles communication with the checkrun/checksuite event.
type CheckService service
+// checkRunResult represents the result of a test case.
type checkRunResult struct {
title string
passed bool
body string
}
+// processCheckRun process the checkrun event payload.
func (s *CheckService) processCheckRun(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload) {
if p.Action == "created" {
result, overralResults := s.runTestSuite(owner, pullRequest, p)
@@ -25,6 +32,7 @@ func (s *CheckService) processCheckRun(owner *string, pullRequest *v41.PullReque
}
}
+// runTestSuite run the test suite.
func (s *CheckService) runTestSuite(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload) ([]*checkRunResult, bool) {
var results []*checkRunResult
overralResults := true
@@ -49,6 +57,7 @@ func (s *CheckService) runTestSuite(owner *string, pullRequest *v41.PullRequest,
return results, overralResults
}
+// isNamePatternValid check if the pull request name is valid.
func (s *CheckService) isNamePatternValid(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload) *checkRunResult {
match, _ := regexp.MatchString(s.w.Config.Layout.PullRequest.TestSuite.NamePattern, *pullRequest.Title)
var body string
@@ -62,6 +71,7 @@ func (s *CheckService) isNamePatternValid(owner *string, pullRequest *v41.PullRe
}
}
+// hasReviewers check if the pull request has reviewers.
func (s *CheckService) hasReviewers(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload) *checkRunResult {
if len(pullRequest.RequestedReviewers) == 0 {
return &checkRunResult{
@@ -76,6 +86,7 @@ func (s *CheckService) hasReviewers(owner *string, pullRequest *v41.PullRequest,
}
}
+// hasAssignees check if the pull request has assignees.
func (s *CheckService) hasAssignees(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload) *checkRunResult {
if len(pullRequest.Assignees) == 0 {
return &checkRunResult{
@@ -90,6 +101,7 @@ func (s *CheckService) hasAssignees(owner *string, pullRequest *v41.PullRequest,
}
}
+// hasLabels check if the pull request has labels.
func (s *CheckService) hasLabels(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload) *checkRunResult {
if len(pullRequest.Labels) == 0 {
return &checkRunResult{
@@ -104,6 +116,7 @@ func (s *CheckService) hasLabels(owner *string, pullRequest *v41.PullRequest, p
}
}
+// updateCheckRunStatus update the check run status in github.
func (s *CheckService) updateCheckRunStatus(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload, overralResults bool) {
var conclusion string
if overralResults {
@@ -117,6 +130,7 @@ func (s *CheckService) updateCheckRunStatus(owner *string, pullRequest *v41.Pull
})
}
+// printResults comments the result of the test suite on the pull request.
func (s *CheckService) printResults(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.CheckRunPayload, results []*checkRunResult, overralResults bool) {
var title string
var body bytes.Buffer
diff --git a/pkg/github/common.go b/pkg/github/common.go
index 0f360ff..7068449 100644
--- a/pkg/github/common.go
+++ b/pkg/github/common.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -12,6 +16,7 @@ import (
v41 "github.com/google/go-github/v41/github"
)
+// GetPullRequest get a pull request.
func (w *Worker) GetPullRequest(owner string, repo string, number int) (*v41.PullRequest, error) {
resp, _, err := w.Client.PullRequests.Get(context.TODO(), owner, repo, number)
if err != nil {
@@ -20,6 +25,7 @@ func (w *Worker) GetPullRequest(owner string, repo string, number int) (*v41.Pul
return resp, err
}
+// GetPullRequestFiles list files from a pull request.
func (w *Worker) GetPullRequestFiles(owner string, repo string, number int, opts *v41.ListOptions) ([]*v41.CommitFile, error) {
resp, _, err := w.Client.PullRequests.ListFiles(context.TODO(), owner, repo, number, opts)
if err != nil {
@@ -28,6 +34,7 @@ func (w *Worker) GetPullRequestFiles(owner string, repo string, number int, opts
return resp, err
}
+// MergePullRequest merge a pull request.
func (w *Worker) MergePullRequest(owner string, repo string, number int, commitMessage string, options v41.PullRequestOptions) (*v41.PullRequestMergeResult, error) {
resp, _, err := w.Client.PullRequests.Merge(context.TODO(), owner, repo, number, commitMessage, &options)
if err != nil {
@@ -36,6 +43,7 @@ func (w *Worker) MergePullRequest(owner string, repo string, number int, commitM
return resp, err
}
+// PullRequestCreateReview create a pull request review.
func (w *Worker) PullRequestCreateReview(owner string, repo string, number int, review v41.PullRequestReviewRequest) (*v41.PullRequestReview, error) {
resp, _, err := w.Client.PullRequests.CreateReview(context.TODO(), owner, repo, number, &review)
if err != nil {
@@ -44,14 +52,7 @@ func (w *Worker) PullRequestCreateReview(owner string, repo string, number int,
return resp, err
}
-func (w *Worker) PullRequestCreateCommentReview(owner string, repo string, number int, comment v41.PullRequestComment) (*v41.PullRequestComment, error) {
- resp, _, err := w.Client.PullRequests.CreateComment(context.TODO(), owner, repo, number, &comment)
- if err != nil {
- log.Printf("error creating pull request review comment: %v\n", err)
- }
- return resp, err
-}
-
+// IssueCreateComment create an issue or pull request comment.
func (w *Worker) IssueCreateComment(owner string, repo string, number int, comment v41.IssueComment) (*v41.IssueComment, error) {
resp, _, err := w.Client.Issues.CreateComment(context.TODO(), owner, repo, number, &comment)
if err != nil {
@@ -60,14 +61,16 @@ func (w *Worker) IssueCreateComment(owner string, repo string, number int, comme
return resp, err
}
-func (w *Worker) IssueUpdateComment(owner string, repo string, commentId int, comment v41.IssueComment) (*v41.IssueComment, error) {
- resp, _, err := w.Client.Issues.EditComment(context.TODO(), owner, repo, int64(commentId), &comment)
+// IssueUpdateComment update an issue or pull request comment.
+func (w *Worker) IssueUpdateComment(owner string, repo string, commentID int, comment v41.IssueComment) (*v41.IssueComment, error) {
+ resp, _, err := w.Client.Issues.EditComment(context.TODO(), owner, repo, int64(commentID), &comment)
if err != nil {
log.Printf("error updating issue comment: %v\n", err)
}
return resp, err
}
+// IssueListComments list the comments of an issue or pull request.
func (w *Worker) IssueListComments(owner string, repo string, number int, opts *v41.IssueListCommentsOptions) ([]*v41.IssueComment, error) {
resp, _, err := w.Client.Issues.ListComments(context.TODO(), owner, repo, number, opts)
if err != nil {
@@ -76,30 +79,16 @@ func (w *Worker) IssueListComments(owner string, repo string, number int, opts *
return resp, err
}
-func (w *Worker) PullRequestListReviewComments(owner string, repo string, number int, opts *v41.PullRequestListCommentsOptions) ([]*v41.PullRequestComment, error) {
- resp, _, err := w.Client.PullRequests.ListComments(context.TODO(), owner, repo, number, opts)
- if err != nil {
- log.Printf("error getting pull list of comments: %v\n", err)
- }
- return resp, err
-}
-
-func (w *Worker) AddLabels(owner string, repo string, number int, labels []string) ([]*v41.Label, error) {
- resp, _, err := w.Client.Issues.AddLabelsToIssue(context.TODO(), owner, repo, number, labels)
- if err != nil {
- log.Printf("error adding labels: %v\n", err)
- }
- return resp, err
-}
-
-func (w *Worker) GetCheckRun(owner string, repo string, checkrunId int64) (*v41.CheckRun, error) {
- resp, _, err := w.Client.Checks.GetCheckRun(context.TODO(), owner, repo, checkrunId)
+// GetCheckRun get a check run.
+func (w *Worker) GetCheckRun(owner string, repo string, checkrunID int64) (*v41.CheckRun, error) {
+ resp, _, err := w.Client.Checks.GetCheckRun(context.TODO(), owner, repo, checkrunID)
if err != nil {
log.Printf("error creating checkrun: %v\n", err)
}
return resp, err
}
+// CreateCheckRun create a check run.
func (w *Worker) CreateCheckRun(owner string, repo string, checkrun v41.CreateCheckRunOptions) (*v41.CheckRun, error) {
resp, _, err := w.Client.Checks.CreateCheckRun(context.TODO(), owner, repo, checkrun)
if err != nil {
@@ -108,14 +97,16 @@ func (w *Worker) CreateCheckRun(owner string, repo string, checkrun v41.CreateCh
return resp, err
}
-func (w *Worker) UpdateCheckRun(owner string, repo string, checkRunId int64, checkRun v41.UpdateCheckRunOptions) (*v41.CheckRun, error) {
- resp, _, err := w.Client.Checks.UpdateCheckRun(context.TODO(), owner, repo, checkRunId, checkRun)
+// UpdateCheckRun update a check run.
+func (w *Worker) UpdateCheckRun(owner string, repo string, checkrunID int64, checkRun v41.UpdateCheckRunOptions) (*v41.CheckRun, error) {
+ resp, _, err := w.Client.Checks.UpdateCheckRun(context.TODO(), owner, repo, checkrunID, checkRun)
if err != nil {
log.Printf("error updating checkrun: %v\n", err)
}
return resp, err
}
+// GetRef get a reference.
func (w *Worker) GetRef(owner string, repo string, ref string) (*v41.Reference, error) {
resp, _, err := w.Client.Git.GetRef(context.TODO(), owner, repo, ref)
if err != nil {
@@ -124,6 +115,7 @@ func (w *Worker) GetRef(owner string, repo string, ref string) (*v41.Reference,
return resp, err
}
+// DeleteRef delete a reference.
func (w *Worker) DeleteRef(owner string, repo string, ref string) (*v41.Response, error) {
resp, err := w.Client.Git.DeleteRef(context.TODO(), owner, repo, ref)
if err != nil {
@@ -132,6 +124,7 @@ func (w *Worker) DeleteRef(owner string, repo string, ref string) (*v41.Response
return resp, err
}
+// CreatePulllRequestOverviewComment create a pull request comment with the report (overview diff).
func (w *Worker) CreatePulllRequestOverviewComment(owner *string, repo string, pullRequestNumber int) {
if pullRequest, err := w.GetPullRequest(*owner, repo, pullRequestNumber); err == nil {
currentIssueComment := w.GetPulllRequestOverviewComment(owner, repo, pullRequestNumber)
@@ -183,8 +176,9 @@ func (w *Worker) CreatePulllRequestOverviewComment(owner *string, repo string, p
}
}
-func (w *Worker) GetPulllRequestOverviewComment(owner *string, repo string, pullrequestId int) *v41.IssueComment {
- if comments, err := w.IssueListComments(*owner, repo, pullrequestId, nil); err == nil {
+// GetPulllRequestOverviewComment get a pull request comment with the report (overview diff).
+func (w *Worker) GetPulllRequestOverviewComment(owner *string, repo string, pullrequestID int) *v41.IssueComment {
+ if comments, err := w.IssueListComments(*owner, repo, pullrequestID, nil); err == nil {
for _, comment := range comments {
if strings.HasPrefix(*comment.Body, "\u003ch3 align=\"center\"\u003ePull request Overview :checkered_flag:") {
if strings.EqualFold("Bot", *comment.User.Type) && strings.Contains(*comment.User.AvatarURL, strconv.Itoa(w.Config.Github.AppID)) {
diff --git a/pkg/github/github.go b/pkg/github/github.go
index 97d4559..6f7330a 100644
--- a/pkg/github/github.go
+++ b/pkg/github/github.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -15,11 +19,13 @@ type service struct {
w Worker
}
+// Worker represents the general configuration to run a provider.
type Worker struct {
Config config.Settings
Client v41.Client
}
+// getOwner get an owner of a provider.
func getOwner(auth *config.Settings) (*string, error) {
if len(auth.Github.Organization) > 0 {
return &auth.Github.Organization, nil
@@ -29,6 +35,7 @@ func getOwner(auth *config.Settings) (*string, error) {
return nil, errors.New("owner not configured")
}
+// isUserAuthorized check if the user running a command is authorized.
func isUserAuthorized(auth *config.Settings, user *string, repo *string) bool {
result := false
if user != nil && repo != nil {
@@ -54,6 +61,7 @@ func isUserAuthorized(auth *config.Settings, user *string, repo *string) bool {
return result
}
+// New initialize a Worker.
func New(auth *config.Settings) *Worker {
var appTransport *ghinstallation.AppsTransport
var installationTransport *ghinstallation.Transport
diff --git a/pkg/github/handler.go b/pkg/github/handler.go
index f6f039a..979b183 100644
--- a/pkg/github/handler.go
+++ b/pkg/github/handler.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -7,6 +11,7 @@ import (
ghwebhooks "github.com/go-playground/webhooks/v6/github"
)
+// Handler webhook event handler.
func (w *Worker) Handler(response http.ResponseWriter, request *http.Request) {
log.Println(request.Header.Get("X-GitHub-Event"))
hook, err := ghwebhooks.New(ghwebhooks.Options.Secret(w.Config.Github.WebhookSecret))
diff --git a/pkg/github/issue.go b/pkg/github/issue.go
index 900b706..de35612 100644
--- a/pkg/github/issue.go
+++ b/pkg/github/issue.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -10,8 +14,11 @@ import (
v41 "github.com/google/go-github/v41/github"
)
+// IssueService handles communication with the issue event.
+// Issue Comment also refer to a pull request comment.
type IssueService service
+// processIssueComment process the issue comment event payload.
func (s *IssueService) processIssueComment(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.IssueCommentPayload) {
s.reRunPullRequestOverview(owner, pullRequest, p)
s.approve(owner, pullRequest, p)
@@ -20,6 +27,7 @@ func (s *IssueService) processIssueComment(owner *string, pullRequest *v41.PullR
s.reRunLaboratoryTest(owner, pullRequest, p)
}
+// reRunPullRequestOverview re-run the pull request report (diff overview).
func (s *IssueService) reRunPullRequestOverview(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.IssueCommentPayload) {
if pullRequest != nil {
if strings.EqualFold(p.Comment.Body, s.w.Config.Layout.PullRequest.OverViewCommand) {
@@ -28,6 +36,7 @@ func (s *IssueService) reRunPullRequestOverview(owner *string, pullRequest *v41.
}
}
+// approve approves a pull request.
func (s *IssueService) approve(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.IssueCommentPayload) {
if pullRequest != nil {
if strings.EqualFold(p.Comment.Body, s.w.Config.Layout.PullRequest.ApproveCommand) {
@@ -43,6 +52,7 @@ func (s *IssueService) approve(owner *string, pullRequest *v41.PullRequest, p *g
}
}
+// merge a pull request.
func (s *IssueService) merge(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.IssueCommentPayload) {
if pullRequest != nil {
if strings.EqualFold(p.Comment.Body, s.w.Config.Layout.PullRequest.MergeCommand) {
@@ -51,6 +61,7 @@ func (s *IssueService) merge(owner *string, pullRequest *v41.PullRequest, p *ghw
}
}
+// merge and delete the reference of the pull request.
func (s *IssueService) mergeAndDelete(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.IssueCommentPayload) {
if pullRequest != nil {
if strings.EqualFold(p.Comment.Body, s.w.Config.Layout.PullRequest.MergeAndDeleteCommand) {
@@ -63,6 +74,7 @@ func (s *IssueService) mergeAndDelete(owner *string, pullRequest *v41.PullReques
}
}
+// reRunLaboratoryTest re-run the pull request test suite.
func (s *IssueService) reRunLaboratoryTest(owner *string, pullRequest *v41.PullRequest, p *ghwebhooks.IssueCommentPayload) {
if pullRequest != nil {
if strings.EqualFold(p.Comment.Body, s.w.Config.Layout.PullRequest.RunTestSuiteCommand) {
diff --git a/pkg/github/pull_request.go b/pkg/github/pull_request.go
index ad42835..bea95a9 100644
--- a/pkg/github/pull_request.go
+++ b/pkg/github/pull_request.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -7,8 +11,10 @@ import (
v41 "github.com/google/go-github/v41/github"
)
+// PullRequestService handles communication with the pull request event.
type PullRequestService service
+// processPullRequest process the pull request event payload.
func (s *PullRequestService) processPullRequest(owner *string, p *ghwebhooks.PullRequestPayload) {
s.createPullRequestOverview(owner, p)
if p.Action == "opened" || p.Action == "reopened" || p.Action == "edited" {
@@ -23,6 +29,7 @@ func (s *PullRequestService) processPullRequest(owner *string, p *ghwebhooks.Pul
}
}
+// createPullRequestOverview create the pull request report (diff overview).
func (s *PullRequestService) createPullRequestOverview(owner *string, p *ghwebhooks.PullRequestPayload) {
if (p.Action == "opened" || p.Action == "reopened") && s.w.Config.Layout.PullRequest.EnableOverview {
s.w.CreatePulllRequestOverviewComment(owner, p.Repository.Name, int(p.PullRequest.Number))
diff --git a/pkg/github/worker.go b/pkg/github/worker.go
index 86c838e..b08ce2a 100644
--- a/pkg/github/worker.go
+++ b/pkg/github/worker.go
@@ -1,3 +1,7 @@
+// Copyright 2021 Diego Lima. All rights reserved.
+
+// Use of this source code is governed by a Apache license.
+// license that can be found in the LICENSE file.
package github
import (
@@ -8,11 +12,13 @@ import (
v41 "github.com/google/go-github/v41/github"
)
+// processPullRequestEvent start a pull request event process.
func (s *PullRequestService) processPullRequestEvent(p *ghwebhooks.PullRequestPayload) {
owner, _ := getOwner(&s.w.Config)
s.processPullRequest(owner, p)
}
+// processIssueCommentEvent start an issue comment event process.
func (s *IssueService) processIssueCommentEvent(p *ghwebhooks.IssueCommentPayload) {
if isUserAuthorized(&s.w.Config, &p.Sender.Login, &p.Repository.Name) && p.Action == "created" {
var pullRequest *v41.PullRequest
@@ -29,6 +35,7 @@ func (s *IssueService) processIssueCommentEvent(p *ghwebhooks.IssueCommentPayloa
}
}
+// processCheckRunEvent start an check run event process.
func (s *CheckService) processCheckRunEvent(p *ghwebhooks.CheckRunPayload) {
if p.CheckRun.App.ID == int64(s.w.Config.Github.AppID) {
var pullRequest *v41.PullRequest
@@ -41,8 +48,8 @@ func (s *CheckService) processCheckRunEvent(p *ghwebhooks.CheckRunPayload) {
return
}
if len(*chekRun.ExternalID) > 0 {
- pullRequestId, _ := strconv.Atoi(*chekRun.ExternalID)
- pullRequest, _ = s.w.GetPullRequest(*owner, p.Repository.Name, pullRequestId)
+ pullRequestID, _ := strconv.Atoi(*chekRun.ExternalID)
+ pullRequest, _ = s.w.GetPullRequest(*owner, p.Repository.Name, pullRequestID)
}
}
s.processCheckRun(owner, pullRequest, p)