mirror of
				https://github.com/lkmio/lkm.git
				synced 2025-10-26 00:30:22 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package stream
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"encoding/json"
 | |
| 	"fmt"
 | |
| 	"github.com/lkmio/lkm/log"
 | |
| 	"io"
 | |
| 	"net/http"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // 每个通知事件都需要携带的字段
 | |
| type eventInfo struct {
 | |
| 	Stream     string `json:"stream"`      //stream id
 | |
| 	Protocol   string `json:"protocol"`    //推拉流协议
 | |
| 	RemoteAddr string `json:"remote_addr"` //peer地址
 | |
| }
 | |
| 
 | |
| func responseBodyToString(resp *http.Response) string {
 | |
| 	bodyBytes, err := io.ReadAll(resp.Body)
 | |
| 	if err != nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 
 | |
| 	resp.Body = io.NopCloser(bytes.NewBuffer(bodyBytes))
 | |
| 	return string(bodyBytes)
 | |
| }
 | |
| 
 | |
| func sendHookEvent(url string, body []byte) (*http.Response, error) {
 | |
| 	client := &http.Client{
 | |
| 		Timeout: time.Duration(AppConfig.Hook.Timeout),
 | |
| 	}
 | |
| 	request, err := http.NewRequest("post", url, bytes.NewBuffer(body))
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	request.Header.Set("Content-Type", "application/json")
 | |
| 	return client.Do(request)
 | |
| }
 | |
| 
 | |
| func Hook(event HookEvent, params string, body interface{}) (*http.Response, error) {
 | |
| 	url, ok := hookUrls[event]
 | |
| 	if url == "" || !ok {
 | |
| 		return nil, fmt.Errorf("the url for this %s event does not exist", event.ToString())
 | |
| 	}
 | |
| 
 | |
| 	bytes, err := json.Marshal(body)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	if "" != params {
 | |
| 		url += "?" + params
 | |
| 	}
 | |
| 
 | |
| 	log.Sugar.Infof("sent a hook event for %s. url: %s body: %s", event.ToString(), url, bytes)
 | |
| 	response, err := sendHookEvent(url, bytes)
 | |
| 	if err != nil {
 | |
| 		log.Sugar.Errorf("failed to %s the hook event. err: %s", event.ToString(), err.Error())
 | |
| 	} else {
 | |
| 		log.Sugar.Infof("received response for hook %s event: status='%s', response body='%s'", event.ToString(), response.Status, responseBodyToString(response))
 | |
| 	}
 | |
| 
 | |
| 	if err == nil && http.StatusOK != response.StatusCode {
 | |
| 		return response, fmt.Errorf("unexpected response status: %s for request %s", response.Status, url)
 | |
| 	}
 | |
| 
 | |
| 	return response, err
 | |
| }
 | |
| 
 | |
| func NewHookPlayEventInfo(sink Sink) eventInfo {
 | |
| 	return eventInfo{Stream: sink.SourceId(), Protocol: sink.Protocol().ToString(), RemoteAddr: sink.PrintInfo()}
 | |
| }
 | |
| 
 | |
| func NewHookPublishEventInfo(source Source) eventInfo {
 | |
| 	return eventInfo{Stream: source.Id(), Protocol: source.Type().ToString(), RemoteAddr: source.RemoteAddr()}
 | |
| }
 | 
