add line message log

This commit is contained in:
Jay
2018-09-20 00:17:00 +08:00
parent ee12feda5d
commit 116c43b0cb
4 changed files with 103 additions and 4 deletions
+59 -4
View File
@@ -3,9 +3,12 @@ package line
import (
"bytes"
"encoding/json"
"errors"
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strings"
"git.trj.tw/golang/mtfosbot/module/apis"
"git.trj.tw/golang/mtfosbot/module/config"
@@ -24,6 +27,12 @@ type ImageMessage struct {
PreviewImageURL string `json:"previewImageUrl"`
}
// LineUserInfo -
type LineUserInfo struct {
DisplayName string `json:"displayName"`
UserID string `json:"userId"`
}
type pushBody struct {
To string `json:"to"`
Messages []interface{} `json:"messages"`
@@ -61,7 +70,7 @@ func PushMessage(target string, message interface{}) {
if len(target) == 0 {
return
}
url := "/v2/bot/message/push"
urlPath := "/v2/bot/message/push"
body := &pushBody{
To: target,
@@ -90,7 +99,7 @@ func PushMessage(target string, message interface{}) {
byteReader := bytes.NewReader(dataByte)
apiURL, ok := getURL(url)
apiURL, ok := getURL(urlPath)
if !ok {
fmt.Println("url parser fail")
return
@@ -120,7 +129,7 @@ func ReplyMessage(replyToken string, message interface{}) {
if len(replyToken) == 0 {
return
}
url := "/v2/bot/message/reply"
urlPath := "/v2/bot/message/reply"
body := &replyBody{
ReplyToken: replyToken,
@@ -150,7 +159,7 @@ func ReplyMessage(replyToken string, message interface{}) {
byteReader := bytes.NewReader(dataByte)
apiURL, ok := getURL(url)
apiURL, ok := getURL(urlPath)
if !ok {
fmt.Println("url parser fail")
return
@@ -174,3 +183,49 @@ func ReplyMessage(replyToken string, message interface{}) {
return
}
}
// GetUserInfo -
func GetUserInfo(u, g string) (user *LineUserInfo, err error) {
urlPath := fmt.Sprintf("/v2/bot/group/%s/member/%s", g, u)
header := getHeaders()
apiURL, ok := getURL(urlPath)
if !ok {
return nil, errors.New("url parser fail")
}
reqObj := apis.RequestObj{
Method: "GET",
URL: apiURL,
Headers: header,
}
req, err := apis.GetRequest(reqObj)
if err != nil {
return nil, err
}
resp, err := http.DefaultClient.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
return nil, errors.New("api response not 200")
}
if !strings.HasPrefix(resp.Header.Get("Content-Type"), "application/json") {
return nil, errors.New("response body not json")
}
bodyBytes, err := ioutil.ReadAll(resp.Body)
if err != nil {
return nil, err
}
err = json.Unmarshal(bodyBytes, &user)
if err != nil {
return nil, err
}
return
}