[IOMultiplexerV2] started to implement c-ares backend
[NextIRCd.git] / src / IOHandler / IOSockets.c
index 4a7da99c6b8618c6df169a7ff65ce3775e3e0034..b844d64f8228240729807aa6fece42c7474dec3c 100644 (file)
@@ -20,6 +20,7 @@
 #include "IOSockets.h"
 #include "IOLog.h"
 #include "IODNSLookup.h"
+#include "IOSSLBackend.h"
 
 #ifdef WIN32
 #define _WIN32_WINNT 0x501
@@ -51,8 +52,6 @@ struct _IOSocket *iosocket_last = NULL;
 
 struct IOEngine *engine = NULL;
 
-static void iosocket_activate(struct _IOSocket *iosock);
-static void iosocket_deactivate(struct _IOSocket *iosock);
 static void iosocket_increase_buffer(struct IOSocketBuffer *iobuf, size_t required);
 static int iosocket_parse_address(const char *hostname, struct IODNSAddress *addr, int records);
 static int iosocket_lookup_hostname(struct _IOSocket *iosock, const char *hostname, int records, int bindaddr);
@@ -147,20 +146,26 @@ void _free_socket(struct _IOSocket *iosock) {
        free(iosock);
 }
 
-static void iosocket_activate(struct _IOSocket *iosock) {
+void iosocket_activate(struct _IOSocket *iosock) {
        if((iosock->socket_flags & IOSOCKETFLAG_ACTIVE))
                return;
        iosock->socket_flags |= IOSOCKETFLAG_ACTIVE;
        engine->add(iosock);
 }
 
-static void iosocket_deactivate(struct _IOSocket *iosock) {
+void iosocket_deactivate(struct _IOSocket *iosock) {
        if(!(iosock->socket_flags & IOSOCKETFLAG_ACTIVE))
                return;
        iosock->socket_flags &= ~IOSOCKETFLAG_ACTIVE;
        engine->remove(iosock);
 }
 
+void iosocket_update(struct _IOSocket *iosock) {
+       if(!(iosock->socket_flags & IOSOCKETFLAG_ACTIVE))
+               return;
+       engine->update(iosock);
+}
+
 static void iosocket_increase_buffer(struct IOSocketBuffer *iobuf, size_t required) {
        if(iobuf->buflen >= required) return;
        char *new_buf;
@@ -1056,7 +1061,7 @@ void iosocket_events_callback(struct _IOSocket *iosock, int readable, int writea
                        iosocket_close(iosocket);
                
        } else if((iosock->socket_flags & IOSOCKETFLAG_PARENT_DNSENGINE)) {
-               //TODO: IODNS callback
+               iodns_socket_callback(iosock, readable, writeable);
        }
 }