123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- package dao
- import (
- "bytes"
- "context"
- "encoding/json"
- "fmt"
- "net/http"
- "net/url"
- "regexp"
- "strconv"
- "strings"
- "go-common/app/admin/main/apm/conf"
- "go-common/app/admin/main/apm/model/ut"
- "go-common/library/log"
- "github.com/jinzhu/gorm"
- )
- const (
- _sagaWechatURL = "http://uat-saga-admin.bilibili.co/ep/admin/saga/v2/wechat"
- _gitCommitsAPI = "http://git.bilibili.co/api/v4/projects/682/repository/commits"
- )
- // ParseUTFiles parse html to get specific file
- func (d *Dao) ParseUTFiles(c context.Context, url string) (pkgs []*ut.PkgAnls, err error) {
- var (
- req *http.Request
- html []byte
- files []string
- )
- if req, err = http.NewRequest(http.MethodGet, url, nil); err != nil {
- log.Error("apmSvc.ParseUTFiless error (%v)", err)
- return
- }
- if html, err = d.client.Raw(c, req); err != nil {
- log.Error("apmSvc.ParseUTFiles error (%v)", err)
- return
- }
- reg := regexp.MustCompile(`<option(.*)</option>`)
- files = reg.FindAllString(string(html), -1)
- for _, file := range files {
- cov, _ := strconv.ParseFloat(file[strings.Index(file, "(")+1:strings.Index(file, "%)")], 64)
- pkg := &ut.PkgAnls{
- PKG: file[strings.Index(file, "go-common") : strings.Index(file, ".go")+3],
- Coverage: cov,
- HTMLURL: url + "#" + file[strings.Index(file, `="`)+2:strings.Index(file, `">`)],
- }
- pkgs = append(pkgs, pkg)
- }
- return
- }
- // SendWechatToUsers send msg to multiple users by saga-admin api
- func (d *Dao) SendWechatToUsers(c context.Context, users []string, msg string) (err error) {
- var (
- req *http.Request
- b = &bytes.Buffer{}
- url = _sagaWechatURL + "/message/send"
- res struct {
- Code int `json:"code"`
- Message string `json:"message"`
- }
- body = &ut.WechatUsersMsg{
- ToUser: users,
- Content: msg,
- }
- )
- if err = json.NewEncoder(b).Encode(body); err != nil {
- log.Error("apmSvc.SendWechatToUsers Error(%v)", err)
- return
- }
- if req, err = http.NewRequest(http.MethodPost, url, b); err != nil {
- log.Error("apmSvc.SendWechatToUsers Error(%v)", err)
- return
- }
- if err = d.client.Do(c, req, &res); err != nil {
- log.Error("apmSvc.SendWechatToUsers Error(%v)", err)
- return
- }
- if res.Code != 0 {
- err = fmt.Errorf("Http response Code(%v)!=0", res.Code)
- log.Error("apmSvc.SendWechatToUsers Error(%v)", err)
- return
- }
- return
- }
- // SendWechatToGroup send msg to a group by saga-admin api
- func (d *Dao) SendWechatToGroup(c context.Context, chatid, msg string) (err error) {
- var (
- num int
- req *http.Request
- b = &bytes.Buffer{}
- url = _sagaWechatURL + "/appchat/send"
- body = &ut.WechatGroupMsg{
- ChatID: chatid,
- MsgType: "text",
- Safe: 0,
- }
- )
- msgBlock := strings.Split(msg, "\n")
- if len(msgBlock)%40 == 0 {
- num = len(msgBlock)/40 - 1
- } else {
- num = len(msgBlock) / 40
- }
- for i := 0; i <= num; i++ {
- var (
- res struct {
- Code int `json:"code"`
- Message string `json:"message"`
- }
- )
- start, end := 40*i, 40*(i+1)
- if end > len(msgBlock) {
- end = len(msgBlock)
- }
- body.Text = &ut.TextContent{
- Content: strings.Join(msgBlock[start:end], "\n") + fmt.Sprintf("\n(%d/%d)", i+1, num+1),
- }
- if err = json.NewEncoder(b).Encode(body); err != nil {
- log.Error("apmSvc.SendWechatToGroup Error(%v)", err)
- return
- }
- if req, err = http.NewRequest(http.MethodPost, url, b); err != nil {
- log.Error("apmSvc.SendWechatToGroup Error(%v)", err)
- return
- }
- if err = d.client.Do(c, req, &res); err != nil {
- log.Error("apmSvc.SendWechatToGroup Error(%v)", err)
- return
- }
- if res.Code != 0 {
- err = fmt.Errorf("Http response Code(%v)!=0", res.Code)
- log.Error("apmSvc.SendWechatToGroup Error(%v)", err)
- return
- }
- }
- return
- }
- // GitLabCommits transfer gitlab uri,now support get method
- func (d *Dao) GitLabCommits(c context.Context, commitID string) (commit *ut.GitlabCommit, err error) {
- var req *http.Request
- params := url.Values{}
- params.Set("private_token", conf.Conf.Gitlab.Token)
- if req, err = http.NewRequest(http.MethodGet, _gitCommitsAPI+"/"+commitID+"?"+params.Encode(), nil); err != nil {
- log.Error("GitLabCommits http.NewRequest error(%v) params(%s)", err, params.Encode())
- return
- }
- if err = d.client.Do(c, req, &commit); err != nil {
- log.Error("GitLabCommits d.client.Do error(%v) params(%s)", err, params.Encode())
- return
- }
- return
- }
- // GetCoverage get the none-file coverage by commitID and pkg (pkg cannot be fileName)
- func (d *Dao) GetCoverage(c context.Context, commitID, pkg string) (cov float64, err error) {
- var (
- count = strings.Count(pkg, "/")
- file = &ut.File{}
- )
- if len(pkg) == 0 {
- err = fmt.Errorf("The pkg should not be empty")
- return
- }
- if pkg[len(pkg)-1] != '/' {
- count++
- }
- err = d.DB.Select(`commit_id,substring_index(name,"/",?) as pkg,round(sum(covered_statements)/sum(statements)*100,2) as coverage`, count).Group(fmt.Sprintf(`commit_id,substring_index(name,"/",%d)`, count)).Having("commit_id=? and pkg=?", commitID, pkg).First(file).Error
- if err == gorm.ErrRecordNotFound {
- cov, err = 0.00, nil
- return
- } else if err != nil {
- log.Error("dao.GetCoverage commitID(%s) pkg(%s) error(%v)", commitID, pkg, err)
- return
- }
- cov = file.Coverage
- return
- }
|