*/
+
/*
* Attach an OpenID to a Citadel account
*/
* When a user is being deleted, we have to delete any OpenID associations
*/
void openid_purge(struct ctdluser *usbuf) {
- /* FIXME finish this */
+ struct cdbdata *cdboi;
+ HashList *keys = NULL;
+ HashPos *HashPos;
+ char *deleteme = NULL;
+ long len;
+ void *Value;
+ char *Key;
+
+ keys = NewHash(1, NULL);
+ if (!keys) return;
+
+
+ cdb_rewind(CDB_OPENID);
+ while (cdboi = cdb_next_item(CDB_OPENID), cdboi != NULL) {
+ if (cdboi->len > sizeof(long)) {
+ if (((long)*(cdboi->ptr)) == usbuf->usernum) {
+ deleteme = strdup(cdboi->ptr + sizeof(long)),
+ Put(keys, deleteme, strlen(deleteme), deleteme, generic_free_handler);
+ }
+ }
+ cdb_free(cdboi);
+ }
+
+ /* Go through the hash list, deleting keys we stored in it */
+
+ HashPos = GetNewHashPos();
+ while (GetNextHashPos(keys, HashPos, &len, &Key, &Value)!=0)
+ {
+ CtdlLogPrintf(CTDL_DEBUG, "Deleting associated OpenID <%s>\n", Value);
+ cdb_delete(CDB_OPENID, Value, strlen(Value));
+ /* note: don't free(Value) -- deleting the hash list will handle this for us */
+ }
+ DeleteHashPos(&HashPos);
+ DeleteHash(&keys);
}
cprintf("%s\n", cdboi->ptr + sizeof(long));
}
}
+ cdb_free(cdboi);
}
cprintf("000\n");
}
this_is_mine = 1;
}
}
+ cdb_free(cdboi);
}
if (!this_is_mine) {
-/*
- * Callback function to free a pointer (used below in the hash list)
- */
-void free_oid_key(void *ptr) {
- free(ptr);
-}
/*
extract_token(thiskey, buf, 0, '|', sizeof thiskey);
extract_token(thisdata, buf, 1, '|', sizeof thisdata);
CtdlLogPrintf(CTDL_DEBUG, "%s: [%d] %s\n", thiskey, strlen(thisdata), thisdata);
- Put(keys, thiskey, strlen(thiskey), strdup(thisdata), free_oid_key);
+ Put(keys, thiskey, strlen(thiskey), strdup(thisdata), generic_free_handler);
}
free(Value);
}
DeleteHashPos(&HashPos);
+ DeleteHash(&keys);
}