Merge pull request #136 from rocboss/dev

merge from dev branch
pull/138/head
Michael Li 3 years ago committed by GitHub
commit 640ad0424d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -11,7 +11,6 @@ import (
var ( var (
_ core.DataService = (*dataServant)(nil) _ core.DataService = (*dataServant)(nil)
_ core.AttachmentCheckService = (*attachmentCheckServant)(nil) _ core.AttachmentCheckService = (*attachmentCheckServant)(nil)
_ core.TweetSearchService = (*zincTweetSearchServant)(nil)
) )
type dataServant struct { type dataServant struct {

@ -104,10 +104,6 @@ func tagsFrom(originTags []string) []string {
// TODO: maybe have bug need optimize for use transaction to create post // TODO: maybe have bug need optimize for use transaction to create post
func CreatePost(c *gin.Context, userID int64, param PostCreationReq) (*model.Post, error) { func CreatePost(c *gin.Context, userID int64, param PostCreationReq) (*model.Post, error) {
ip := c.ClientIP() ip := c.ClientIP()
if len(ip) == 0 {
ip = "未知"
}
tags := tagsFrom(param.Tags) tags := tagsFrom(param.Tags)
post := &model.Post{ post := &model.Post{
UserID: userID, UserID: userID,

@ -1 +0,0 @@
package types

@ -0,0 +1,36 @@
package util
import "testing"
func TestGetIPLoc(t *testing.T) {
type args struct {
ip string
}
tests := []struct {
name string
args args
want string
}{
{
name: "test1",
args: args{
ip: "",
},
want: "",
},
{
name: "test2",
args: args{
ip: "103.197.70.244",
},
want: "香港",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := GetIPLoc(tt.args.ip); got != tt.want {
t.Errorf("GetIPLoc() = %v, want %v", got, tt.want)
}
})
}
}

@ -4,6 +4,7 @@ import (
_ "embed" _ "embed"
"encoding/binary" "encoding/binary"
"net" "net"
"strings"
"github.com/yinheli/mahonia" "github.com/yinheli/mahonia"
) )
@ -19,17 +20,27 @@ const (
cRedirectMode2 = 0x02 cRedirectMode2 = 0x02
) )
// Find get country and city base ip // Find get country and city base ip. return empty country
// and city when ip that pass from argument is empty string
// or invalid ip address that net.ParseIP(...).To4 return nil
// eg: "::1"
func Find(ip string) (string, string) { func Find(ip string) (string, string) {
// If ip is "::1", To4 returns nil. ip = strings.Trim(ip, " ")
if len(ip) == 0 {
return "", ""
}
to4 := net.ParseIP(ip).To4() to4 := net.ParseIP(ip).To4()
// If ip is "::1", To4 returns nil.
if to4 == nil { if to4 == nil {
to4 = net.ParseIP("127.0.0.1").To4() return "", ""
} }
offset := searchIndex(binary.BigEndian.Uint32(to4)) offset := searchIndex(binary.BigEndian.Uint32(to4))
if offset <= 0 { if offset <= 0 {
return "", "" return "", ""
} }
var country, area []byte var country, area []byte
mode := readMode(offset + 4) mode := readMode(offset + 4)
if mode == cRedirectMode1 { if mode == cRedirectMode1 {

@ -0,0 +1,43 @@
package util
import "testing"
func TestEncodeMD5(t *testing.T) {
type args struct {
value string
}
tests := []struct {
name string
args args
want string
}{
{
name: "test1",
args: args{
value: "123456",
},
want: "e10adc3949ba59abbe56e057f20f883e",
},
{
name: "test2",
args: args{
value: "",
},
want: "d41d8cd98f00b204e9800998ecf8427e", // really odd, why?
},
{
name: "test3",
args: args{
value: "paopaocestr",
},
want: "8a5033dda1a8919224c66e68d846a289",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := EncodeMD5(tt.args.value); got != tt.want {
t.Errorf("EncodeMD5() = %v, want %v", got, tt.want)
}
})
}
}
Loading…
Cancel
Save