1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
/*
* Anope IRC Services
*
* Copyright (C) 2011-2016 Anope Team <team@anope.org>
*
* This file is part of Anope. Anope is free software; you can
* redistribute it and/or modify it under the terms of the GNU
* General Public License as published by the Free Software
* Foundation, version 2.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see see <http://www.gnu.org/licenses/>.
*/
#include "services.h"
#include "anope.h"
#include "logger.h"
#include "sockets.h"
#include <errno.h>
void ConnectionSocket::Connect(const Anope::string &TargetHost, int Port)
{
this->io->Connect(this, TargetHost, Port);
}
bool ConnectionSocket::Process()
{
try
{
if (this->flags[SF_CONNECTED])
return true;
else if (this->flags[SF_CONNECTING])
this->flags[this->io->FinishConnect(this)] = true;
else
this->flags[SF_DEAD] = true;
}
catch (const SocketException &ex)
{
Anope::Logger.Log(ex.GetReason());
}
return false;
}
void ConnectionSocket::ProcessError()
{
int optval = 0;
socklen_t optlen = sizeof(optval);
getsockopt(this->GetFD(), SOL_SOCKET, SO_ERROR, reinterpret_cast<char *>(&optval), &optlen);
errno = optval;
this->OnError(optval ? Anope::LastError() : "");
}
void ConnectionSocket::OnConnect()
{
}
void ConnectionSocket::OnError(const Anope::string &error)
{
Anope::Logger.Debug("Socket error: {0}", error);
}
ClientSocket::ClientSocket(ListenSocket *l, const sockaddrs &addr) : ls(l), clientaddr(addr)
{
}
bool ClientSocket::Process()
{
try
{
if (this->flags[SF_ACCEPTED])
return true;
else if (this->flags[SF_ACCEPTING])
this->flags[this->io->FinishAccept(this)] = true;
else
this->flags[SF_DEAD] = true;
}
catch (const SocketException &ex)
{
Anope::Logger.Log(ex.GetReason());
}
return false;
}
void ClientSocket::ProcessError()
{
int optval = 0;
socklen_t optlen = sizeof(optval);
getsockopt(this->GetFD(), SOL_SOCKET, SO_ERROR, reinterpret_cast<char *>(&optval), &optlen);
errno = optval;
this->OnError(optval ? Anope::LastError() : "");
}
void ClientSocket::OnAccept()
{
}
void ClientSocket::OnError(const Anope::string &error)
{
Anope::Logger.Debug("Socket error: {0}", error);
}
|