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_pithy_print.hpp

151 lines
4.9 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-29 14:21:31 +00:00
#ifndef SRS_APP_PITHY_PRINT_HPP
#define SRS_APP_PITHY_PRINT_HPP
2013-11-29 14:21:31 +00:00
#include <srs_core.hpp>
#include <map>
#include <srs_app_reload.hpp>
2019-04-30 00:24:52 +00:00
// The stage info to calc the age.
class SrsStageInfo : public ISrsReloadHandler
{
public:
int stage_id;
2019-04-09 00:55:54 +00:00
srs_utime_t interval;
int nb_clients;
2020-08-12 09:07:37 +00:00
// The number of call of can_print().
uint32_t nn_count;
// The ratio for interval, 1.0 means no change.
double interval_ratio;
public:
2019-04-09 00:55:54 +00:00
srs_utime_t age;
public:
SrsStageInfo(int _stage_id, double ratio = 1.0);
virtual ~SrsStageInfo();
virtual void update_print_time();
public:
2019-04-09 00:55:54 +00:00
virtual void elapse(srs_utime_t diff);
virtual bool can_print();
public:
2017-09-22 08:14:30 +00:00
virtual srs_error_t on_reload_pithy_print();
};
// The manager for stages, it's used for a single client stage.
// Of course, we can add the multiple user support, which is SrsPithyPrint.
class SrsStageManager
{
private:
std::map<int, SrsStageInfo*> stages;
public:
SrsStageManager();
virtual ~SrsStageManager();
public:
// Fetch a stage, create one if not exists.
SrsStageInfo* fetch_or_create(int stage_id, bool* pnew = NULL);
};
// The error pithy print is a single client stage manager, each stage only has one client.
// For example, we use it for error pithy print for each UDP packet processing.
class SrsErrorPithyPrint
{
2020-07-27 04:44:29 +00:00
public:
// The number of call of can_print().
uint32_t nn_count;
private:
double ratio_;
SrsStageManager stages;
std::map<int, srs_utime_t> ticks;
public:
SrsErrorPithyPrint(double ratio = 1.0);
virtual ~SrsErrorPithyPrint();
public:
// Whether specified stage is ready for print.
2020-08-12 09:07:37 +00:00
bool can_print(srs_error_t err, uint32_t* pnn = NULL);
2020-07-27 04:28:15 +00:00
// We also support int error code.
2020-08-12 09:07:37 +00:00
bool can_print(int err, uint32_t* pnn = NULL);
};
2019-04-30 00:24:52 +00:00
// The stage is used for a collection of object to do print,
// the print time in a stage is constant and not changed,
// that is, we always got one message to print every specified time.
//
// For example, stage #1 for all play clients, print time is 3s,
// if there is 1client, it will print every 3s.
// if there is 10clients, random select one to print every 3s.
// Usage:
// SrsPithyPrint* pprint = SrsPithyPrint::create_rtmp_play();
// SrsAutoFree(SrsPithyPrint, pprint);
// while (true) {
// pprint->elapse();
// if (pprint->can_print()) {
// // print pithy message.
// // user can get the elapse time by: pprint->age()
// }
// // read and write RTMP messages.
// }
2013-11-29 14:21:31 +00:00
class SrsPithyPrint
{
private:
2014-03-18 03:32:58 +00:00
int client_id;
int stage_id;
srs_utime_t _age;
srs_utime_t previous_tick;
private:
2014-03-18 03:32:58 +00:00
SrsPithyPrint(int _stage_id);
public:
static SrsPithyPrint* create_rtmp_play();
static SrsPithyPrint* create_rtmp_publish();
static SrsPithyPrint* create_hls();
static SrsPithyPrint* create_forwarder();
static SrsPithyPrint* create_encoder();
static SrsPithyPrint* create_exec();
static SrsPithyPrint* create_ingester();
static SrsPithyPrint* create_edge();
static SrsPithyPrint* create_caster();
static SrsPithyPrint* create_http_stream();
static SrsPithyPrint* create_http_stream_cache();
static SrsPithyPrint* create_rtc_play();
// For RTC sender and receiver, we create printer for each fd.
static SrsPithyPrint* create_rtc_send(int fd);
static SrsPithyPrint* create_rtc_recv(int fd);
2014-03-18 03:32:58 +00:00
virtual ~SrsPithyPrint();
2013-11-29 14:21:31 +00:00
private:
2019-04-30 00:24:52 +00:00
// Enter the specified stage, return the client id.
2014-03-18 03:32:58 +00:00
virtual int enter_stage();
2019-04-30 00:24:52 +00:00
// Leave the specified stage, release the client id.
2014-03-18 03:32:58 +00:00
virtual void leave_stage();
2013-11-29 14:21:31 +00:00
public:
2019-04-30 00:24:52 +00:00
// Auto calc the elapse time
virtual void elapse();
2019-04-30 00:24:52 +00:00
// Whether current client can print.
2014-03-18 03:32:58 +00:00
virtual bool can_print();
2019-04-30 00:24:52 +00:00
// Get the elapsed time in srs_utime_t.
virtual srs_utime_t age();
2013-11-29 14:21:31 +00:00
};
2014-08-02 14:18:39 +00:00
#endif