diff options
author | Adam <Adam@drink-coca-cola.info> | 2010-05-07 21:04:18 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-06-18 20:58:55 -0400 |
commit | af805e5b45f75dec7f4ce16ffc322c8880f9859c (patch) | |
tree | ccc5fb87394b0a80dd780d98d2af2f679c0eff68 /src/modules/ssl/m_ssl.cpp | |
parent | b775c84402c309ccf4bced359ee714fbedb4dd6e (diff) |
Allow enabling ssl on a per-uplink basis
Diffstat (limited to 'src/modules/ssl/m_ssl.cpp')
-rw-r--r-- | src/modules/ssl/m_ssl.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/src/modules/ssl/m_ssl.cpp b/src/modules/ssl/m_ssl.cpp index 075352551..be3e5da1f 100644 --- a/src/modules/ssl/m_ssl.cpp +++ b/src/modules/ssl/m_ssl.cpp @@ -122,28 +122,26 @@ class SSLModule : public Module SSL_CTX_free(ctx); } - EventReturn OnPreServerConnect() + EventReturn OnPreServerConnect(Uplink *u, int Number) { - int servernum = 1; - for (std::list<Uplink *>::iterator curr_uplink = Config.Uplinks.begin(); curr_uplink != Config.Uplinks.end(); ++curr_uplink, ++servernum) - { - uplink_server = *curr_uplink; + ConfigReader config; + if (config.ReadFlag("uplink", "ssl", "no", Number - 1)) + { try { - new SSLSocket(uplink_server->host, uplink_server->port, Config.LocalHost ? Config.LocalHost : "", uplink_server->ipv6); + new SSLSocket(u->host, u->port, Config.LocalHost ? Config.LocalHost : "", u->ipv6); + Alog() << "Connected to Server " << Number << " (" << u->host << ":" << u->port << ")"; } catch (SocketException& ex) { - Alog() << "Unable to connect to server" << servernum << " (" << uplink_server->host << ":" << uplink_server->port << "), " << ex.GetReason(); - continue; + Alog() << "Unable to connect with SSL to server" << Number << " (" << u->host << ":" << u->port << "), " << ex.GetReason(); } - Alog() << "Connected to Server " << servernum << " (" << uplink_server->host << ":" << uplink_server->port << ")"; return EVENT_ALLOW; } - return EVENT_STOP; + return EVENT_CONTINUE; } }; |