# HG changeset patch
# User Eric Warmenhoven <eric@warmenhoven.org>
# Date 976668697 0
# Node ID f50146ce818e49a4e0f898ff5822d981b6f32745
# Parent  42ca87108cd1e3841ae28aeb1cdef6a763206bfe
[gaim-migrate @ 1257]
more libfaim stuff

committer: Tailor Script <tailor@pidgin.im>

diff -r 42ca87108cd1 -r f50146ce818e libfaim/CHANGES
--- a/libfaim/CHANGES	Wed Dec 13 00:21:06 2000 +0000
+++ b/libfaim/CHANGES	Wed Dec 13 00:51:37 2000 +0000
@@ -1,6 +1,10 @@
 
 No release numbers
 ------------------
+ - Wed Dec 13 00:38:56 UTC 2000
+  - Added the client update/version info to the authresp callback
+  - Added the prototype for aim_getfile_send_chunk to aim.h
+
  - Tue Dec 12 23:02:41 UTC 2000
   - Got pissed off at sess->logininfo.  Got rid of it.
     - Now pass all that stuff in as varargs, like it should be.
diff -r 42ca87108cd1 -r f50146ce818e libfaim/aim_ft.c
--- a/libfaim/aim_ft.c	Wed Dec 13 00:21:06 2000 +0000
+++ b/libfaim/aim_ft.c	Wed Dec 13 00:51:37 2000 +0000
@@ -1591,7 +1591,6 @@
  * if (pos + chunksize > fh->size), we only send as much data as we
  *  can get (ie: up to fh->size.  
  */
-
 faim_export int aim_getfile_send_chunk(struct aim_conn_t *conn, FILE *tosend, struct aim_fileheader_t *fh, int pos, int bufsize)
 {
   int bufpos; 
diff -r 42ca87108cd1 -r f50146ce818e libfaim/aim_login.c
--- a/libfaim/aim_login.c	Wed Dec 13 00:21:06 2000 +0000
+++ b/libfaim/aim_login.c	Wed Dec 13 00:51:37 2000 +0000
@@ -298,6 +298,10 @@
   char *sn = NULL, *bosip = NULL, *errurl = NULL, *email = NULL;
   unsigned char *cookie = NULL;
   int errorcode = 0, regstatus = 0;
+  int latestbuild = 0, latestbetabuild = 0;
+  char *latestrelease = NULL, *latestbeta = NULL;
+  char *latestreleaseurl = NULL, *latestbetaurl = NULL;
+  char *latestreleaseinfo = NULL, *latestbetainfo = NULL;
 
   /*
    * Read block of TLVs.  All further data is derived
@@ -361,9 +365,31 @@
   if (aim_gettlv(tlvlist, 0x0013, 1))
     regstatus = aim_gettlv16(tlvlist, 0x0013, 1);
 
+  if (aim_gettlv(tlvlist, 0x0040, 1))
+    latestbetabuild = aim_gettlv32(tlvlist, 0x0040, 1);
+  if (aim_gettlv(tlvlist, 0x0041, 1))
+    latestbetaurl = aim_gettlv_str(tlvlist, 0x0041, 1);
+  if (aim_gettlv(tlvlist, 0x0042, 1))
+    latestbetainfo = aim_gettlv_str(tlvlist, 0x0042, 1);
+  if (aim_gettlv(tlvlist, 0x0043, 1))
+    latestbeta = aim_gettlv_str(tlvlist, 0x0043, 1);
+  if (aim_gettlv(tlvlist, 0x0048, 1))
+    ; /* no idea what this is */
+
+  if (aim_gettlv(tlvlist, 0x0044, 1))
+    latestbuild = aim_gettlv32(tlvlist, 0x0044, 1);
+  if (aim_gettlv(tlvlist, 0x0045, 1))
+    latestreleaseurl = aim_gettlv_str(tlvlist, 0x0045, 1);
+  if (aim_gettlv(tlvlist, 0x0046, 1))
+    latestreleaseinfo = aim_gettlv_str(tlvlist, 0x0046, 1);
+  if (aim_gettlv(tlvlist, 0x0047, 1))
+    latestrelease = aim_gettlv_str(tlvlist, 0x0047, 1);
+  if (aim_gettlv(tlvlist, 0x0049, 1))
+    ; /* no idea what this is */
+
 
   if ((userfunc = aim_callhandler(command->conn, 0x0017, 0x0003)))
-    ret = userfunc(sess, command, sn, errorcode, errurl, regstatus, email, bosip, cookie);
+    ret = userfunc(sess, command, sn, errorcode, errurl, regstatus, email, bosip, cookie, latestrelease, latestbuild, latestreleaseurl, latestreleaseinfo, latestbeta, latestbetabuild, latestbetaurl, latestbetainfo);
 
 
   if (sn)
@@ -376,6 +402,19 @@
     free(email);
   if (cookie)
     free(cookie);
+  if (latestrelease)
+    free(latestrelease);
+  if (latestreleaseurl)
+    free(latestreleaseurl);
+  if (latestbeta)
+    free(latestbeta);
+  if (latestbetaurl)
+    free(latestbetaurl);
+  if (latestreleaseinfo)
+    free(latestreleaseinfo);
+  if (latestbetainfo)
+    free(latestbetainfo);
+
   aim_freetlvchain(&tlvlist);
 
   return ret;
diff -r 42ca87108cd1 -r f50146ce818e libfaim/faim/aim.h
--- a/libfaim/faim/aim.h	Wed Dec 13 00:21:06 2000 +0000
+++ b/libfaim/faim/aim.h	Wed Dec 13 00:51:37 2000 +0000
@@ -447,6 +447,7 @@
 faim_internal struct aim_fileheader_t *aim_oft_getfh(unsigned char *hdr);
 faim_export int aim_oft_registerlisting(struct aim_session_t *sess, FILE *file, char* listingdir);
 faim_export int aim_getfile_send(struct aim_conn_t *conn, FILE *tosend, struct aim_fileheader_t *fh);
+faim_export int aim_getfile_send_chunk(struct aim_conn_t *conn, FILE *tosend, struct aim_fileheader_t *fh, int pos, int bufsize);
 
 /* aim_login.c */
 faim_export int aim_sendconnack(struct aim_session_t *sess, struct aim_conn_t *conn);
diff -r 42ca87108cd1 -r f50146ce818e src/oscar.c
--- a/src/oscar.c	Wed Dec 13 00:21:06 2000 +0000
+++ b/src/oscar.c	Wed Dec 13 00:51:37 2000 +0000
@@ -458,6 +458,10 @@
 	char *sn = NULL, *bosip = NULL, *errurl = NULL, *email = NULL;
 	unsigned char *cookie = NULL;
 	int errorcode = 0, regstatus = 0;
+	int latestbuild = 0, latestbetabuild = 0;
+	char *latestrelease = NULL, *latestbeta = NULL;
+	char *latestreleaseurl = NULL, *latestbetaurl = NULL;
+	char *latestreleaseinfo = NULL, *latestbetainfo = NULL;
 
 	struct gaim_connection *gc = find_gaim_conn_by_aim_sess(sess);
 
@@ -469,6 +473,17 @@
 	email = va_arg(ap, char *);
 	bosip = va_arg(ap, char *);
 	cookie = va_arg(ap, unsigned char *);
+
+	latestrelease = va_arg(ap, char *);
+	latestbuild = va_arg(ap, int);
+	latestreleaseurl = va_arg(ap, char *);
+	latestreleaseinfo = va_arg(ap, char *);
+
+	latestbeta = va_arg(ap, char *);
+	latestbetabuild = va_arg(ap, int);
+	latestbetaurl = va_arg(ap, char *);
+	latestbetainfo = va_arg(ap, char *);
+
 	va_end(ap);
 
 	sprintf(debug_buff, "inside auth_resp (Screen name: %s)\n", sn);
@@ -505,13 +520,20 @@
 	}
 
 
+	debug_printf("Reg status: %2d\n", regstatus);
 	if (email) {
 		debug_printf("Email: %s\n", email);
 	} else {
 		debug_printf("Email is NULL\n");
 	}
-	sprintf(debug_buff, "Closing auth connection...\n");
-	debug_print(debug_buff);
+	debug_printf("BOSIP: %s\n", bosip);
+	if (latestbeta)
+		debug_printf("Latest WinAIM beta version %s, build %d, at %s (%s)\n",
+				latestbeta, latestbetabuild, latestbetaurl, latestbetainfo);
+	if (latestrelease)
+		debug_printf("Latest WinAIM released version %s, build %d, at %s (%s)\n",
+				latestrelease, latestbuild, latestreleaseurl, latestreleaseinfo);
+	debug_printf("Closing auth connection...\n");
 	gdk_input_remove(gc->inpa);
 	aim_conn_kill(sess, &command->conn);