2013-11-23 03:36:07 +00:00
|
|
|
/*
|
|
|
|
The MIT License (MIT)
|
|
|
|
|
2014-01-01 02:37:12 +00:00
|
|
|
Copyright (c) 2013-2014 winlin
|
2013-11-23 03:36:07 +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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <srs_core_conn.hpp>
|
|
|
|
|
|
|
|
#include <srs_core_log.hpp>
|
2014-03-01 02:30:16 +00:00
|
|
|
#include <srs_kernel_error.hpp>
|
2013-11-23 03:36:07 +00:00
|
|
|
#include <srs_core_server.hpp>
|
|
|
|
|
|
|
|
SrsConnection::SrsConnection(SrsServer* srs_server, st_netfd_t client_stfd)
|
|
|
|
{
|
|
|
|
server = srs_server;
|
|
|
|
stfd = client_stfd;
|
2013-12-08 04:45:12 +00:00
|
|
|
connection_id = 0;
|
2013-11-23 03:36:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
SrsConnection::~SrsConnection()
|
|
|
|
{
|
2013-12-14 06:06:32 +00:00
|
|
|
srs_close_stfd(stfd);
|
2013-11-23 03:36:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int SrsConnection::start()
|
|
|
|
{
|
|
|
|
int ret = ERROR_SUCCESS;
|
|
|
|
|
|
|
|
if (st_thread_create(cycle_thread, this, 0, 0) == NULL) {
|
|
|
|
ret = ERROR_ST_CREATE_CYCLE_THREAD;
|
|
|
|
srs_error("st_thread_create conn cycle thread error. ret=%d", ret);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
srs_verbose("create st conn cycle thread success.");
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SrsConnection::cycle()
|
|
|
|
{
|
|
|
|
int ret = ERROR_SUCCESS;
|
|
|
|
|
|
|
|
log_context->generate_id();
|
2013-12-08 04:45:12 +00:00
|
|
|
connection_id = log_context->get_id();
|
|
|
|
|
2013-11-23 03:36:07 +00:00
|
|
|
ret = do_cycle();
|
|
|
|
|
|
|
|
// if socket io error, set to closed.
|
|
|
|
if (ret == ERROR_SOCKET_READ || ret == ERROR_SOCKET_READ_FULLY || ret == ERROR_SOCKET_WRITE) {
|
|
|
|
ret = ERROR_SOCKET_CLOSED;
|
|
|
|
}
|
|
|
|
|
|
|
|
// success.
|
|
|
|
if (ret == ERROR_SUCCESS) {
|
|
|
|
srs_trace("client process normally finished. ret=%d", ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
// client close peer.
|
|
|
|
if (ret == ERROR_SOCKET_CLOSED) {
|
|
|
|
srs_trace("client disconnect peer. ret=%d", ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
server->remove(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
void* SrsConnection::cycle_thread(void* arg)
|
|
|
|
{
|
|
|
|
SrsConnection* conn = (SrsConnection*)arg;
|
|
|
|
srs_assert(conn != NULL);
|
|
|
|
|
|
|
|
conn->cycle();
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|