]> andersk Git - libfaim.git/blobdiff - aim_search.c
- Sun Feb 11 01:07:36 UTC 2001
[libfaim.git] / aim_search.c
index 78aef0fc7c55da9edebac0498e1564f32c0283d0..d1cba01b05ede42d0ea4ac20904873e3517e4cf7 100644 (file)
  *
  */
 
+#define FAIM_INTERNAL
 #include <faim/aim.h>
 
-u_long aim_usersearch_address(struct aim_session_t *sess,
-                             struct aim_conn_t *conn, 
-                             char *address)
+faim_export unsigned long aim_usersearch_address(struct aim_session_t *sess,
+                                                struct aim_conn_t *conn, 
+                                                char *address)
 {
-  struct command_tx_struct newpacket;
+  struct command_tx_struct *newpacket;
   
   if (!address)
     return -1;
 
-  newpacket.lock = 1;
+  if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+strlen(address))))
+    return -1;
+
+  newpacket->lock = 1;
+
+  aim_putsnac(newpacket->data, 0x000a, 0x0002, 0x0000, sess->snac_nextid);
+
+  aimutil_putstr(newpacket->data+10, address, strlen(address));
+
+  aim_tx_enqueue(sess, newpacket);
+
+  aim_cachesnac(sess, 0x000a, 0x0002, 0x0000, address, strlen(address)+1);
+
+  return sess->snac_nextid;
+}
+
+
+faim_internal unsigned long aim_parse_searcherror(struct aim_session_t *sess, struct command_rx_struct *command) 
+{
+  u_int i, ret;
+  int snacid;
+  rxcallback_t userfunc;
+  struct aim_snac_t *snac;
+
+  i = 6;
+
+  snacid = aimutil_get32(command->data+i);
+  i += 4;
+  
+  if(!(snac = aim_remsnac(sess, snacid))) {
+    faimdprintf(2, "faim: couldn't get a snac for %d, probably should crash.\n", snacid);
+    return 0;
+  }
 
-  if (conn)
-    newpacket.conn = conn;
+  if((userfunc = aim_callhandler(command->conn, 0x000a, 0x0001)))
+    ret = userfunc(sess, command, snac->data /* address */);
   else
-    newpacket.conn = aim_getconn_type(sess, AIM_CONN_TYPE_BOS);
+    ret = 0;
 
-  newpacket.type = 0x0002;
+  if(snac) {
+    if(snac->data)
+      free(snac->data);
+    free(snac);
+  }
+
+  return ret;
+}
+       
   
-  newpacket.commandlen = 10 + strlen(address);
-  newpacket.data = (char *) malloc(newpacket.commandlen);
+faim_internal unsigned long aim_parse_searchreply(struct aim_session_t *sess, struct command_rx_struct *command)
+{
+  u_int i, j, m, ret;
+  int snacid;
+  struct aim_tlvlist_t *tlvlist;
+  char *cur = NULL, *buf = NULL;
+  rxcallback_t userfunc;
+  struct aim_snac_t *snac;
+
+  i = 6;
+
+  snacid = aimutil_get32(command->data+i);
+  i += 4;
+
+  if(!(snac = aim_remsnac(sess, snacid))) {
+    faimdprintf(2, "faim: couldn't get a snac for %d, probably should crash.\n", snacid);
+    return 0;
+  }
 
-  aim_putsnac(newpacket.data, 0x000a, 0x0002, 0x0000, sess->snac_nextid);
+  tlvlist = aim_readtlvchain(command->data+i, command->commandlen-i);
 
-  memcpy(&(newpacket.data[10]), address, strlen(address));
+  j = 0;
 
-  aim_tx_enqueue(sess, &newpacket);
+  m = aim_counttlvchain(&tlvlist);
 
-  {
-    struct aim_snac_t snac;
-    
-    snac.id = sess->snac_nextid;
-    snac.family = 0x000a;
-    snac.type = 0x0002;
-    snac.flags = 0x0000;
+  while((cur = aim_gettlv_str(tlvlist, 0x0001, j+1)) && j < m) {
+    if(!(buf = realloc(buf, (j+1) * (MAXSNLEN+1))))
+      faimdprintf(2, "faim: couldn't realloc buf. oh well.\n");
 
-    snac.data = malloc(strlen(address)+1);
-    memcpy(snac.data, address, strlen(address)+1);
+    strncpy(&buf[j * (MAXSNLEN+1)], cur, MAXSNLEN);
+    free(cur);
 
-    aim_newsnac(sess, &snac);
+    j++; 
   }
 
-  return (sess->snac_nextid++);
-}
+  aim_freetlvchain(&tlvlist);
+
+  if((userfunc = aim_callhandler(command->conn, 0x000a, 0x0003)))
+    ret = userfunc(sess, command, snac->data /* address */, j, buf);
+  else
+    ret = 0;
 
+  if(snac) {
+    if(snac->data)
+      free(snac->data);
+    free(snac);
+  }
+
+  if(buf)
+    free(buf);
+
+  return ret;
+}
This page took 0.341011 seconds and 4 git commands to generate.