* user information structure. Its close enough to run
* through aim_extractuserinfo() however.
*
+ * Although the offgoing notification contains no information,
+ * it is still in a format parsable by extractuserinfo.
+ *
*/
-static int oncoming(struct aim_session_t *sess, aim_module_t *mod, struct command_rx_struct *rx, aim_modsnac_t *snac, unsigned char *data, int datalen)
+static int buddychange(struct aim_session_t *sess, aim_module_t *mod, struct command_rx_struct *rx, aim_modsnac_t *snac, unsigned char *data, int datalen)
{
struct aim_userinfo_s userinfo;
rxcallback_t userfunc;
return 0;
}
-/*
- * Offgoing Buddy notifications contain no useful
- * information other than the name it applies to.
- *
- */
-static int offgoing(struct aim_session_t *sess, aim_module_t *mod, struct command_rx_struct *rx, aim_modsnac_t *snac, unsigned char *data, int datalen)
-{
- char sn[MAXSNLEN+1];
- rxcallback_t userfunc;
-
- strncpy(sn, (char *)data+1, (int)*data);
-
- if ((userfunc = aim_callhandler(sess, rx->conn, snac->family, snac->subtype)))
- return userfunc(sess, rx, sn);
-
- return 0;
-}
-
static int rights(struct aim_session_t *sess, aim_module_t *mod, struct command_rx_struct *rx, aim_modsnac_t *snac, unsigned char *data, int datalen)
{
rxcallback_t userfunc;
if (snac->subtype == 0x0003)
return rights(sess, mod, rx, snac, data, datalen);
- else if (snac->subtype == 0x000b)
- return oncoming(sess, mod, rx, snac, data, datalen);
- else if (snac->subtype == 0x000c)
- return offgoing(sess, mod, rx, snac, data, datalen);
+ else if ((snac->subtype == 0x000b) || (snac->subtype == 0x000c))
+ return buddychange(sess, mod, rx, snac, data, datalen);
return 0;
}
int faimtest_parse_offgoing(struct aim_session_t *sess, struct command_rx_struct *command, ...)
{
- char *sn;
+ struct aim_userinfo_s *userinfo;
+
va_list ap;
-
va_start(ap, command);
- sn = va_arg(ap, char *);
+ userinfo = va_arg(ap, struct aim_userinfo_s *);
va_end(ap);
- dvprintf("\n%s has left\n", sn);
-
+ dvprintf("%ld %s is now offline (flags: %04x = %s%s%s%s%s%s%s%s) (caps = 0x%04x)\n",
+ time(NULL),
+ userinfo->sn, userinfo->flags,
+ (userinfo->flags&AIM_FLAG_UNCONFIRMED)?" UNCONFIRMED":"",
+ (userinfo->flags&AIM_FLAG_ADMINISTRATOR)?" ADMINISTRATOR":"",
+ (userinfo->flags&AIM_FLAG_AOL)?" AOL":"",
+ (userinfo->flags&AIM_FLAG_OSCAR_PAY)?" OSCAR_PAY":"",
+ (userinfo->flags&AIM_FLAG_FREE)?" FREE":"",
+ (userinfo->flags&AIM_FLAG_AWAY)?" AWAY":"",
+ (userinfo->flags&AIM_FLAG_UNKNOWN40)?" UNKNOWN40":"",
+ (userinfo->flags&AIM_FLAG_UNKNOWN80)?" UNKNOWN80":"",
+ userinfo->capabilities);
return 1;
}