mirror of
https://github.com/lkmio/lkm.git
synced 2025-09-27 19:42:07 +08:00
98 lines
2.6 KiB
Go
98 lines
2.6 KiB
Go
package stream
|
|
|
|
import (
|
|
"encoding/json"
|
|
"github.com/lkmio/avformat/utils"
|
|
"github.com/lkmio/lkm/log"
|
|
"net/http"
|
|
)
|
|
|
|
func PreparePublishSource(source Source, hook bool) (*http.Response, utils.HookState) {
|
|
var response *http.Response
|
|
|
|
if hook && AppConfig.Hook.IsEnablePublishEvent() {
|
|
rep, state := HookPublishEvent(source)
|
|
if utils.HookStateOK != state {
|
|
return rep, state
|
|
}
|
|
|
|
response = rep
|
|
}
|
|
|
|
if err := SourceManager.Add(source); err != nil {
|
|
log.Sugar.Errorf("添加源失败 source:%s err:%s", source.Id(), err.Error())
|
|
return nil, utils.HookStateOccupy
|
|
}
|
|
|
|
if AppConfig.ReceiveTimeout > 0 {
|
|
source.StartReceiveDataTimer()
|
|
}
|
|
|
|
if AppConfig.IdleTimeout > 0 {
|
|
source.StartIdleTimer()
|
|
}
|
|
|
|
urls := GetStreamPlayUrls(source.Id())
|
|
indent, _ := json.MarshalIndent(urls, "", "\t")
|
|
log.Sugar.Infof("%s准备推流 source:%s 拉流地址:\r\n%s", source.Type().ToString(), source.Id(), indent)
|
|
|
|
return response, utils.HookStateOK
|
|
}
|
|
|
|
func HookPublishEvent(source Source) (*http.Response, utils.HookState) {
|
|
var response *http.Response
|
|
|
|
if AppConfig.Hook.IsEnablePublishEvent() {
|
|
hook, err := Hook(HookEventPublish, source.UrlValues().Encode(), NewHookPublishEventInfo(source))
|
|
if err != nil {
|
|
log.Sugar.Errorf("通知推流事件失败 source:%s err:%s", source.Id(), err.Error())
|
|
return hook, utils.HookStateFailure
|
|
}
|
|
|
|
response = hook
|
|
}
|
|
|
|
return response, utils.HookStateOK
|
|
}
|
|
|
|
func HookPublishDoneEvent(source Source) {
|
|
if AppConfig.Hook.IsEnablePublishEvent() {
|
|
_, err := Hook(HookEventPublishDone, source.UrlValues().Encode(), NewHookPublishEventInfo(source))
|
|
if err != nil {
|
|
log.Sugar.Errorf("通知推流结束事件失败 source:%s err:%s", source.Id(), err.Error())
|
|
}
|
|
}
|
|
}
|
|
|
|
func HookReceiveTimeoutEvent(source Source) (*http.Response, utils.HookState) {
|
|
var response *http.Response
|
|
|
|
if AppConfig.Hook.IsEnableOnReceiveTimeout() {
|
|
resp, err := Hook(HookEventReceiveTimeout, source.UrlValues().Encode(), NewHookPublishEventInfo(source))
|
|
if err != nil {
|
|
log.Sugar.Errorf("通知收流超时事件失败 source:%s err:%s", source.Id(), err.Error())
|
|
return resp, utils.HookStateFailure
|
|
}
|
|
|
|
response = resp
|
|
}
|
|
|
|
return response, utils.HookStateOK
|
|
}
|
|
|
|
func HookIdleTimeoutEvent(source Source) (*http.Response, utils.HookState) {
|
|
var response *http.Response
|
|
|
|
if AppConfig.Hook.IsEnableOnIdleTimeout() {
|
|
resp, err := Hook(HookEventIdleTimeout, source.UrlValues().Encode(), NewHookPublishEventInfo(source))
|
|
if err != nil {
|
|
log.Sugar.Errorf("通知空闲超时时间失败 source:%s err:%s", source.Id(), err.Error())
|
|
return resp, utils.HookStateFailure
|
|
}
|
|
|
|
response = resp
|
|
}
|
|
|
|
return response, utils.HookStateOK
|
|
}
|