summaryrefslogtreecommitdiff
path: root/lib/radsecproxy/hash.h
diff options
context:
space:
mode:
authorLinus Nordberg <linus@nordberg.se>2013-01-22 11:01:59 +0100
committerLinus Nordberg <linus@nordberg.se>2013-01-22 11:39:52 +0100
commit95c4d4a42f2b4457c64a87c45c7c170dfba6a7c4 (patch)
tree2db13956be8e5c2152b2b472185e295938fc347d /lib/radsecproxy/hash.h
parent0be487506195d069c468fa71c32dc2cd50450363 (diff)
Revive radsecproxy.h and hostport_types.h and move rsp_* into radsecproxy/.
Diffstat (limited to 'lib/radsecproxy/hash.h')
-rw-r--r--lib/radsecproxy/hash.h51
1 files changed, 51 insertions, 0 deletions
diff --git a/lib/radsecproxy/hash.h b/lib/radsecproxy/hash.h
new file mode 100644
index 0000000..90ba64b
--- /dev/null
+++ b/lib/radsecproxy/hash.h
@@ -0,0 +1,51 @@
+/* Copyright (c) 2008, UNINETT AS */
+/* See LICENSE for licensing information. */
+
+#ifndef SYS_SOLARIS9
+#include <stdint.h>
+#endif
+
+#if defined (__cplusplus)
+extern "C" {
+#endif
+
+struct hash {
+ struct list *hashlist;
+ pthread_mutex_t mutex;
+};
+
+struct hash_entry {
+ void *key;
+ uint32_t keylen;
+ void *data;
+ struct list_node *next; /* used when walking through hash */
+};
+
+/* allocates and initialises hash structure; returns NULL if malloc fails */
+struct hash *hash_create();
+
+/* frees all memory associated with the hash */
+void hash_destroy(struct hash *hash);
+
+/* insert entry in hash; returns 1 if ok, 0 if malloc fails */
+int hash_insert(struct hash *hash, void *key, uint32_t keylen, void *data);
+
+/* reads entry from hash */
+void *hash_read(struct hash *hash, void *key, uint32_t keylen);
+
+/* extracts (read and remove) entry from hash */
+void *hash_extract(struct hash *hash, void *key, uint32_t keylen);
+
+/* returns first entry */
+struct hash_entry *hash_first(struct hash *hash);
+
+/* returns the next entry after the argument */
+struct hash_entry *hash_next(struct hash_entry *entry);
+
+#if defined (__cplusplus)
+}
+#endif
+
+/* Local Variables: */
+/* c-file-style: "stroustrup" */
+/* End: */