2018-01-21 11:17:43 +00:00
|
|
|
package common
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
|
2019-10-26 23:11:09 +00:00
|
|
|
qgen "github.com/Azareal/Gosora/query_gen"
|
2018-01-21 11:17:43 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var IPSearch IPSearcher
|
|
|
|
|
|
|
|
type IPSearcher interface {
|
2021-03-24 11:45:18 +00:00
|
|
|
Lookup(ip string) (uids []int, e error)
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type DefaultIPSearcher struct {
|
2018-01-22 08:15:45 +00:00
|
|
|
searchUsers *sql.Stmt
|
|
|
|
searchTopics *sql.Stmt
|
|
|
|
searchReplies *sql.Stmt
|
|
|
|
searchUsersReplies *sql.Stmt
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewDefaultIPSearcher gives you a new instance of DefaultIPSearcher
|
|
|
|
func NewDefaultIPSearcher() (*DefaultIPSearcher, error) {
|
2018-08-04 11:46:36 +00:00
|
|
|
acc := qgen.NewAcc()
|
2020-01-02 21:52:41 +00:00
|
|
|
uu := "users"
|
2021-03-24 11:45:18 +00:00
|
|
|
q := func(tbl string) *sql.Stmt {
|
|
|
|
return acc.Select(uu).Columns("uid").InQ("uid", acc.Select(tbl).Columns("createdBy").Where("ip=?")).Prepare()
|
|
|
|
}
|
2018-01-21 11:17:43 +00:00
|
|
|
return &DefaultIPSearcher{
|
2020-01-02 21:52:41 +00:00
|
|
|
searchUsers: acc.Select(uu).Columns("uid").Where("last_ip=? OR last_ip LIKE CONCAT('%-',?)").Prepare(),
|
2021-03-24 11:45:18 +00:00
|
|
|
searchTopics: q("topics"),
|
|
|
|
searchReplies: q("replies"),
|
|
|
|
searchUsersReplies: q("users_replies"),
|
2018-01-21 11:17:43 +00:00
|
|
|
}, acc.FirstError()
|
|
|
|
}
|
|
|
|
|
2021-03-24 11:45:18 +00:00
|
|
|
func (s *DefaultIPSearcher) Lookup(ip string) (uids []int, e error) {
|
2018-01-21 11:17:43 +00:00
|
|
|
var uid int
|
2019-09-29 04:56:39 +00:00
|
|
|
reqUserList := make(map[int]bool)
|
2021-03-24 11:45:18 +00:00
|
|
|
runQuery2 := func(rows *sql.Rows, e error) error {
|
|
|
|
if e != nil {
|
|
|
|
return e
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
for rows.Next() {
|
2021-03-24 11:45:18 +00:00
|
|
|
if e := rows.Scan(&uid); e != nil {
|
|
|
|
return e
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
|
|
|
reqUserList[uid] = true
|
|
|
|
}
|
|
|
|
return rows.Err()
|
|
|
|
}
|
2019-12-31 21:57:54 +00:00
|
|
|
runQuery := func(stmt *sql.Stmt) error {
|
|
|
|
return runQuery2(stmt.Query(ip))
|
|
|
|
}
|
2018-01-21 11:17:43 +00:00
|
|
|
|
2021-03-24 11:45:18 +00:00
|
|
|
e = runQuery2(s.searchUsers.Query(ip, ip))
|
|
|
|
if e != nil {
|
|
|
|
return uids, e
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
2021-03-24 11:45:18 +00:00
|
|
|
e = runQuery(s.searchTopics)
|
|
|
|
if e != nil {
|
|
|
|
return uids, e
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
2021-03-24 11:45:18 +00:00
|
|
|
e = runQuery(s.searchReplies)
|
|
|
|
if e != nil {
|
|
|
|
return uids, e
|
2018-01-21 11:17:43 +00:00
|
|
|
}
|
2021-03-24 11:45:18 +00:00
|
|
|
e = runQuery(s.searchUsersReplies)
|
|
|
|
if e != nil {
|
|
|
|
return uids, e
|
2018-01-22 08:15:45 +00:00
|
|
|
}
|
2018-01-21 11:17:43 +00:00
|
|
|
|
|
|
|
// Convert the user ID map to a slice, then bulk load the users
|
|
|
|
uids = make([]int, len(reqUserList))
|
|
|
|
var i int
|
|
|
|
for userID := range reqUserList {
|
|
|
|
uids[i] = userID
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
|
|
|
|
return uids, nil
|
|
|
|
}
|