1
0
Fork 0
mirror of https://github.com/ossrs/srs.git synced 2025-02-15 04:42:04 +00:00
srs/trunk/src/app/srs_app_rtmp_conn.hpp

174 lines
6 KiB
C++
Raw Normal View History

2017-03-25 09:21:39 +00:00
/**
* The MIT License (MIT)
*
2019-12-30 02:10:35 +00:00
* Copyright (c) 2013-2020 Winlin
2017-03-25 09:21:39 +00:00
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal in
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
* the Software, and to permit persons to whom the Software is furnished to do so,
* subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
2013-11-23 03:36:07 +00:00
2014-03-27 04:14:04 +00:00
#ifndef SRS_APP_RTMP_CONN_HPP
#define SRS_APP_RTMP_CONN_HPP
2013-11-23 03:36:07 +00:00
#include <srs_core.hpp>
2015-09-24 10:33:07 +00:00
#include <string>
#include <srs_app_st.hpp>
#include <srs_app_conn.hpp>
#include <srs_app_reload.hpp>
#include <srs_rtmp_stack.hpp>
2017-03-26 05:40:39 +00:00
#include <srs_service_rtmp_conn.hpp>
2013-11-23 03:36:07 +00:00
class SrsServer;
class SrsRtmpServer;
2013-11-23 03:36:07 +00:00
class SrsRequest;
class SrsResponse;
class SrsSource;
class SrsRefer;
class SrsConsumer;
class SrsCommonMessage;
class SrsStSocket;
2013-12-07 14:06:53 +00:00
class SrsHttpHooks;
class SrsBandwidth;
2014-05-12 09:27:50 +00:00
class SrsKbps;
class SrsRtmpClient;
class SrsSharedPtrMessage;
class SrsQueueRecvThread;
class SrsPublishRecvThread;
class SrsSecurity;
class ISrsWakable;
2015-10-14 06:37:24 +00:00
class SrsCommonMessage;
class SrsPacket;
2013-11-23 03:36:07 +00:00
2019-04-30 00:24:52 +00:00
// The simple rtmp client for SRS.
2017-03-26 05:40:39 +00:00
class SrsSimpleRtmpClient : public SrsBasicRtmpClient
{
public:
SrsSimpleRtmpClient(std::string u, srs_utime_t ctm, srs_utime_t stm);
virtual ~SrsSimpleRtmpClient();
2017-03-26 05:40:39 +00:00
protected:
2018-01-01 11:39:57 +00:00
virtual srs_error_t connect_app();
};
2019-04-30 00:24:52 +00:00
// Some information of client.
class SrsClientInfo
{
public:
// The type of client, play or publish.
SrsRtmpConnType type;
// Whether the client connected at the edge server.
bool edge;
// Original request object from client.
SrsRequest* req;
// Response object to client.
SrsResponse* res;
public:
SrsClientInfo();
virtual ~SrsClientInfo();
};
2019-04-30 00:24:52 +00:00
// The client provides the main logic control for RTMP clients.
2020-11-04 10:15:43 +00:00
// TODO: FIXME: Refine arch, change to use SrsTcpConnection
class SrsRtmpConn : virtual public SrsTcpConnection, virtual public ISrsReloadHandler
2013-11-23 03:36:07 +00:00
{
2019-04-30 00:24:52 +00:00
// For the thread to directly access any field of connection.
friend class SrsPublishRecvThread;
2013-11-23 03:36:07 +00:00
private:
SrsServer* server;
2014-03-18 03:32:58 +00:00
SrsRtmpServer* rtmp;
SrsRefer* refer;
SrsBandwidth* bandwidth;
SrsSecurity* security;
2019-04-30 00:24:52 +00:00
// The wakable handler, maybe NULL.
// TODO: FIXME: Should refine the state for receiving thread.
ISrsWakable* wakable;
2019-04-30 00:24:52 +00:00
// The elapsed duration in srs_utime_t
// For live play duration, for instance, rtmpdump to record.
2015-11-11 02:37:50 +00:00
// @see https://github.com/ossrs/srs/issues/47
srs_utime_t duration;
2019-04-30 00:24:52 +00:00
// The MR(merged-write) sleep time in srs_utime_t.
2019-04-09 01:39:16 +00:00
srs_utime_t mw_sleep;
int mw_msgs;
2019-04-30 00:24:52 +00:00
// For realtime
2015-11-11 02:37:50 +00:00
// @see https://github.com/ossrs/srs/issues/257
bool realtime;
2019-04-30 00:24:52 +00:00
// The minimal interval in srs_utime_t for delivery stream.
srs_utime_t send_min_interval;
2019-04-30 00:24:52 +00:00
// The publish 1st packet timeout in srs_utime_t
srs_utime_t publish_1stpkt_timeout;
2019-04-30 00:24:52 +00:00
// The publish normal packet timeout in srs_utime_t
srs_utime_t publish_normal_timeout;
2019-04-30 00:24:52 +00:00
// Whether enable the tcp_nodelay.
bool tcp_nodelay;
// About the rtmp client.
SrsClientInfo* info;
2013-11-23 03:36:07 +00:00
public:
2020-07-04 09:19:08 +00:00
SrsRtmpConn(SrsServer* svr, srs_netfd_t c, std::string cip, int port);
2014-03-27 04:27:47 +00:00
virtual ~SrsRtmpConn();
2020-09-19 02:30:05 +00:00
// Interface ISrsResource.
public:
virtual std::string desc();
public:
virtual void dispose();
2013-11-23 03:36:07 +00:00
protected:
2017-07-29 13:39:57 +00:00
virtual srs_error_t do_cycle();
2019-04-30 00:30:13 +00:00
// Interface ISrsReloadHandler
2013-12-14 14:54:10 +00:00
public:
2017-09-22 08:14:30 +00:00
virtual srs_error_t on_reload_vhost_removed(std::string vhost);
virtual srs_error_t on_reload_vhost_play(std::string vhost);
virtual srs_error_t on_reload_vhost_tcp_nodelay(std::string vhost);
virtual srs_error_t on_reload_vhost_realtime(std::string vhost);
virtual srs_error_t on_reload_vhost_publish(std::string vhost);
2019-04-30 00:30:13 +00:00
// Interface ISrsKbpsDelta
public:
2019-01-01 09:36:27 +00:00
virtual void remark(int64_t* in, int64_t* out);
2013-11-23 03:36:07 +00:00
private:
2019-04-30 00:24:52 +00:00
// When valid and connected to vhost/app, service the client.
2017-09-23 14:12:33 +00:00
virtual srs_error_t service_cycle();
2019-04-30 00:24:52 +00:00
// The stream(play/publish) service cycle, identify client first.
2017-09-23 14:12:33 +00:00
virtual srs_error_t stream_service_cycle();
virtual srs_error_t check_vhost(bool try_default_vhost);
virtual srs_error_t playing(SrsSource* source);
virtual srs_error_t do_playing(SrsSource* source, SrsConsumer* consumer, SrsQueueRecvThread* trd);
virtual srs_error_t publishing(SrsSource* source);
virtual srs_error_t do_publishing(SrsSource* source, SrsPublishRecvThread* trd);
virtual srs_error_t acquire_publish(SrsSource* source);
virtual void release_publish(SrsSource* source);
2017-09-23 14:12:33 +00:00
virtual srs_error_t handle_publish_message(SrsSource* source, SrsCommonMessage* msg);
virtual srs_error_t process_publish_message(SrsSource* source, SrsCommonMessage* msg);
virtual srs_error_t process_play_control_msg(SrsConsumer* consumer, SrsCommonMessage* msg);
virtual void set_sock_options();
private:
2017-09-23 14:12:33 +00:00
virtual srs_error_t check_edge_token_traverse_auth();
virtual srs_error_t do_token_traverse_auth(SrsRtmpClient* client);
private:
2019-04-30 00:24:52 +00:00
// When the connection disconnect, call this method.
// e.g. log msg of connection and report to other system.
2017-07-29 13:39:57 +00:00
virtual srs_error_t on_disconnect();
private:
virtual srs_error_t http_hooks_on_connect();
2014-04-27 06:57:28 +00:00
virtual void http_hooks_on_close();
virtual srs_error_t http_hooks_on_publish();
2014-04-27 06:57:28 +00:00
virtual void http_hooks_on_unpublish();
virtual srs_error_t http_hooks_on_play();
2014-04-27 06:57:28 +00:00
virtual void http_hooks_on_stop();
2013-11-23 03:36:07 +00:00
};
#endif
2014-08-02 14:18:39 +00:00