diff libgaim/protocols/oscar/misc.c @ 14192:60b1bc8dbf37

[gaim-migrate @ 16863] Renamed 'core' to 'libgaim' committer: Tailor Script <tailor@pidgin.im>
author Evan Schoenberg <evan.s@dreskin.net>
date Sat, 19 Aug 2006 01:50:10 +0000
parents
children f3573d941d66
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libgaim/protocols/oscar/misc.c	Sat Aug 19 01:50:10 2006 +0000
@@ -0,0 +1,162 @@
+/*
+ * Gaim's oscar protocol plugin
+ * This file is the legal property of its developers.
+ * Please see the AUTHORS file distributed alongside this file.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+*/
+
+/*
+ * Random stuff.  Basically just a few functions for sending
+ * simple SNACs, and then the generic error handler.
+ */
+
+#include "oscar.h"
+
+/*
+ * Generic routine for sending commands.
+ *
+ * I know I can do this in a smarter way...but I'm not thinking straight
+ * right now...
+ *
+ * I had one big function that handled all three cases, but then it broke
+ * and I split it up into three.  But then I fixed it.  I just never went
+ * back to the single.  I don't see any advantage to doing it either way.
+ *
+ */
+int
+aim_genericreq_n(OscarData *od, FlapConnection *conn, guint16 family, guint16 subtype)
+{
+	FlapFrame *frame;
+	aim_snacid_t snacid = 0x00000000;
+
+	frame = flap_frame_new(od, 0x02, 10);
+
+	aim_putsnac(&frame->data, family, subtype, 0x0000, snacid);
+
+	flap_connection_send(conn, frame);
+
+	return 0;
+}
+
+void
+aim_genericreq_n_snacid(OscarData *od, FlapConnection *conn, guint16 family, guint16 subtype)
+{
+	FlapFrame *frame;
+	aim_snacid_t snacid;
+
+	frame = flap_frame_new(od, 0x02, 10);
+
+	snacid = aim_cachesnac(od, family, subtype, 0x0000, NULL, 0);
+	aim_putsnac(&frame->data, family, subtype, 0x0000, snacid);
+
+	flap_connection_send(conn, frame);
+}
+
+int
+aim_genericreq_l(OscarData *od, FlapConnection *conn, guint16 family, guint16 subtype, guint32 *longdata)
+{
+	FlapFrame *frame;
+	aim_snacid_t snacid;
+
+	if (!longdata)
+		return aim_genericreq_n(od, conn, family, subtype);
+
+	frame = flap_frame_new(od, 0x02, 10+4);
+
+	snacid = aim_cachesnac(od, family, subtype, 0x0000, NULL, 0);
+
+	aim_putsnac(&frame->data, family, subtype, 0x0000, snacid);
+	byte_stream_put32(&frame->data, *longdata);
+
+	flap_connection_send(conn, frame);
+
+	return 0;
+}
+
+int
+aim_genericreq_s(OscarData *od, FlapConnection *conn, guint16 family, guint16 subtype, guint16 *shortdata)
+{
+	FlapFrame *frame;
+	aim_snacid_t snacid;
+
+	if (!shortdata)
+		return aim_genericreq_n(od, conn, family, subtype);
+
+	frame = flap_frame_new(od, 0x02, 10+2);
+
+	snacid = aim_cachesnac(od, family, subtype, 0x0000, NULL, 0);
+
+	aim_putsnac(&frame->data, family, subtype, 0x0000, snacid);
+	byte_stream_put16(&frame->data, *shortdata);
+
+	flap_connection_send(conn, frame);
+
+	return 0;
+}
+
+/*
+ * Should be generic enough to handle the errors for all groups.
+ *
+ */
+static int
+generror(OscarData *od, FlapConnection *conn, aim_module_t *mod, FlapFrame *frame, aim_modsnac_t *snac, ByteStream *bs)
+{
+	int ret = 0;
+	int error = 0;
+	aim_rxcallback_t userfunc;
+	aim_snac_t *snac2;
+
+	snac2 = aim_remsnac(od, snac->id);
+
+	if (byte_stream_empty(bs))
+		error = byte_stream_get16(bs);
+
+	if ((userfunc = aim_callhandler(od, snac->family, snac->subtype)))
+		ret = userfunc(od, conn, frame, error, snac2 ? snac2->data : NULL);
+
+	if (snac2)
+		free(snac2->data);
+	free(snac2);
+
+	return ret;
+}
+
+static int
+snachandler(OscarData *od, FlapConnection *conn, aim_module_t *mod, FlapFrame *frame, aim_modsnac_t *snac, ByteStream *bs)
+{
+	if (snac->subtype == 0x0001)
+		return generror(od, conn, mod, frame, snac, bs);
+	else if ((snac->family == 0xffff) && (snac->subtype == 0xffff)) {
+		aim_rxcallback_t userfunc;
+
+		if ((userfunc = aim_callhandler(od, snac->family, snac->subtype)))
+			return userfunc(od, conn, frame);
+	}
+
+	return 0;
+}
+
+int
+misc_modfirst(OscarData *od, aim_module_t *mod)
+{
+	mod->family = 0xffff;
+	mod->version = 0x0000;
+	mod->flags = AIM_MODFLAG_MULTIFAMILY;
+	strncpy(mod->name, "misc", sizeof(mod->name));
+	mod->snachandler = snachandler;
+
+	return 0;
+}