mirror of
https://github.com/fhmq/hmq.git
synced 2026-05-02 14:28:34 +00:00
update
This commit is contained in:
@@ -2,10 +2,12 @@ package authhttp
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/fhmq/hmq/logger"
|
"github.com/fhmq/hmq/logger"
|
||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
@@ -17,8 +19,9 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
config Config
|
config Config
|
||||||
log = logger.Get().Named("http")
|
log = logger.Get().Named("http")
|
||||||
|
httpClient *http.Client
|
||||||
)
|
)
|
||||||
|
|
||||||
//Config device kafka config
|
//Config device kafka config
|
||||||
@@ -41,16 +44,36 @@ func Init() {
|
|||||||
log.Fatal("Unmarshal config file error: ", zap.Error(err))
|
log.Fatal("Unmarshal config file error: ", zap.Error(err))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
httpClient = &http.Client{
|
||||||
|
Transport: &http.Transport{
|
||||||
|
MaxConnsPerHost: 100,
|
||||||
|
MaxIdleConns: 100,
|
||||||
|
MaxIdleConnsPerHost: 100,
|
||||||
|
},
|
||||||
|
Timeout: time.Second * 100,
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//CheckAuth check mqtt connect
|
//CheckAuth check mqtt connect
|
||||||
func CheckAuth(clientID, username, password string) bool {
|
func CheckAuth(clientID, username, password string) bool {
|
||||||
payload := fmt.Sprintf("username=%s&password=%s&clientid=%s", username, password, clientID)
|
data := url.Values{}
|
||||||
resp, err := http.Post(config.AuthURL,
|
data.Add("username", username)
|
||||||
"application/x-www-form-urlencoded",
|
data.Add("clientid", clientID)
|
||||||
strings.NewReader(payload))
|
data.Add("password", password)
|
||||||
|
|
||||||
|
req, err := http.NewRequest("POST", config.AuthURL, strings.NewReader(data.Encode()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("request acl: ", zap.Error(err))
|
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()
|
defer resp.Body.Close()
|
||||||
@@ -62,12 +85,23 @@ func CheckAuth(clientID, username, password string) bool {
|
|||||||
|
|
||||||
//CheckSuper check mqtt connect
|
//CheckSuper check mqtt connect
|
||||||
func CheckSuper(clientID, username, password string) bool {
|
func CheckSuper(clientID, username, password string) bool {
|
||||||
payload := fmt.Sprintf("username=%s&password=%s&clientid=%s", username, password, clientID)
|
data := url.Values{}
|
||||||
resp, err := http.Post(config.SuperURL,
|
data.Add("username", username)
|
||||||
"application/x-www-form-urlencoded",
|
data.Add("clientid", clientID)
|
||||||
strings.NewReader(payload))
|
data.Add("password", password)
|
||||||
|
|
||||||
|
req, err := http.NewRequest("POST", config.SuperURL, strings.NewReader(data.Encode()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error("request acl: ", zap.Error(err))
|
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()
|
defer resp.Body.Close()
|
||||||
@@ -79,10 +113,23 @@ func CheckSuper(clientID, username, password string) bool {
|
|||||||
|
|
||||||
//CheckACL check mqtt connect
|
//CheckACL check mqtt connect
|
||||||
func CheckACL(username, access, topic string) bool {
|
func CheckACL(username, access, topic string) bool {
|
||||||
url := fmt.Sprintf(config.ACLURL+"?username=%s&access=%s&topic=%s", username, access, topic)
|
req, err := http.NewRequest("GET", config.ACLURL, nil)
|
||||||
resp, err := http.Get(url)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// handle error
|
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()
|
||||||
|
// log.Debugf("req is :%v", req)
|
||||||
|
resp, err := httpClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
log.Error("request acl: ", zap.Error(err))
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
|
|||||||
@@ -46,7 +46,7 @@ func Init() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal("Unmarshal config file error: ", zap.Error(err))
|
log.Fatal("Unmarshal config file error: ", zap.Error(err))
|
||||||
}
|
}
|
||||||
|
connect()
|
||||||
}
|
}
|
||||||
|
|
||||||
//connect
|
//connect
|
||||||
|
|||||||
Reference in New Issue
Block a user