HaishinKit.swift/Sources/HTTP/HTTPStream.swift

53 lines
1.8 KiB
Swift

import Foundation
import AVFoundation
open class HTTPStream: NetStream {
internal fileprivate(set) var name:String?
fileprivate var tsWriter:TSWriter = TSWriter()
open func publish(withName:String?) {
lockQueue.async {
if (withName == nil) {
self.name = withName
#if os(iOS)
self.mixer.videoIO.screen?.stopRunning()
#endif
self.mixer.videoIO.encoder.delegate = nil
self.mixer.videoIO.encoder.stopRunning()
self.mixer.audioIO.encoder.delegate = nil
self.mixer.audioIO.encoder.stopRunning()
self.tsWriter.stopRunning()
return
}
self.name = withName
#if os(iOS)
self.mixer.videoIO.screen?.startRunning()
#endif
self.mixer.videoIO.encoder.delegate = self.tsWriter
self.mixer.videoIO.encoder.startRunning()
self.mixer.audioIO.encoder.delegate = self.tsWriter
self.mixer.audioIO.encoder.startRunning()
self.tsWriter.startRunning()
}
}
internal func getResource(_ resourceName:String) -> (MIME, String)? {
let url:URL = URL(fileURLWithPath: resourceName)
guard let name:String = name, 2 <= url.pathComponents.count && url.pathComponents[1] == name else {
return nil
}
let fileName:String = url.pathComponents.last!
switch true {
case fileName == "playlist.m3u8":
return (.ApplicationXMpegURL, tsWriter.playlist)
case fileName.contains(".ts"):
if let mediaFile:String = tsWriter.getFilePath(fileName) {
return (.VideoMP2T, mediaFile)
}
return nil
default:
return nil
}
}
}