File:  [Coherent Logic Development] / ChivanetAimPidgin / oscarprpl / src / c / msgcookie.c
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs
Mon Jan 27 19:48:25 2025 UTC (6 months ago) by snw
Branches: MAIN, CoherentLogicDevelopment
CVS tags: test-tag, start, HEAD
Pidgin AIM Plugin for ChivaNet

    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>