X-Git-Url: http://git.openwrt.org/?a=blobdiff_plain;f=cache.h;h=10859a593a735611aac72ec5c9035075bb2d1024;hb=9f1cc226e4be47d32e4df796c94cbee1437960aa;hp=df3593f3df55fd9363f6b85b564d3723cbbbe788;hpb=5bdbcd785b0a08e866631a6a062ea9ced1f6dce8;p=project%2Fmdnsd.git diff --git a/cache.h b/cache.h index df3593f..10859a5 100644 --- a/cache.h +++ b/cache.h @@ -19,14 +19,17 @@ #include #include "dns.h" +#include "interface.h" -struct cache_entry { +struct cache_service { struct avl_node avl; const char *entry; const char *host; uint32_t ttl; time_t time; + struct interface *iface; + int refresh; }; struct cache_record { @@ -40,17 +43,20 @@ struct cache_record { const uint8_t *rdata; uint16_t rdlength; time_t time; + struct interface *iface; + int refresh; }; -extern struct avl_tree entries; +extern struct avl_tree services; +extern struct avl_tree records; int cache_init(void); -void cache_scan(void); -void cache_cleanup(void); +void cache_update(void); +void cache_cleanup(struct interface *iface); void cache_answer(struct interface *iface, uint8_t *base, int blen, char *name, struct dns_answer *a, uint8_t *rdata, int flush); int cache_host_is_known(char *record); -char *cache_lookup_name(const char *key); void cache_dump_records(struct blob_buf *buf, const char *name); +void cache_dump_recursive(struct blob_buf *b, const char *name, uint16_t type, struct interface *iface); #endif