diff --git a/.github/workflows/go.yml b/.github/workflows/go.yml index d319cda..b3f4a04 100644 --- a/.github/workflows/go.yml +++ b/.github/workflows/go.yml @@ -19,7 +19,7 @@ jobs: - name: Set up Go uses: actions/setup-go@v5 with: - go-version: "1.20" + go-version: "1.23" - name: Build uses: goreleaser/goreleaser-action@v6 diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 2cebf72..7fb8f53 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -30,7 +30,7 @@ jobs: - name: Set up Go uses: actions/setup-go@v5 with: - go-version: "1.20" + go-version: "1.23" - name: Run GoReleaser uses: goreleaser/goreleaser-action@v6 diff --git a/go.mod b/go.mod index b029bd7..6c256c2 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/voxpupuli/webhook-go -go 1.19 +go 1.23 require ( code.gitea.io/gitea/modules/structs v0.0.0-20190610152049-835b53fc259c diff --git a/go.sum b/go.sum index 47309b4..2e7ed6c 100644 --- a/go.sum +++ b/go.sum @@ -17,7 +17,9 @@ github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc h1:U9qPSI2PIWSS1VwoXQT9A3Wy9MM3WgvqSxFWenqJduM= github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/fatih/color v1.16.0 h1:zmkK9Ngbjj+K0yRhTVONQh1p/HknKYSlNT+vZCzyokM= +github.com/fatih/color v1.16.0/go.mod h1:fL2Sau1YI5c0pdGEVCbKQbLXB6edEj1ZgiY4NijnWvE= github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHkI4W8= +github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0= github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= github.com/gabriel-vasile/mimetype v1.4.3 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0= @@ -27,6 +29,7 @@ github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm github.com/gin-gonic/gin v1.10.0 h1:nTuyha1TYqgedzytsKYqna+DfLos46nTv2ygFy86HFU= github.com/gin-gonic/gin v1.10.0/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y= github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= +github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= @@ -66,6 +69,7 @@ github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/ad github.com/hashicorp/go-cleanhttp v0.5.2 h1:035FKYIWjmULyFRBKPs8TBQoi0x6d9G4xc9neXJWAZQ= github.com/hashicorp/go-cleanhttp v0.5.2/go.mod h1:kO/YDlP8L1346E6Sodw+PrpBSV4/SoxCXGY6BqNFT48= github.com/hashicorp/go-hclog v1.6.3 h1:Qr2kF+eVWjTiYmU7Y31tYlP1h0q/X3Nl3tPGdaB11/k= +github.com/hashicorp/go-hclog v1.6.3/go.mod h1:W4Qnvbt70Wk/zYJryRzDRU/4r0kIg0PVHBcfoyhpF5M= github.com/hashicorp/go-retryablehttp v0.7.7 h1:C8hUCYzor8PIfXHa4UrZkU4VvK8o9ISHxT2Q8+VepXU= github.com/hashicorp/go-retryablehttp v0.7.7/go.mod h1:pkQpWZeYWskR+D1tR2O5OcBFOxfA7DoAO6xtkuQnHTk= github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= @@ -79,12 +83,15 @@ github.com/klauspost/cpuid/v2 v2.2.7 h1:ZWSB3igEs+d0qvnxR/ZBzXVmxkgt8DdzP6m9pfuV github.com/klauspost/cpuid/v2 v2.2.7/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws= github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= +github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= +github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= github.com/magiconair/properties v1.8.7 h1:IeQXZAiQcpL9mgcAe1Nu6cX9LLw6ExEHKjN0VQdvPDY= github.com/magiconair/properties v1.8.7/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3vdS329zhj2hYo0= github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= +github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mcdafydd/go-azuredevops v0.12.1 h1:WxwLVyGuJ8oL7uWQp1/J6GefX1wMQQZUHWRGsrm+uE8= @@ -108,6 +115,7 @@ github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2/go.mod h1:iKH github.com/proclaim/mock-slack v0.0.0-20201019114328-0aae156a5005 h1:SlqtZxOnV3YSVbB6JMMscoaWjVt6wQmw+LQXs1BoV1k= github.com/proclaim/mock-slack v0.0.0-20201019114328-0aae156a5005/go.mod h1:71oDxYqpK2P74MmQSH18vl6KzSIqcBw3o2bSICV0Fqw= github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8= +github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/sagikazarmark/locafero v0.4.0 h1:HApY1R9zGo4DBgr7dqsTH/JJxLTTsOt7u6keLGt6kNQ= github.com/sagikazarmark/locafero v0.4.0/go.mod h1:Pe1W6UlPYUk/+wc/6KFhbORCfqzgYEpgQ3O5fPuL3H4= @@ -221,6 +229,7 @@ google.golang.org/protobuf v1.34.1 h1:9ddQBjfCyZPOHPUiPxpYESBLc+T8P3E+Vo4IbKZgFW google.golang.org/protobuf v1.34.1/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo= +gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA= gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= diff --git a/lib/chatops/rcserver/rcserver.go b/lib/chatops/rcserver/rcserver.go index 1e2670b..7ac9645 100644 --- a/lib/chatops/rcserver/rcserver.go +++ b/lib/chatops/rcserver/rcserver.go @@ -3,7 +3,7 @@ package rcserver import ( "encoding/json" "fmt" - "io/ioutil" + "io" "net/http" "net/http/httptest" "net/url" @@ -44,7 +44,7 @@ func parseAttachment(data string) []Attachment { } func handlePostMessage(w http.ResponseWriter, r *http.Request) { - body, _ := ioutil.ReadAll(r.Body) + body, _ := io.ReadAll(r.Body) kvs := strings.Split(string(body), "&") m := make(map[string]string) diff --git a/lib/parsers/azure-devops.go b/lib/parsers/azure-devops.go index 8bfc6f7..b1f483f 100644 --- a/lib/parsers/azure-devops.go +++ b/lib/parsers/azure-devops.go @@ -3,7 +3,7 @@ package parsers import ( "encoding/json" "fmt" - "io/ioutil" + "io" "strings" "github.com/gin-gonic/gin" @@ -13,7 +13,7 @@ import ( // parseAzureDevops processes an Azure DevOps webhook, extracting event details such as branch, module name, and repository info. // It handles the PushEvent type and marks the data as completed and successful upon successful parsing. func (d *Data) parseAzureDevops(c *gin.Context) error { - payload, err := ioutil.ReadAll(c.Request.Body) + payload, err := io.ReadAll(c.Request.Body) if err != nil { return err } diff --git a/lib/parsers/gitea.go b/lib/parsers/gitea.go index afbaeb5..1efa4d1 100644 --- a/lib/parsers/gitea.go +++ b/lib/parsers/gitea.go @@ -2,7 +2,7 @@ package parsers import ( "fmt" - "io/ioutil" + "io" "net/http" api "code.gitea.io/gitea/modules/structs" @@ -17,7 +17,7 @@ func giteaWebhookType(r *http.Request) string { // parseGitea processes a Gitea webhook, extracting branch, repository, and user information. // Handles "push" events to set relevant fields based on the payload. func (d *Data) parseGitea(c *gin.Context) error { - payload, err := ioutil.ReadAll(c.Request.Body) + payload, err := io.ReadAll(c.Request.Body) if err != nil { return err } diff --git a/lib/parsers/github.go b/lib/parsers/github.go index 7d1ea81..ece3de9 100644 --- a/lib/parsers/github.go +++ b/lib/parsers/github.go @@ -2,7 +2,7 @@ package parsers import ( "fmt" - "io/ioutil" + "io" "strings" "github.com/gin-gonic/gin" @@ -12,7 +12,7 @@ import ( // parseGithub processes a GitHub webhook, extracting branch, repository, and user information. // Handles both "push" and "workflow_run" events to set relevant fields based on the payload. func (d *Data) parseGithub(c *gin.Context) error { - payload, err := ioutil.ReadAll(c.Request.Body) + payload, err := io.ReadAll(c.Request.Body) if err != nil { return err } diff --git a/lib/parsers/gitlab.go b/lib/parsers/gitlab.go index ab66fa9..7d80275 100644 --- a/lib/parsers/gitlab.go +++ b/lib/parsers/gitlab.go @@ -2,7 +2,7 @@ package parsers import ( "fmt" - "io/ioutil" + "io" "strings" "github.com/gin-gonic/gin" @@ -10,7 +10,7 @@ import ( ) func (d *Data) parseGitlab(c *gin.Context) error { - payload, err := ioutil.ReadAll(c.Request.Body) + payload, err := io.ReadAll(c.Request.Body) if err != nil { return err }