Move Socket::*Stream > Util::Stream::*
This commit is contained in:
parent
a995e7215d
commit
9c0aa93bfd
5 changed files with 87 additions and 48 deletions
|
@ -1,5 +1,5 @@
|
|||
lib_LTLIBRARIES=libmist-1.0.la
|
||||
libmist_1_0_la_SOURCES=amf.h amf.cpp auth.h auth.cpp base64.h base64.cpp config.h config.cpp crypto.h crypto.cpp dtsc.h dtsc.cpp flv_tag.h flv_tag.cpp http_parser.h http_parser.cpp json.h json.cpp procs.h procs.cpp rtmpchunks.h rtmpchunks.cpp socket.h socket.cpp mp4.h mp4.cpp
|
||||
libmist_1_0_la_SOURCES=amf.h amf.cpp auth.h auth.cpp base64.h base64.cpp config.h config.cpp crypto.h crypto.cpp dtsc.h dtsc.cpp flv_tag.h flv_tag.cpp http_parser.h http_parser.cpp json.h json.cpp procs.h procs.cpp rtmpchunks.h rtmpchunks.cpp socket.h socket.cpp mp4.h mp4.cpp stream.h stream.cpp
|
||||
libmist_1_0_la_LIBADD=-lssl -lcrypto
|
||||
libmist_1_0_la_LDFLAGS = -version-info 1:0:0
|
||||
|
||||
|
@ -7,4 +7,4 @@ pkgconfigdir = $(libdir)/pkgconfig
|
|||
pkgconfig_DATA = mist-1.0.pc
|
||||
|
||||
library_includedir=$(includedir)/mist-1.0/mist
|
||||
library_include_HEADERS = amf.h auth.h base64.h config.h crypto.h dtsc.h flv_tag.h http_parser.h json.h procs.h rtmpchunks.h socket.h mp4.h
|
||||
library_include_HEADERS = amf.h auth.h base64.h config.h crypto.h dtsc.h flv_tag.h http_parser.h json.h procs.h rtmpchunks.h socket.h mp4.h stream.h
|
||||
|
|
|
@ -609,43 +609,3 @@ bool Socket::Server::connected() const{
|
|||
|
||||
/// Returns internal socket number.
|
||||
int Socket::Server::getSocket(){return sock;}
|
||||
|
||||
/// Connect to a stream on the system.
|
||||
/// Filters the streamname, removing invalid characters and
|
||||
/// converting all letters to lowercase.
|
||||
/// If a '?' character is found, everything following that character is deleted.
|
||||
Socket::Connection Socket::getStream(std::string streamname){
|
||||
//strip anything that isn't a number, alpha or underscore
|
||||
for (std::string::iterator i=streamname.end()-1; i>=streamname.begin(); --i){
|
||||
if (*i == '?'){streamname.erase(i, streamname.end()); break;}
|
||||
if (!isalpha(*i) && !isdigit(*i) && *i != '_'){
|
||||
streamname.erase(i);
|
||||
}else{
|
||||
*i=tolower(*i);
|
||||
}
|
||||
}
|
||||
return Socket::Connection("/tmp/mist/stream_"+streamname);
|
||||
}
|
||||
|
||||
/// Create a stream on the system.
|
||||
/// Filters the streamname, removing invalid characters and
|
||||
/// converting all letters to lowercase.
|
||||
/// If a '?' character is found, everything following that character is deleted.
|
||||
/// If the /tmp/mist directory doesn't exist yet, this will create it.
|
||||
Socket::Server Socket::makeStream(std::string streamname){
|
||||
//strip anything that isn't numbers, digits or underscores
|
||||
for (std::string::iterator i=streamname.end()-1; i>=streamname.begin(); --i){
|
||||
if (*i == '?'){streamname.erase(i, streamname.end()); break;}
|
||||
if (!isalpha(*i) && !isdigit(*i) && *i != '_'){
|
||||
streamname.erase(i);
|
||||
}else{
|
||||
*i=tolower(*i);
|
||||
}
|
||||
}
|
||||
std::string loc = "/tmp/mist/stream_"+streamname;
|
||||
//attempt to create the /tmp/mist directory if it doesn't exist already.
|
||||
//ignore errors - we catch all problems in the Socket::Server creation already
|
||||
mkdir("/tmp/mist", S_IRWXU | S_IRWXG | S_IRWXO);
|
||||
//create and return the Socket::Server
|
||||
return Socket::Server(loc);
|
||||
}
|
||||
|
|
|
@ -86,10 +86,4 @@ namespace Socket{
|
|||
int getSocket(); ///< Returns internal socket number.
|
||||
};
|
||||
|
||||
/// Connect to a stream on the system.
|
||||
Connection getStream(std::string streamname);
|
||||
|
||||
/// Create a stream on the system.
|
||||
Server makeStream(std::string streamname);
|
||||
|
||||
};
|
||||
|
|
62
lib/stream.cpp
Normal file
62
lib/stream.cpp
Normal file
|
@ -0,0 +1,62 @@
|
|||
/// \file stream.cpp
|
||||
/// Utilities for handling streams.
|
||||
|
||||
#include "stream.h"
|
||||
#include "procs.h"
|
||||
#include "socket.h"
|
||||
|
||||
/// Filters the streamname, removing invalid characters and converting all
|
||||
/// letters to lowercase. If a '?' character is found, everything following
|
||||
/// that character is deleted. The original string is modified.
|
||||
void Util::Stream::sanitizeName(std::string & streamname){
|
||||
//strip anything that isn't numbers, digits or underscores
|
||||
for (std::string::iterator i=streamname.end()-1; i>=streamname.begin(); --i){
|
||||
if (*i == '?'){streamname.erase(i, streamname.end()); break;}
|
||||
if (!isalpha(*i) && !isdigit(*i) && *i != '_'){
|
||||
streamname.erase(i);
|
||||
}else{
|
||||
*i=tolower(*i);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Socket::Connection Util::Stream::getLive(std::string streamname){
|
||||
sanitizeName(streamname);
|
||||
return Socket::Connection("/tmp/mist/stream_"+streamname);
|
||||
}
|
||||
|
||||
/// Starts a process for the VoD stream.
|
||||
Socket::Connection Util::Stream::getVod(std::string streamname){
|
||||
sanitizeName(streamname);
|
||||
std::string filename = "/tmp/mist/vod_" + streamname;
|
||||
/// \todo Is the name unique enough?
|
||||
std::string name = "MistPlayer " + filename;
|
||||
const char *argv[] = { "MistPlayer", filename.c_str(), NULL };
|
||||
int fdin = -1, fdout = -1;
|
||||
Util::Procs::StartPiped(name, (char **)argv, &fdin, &fdout, 0);
|
||||
// if StartPiped fails then fdin and fdout will be unmodified (-1)
|
||||
return Socket::Connection(fdin, fdout);
|
||||
}
|
||||
|
||||
/// Probe for available streams. Currently first VoD, then Live.
|
||||
Socket::Connection Util::Stream::getStream(std::string streamname){
|
||||
Socket::Connection vod = getVod(streamname);
|
||||
if (vod.connected()){
|
||||
return vod;
|
||||
}
|
||||
return getLive(streamname);
|
||||
}
|
||||
/// Create a stream on the system.
|
||||
/// Filters the streamname, removing invalid characters and
|
||||
/// converting all letters to lowercase.
|
||||
/// If a '?' character is found, everything following that character is deleted.
|
||||
/// If the /tmp/mist directory doesn't exist yet, this will create it.
|
||||
Socket::Server Util::Stream::makeLive(std::string streamname){
|
||||
sanitizeName(streamname);
|
||||
std::string loc = "/tmp/mist/stream_"+streamname;
|
||||
//attempt to create the /tmp/mist directory if it doesn't exist already.
|
||||
//ignore errors - we catch all problems in the Socket::Server creation already
|
||||
mkdir("/tmp/mist", S_IRWXU | S_IRWXG | S_IRWXO);
|
||||
//create and return the Socket::Server
|
||||
return Socket::Server(loc);
|
||||
}
|
23
lib/stream.h
Normal file
23
lib/stream.h
Normal file
|
@ -0,0 +1,23 @@
|
|||
/// \file stream.h
|
||||
/// Utilities for handling streams.
|
||||
|
||||
#pragma once
|
||||
#include <string>
|
||||
#include <mist/socket.h>
|
||||
|
||||
namespace Util{
|
||||
class Stream{
|
||||
/// Sanitize a streamname.
|
||||
void sanitizeName(std::string & streamname);
|
||||
public:
|
||||
/// Get a connection to a Live stream.
|
||||
static Socket::Connection getLive(std::string streamname);
|
||||
/// Get a connection to a VoD stream.
|
||||
static Socket::Connection getVod(std::string streamname);
|
||||
/// Probe for available streams. Currently first VoD, then Live.
|
||||
static Socket::Connection getStream(std::string streamname);
|
||||
|
||||
/// Create a Live stream on the system.
|
||||
static Socket::Server makeLive(std::string streamname);
|
||||
};
|
||||
}
|
Loading…
Add table
Reference in a new issue