X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Fgns%2Fgnunet-service-gns_resolver.h;h=d4cbd08f86deaf0b6590c7a5e9ff3be504cc43a0;hb=4df7069dcd17ac39c786ee6f21455c96e6a6dbf4;hp=4f857825cd2c25ebd556c3e3a681549aff4f1625;hpb=34243a1a0c04ef5723a327124f96e2571ac5fd2e;p=oweals%2Fgnunet.git diff --git a/src/gns/gnunet-service-gns_resolver.h b/src/gns/gnunet-service-gns_resolver.h index 4f857825c..d4cbd08f8 100644 --- a/src/gns/gnunet-service-gns_resolver.h +++ b/src/gns/gnunet-service-gns_resolver.h @@ -1,286 +1,101 @@ +/* + This file is part of GNUnet. + Copyright (C) 2009-2013 GNUnet e.V. + + GNUnet is free software: you can redistribute it and/or modify it + under the terms of the GNU Affero General Public License as published + by the Free Software Foundation, either version 3 of the License, + or (at your option) any later version. + + GNUnet is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . +*/ +/** + * @file gns/gnunet-service-gns_resolver.h + * @brief GNUnet GNS service + * @author Martin Schanzenbach + */ #ifndef GNS_RESOLVER_H #define GNS_RESOLVER_H - #include "gns.h" #include "gnunet_dht_service.h" - -#define DHT_OPERATION_TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 3) -#define DHT_LOOKUP_TIMEOUT DHT_OPERATION_TIMEOUT -#define DHT_GNS_REPLICATION_LEVEL 5 - -/* - * DLL to hold the authority chain - * we had to pass in the resolution process - */ -struct AuthorityChain -{ - struct AuthorityChain *prev; - - struct AuthorityChain *next; - - /* the zone hash of the authority */ - GNUNET_HashCode zone; - - /* (local) name of the authority */ - char name[MAX_DNS_LABEL_LENGTH]; - - /* was the ns entry fresh */ - int fresh; -}; - -/* handle to a resolution process */ -struct ResolverHandle; - - -/** - * processor for a resultion result - * - * @param cls the closure - * @param rh the resolution handle - * @param rd_count number of results - * @pram rd resukt data - */ -typedef void (*RecordLookupProcessor) (void *cls, - uint32_t rd_count, - const struct GNUNET_NAMESTORE_RecordData *rd); - +#include "gnunet_gns_service.h" +#include "gnunet_namecache_service.h" /** - * processor for a shorten result + * Initialize the resolver subsystem. + * MUST be called before #GNS_resolver_lookup. * - * @param cls the closure - * @param name shortened name - */ -typedef void (*ShortenResultProcessor) (void *cls, const char* name); - - -/** - * processor for an authority result - * - * @param cls the closure - * @param name name - */ -typedef void (*GetAuthorityResultProcessor) (void *cls, const char* name); - -/** - * processor for a resultion result - * - * @param cls the closure - * @param rh the resolution handle - * @param rd_count number of results - * @param rd result data - */ -typedef void (*ResolutionResultProcessor) (void *cls, - struct ResolverHandle *rh, - uint32_t rd_count, - const struct GNUNET_NAMESTORE_RecordData *rd); - - -/** - * Resoltion status indicator - * EXISTS: the name to lookup exists - * EXPIRED: the name in the record expired - */ -enum ResolutionStatus -{ - EXISTS = 1, - EXPIRED = 2 -}; - -/** - * Handle to a currenty pending resolution - */ -struct ResolverHandle -{ - /* The name to resolve */ - char name[MAX_DNS_NAME_LENGTH]; - - /* has this query been answered? how many matches */ - int answered; - - /* the authoritative zone to query */ - GNUNET_HashCode authority; - - /* the name of the authoritative zone to query */ - char authority_name[MAX_DNS_LABEL_LENGTH]; - - /** - * we have an authority in namestore that - * may be able to resolve - */ - int authority_found; - - /* a handle for dht lookups. should be NULL if no lookups are in progress */ - struct GNUNET_DHT_GetHandle *get_handle; - - /* timeout task for dht lookups */ - GNUNET_SCHEDULER_TaskIdentifier dht_timeout_task; - - /* called when resolution phase finishes */ - ResolutionResultProcessor proc; - - /* closure passed to proc */ - void* proc_cls; - - /* DLL to store the authority chain */ - struct AuthorityChain *authority_chain_head; - - /* DLL to store the authority chain */ - struct AuthorityChain *authority_chain_tail; - - /* status of the resolution result */ - enum ResolutionStatus status; - - struct GNUNET_CRYPTO_RsaPrivateKey *priv_key; - -}; - - -/** - * Handle to a record lookup + * @param nc the namecache handle + * @param dht handle to the dht + * @param c configuration handle + * @param max_bg_queries maximum amount of background queries */ -struct RecordLookupHandle -{ - /* the record type to look up */ - enum GNUNET_GNS_RecordType record_type; - - /* the name to look up */ - char name[MAX_DNS_NAME_LENGTH]; - - /* Method to call on record resolution result */ - RecordLookupProcessor proc; - - /* closure to pass to proc */ - void* proc_cls; - -}; - - -/** - * Handle to a shorten context - */ -struct NameShortenHandle -{ - - - /* Method to call on shorten result */ - ShortenResultProcessor proc; - - /* closure to pass to proc */ - void* proc_cls; +void +GNS_resolver_init (struct GNUNET_NAMECACHE_Handle *nc, + struct GNUNET_DHT_Handle *dht, + const struct GNUNET_CONFIGURATION_Handle *c, + unsigned long long max_bg_queries); -}; /** - * Handle to a get authority context + * Cleanup resolver: Terminate pending lookups */ -struct GetNameAuthorityHandle -{ - - /* the name to look up authority for */ - char name[MAX_DNS_NAME_LENGTH]; - - /* Method to call on result */ - GetAuthorityResultProcessor proc; - - /* closure to pass to proc */ - void* proc_cls; +void +GNS_resolver_done (void); -}; /** - * Handle to a pseu lookup + * Handle for an active request. */ -struct GetPseuAuthorityHandle -{ - /* the name given from delegation */ - char name[MAX_DNS_LABEL_LENGTH]; - - /* name to store the pseu under */ - char new_name[MAX_DNS_LABEL_LENGTH]; - - /* the zone of discovered authority */ - GNUNET_HashCode new_zone; +struct GNS_ResolverHandle; - /* the zone of our authority */ - GNUNET_HashCode zone; - - /* the private key of the zone to store the pseu in */ - struct GNUNET_CRYPTO_RsaPrivateKey *key; - - /* a handle for dht lookups. should be NULL if no lookups are in progress */ - struct GNUNET_DHT_GetHandle *get_handle; - - /* timeout task for dht lookups */ - GNUNET_SCHEDULER_TaskIdentifier dht_timeout; -}; /** - * Initialize the resolver + * Function called with results for a GNS resolution. * - * @param nh handle to the namestore - * @param dh handle to the dht - * @returns GNUNET_OK on success + * @param cls closure + * @param rd_count number of records in @a rd + * @param rd records returned for the lookup */ -int -gns_resolver_init(struct GNUNET_NAMESTORE_Handle *nh, - struct GNUNET_DHT_Handle *dh); +typedef void +(*GNS_ResultProcessor)(void *cls, + uint32_t rd_count, + const struct GNUNET_GNSRECORD_Data *rd); + /** * Lookup of a record in a specific zone - * calls lookup result processor on result + * calls RecordLookupProcessor on result or timeout * - * @param zone the root zone + * @param zone the zone to perform the lookup in * @param record_type the record type to look up * @param name the name to look up - * @param key optional private key for authority caching + * @param options options set to control local lookup * @param proc the processor to call - * @param cls the closure to pass to proc + * @param proc_cls the closure to pass to @a proc + * @return handle to cancel operation */ -void -gns_resolver_lookup_record(GNUNET_HashCode zone, - uint32_t record_type, - const char* name, - struct GNUNET_CRYPTO_RsaPrivateKey *key, - RecordLookupProcessor proc, - void* cls); +struct GNS_ResolverHandle * +GNS_resolver_lookup (const struct GNUNET_CRYPTO_EcdsaPublicKey *zone, + uint32_t record_type, + const char *name, + enum GNUNET_GNS_LocalOptions options, + GNS_ResultProcessor proc, + void *proc_cls); -void -gns_resolver_shorten_name(GNUNET_HashCode zone, - const char* name, - ShortenResultProcessor proc, - void* cls); /** - * Tries to resolve the authority for name - * in our namestore + * Cancel active resolution (i.e. client disconnected). * - * @param zone the root zone to look up for - * @param name the name to lookup up - * @param proc the processor to call when finished - * @param cls the closure to pass to the processor + * @param rh resolution to abort */ void -gns_resolver_get_authority(GNUNET_HashCode zone, - const char* name, - GetAuthorityResultProcessor proc, - void* cls); - -/** - * Generic function to check for TLDs - * - * @param name the name to check - * @param tld the tld to check - * @return GNUNET_YES or GNUNET_NO - */ -int -is_tld(const char* name, const char* tld); - -/** - * Checks for gnunet/zkey - */ -#define is_gnunet_tld(name) is_tld(name, GNUNET_GNS_TLD) -#define is_zkey_tld(name) is_tld(name, GNUNET_GNS_TLD_ZKEY) - +GNS_resolver_lookup_cancel (struct GNS_ResolverHandle *rh); #endif