mirror of
https://github.com/lkmio/lkm.git
synced 2025-10-13 02:43:42 +08:00
106 lines
2.4 KiB
Go
106 lines
2.4 KiB
Go
package gb28181
|
|
|
|
import (
|
|
"github.com/yangjiechina/avformat/transport"
|
|
"github.com/yangjiechina/lkm/stream"
|
|
"net"
|
|
"runtime"
|
|
)
|
|
|
|
// TCPServer GB28181TCP被动收流
|
|
type TCPServer struct {
|
|
stream.StreamServer[*TCPSession]
|
|
|
|
tcp *transport.TCPServer
|
|
filter Filter
|
|
}
|
|
|
|
func (T *TCPServer) OnNewSession(conn net.Conn) *TCPSession {
|
|
return NewTCPSession(conn, T.filter)
|
|
}
|
|
|
|
func (T *TCPServer) OnCloseSession(session *TCPSession) {
|
|
session.Close()
|
|
|
|
if session.source != nil {
|
|
T.filter.RemoveSource(session.source.SSRC())
|
|
}
|
|
|
|
if stream.AppConfig.GB28181.IsMultiPort() {
|
|
T.tcp.Close()
|
|
T.Handler = nil
|
|
}
|
|
}
|
|
|
|
func (T *TCPServer) OnConnected(conn net.Conn) []byte {
|
|
T.StreamServer.OnConnected(conn)
|
|
|
|
//TCP使用ReceiveBuffer区别在于,多端口模式从第一包就使用ReceiveBuffer, 单端口模式先解析出ssrc, 找到source. 后续再使用ReceiveBuffer.
|
|
if conn.(*transport.Conn).Data.(*TCPSession).source != nil {
|
|
return conn.(*transport.Conn).Data.(*TCPSession).receiveBuffer.GetBlock()
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (T *TCPServer) OnPacket(conn net.Conn, data []byte) []byte {
|
|
T.StreamServer.OnPacket(conn, data)
|
|
session := conn.(*transport.Conn).Data.(*TCPSession)
|
|
|
|
//单端口收流
|
|
if session.source == nil {
|
|
//直接传给解码器, 先根据ssrc找到source. 后续还是会直接传给source
|
|
session.Input(data)
|
|
} else {
|
|
session.source.(*PassiveSource).PublishSource.Input(data)
|
|
}
|
|
|
|
if session.source != nil {
|
|
return session.receiveBuffer.GetBlock()
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func NewTCPServer(filter Filter) (*TCPServer, error) {
|
|
server := &TCPServer{
|
|
filter: filter,
|
|
}
|
|
|
|
var tcp *transport.TCPServer
|
|
var err error
|
|
if stream.AppConfig.GB28181.IsMultiPort() {
|
|
tcp = &transport.TCPServer{}
|
|
tcp, err = TransportManger.NewTCPServer(stream.AppConfig.ListenIP)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
} else {
|
|
tcp = &transport.TCPServer{
|
|
ReuseServer: transport.ReuseServer{
|
|
EnableReuse: true,
|
|
ConcurrentNumber: runtime.NumCPU(),
|
|
},
|
|
}
|
|
|
|
var gbAddr *net.TCPAddr
|
|
gbAddr, err = net.ResolveTCPAddr("tcp", stream.ListenAddr(stream.AppConfig.GB28181.Port[0]))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if err = tcp.Bind(gbAddr); err != nil {
|
|
return server, err
|
|
}
|
|
}
|
|
|
|
tcp.SetHandler(server)
|
|
tcp.Accept()
|
|
server.tcp = tcp
|
|
server.StreamServer = stream.StreamServer[*TCPSession]{
|
|
SourceType: stream.SourceType28181,
|
|
Handler: server,
|
|
}
|
|
return server, nil
|
|
}
|