tokarchuk/v1.17
Unknown 11 years ago
parent 015174484a
commit 48b2425c1d
  1. 4
      models/action.go
  2. 20
      modules/base/tool.go

@ -44,6 +44,10 @@ func (a Action) GetRepoName() string {
return a.RepoName return a.RepoName
} }
func (a Action) GetContent() string {
return a.Content
}
// CommitRepoAction records action for commit repository. // CommitRepoAction records action for commit repository.
func CommitRepoAction(userId int64, userName string, func CommitRepoAction(userId int64, userName string,
repoId int64, repoName string, commits [][]string) error { repoId int64, repoName string, commits [][]string) error {

@ -7,6 +7,7 @@ package base
import ( import (
"crypto/md5" "crypto/md5"
"encoding/hex" "encoding/hex"
"encoding/json"
"fmt" "fmt"
"math" "math"
"strings" "strings"
@ -235,6 +236,7 @@ type Actioner interface {
GetOpType() int GetOpType() int
GetActUserName() string GetActUserName() string
GetRepoName() string GetRepoName() string
GetContent() string
} }
// ActionIcon accepts a int that represents action operation type // ActionIcon accepts a int that represents action operation type
@ -243,13 +245,19 @@ func ActionIcon(opType int) string {
switch opType { switch opType {
case 1: // Create repository. case 1: // Create repository.
return "plus-circle" return "plus-circle"
case 5: // Commit repository.
return "arrow-circle-o-right"
default: default:
return "invalid type" return "invalid type"
} }
} }
const ( const (
CreateRepoTpl = `<a href="/user/%s">%s</a> created repository <a href="/%s/%s">%s</a>` TPL_CREATE_REPO = `<a href="/user/%s">%s</a> created repository <a href="/%s/%s">%s</a>`
TPL_COMMIT_REPO = `<a href="/user/%s">%s</a> pushed to <a href="/%s/%s/tree/%s">%s</a> at <a href="/%s/%s">%s/%s</a>
<ul>
<li><a href="/%s/%s/commit/%s">%s</a> %s</li>
</ul>`
) )
// ActionDesc accepts int that represents action operation type // ActionDesc accepts int that represents action operation type
@ -257,9 +265,17 @@ const (
func ActionDesc(act Actioner) string { func ActionDesc(act Actioner) string {
actUserName := act.GetActUserName() actUserName := act.GetActUserName()
repoName := act.GetRepoName() repoName := act.GetRepoName()
content := act.GetContent()
switch act.GetOpType() { switch act.GetOpType() {
case 1: // Create repository. case 1: // Create repository.
return fmt.Sprintf(CreateRepoTpl, actUserName, actUserName, actUserName, repoName, repoName) return fmt.Sprintf(TPL_CREATE_REPO, actUserName, actUserName, actUserName, repoName, repoName)
case 5: // Commit repository.
var commits [][]string
if err := json.Unmarshal([]byte(content), &commits); err != nil {
return err.Error()
}
return fmt.Sprintf(TPL_COMMIT_REPO, actUserName, actUserName, actUserName, repoName, "master", "master", actUserName, repoName, actUserName, repoName,
actUserName, repoName, commits[0][0], commits[0][0][:7], commits[0][1])
default: default:
return "invalid type" return "invalid type"
} }

Loading…
Cancel
Save