]> andersk Git - libfaim.git/blame - src/bos.c
- Tue Mar 27 19:15:10 PST 2001
[libfaim.git] / src / bos.c
CommitLineData
9f1a4013 1
2#define FAIM_INTERNAL
3#include <aim.h>
4
5/*
6 * aim_bos_setgroupperm(mask)
7 *
8 * Set group permisson mask. Normally 0x1f (all classes).
9 *
10 * The group permission mask allows you to keep users of a certain
11 * class or classes from talking to you. The mask should be
12 * a bitwise OR of all the user classes you want to see you.
13 *
14 */
15faim_export unsigned long aim_bos_setgroupperm(struct aim_session_t *sess,
16 struct aim_conn_t *conn,
17 u_long mask)
18{
19 return aim_genericreq_l(sess, conn, 0x0009, 0x0004, &mask);
20}
21
e80a0fa9 22faim_export int aim_0001_0020(struct aim_session_t *sess, struct aim_conn_t *conn)
23{
24 struct command_tx_struct *tx;
25 int i = 0;
26
27 if (!sess || !conn)
28 return 0;
29
30 if (!(tx = aim_tx_new(sess, conn, AIM_FRAMETYPE_OSCAR, 0x0002, 10+2+16)))
31 return -1;
32
33 tx->lock = 1;
34
35 /* Hummm.... */
36 i = aim_putsnac(tx->data, 0x0001, 0x0020, 0x0000, sess->snac_nextid++);
37 i += aimutil_put16(tx->data+i, 0x0010);
d32954e7 38 i += aimutil_put32(tx->data+i, 0x92bd6757);
39 i += aimutil_put32(tx->data+i, 0x3722cbd3);
40 i += aimutil_put32(tx->data+i, 0x2b048ab9);
41 i += aimutil_put32(tx->data+i, 0xd0b1e4ab);
42
e80a0fa9 43 tx->commandlen = i;
44 tx->lock = 0;
45 aim_tx_enqueue(sess, tx);
46
47 return 0;
48}
49
9f1a4013 50static 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)
51{
52 rxcallback_t userfunc;
53 int ret = 0;
54 struct aim_tlvlist_t *tlvlist;
55 unsigned short maxpermits = 0, maxdenies = 0;
56
57 /*
58 * TLVs follow
59 */
60 if (!(tlvlist = aim_readtlvchain(data, datalen)))
61 return 0;
62
63 /*
64 * TLV type 0x0001: Maximum number of buddies on permit list.
65 */
66 if (aim_gettlv(tlvlist, 0x0001, 1))
67 maxpermits = aim_gettlv16(tlvlist, 0x0001, 1);
68
69 /*
70 * TLV type 0x0002: Maximum number of buddies on deny list.
71 *
72 */
73 if (aim_gettlv(tlvlist, 0x0002, 1))
74 maxdenies = aim_gettlv16(tlvlist, 0x0002, 1);
75
76 if ((userfunc = aim_callhandler(sess, rx->conn, snac->family, snac->subtype)))
77 ret = userfunc(sess, rx, maxpermits, maxdenies);
78
79 aim_freetlvchain(&tlvlist);
80
81 return ret;
82}
83
84static int snachandler(struct aim_session_t *sess, aim_module_t *mod, struct command_rx_struct *rx, aim_modsnac_t *snac, unsigned char *data, int datalen)
85{
86
00ef5271 87 if (snac->subtype == 0x0003)
9f1a4013 88 return rights(sess, mod, rx, snac, data, datalen);
89
90 return 0;
91}
92
93faim_internal int bos_modfirst(struct aim_session_t *sess, aim_module_t *mod)
94{
95
96 mod->family = 0x0009;
97 mod->version = 0x0000;
98 mod->flags = 0;
99 strncpy(mod->name, "bos", sizeof(mod->name));
100 mod->snachandler = snachandler;
101
102 return 0;
103}
This page took 0.058074 seconds and 5 git commands to generate.