feat(all_files): adding plugin
Signed-off-by: Mark Sharpley <698889+markopolo123@users.noreply.github.com>
This commit is contained in:
parent
e08655b158
commit
30383e0c79
6 changed files with 206 additions and 1 deletions
46
.woodpecker/pull_request.yml
Normal file
46
.woodpecker/pull_request.yml
Normal file
|
@ -0,0 +1,46 @@
|
|||
pipeline:
|
||||
lint-go:
|
||||
image: golangci/golangci-lint
|
||||
group: lint-build
|
||||
commands:
|
||||
- golangci-lint run *.go --enable=gofumpt
|
||||
when:
|
||||
path: "*.go"
|
||||
lint-docker:
|
||||
image: hadolint/hadolint:latest-debian
|
||||
group: lint-build
|
||||
commands:
|
||||
- hadolint --ignore DL3003 Dockerfile
|
||||
when:
|
||||
path: "Dockerfile"
|
||||
build-go:
|
||||
image: golang
|
||||
group: lint-build
|
||||
commands:
|
||||
- go build
|
||||
when:
|
||||
path: ["Dockerfile", "*.go"]
|
||||
build-docker-pr:
|
||||
image: plugins/kaniko
|
||||
settings:
|
||||
repo: mcs94/gitea-comment
|
||||
tags: latest
|
||||
dockerfile: Dockerfile
|
||||
no_push: true
|
||||
when:
|
||||
event: pull_request
|
||||
branch: main
|
||||
path: ["Dockerfile", "*.go"]
|
||||
build-docker:
|
||||
image: plugins/kaniko
|
||||
settings:
|
||||
repo: mcs94/gitea-comment
|
||||
tags: latest
|
||||
dockerfile: Dockerfile
|
||||
username: mcs94
|
||||
password:
|
||||
from_secret: docker_password
|
||||
when:
|
||||
event: [push, tag]
|
||||
branch: main
|
||||
path: ["Dockerfile", "*.go"]
|
15
Dockerfile
Normal file
15
Dockerfile
Normal file
|
@ -0,0 +1,15 @@
|
|||
# syntax=docker/dockerfile:1
|
||||
## Build
|
||||
FROM golang:1.19.2-alpine3.16 AS build
|
||||
WORKDIR /app
|
||||
COPY go.mod ./
|
||||
# COPY go.sum ./
|
||||
RUN go mod download
|
||||
COPY *.go ./
|
||||
RUN go build -o /main
|
||||
|
||||
## Deploy
|
||||
FROM alpine:3.16.2
|
||||
WORKDIR /
|
||||
COPY --from=build /main /main
|
||||
ENTRYPOINT ["/main"]
|
48
README.md
48
README.md
|
@ -1,2 +1,48 @@
|
|||
# gitea-comment-plugin
|
||||
Woodpecker Plugin for Gitea PR Comments
|
||||
|
||||
A Woodpecker plugin to post comments onto a Gitea Pull Request.
|
||||
|
||||
Note this currently only works on `pull request` events.
|
||||
|
||||
## Usage/Examples
|
||||
|
||||
```yaml
|
||||
pipeline:
|
||||
comment:
|
||||
image: mcs94/gitea-comment
|
||||
settings:
|
||||
gitea_address: https://gitea.url.goes.here
|
||||
gitea_token:
|
||||
from_secret: gitea_token
|
||||
comment: >
|
||||
✅ Build ${CI_BUILD_EVENT} of `${CI_REPO_NAME}` has status `${CI_BUILD_STATUS}`.
|
||||
|
||||
📝 Commit by ${CI_COMMIT_AUTHOR} on `${CI_COMMIT_BRANCH}`:
|
||||
|
||||
`${CI_COMMIT_MESSAGE}`
|
||||
|
||||
🌐 ${CI_BUILD_LINK}
|
||||
when:
|
||||
event: [pull_request]
|
||||
```
|
||||
|
||||
Produces something with looks like the screenshot below on pull requests:
|
||||
|
||||

|
||||
|
||||
## Authors
|
||||
|
||||
* [@markopolo123](https://www.github.com/markopolo123)
|
||||
|
||||
## Running just the container
|
||||
|
||||
```bash
|
||||
docker run \
|
||||
-e PLUGIN_COMMENT="test comment" \
|
||||
-e PLUGIN_GITEA_TOKEN="tokenhere" \
|
||||
-e PLUGIN_GITEA_ADDRESS="https://gitea.url.here" \
|
||||
-e CI_REPO_OWNER="repoowwer" \
|
||||
-e CI_REPO_NAME="yourrepo" \
|
||||
-e CI_COMMIT_PULL_REQUEST=8 \
|
||||
test-gitea
|
||||
```
|
||||
|
|
3
go.mod
Normal file
3
go.mod
Normal file
|
@ -0,0 +1,3 @@
|
|||
module gitea-comment
|
||||
|
||||
go 1.19
|
BIN
img/comments.png
Normal file
BIN
img/comments.png
Normal file
Binary file not shown.
After ![]() (image error) Size: 633 KiB |
95
main.go
Normal file
95
main.go
Normal file
|
@ -0,0 +1,95 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/json"
|
||||
"flag"
|
||||
"fmt"
|
||||
"log"
|
||||
"net/http"
|
||||
"os"
|
||||
"strconv"
|
||||
)
|
||||
|
||||
type Payload struct {
|
||||
Body string `json:"body"`
|
||||
}
|
||||
|
||||
func LookupEnvOrString(key string, defaultVal string) string {
|
||||
if val, ok := os.LookupEnv(key); ok {
|
||||
return val
|
||||
}
|
||||
return defaultVal
|
||||
}
|
||||
|
||||
func LookupEnvOrInt(key string, defaultVal int) int {
|
||||
if val, ok := os.LookupEnv(key); ok {
|
||||
v, err := strconv.Atoi(val)
|
||||
if err != nil {
|
||||
log.Fatalf("LookupEnvOrInt[%s]: %v", key, err)
|
||||
}
|
||||
return v
|
||||
}
|
||||
return defaultVal
|
||||
}
|
||||
|
||||
func main() {
|
||||
var giteaToken string
|
||||
var giteaAddress string
|
||||
var comment string
|
||||
var repoOwner string
|
||||
var repoName string
|
||||
var prIndex int
|
||||
|
||||
flag.StringVar(&giteaToken, "gitea-token", LookupEnvOrString("PLUGIN_GITEA_TOKEN", giteaToken), "API token for Gitea")
|
||||
flag.StringVar(&giteaAddress, "gitea-address", LookupEnvOrString("PLUGIN_GITEA_ADDRESS", giteaAddress), "Gitea URL")
|
||||
flag.StringVar(&comment, "comment", LookupEnvOrString("PLUGIN_COMMENT", comment), "Comment for Gitea")
|
||||
flag.StringVar(&repoOwner, "repo-owner", LookupEnvOrString("CI_REPO_OWNER", repoOwner), "Owner of the repository")
|
||||
flag.StringVar(&repoName, "repo-name", LookupEnvOrString("CI_REPO_NAME", repoName), "Name of the repository")
|
||||
flag.IntVar(&prIndex, "pr-index", LookupEnvOrInt("CI_COMMIT_PULL_REQUEST", prIndex), "Index of the PR")
|
||||
|
||||
flag.Parse()
|
||||
|
||||
if comment == "" {
|
||||
panic("You must provide a comment")
|
||||
}
|
||||
if giteaToken == "" {
|
||||
panic("You must provide a Gitea API Token")
|
||||
}
|
||||
if giteaAddress == "" {
|
||||
panic("You must provide a Gitea URL")
|
||||
}
|
||||
if repoOwner == "" {
|
||||
panic("You must provide an repo owner")
|
||||
}
|
||||
if repoName == "" {
|
||||
panic("You must provide a repo name")
|
||||
}
|
||||
if prIndex == 0 {
|
||||
panic("You must provide an index for PR")
|
||||
}
|
||||
|
||||
data := Payload{
|
||||
Body: comment,
|
||||
}
|
||||
payloadBytes, err := json.Marshal(data)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
body := bytes.NewReader(payloadBytes)
|
||||
|
||||
url := fmt.Sprintf("%s/api/v1/repos/%s/%s/issues/%d/comments?access_token=%s", giteaAddress, repoOwner, repoName, prIndex, giteaToken)
|
||||
|
||||
req, err := http.NewRequest("POST", url, body)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
req.Header.Set("Accept", "application/json")
|
||||
req.Header.Set("Content-Type", "application/json")
|
||||
|
||||
resp, err := http.DefaultClient.Do(req)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
}
|
Loading…
Add table
Reference in a new issue