Annotation of ChivanetAimPidgin/oscarprpl/src/c/msgcookie.c, revision 1.1
1.1 ! snw 1: /*
! 2: * Purple's oscar protocol plugin
! 3: * This file is the legal property of its developers.
! 4: * Please see the AUTHORS file distributed alongside this file.
! 5: *
! 6: * This library is free software; you can redistribute it and/or
! 7: * modify it under the terms of the GNU Lesser General Public
! 8: * License as published by the Free Software Foundation; either
! 9: * version 2 of the License, or (at your option) any later version.
! 10: *
! 11: * This library is distributed in the hope that it will be useful,
! 12: * but WITHOUT ANY WARRANTY; without even the implied warranty of
! 13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
! 14: * Lesser General Public License for more details.
! 15: *
! 16: * You should have received a copy of the GNU Lesser General Public
! 17: * License along with this library; if not, write to the Free Software
! 18: * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
! 19: */
! 20:
! 21: /*
! 22: * Cookie Caching stuff. Adam wrote this, apparently just some
! 23: * derivatives of n's SNAC work. I cleaned it up, added comments.
! 24: *
! 25: */
! 26:
! 27: /*
! 28: * I'm assuming that cookies are type-specific. that is, we can have
! 29: * "1234578" for type 1 and type 2 concurrently. if i'm wrong, then we
! 30: * lose some error checking. if we assume cookies are not type-specific and are
! 31: * wrong, we get quirky behavior when cookies step on each others' toes.
! 32: */
! 33:
! 34: #include "oscar.h"
! 35:
! 36: /**
! 37: * aim_cachecookie - appends a cookie to the cookie list
! 38: *
! 39: * if cookie->cookie for type cookie->type is found, updates the
! 40: * ->addtime of the found structure; otherwise adds the given cookie
! 41: * to the cache
! 42: *
! 43: * @param od session to add to
! 44: * @param cookie pointer to struct to append
! 45: * @return returns -1 on error, 0 on append, 1 on update. the cookie you pass
! 46: * in may be free'd, so don't count on its value after calling this!
! 47: */
! 48: int aim_cachecookie(OscarData *od, IcbmCookie *cookie)
! 49: {
! 50: IcbmCookie *newcook;
! 51:
! 52: if (!od || !cookie)
! 53: return -EINVAL;
! 54:
! 55: newcook = aim_checkcookie(od, cookie->cookie, cookie->type);
! 56:
! 57: if (newcook == cookie) {
! 58: newcook->addtime = time(NULL);
! 59: return 1;
! 60: } else if (newcook)
! 61: aim_cookie_free(od, newcook);
! 62:
! 63: cookie->addtime = time(NULL);
! 64:
! 65: cookie->next = od->msgcookies;
! 66: od->msgcookies = cookie;
! 67:
! 68: return 0;
! 69: }
! 70:
! 71: /**
! 72: * aim_uncachecookie - grabs a cookie from the cookie cache (removes it from the list)
! 73: *
! 74: * takes a cookie string and a cookie type and finds the cookie struct associated with that duple, removing it from the cookie list ikn the process.
! 75: *
! 76: * @param od session to grab cookie from
! 77: * @param cookie cookie string to look for
! 78: * @param type cookie type to look for
! 79: * @return if found, returns the struct; if none found (or on error), returns NULL:
! 80: */
! 81: IcbmCookie *aim_uncachecookie(OscarData *od, guint8 *cookie, int type)
! 82: {
! 83: IcbmCookie *cur, **prev;
! 84:
! 85: if (!cookie || !od->msgcookies)
! 86: return NULL;
! 87:
! 88: for (prev = &od->msgcookies; (cur = *prev); ) {
! 89: if ((cur->type == type) &&
! 90: (memcmp(cur->cookie, cookie, 8) == 0)) {
! 91: *prev = cur->next;
! 92: return cur;
! 93: }
! 94: prev = &cur->next;
! 95: }
! 96:
! 97: return NULL;
! 98: }
! 99:
! 100: /**
! 101: * aim_mkcookie - generate an IcbmCookie *struct from a cookie string, a type, and a data pointer.
! 102: *
! 103: * @param c pointer to the cookie string array
! 104: * @param type cookie type to use
! 105: * @param data data to be cached with the cookie
! 106: * @return returns NULL on error, a pointer to the newly-allocated
! 107: * cookie on success.
! 108: */
! 109: IcbmCookie *aim_mkcookie(guint8 *c, int type, void *data)
! 110: {
! 111: IcbmCookie *cookie;
! 112:
! 113: if (!c)
! 114: return NULL;
! 115:
! 116: cookie = g_new0(IcbmCookie, 1);
! 117:
! 118: cookie->data = data;
! 119: cookie->type = type;
! 120: memcpy(cookie->cookie, c, 8);
! 121:
! 122: return cookie;
! 123: }
! 124:
! 125: /**
! 126: * aim_checkcookie - check to see if a cookietuple has been cached
! 127: *
! 128: * @param od session to check for the cookie in
! 129: * @param cookie pointer to the cookie string array
! 130: * @param type type of the cookie to look for
! 131: * @return returns a pointer to the cookie struct (still in the list)
! 132: * on success; returns NULL on error/not found
! 133: */
! 134:
! 135: IcbmCookie *aim_checkcookie(OscarData *od, const guint8 *cookie, const int type)
! 136: {
! 137: IcbmCookie *cur;
! 138:
! 139: for (cur = od->msgcookies; cur; cur = cur->next) {
! 140: if ((cur->type == type) &&
! 141: (memcmp(cur->cookie, cookie, 8) == 0))
! 142: return cur;
! 143: }
! 144:
! 145: return NULL;
! 146: }
! 147:
! 148: /**
! 149: * aim_cookie_free - free an IcbmCookie struct
! 150: *
! 151: * this function removes the cookie *cookie from the list of cookies
! 152: * in od, and then frees all memory associated with it. including
! 153: * its data! if you want to use the private data after calling this,
! 154: * make sure you copy it first.
! 155: *
! 156: * @param od session to remove the cookie from
! 157: * @param cookie the address of a pointer to the cookie struct to remove
! 158: * @return returns -1 on error, 0 on success.
! 159: *
! 160: */
! 161: int aim_cookie_free(OscarData *od, IcbmCookie *cookie)
! 162: {
! 163: IcbmCookie *cur, **prev;
! 164:
! 165: if (!od || !cookie)
! 166: return -EINVAL;
! 167:
! 168: for (prev = &od->msgcookies; (cur = *prev); ) {
! 169: if (cur == cookie)
! 170: *prev = cur->next;
! 171: else
! 172: prev = &cur->next;
! 173: }
! 174:
! 175: g_free(cookie->data);
! 176: g_free(cookie);
! 177:
! 178: return 0;
! 179: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>