Mogrus initialization fix, gitea PRs, regexp fix.

Fixed Mogrus initialization to pass log level. Configuration to
follow.

OpenSAPS now fully working with Gitea's pull requests.

Fixed URL/URL names regexp for Gitlab and Gitea to include "+" in
them.
This commit is contained in:
2017-11-11 13:00:50 +05:00
parent c9a111c832
commit e969b7018d
3 changed files with 443 additions and 290 deletions

View File

@@ -18,86 +18,239 @@
package giteaparser
import (
// stdlib
"fmt"
"regexp"
"strconv"
"strings"
// stdlib
"fmt"
"regexp"
"strconv"
"strings"
// local
"lab.pztrn.name/pztrn/opensaps/slack/message"
// local
"lab.pztrn.name/pztrn/opensaps/slack/message"
)
type GiteaParser struct {}
type GiteaParser struct{}
func (gp GiteaParser) Initialize() {
c.Log.Infoln("Initializing Gitea parser...")
c.Log.Infoln("Initializing Gitea parser...")
}
func (gp GiteaParser) parseBranchNew(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo} | Branch: {branch}] {header_message}."
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["repo"] = header_data[0][1]
data["repo_url"] = header_data[0][0]
data["branch"] = header_data[1][1]
data["branch_url"] = header_data[1][0]
header_msg := strings.Split(message.Text, "] ")[1]
data["header_message"] = header_msg
return data
}
func (gp GiteaParser) cutLinks(data string) [][]string {
c.Log.Debugln("Passed:", data)
c.Log.Debugln("Passed:", data)
r := regexp.MustCompile("((https??://[a-zA-Z0-9.#!*/ _-]+)\\|([a-zA-Z0-9.#!*/ _-]+))")
r := regexp.MustCompile("((https??://[a-zA-Z0-9.#!*/ _-]+)\\|([a-zA-Z0-9.#!*/ _+-]+))")
found := r.FindAllStringSubmatch(data, -1)
found := r.FindAllStringSubmatch(data, -1)
// [i][0] - link
// [i][1] - string for link
var result [][]string
for i := range found {
res := make([]string, 0, 2)
res = append(res, found[i][2])
res = append(res, found[i][3])
result = append(result, res)
}
// [i][0] - link
// [i][1] - string for link
var result [][]string
for i := range found {
res := make([]string, 0, 2)
res = append(res, found[i][2])
res = append(res, found[i][3])
result = append(result, res)
}
c.Log.Debugln("Links cutted:", result)
return result
c.Log.Debugln("Links cutted:", result)
return result
}
func (gp GiteaParser) parseCommitNew(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo} | Branch: {branch}] {header_message}{newline}{repeatables}"
data := make(map[string]string)
data["message"] = "[Repo: {repo} | Branch: {branch}] {header_message}{newline}{repeatables}"
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["repo"] = header_data[0][1]
data["repo_url"] = header_data[0][0]
data["branch"] = header_data[1][1]
data["branch_url"] = header_data[1][0]
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["repo"] = header_data[0][1]
data["repo_url"] = header_data[0][0]
data["branch"] = header_data[1][1]
data["branch_url"] = header_data[1][0]
header_msg := strings.Split(message.Text, "] ")[1]
data["header_message"] = header_msg
header_msg := strings.Split(message.Text, "] ")[1]
data["header_message"] = header_msg
// Parse commits.
data["repeatable_message"] = "{commit}: {message}{newline}"
data["repeatables"] = "commit,message"
idx := 0
for i := range message.Attachments {
attachment_link := gp.cutLinks(message.Attachments[i].Text)
data["repeatable_item_commit" + strconv.Itoa(idx)] = attachment_link[0][1]
data["repeatable_item_commit" + strconv.Itoa(idx) + "_url"] = attachment_link[0][0]
data["repeatable_item_message" + strconv.Itoa(idx)] = strings.Split(message.Attachments[i].Text, ">: ")[1]
// Parse commits.
data["repeatable_message"] = "{commit}: {message}{newline}"
data["repeatables"] = "commit,message"
idx := 0
for i := range message.Attachments {
attachment_link := gp.cutLinks(message.Attachments[i].Text)
data["repeatable_item_commit"+strconv.Itoa(idx)] = attachment_link[0][1]
data["repeatable_item_commit"+strconv.Itoa(idx)+"_url"] = attachment_link[0][0]
data["repeatable_item_message"+strconv.Itoa(idx)] = strings.Split(message.Attachments[i].Text, ">: ")[1]
idx += 1
}
data["repeatables_count"] = strconv.Itoa(idx)
idx += 1
}
data["repeatables_count"] = strconv.Itoa(idx)
return data
return data
}
func (gp GiteaParser) ParseMessage(message slackmessage.SlackMessage) map[string]string {
c.Log.Debugln("Parsing Gitea message...")
c.Log.Debugln("Parsing Gitea message...")
var data map[string]string
if strings.Contains(message.Text, "new commit") && strings.Contains(message.Text, "pushed by ") {
data = gp.parseCommitNew(message)
} else {
return map[string]string{"message": "Unknown message type:<br />" + fmt.Sprintf("%+v", message)}
}
var data map[string]string
if strings.Contains(message.Text, "new commit") && strings.Contains(message.Text, "pushed by ") {
data = gp.parseCommitNew(message)
} else if strings.Contains(message.Text, "Pull request closed") {
data = gp.parsePullRequestClosed(message)
} else if strings.Contains(message.Text, "Pull request edited") {
data = gp.parsePullRequestEdited(message)
} else if strings.Contains(message.Text, "Pull request labels updated") {
data = gp.parsePullRequestLabelsUpdated(message)
} else if strings.Contains(message.Text, "Pull request merged") {
data = gp.parsePullRequestMerged(message)
} else if strings.Contains(message.Text, "Pull request re-opened") {
data = gp.parsePullRequestReopened(message)
} else if strings.Contains(message.Text, "Pull request submitted") {
data = gp.parsePullRequestSubmitted(message)
} else if strings.Contains(message.Text, "branch created by") {
data = gp.parseBranchNew(message)
} else {
return map[string]string{"message": "Unknown message type:<br />" + fmt.Sprintf("%+v", message)}
}
c.Log.Debugln("Message:", fmt.Sprintf("%+x", data))
c.Log.Debugln("Message:", fmt.Sprintf("%+x", data))
return data
return data
}
func (gp GiteaParser) parsePullRequestClosed(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo}] Pull request {pr} by {user} was closed."
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["pr"] = header_data[0][1]
data["pr_url"] = header_data[0][0]
data["user"] = header_data[1][1]
data["user_url"] = header_data[1][0]
repo := strings.Split(message.Text, "Pull request")[0]
repo = strings.TrimLeft(repo, "[")
repo = strings.TrimRight(repo, "] ")
data["repo"] = repo
return data
}
func (gp GiteaParser) parsePullRequestEdited(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo}] Pull request {pr} was edited by {user}."
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["pr"] = header_data[0][1]
data["pr_url"] = header_data[0][0]
data["user"] = header_data[1][1]
data["user_url"] = header_data[1][0]
repo := strings.Split(message.Text, "Pull request")[0]
repo = strings.TrimLeft(repo, "[")
repo = strings.TrimRight(repo, "] ")
data["repo"] = repo
return data
}
func (gp GiteaParser) parsePullRequestLabelsUpdated(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo}] Pull request {pr} by {user} labels was updated."
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["pr"] = header_data[0][1]
data["pr_url"] = header_data[0][0]
data["user"] = header_data[1][1]
data["user_url"] = header_data[1][0]
repo := strings.Split(message.Text, "Pull request")[0]
repo = strings.TrimLeft(repo, "[")
repo = strings.TrimRight(repo, "] ")
data["repo"] = repo
return data
}
func (gp GiteaParser) parsePullRequestMerged(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo}] Pull request {pr} by {user} was merged."
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["pr"] = header_data[0][1]
data["pr_url"] = header_data[0][0]
data["user"] = header_data[1][1]
data["user_url"] = header_data[1][0]
repo := strings.Split(message.Text, "Pull request")[0]
repo = strings.TrimLeft(repo, "[")
repo = strings.TrimRight(repo, "] ")
data["repo"] = repo
return data
}
func (gp GiteaParser) parsePullRequestReopened(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo}] Pull request {pr} by {user} was re-opened."
// Parse header.
// [0] is repo, [1] is branch.
header_data := gp.cutLinks(message.Text)
data["pr"] = header_data[0][1]
data["pr_url"] = header_data[0][0]
data["user"] = header_data[1][1]
data["user_url"] = header_data[1][0]
repo := strings.Split(message.Text, "Pull request")[0]
repo = strings.TrimLeft(repo, "[")
repo = strings.TrimRight(repo, "] ")
data["repo"] = repo
return data
}
func (gp GiteaParser) parsePullRequestSubmitted(message slackmessage.SlackMessage) map[string]string {
data := make(map[string]string)
data["message"] = "[Repo: {repo}] Pull request {pr} submitted by {user}."
header_data := gp.cutLinks(message.Text)
data["user"] = header_data[0][1]
data["user_url"] = header_data[0][0]
repo := strings.Split(message.Text, "Pull request")[0]
repo = strings.TrimLeft(repo, "[")
repo = strings.TrimRight(repo, "] ")
data["repo"] = repo
// There is a pull request description in attachments.
prdata := gp.cutLinks(message.Attachments[0].Title)
data["pr"] = prdata[0][1]
data["pr_url"] = prdata[0][0]
return data
}