mirror of
https://github.com/fhmq/hmq.git
synced 2026-05-02 06:18:33 +00:00
* modify * update * add acl * add feature * update dockerfile * add deploy * update * update * plugins * plugins * update * update * update * fixed * remove * fixed * add log * update * fixed * update * fix config * add http api * add http api * resp * add config for work chan * update * fixed * update * disable trace * fixed * change acl * fixed * fixed res * dd * dd * ddd * dd * update * fixed * update * add * fixed * update key * add log * update * format * update * update auth * update * update readme * added * update * fixed * fixed * fix * upade * update * update
181 lines
3.9 KiB
Go
181 lines
3.9 KiB
Go
package authhttp
|
|
|
|
import (
|
|
"encoding/json"
|
|
"io"
|
|
"io/ioutil"
|
|
"net/http"
|
|
"net/url"
|
|
"strconv"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/fhmq/hmq/logger"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
const (
|
|
//AuthHTTP plugin name
|
|
AuthHTTP = "authhttp"
|
|
)
|
|
|
|
var (
|
|
config Config
|
|
log = logger.Get().Named("http")
|
|
httpClient *http.Client
|
|
)
|
|
|
|
//Config device kafka config
|
|
type Config struct {
|
|
AuthURL string `json:"auth"`
|
|
ACLURL string `json:"acl"`
|
|
SuperURL string `json:"super"`
|
|
}
|
|
|
|
//Init init kafak client
|
|
func Init() {
|
|
content, err := ioutil.ReadFile("./plugins/authhttp/http.json")
|
|
if err != nil {
|
|
log.Fatal("Read config file error: ", zap.Error(err))
|
|
}
|
|
// log.Info(string(content))
|
|
|
|
err = json.Unmarshal(content, &config)
|
|
if err != nil {
|
|
log.Fatal("Unmarshal config file error: ", zap.Error(err))
|
|
}
|
|
// fmt.Println("http: config: ", config)
|
|
|
|
httpClient = &http.Client{
|
|
Transport: &http.Transport{
|
|
MaxConnsPerHost: 100,
|
|
MaxIdleConns: 100,
|
|
MaxIdleConnsPerHost: 100,
|
|
},
|
|
Timeout: time.Second * 100,
|
|
}
|
|
|
|
}
|
|
|
|
//CheckAuth check mqtt connect
|
|
func CheckAuth(clientID, username, password string) bool {
|
|
action := "connect"
|
|
{
|
|
aCache := checkCache(action, clientID, username, password, "")
|
|
if aCache != nil {
|
|
if aCache.password == password && aCache.username == username && aCache.action == action {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
|
|
data := url.Values{}
|
|
data.Add("username", username)
|
|
data.Add("clientid", clientID)
|
|
data.Add("password", password)
|
|
|
|
req, err := http.NewRequest("POST", config.AuthURL, strings.NewReader(data.Encode()))
|
|
if err != nil {
|
|
log.Error("new request super: ", zap.Error(err))
|
|
return false
|
|
}
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
req.Header.Add("Content-Length", strconv.Itoa(len(data.Encode())))
|
|
|
|
resp, err := httpClient.Do(req)
|
|
if err != nil {
|
|
log.Error("request super: ", zap.Error(err))
|
|
return false
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
io.Copy(ioutil.Discard, resp.Body)
|
|
if resp.StatusCode == http.StatusOK {
|
|
addCache(action, clientID, username, password, "")
|
|
return true
|
|
}
|
|
|
|
return false
|
|
}
|
|
|
|
//CheckSuper check mqtt connect
|
|
func CheckSuper(clientID, username, password string) bool {
|
|
action := "connect"
|
|
{
|
|
aCache := checkCache(action, clientID, username, password, "")
|
|
if aCache != nil {
|
|
if aCache.password == password && aCache.username == username && aCache.action == action {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
|
|
data := url.Values{}
|
|
data.Add("username", username)
|
|
data.Add("clientid", clientID)
|
|
data.Add("password", password)
|
|
|
|
req, err := http.NewRequest("POST", config.SuperURL, strings.NewReader(data.Encode()))
|
|
if err != nil {
|
|
log.Error("new request super: ", zap.Error(err))
|
|
return false
|
|
}
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
req.Header.Add("Content-Length", strconv.Itoa(len(data.Encode())))
|
|
|
|
resp, err := httpClient.Do(req)
|
|
if err != nil {
|
|
log.Error("request super: ", zap.Error(err))
|
|
return false
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
io.Copy(ioutil.Discard, resp.Body)
|
|
|
|
if resp.StatusCode == http.StatusOK {
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
//CheckACL check mqtt connect
|
|
func CheckACL(username, access, topic string) bool {
|
|
action := access
|
|
{
|
|
aCache := checkCache(action, "", username, "", topic)
|
|
if aCache != nil {
|
|
if aCache.topic == topic && aCache.action == action {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
|
|
req, err := http.NewRequest("GET", config.ACLURL, nil)
|
|
if err != nil {
|
|
log.Error("get acl: ", zap.Error(err))
|
|
return false
|
|
}
|
|
|
|
data := req.URL.Query()
|
|
|
|
data.Add("username", username)
|
|
data.Add("topic", topic)
|
|
data.Add("access", access)
|
|
req.URL.RawQuery = data.Encode()
|
|
// fmt.Println("req:", req)
|
|
resp, err := httpClient.Do(req)
|
|
if err != nil {
|
|
log.Error("request acl: ", zap.Error(err))
|
|
return false
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
io.Copy(ioutil.Discard, resp.Body)
|
|
|
|
if resp.StatusCode == http.StatusOK {
|
|
addCache(action, "", username, "", topic)
|
|
return true
|
|
}
|
|
return false
|
|
}
|