unfinished HandleCapabilities, moved the IRC structs to another headerfile
This commit is contained in:
43
src/IRC.c
43
src/IRC.c
@@ -130,10 +130,42 @@ static void handlePing(irc_message_t *msg, irc_client_t *irc)
|
||||
static void handleCapabilities(irc_message_t *msg, irc_client_t *irc)
|
||||
{
|
||||
// we are willing to tolerate some spaghetti...
|
||||
if(strncmp(msg->argv[1], "LS", 4) == 0)
|
||||
if(strcmp(msg->argv[2], "LS") == 0)
|
||||
{
|
||||
// parse the caps
|
||||
snprintf(irc->supportedCapabilities, sizeof irc->supportedCapabilities, "%s", msg->argv[3]);
|
||||
|
||||
// parse the caps
|
||||
irc_capability_t caps[24];
|
||||
int capCount = IRC_ParseCapabilities(irc->supportedCapabilities, caps, sizeof(caps) / sizeof(irc_capability_t));
|
||||
|
||||
irc_capability_t reqCaps[24];
|
||||
|
||||
int reqCapCount = IRC_ParseCapabilities(irc->requestedCapabilities, reqCaps, sizeof(reqCaps) / sizeof(irc_capability_t));
|
||||
|
||||
char buf[512];
|
||||
int bytesWritten = 0;
|
||||
|
||||
for(int i = 0; i < capCount; i++)
|
||||
{
|
||||
for(int j = 0; j < reqCapCount; j++)
|
||||
{
|
||||
if(strcmp(caps[i].name, reqCaps[j].name) == 0 == 0)
|
||||
{
|
||||
bytesWritten += snprintf(buf + bytesWritten, sizeof(buf) - bytesWritten, "%s ", reqCaps[j].name);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
IRC_RequestCapabilities(buf, irc);
|
||||
}
|
||||
else if (strcmp(msg->argv[2], "ACK"))
|
||||
{
|
||||
int ackedCount = IRC_ParseCapabilities(msg->argv[3], irc->acked, sizeof(irc->acked) / sizeof(irc_capability_t));
|
||||
|
||||
for(int i = 0; i < ackedCount; i++)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -187,7 +219,7 @@ void IRC_USER(char *ident, char *realname, irc_client_t *irc)
|
||||
NET_Send(irc->sockfd, buf);
|
||||
}
|
||||
|
||||
void IRC_REGISTER(char *nick, char *ident, char *realname, bool saslEnabled, irc_sasl_method_t saslMethod, char *saslUsername, char *saslPassword, irc_client_t *irc)
|
||||
void IRC_REGISTER(char *nick, char *ident, char *realname, irc_client_t *irc)
|
||||
{
|
||||
IRC_StartCapabilityNegotiation(irc);
|
||||
IRC_NICK(nick, irc);
|
||||
@@ -206,6 +238,11 @@ void IRC_RequestCapabilities(char *caps, irc_client_t *irc)
|
||||
NET_Send(irc->sockfd, buf);
|
||||
}
|
||||
|
||||
void IRC_NeedCapabilities(char *caps, irc_client_t *irc)
|
||||
{
|
||||
snprintf(irc->requestedCapabilities, sizeof irc->requestedCapabilities, "%s", caps);
|
||||
}
|
||||
|
||||
void IRC_EndCapabilityNegotiation(irc_client_t *irc)
|
||||
{
|
||||
NET_Send(irc->sockfd, "CAP END");
|
||||
|
||||
Reference in New Issue
Block a user