Skip to content

Commit

Permalink
fix: split to server and writer
Browse files Browse the repository at this point in the history
  • Loading branch information
halwu(吴浩麟) committed May 29, 2017
1 parent aef12a7 commit 74eb057
Show file tree
Hide file tree
Showing 3 changed files with 277 additions and 271 deletions.
271 changes: 0 additions & 271 deletions protocol/httpflv/http_flv.go

This file was deleted.

104 changes: 104 additions & 0 deletions protocol/httpflv/server.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
package httpflv

import (
"encoding/json"
"strings"
"net"
"net/http"
"log"
"github.com/gwuhaolin/livego/av"
"github.com/gwuhaolin/livego/protocol/rtmp"
)

type Server struct {
handler av.Handler
}

type stream struct {
Key string `json:"key"`
Id string `json:"id"`
}

type streams struct {
Publishers []stream `json:"publishers"`
Players []stream `json:"players"`
}

func NewServer(h av.Handler) *Server {
return &Server{
handler: h,
}
}

func (server *Server) Serve(l net.Listener) error {
mux := http.NewServeMux()
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
server.handleConn(w, r)
})
mux.HandleFunc("/streams", func(w http.ResponseWriter, r *http.Request) {
server.getStream(w, r)
})
http.Serve(l, mux)
return nil
}

func (server *Server) getStream(w http.ResponseWriter, r *http.Request) {
rtmpStream := server.handler.(*rtmp.RtmpStream)
if rtmpStream == nil {
return
}
msgs := new(streams)
for item := range rtmpStream.GetStreams().IterBuffered() {
if s, ok := item.Val.(*rtmp.Stream); ok {
if s.GetReader() != nil {
msg := stream{item.Key, s.GetReader().Info().UID}
msgs.Publishers = append(msgs.Publishers, msg)
}
}
}

for item := range rtmpStream.GetStreams().IterBuffered() {
ws := item.Val.(*rtmp.Stream).GetWs()
for s := range ws.IterBuffered() {
if pw, ok := s.Val.(*rtmp.PackWriterCloser); ok {
if pw.GetWriter() != nil {
msg := stream{item.Key, pw.GetWriter().Info().UID}
msgs.Players = append(msgs.Players, msg)
}
}
}
}
resp, _ := json.Marshal(msgs)
w.Header().Set("Content-Type", "application/json")
w.Write(resp)

}

func (server *Server) handleConn(w http.ResponseWriter, r *http.Request) {
defer func() {
if r := recover(); r != nil {
log.Println("http flv handleConn panic: ", r)
}
}()

url := r.URL.String()
u := r.URL.Path
if pos := strings.LastIndex(u, "."); pos < 0 || u[pos:] != ".flv" {
http.Error(w, "invalid path", http.StatusBadRequest)
return
}
path := strings.TrimSuffix(strings.TrimLeft(u, "/"), ".flv")
paths := strings.SplitN(path, "/", 2)
log.Println("url:", u, "path:", path, "paths:", paths)

if len(paths) != 2 {
http.Error(w, "invalid path", http.StatusBadRequest)
return
}

w.Header().Set("Access-Control-Allow-Origin", "*")
writer := NewFLVWriter(paths[0], paths[1], url, w)

server.handler.HandleWriter(writer)
writer.Wait()
}
Loading

0 comments on commit 74eb057

Please sign in to comment.