2019-04-19 05:45:02 +03:00
// Copyright 2019 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2019-11-04 01:13:25 +03:00
package webhook
2019-04-19 05:45:02 +03:00
import (
"encoding/json"
"fmt"
"strings"
2019-11-04 01:13:25 +03:00
"code.gitea.io/gitea/models"
2019-04-19 05:45:02 +03:00
"code.gitea.io/gitea/modules/git"
2019-11-04 01:13:25 +03:00
"code.gitea.io/gitea/modules/log"
2019-04-19 05:45:02 +03:00
"code.gitea.io/gitea/modules/markup"
2019-05-11 13:21:34 +03:00
api "code.gitea.io/gitea/modules/structs"
2019-04-19 05:45:02 +03:00
)
type (
// TelegramPayload represents
TelegramPayload struct {
2019-04-23 19:12:00 +03:00
Message string ` json:"text" `
ParseMode string ` json:"parse_mode" `
DisableWebPreview bool ` json:"disable_web_page_preview" `
2019-04-19 05:45:02 +03:00
}
// TelegramMeta contains the telegram metadata
TelegramMeta struct {
BotToken string ` json:"bot_token" `
ChatID string ` json:"chat_id" `
}
)
2019-11-04 01:13:25 +03:00
// GetTelegramHook returns telegram metadata
func GetTelegramHook ( w * models . Webhook ) * TelegramMeta {
s := & TelegramMeta { }
if err := json . Unmarshal ( [ ] byte ( w . Meta ) , s ) ; err != nil {
log . Error ( "webhook.GetTelegramHook(%d): %v" , w . ID , err )
}
return s
}
2019-04-19 05:45:02 +03:00
// SetSecret sets the telegram secret
func ( p * TelegramPayload ) SetSecret ( _ string ) { }
// JSONPayload Marshals the TelegramPayload to json
func ( p * TelegramPayload ) JSONPayload ( ) ( [ ] byte , error ) {
p . ParseMode = "HTML"
2019-04-23 19:12:00 +03:00
p . DisableWebPreview = true
2019-04-19 05:45:02 +03:00
p . Message = markup . Sanitize ( p . Message )
data , err := json . MarshalIndent ( p , "" , " " )
if err != nil {
return [ ] byte { } , err
}
return data , nil
}
func getTelegramCreatePayload ( p * api . CreatePayload ) ( * TelegramPayload , error ) {
// created tag/branch
refName := git . RefEndName ( p . Ref )
title := fmt . Sprintf ( ` [<a href="%s">%s</a>] %s <a href="%s">%s</a> created ` , p . Repo . HTMLURL , p . Repo . FullName , p . RefType ,
p . Repo . HTMLURL + "/src/" + refName , refName )
return & TelegramPayload {
Message : title ,
} , nil
}
func getTelegramDeletePayload ( p * api . DeletePayload ) ( * TelegramPayload , error ) {
// created tag/branch
refName := git . RefEndName ( p . Ref )
title := fmt . Sprintf ( ` [<a href="%s">%s</a>] %s <a href="%s">%s</a> deleted ` , p . Repo . HTMLURL , p . Repo . FullName , p . RefType ,
p . Repo . HTMLURL + "/src/" + refName , refName )
return & TelegramPayload {
Message : title ,
} , nil
}
func getTelegramForkPayload ( p * api . ForkPayload ) ( * TelegramPayload , error ) {
title := fmt . Sprintf ( ` %s is forked to <a href="%s">%s</a> ` , p . Forkee . FullName , p . Repo . HTMLURL , p . Repo . FullName )
return & TelegramPayload {
Message : title ,
} , nil
}
func getTelegramPushPayload ( p * api . PushPayload ) ( * TelegramPayload , error ) {
var (
branchName = git . RefEndName ( p . Ref )
commitDesc string
)
var titleLink string
if len ( p . Commits ) == 1 {
commitDesc = "1 new commit"
titleLink = p . Commits [ 0 ] . URL
} else {
commitDesc = fmt . Sprintf ( "%d new commits" , len ( p . Commits ) )
titleLink = p . CompareURL
}
if titleLink == "" {
titleLink = p . Repo . HTMLURL + "/src/" + branchName
}
title := fmt . Sprintf ( ` [<a href="%s">%s</a>:<a href="%s">%s</a>] %s ` , p . Repo . HTMLURL , p . Repo . FullName , titleLink , branchName , commitDesc )
var text string
// for each commit, generate attachment text
for i , commit := range p . Commits {
var authorName string
if commit . Author != nil {
authorName = " - " + commit . Author . Name
}
text += fmt . Sprintf ( ` [<a href="%s">%s</a>] %s ` , commit . URL , commit . ID [ : 7 ] ,
strings . TrimRight ( commit . Message , "\r\n" ) ) + authorName
// add linebreak to each commit but the last
if i < len ( p . Commits ) - 1 {
text += "\n"
}
}
return & TelegramPayload {
Message : title + "\n" + text ,
} , nil
}
func getTelegramIssuesPayload ( p * api . IssuePayload ) ( * TelegramPayload , error ) {
2020-01-05 01:20:15 +03:00
text , _ , attachmentText , _ := getIssuesPayloadInfo ( p , htmlLinkFormatter , true )
2019-04-19 05:45:02 +03:00
return & TelegramPayload {
2019-12-28 11:55:09 +03:00
Message : text + "\n\n" + attachmentText ,
2019-04-19 05:45:02 +03:00
} , nil
}
func getTelegramIssueCommentPayload ( p * api . IssueCommentPayload ) ( * TelegramPayload , error ) {
2020-01-05 01:20:15 +03:00
text , _ , _ := getIssueCommentPayloadInfo ( p , htmlLinkFormatter , true )
2019-04-19 05:45:02 +03:00
return & TelegramPayload {
2019-12-28 11:55:09 +03:00
Message : text + "\n" + p . Comment . Body ,
2019-04-19 05:45:02 +03:00
} , nil
}
func getTelegramPullRequestPayload ( p * api . PullRequestPayload ) ( * TelegramPayload , error ) {
2020-01-05 01:20:15 +03:00
text , _ , attachmentText , _ := getPullRequestPayloadInfo ( p , htmlLinkFormatter , true )
2019-04-19 05:45:02 +03:00
return & TelegramPayload {
2019-12-28 11:55:09 +03:00
Message : text + "\n" + attachmentText ,
2019-04-19 05:45:02 +03:00
} , nil
}
func getTelegramRepositoryPayload ( p * api . RepositoryPayload ) ( * TelegramPayload , error ) {
var title string
switch p . Action {
case api . HookRepoCreated :
title = fmt . Sprintf ( ` [<a href="%s">%s</a>] Repository created ` , p . Repository . HTMLURL , p . Repository . FullName )
return & TelegramPayload {
Message : title ,
} , nil
case api . HookRepoDeleted :
title = fmt . Sprintf ( "[%s] Repository deleted" , p . Repository . FullName )
return & TelegramPayload {
Message : title ,
} , nil
}
return nil , nil
}
func getTelegramReleasePayload ( p * api . ReleasePayload ) ( * TelegramPayload , error ) {
2020-01-05 01:20:15 +03:00
text , _ := getReleasePayloadInfo ( p , htmlLinkFormatter , true )
2019-04-19 05:45:02 +03:00
2019-12-28 11:55:09 +03:00
return & TelegramPayload {
Message : text + "\n" ,
} , nil
2019-04-19 05:45:02 +03:00
}
// GetTelegramPayload converts a telegram webhook into a TelegramPayload
2019-11-04 01:13:25 +03:00
func GetTelegramPayload ( p api . Payloader , event models . HookEventType , meta string ) ( * TelegramPayload , error ) {
2019-04-19 05:45:02 +03:00
s := new ( TelegramPayload )
switch event {
2019-11-04 01:13:25 +03:00
case models . HookEventCreate :
2019-04-19 05:45:02 +03:00
return getTelegramCreatePayload ( p . ( * api . CreatePayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventDelete :
2019-04-19 05:45:02 +03:00
return getTelegramDeletePayload ( p . ( * api . DeletePayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventFork :
2019-04-19 05:45:02 +03:00
return getTelegramForkPayload ( p . ( * api . ForkPayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventIssues :
2019-04-19 05:45:02 +03:00
return getTelegramIssuesPayload ( p . ( * api . IssuePayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventIssueComment :
2019-04-19 05:45:02 +03:00
return getTelegramIssueCommentPayload ( p . ( * api . IssueCommentPayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventPush :
2019-04-19 05:45:02 +03:00
return getTelegramPushPayload ( p . ( * api . PushPayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventPullRequest :
2019-04-19 05:45:02 +03:00
return getTelegramPullRequestPayload ( p . ( * api . PullRequestPayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventRepository :
2019-04-19 05:45:02 +03:00
return getTelegramRepositoryPayload ( p . ( * api . RepositoryPayload ) )
2019-11-04 01:13:25 +03:00
case models . HookEventRelease :
2019-04-19 05:45:02 +03:00
return getTelegramReleasePayload ( p . ( * api . ReleasePayload ) )
}
return s , nil
}