Current Path: > > usr > include > bind9 > isc >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
aes.h | File | 1080 bytes | February 20 2025 09:05:24. | |
app.h | File | 10478 bytes | February 20 2025 09:05:24. | |
assertions.h | File | 2907 bytes | February 20 2025 09:05:24. | |
atomic.h | File | 4168 bytes | February 20 2025 09:05:24. | |
backtrace.h | File | 3891 bytes | February 20 2025 09:05:24. | |
base32.h | File | 4453 bytes | February 20 2025 09:05:24. | |
base64.h | File | 2866 bytes | February 20 2025 09:05:24. | |
bind9.h | File | 830 bytes | February 20 2025 09:05:24. | |
boolean.h | File | 594 bytes | February 20 2025 09:05:24. | |
buffer.h | File | 26268 bytes | February 20 2025 09:05:24. | |
bufferlist.h | File | 1452 bytes | February 20 2025 09:05:24. | |
cmocka.h | File | 1383 bytes | February 20 2025 09:05:24. | |
commandline.h | File | 1713 bytes | February 20 2025 09:05:24. | |
condition.h | File | 1478 bytes | February 20 2025 09:05:24. | |
counter.h | File | 1926 bytes | February 20 2025 09:05:24. | |
crc64.h | File | 998 bytes | February 20 2025 09:05:24. | |
deprecated.h | File | 623 bytes | February 20 2025 09:05:24. | |
dir.h | File | 1598 bytes | February 20 2025 09:05:24. | |
endian.h | File | 4778 bytes | February 20 2025 09:05:24. | |
entropy.h | File | 10373 bytes | February 20 2025 09:05:24. | |
errno.h | File | 659 bytes | February 20 2025 09:05:24. | |
errno2result.h | File | 902 bytes | February 20 2025 09:05:37. | |
error.h | File | 1430 bytes | February 20 2025 09:05:24. | |
event.h | File | 3053 bytes | February 20 2025 09:05:24. | |
eventclass.h | File | 1381 bytes | February 20 2025 09:05:24. | |
file.h | File | 11667 bytes | February 20 2025 09:05:24. | |
formatcheck.h | File | 893 bytes | February 20 2025 09:05:24. | |
fsaccess.h | File | 7442 bytes | February 20 2025 09:05:24. | |
hash.h | File | 7662 bytes | February 20 2025 09:05:24. | |
heap.h | File | 5264 bytes | February 20 2025 09:05:24. | |
hex.h | File | 2806 bytes | February 20 2025 09:05:24. | |
hmacmd5.h | File | 1787 bytes | February 20 2025 09:05:24. | |
hmacsha.h | File | 4511 bytes | February 20 2025 09:05:24. | |
ht.h | File | 4396 bytes | February 20 2025 09:05:24. | |
httpd.h | File | 2318 bytes | February 20 2025 09:05:24. | |
int.h | File | 1088 bytes | February 20 2025 09:05:24. | |
interfaceiter.h | File | 3120 bytes | February 20 2025 09:05:24. | |
iterated_hash.h | File | 1046 bytes | February 20 2025 09:05:24. | |
json.h | File | 1459 bytes | February 20 2025 09:05:24. | |
keyboard.h | File | 989 bytes | February 20 2025 09:05:24. | |
lang.h | File | 637 bytes | February 20 2025 09:05:24. | |
lex.h | File | 9771 bytes | February 20 2025 09:05:24. | |
lfsr.h | File | 2958 bytes | February 20 2025 09:05:24. | |
lib.h | File | 1068 bytes | February 20 2025 09:05:24. | |
likely.h | File | 818 bytes | February 20 2025 09:05:24. | |
list.h | File | 5751 bytes | February 20 2025 09:05:24. | |
log.h | File | 28734 bytes | February 20 2025 09:05:24. | |
magic.h | File | 994 bytes | February 20 2025 09:05:24. | |
md5.h | File | 2380 bytes | February 20 2025 09:05:24. | |
mem.h | File | 21110 bytes | February 20 2025 09:05:24. | |
meminfo.h | File | 710 bytes | February 20 2025 09:05:24. | |
msgcat.h | File | 2726 bytes | February 20 2025 09:05:24. | |
msgs.h | File | 8422 bytes | February 20 2025 09:05:24. | |
mutex.h | File | 3524 bytes | February 20 2025 09:05:24. | |
mutexblock.h | File | 1375 bytes | February 20 2025 09:05:24. | |
net.h | File | 10534 bytes | February 20 2025 09:05:24. | |
netaddr.h | File | 4590 bytes | February 20 2025 09:05:24. | |
netdb.h | File | 863 bytes | February 20 2025 09:05:24. | |
netscope.h | File | 967 bytes | February 20 2025 09:05:24. | |
offset.h | File | 700 bytes | February 20 2025 09:05:24. | |
once.h | File | 983 bytes | February 20 2025 09:05:24. | |
ondestroy.h | File | 2799 bytes | February 20 2025 09:05:24. | |
os.h | File | 671 bytes | February 20 2025 09:05:24. | |
parseint.h | File | 1542 bytes | February 20 2025 09:05:24. | |
platform.h | File | 9717 bytes | February 20 2025 09:05:24. | |
pool.h | File | 3502 bytes | February 20 2025 09:05:24. | |
portset.h | File | 3295 bytes | February 20 2025 09:05:24. | |
print.h | File | 2475 bytes | February 20 2025 09:05:24. | |
queue.h | File | 5204 bytes | February 20 2025 09:05:24. | |
quota.h | File | 2440 bytes | February 20 2025 09:05:24. | |
radix.h | File | 6491 bytes | February 20 2025 09:05:24. | |
random.h | File | 3582 bytes | February 20 2025 09:05:24. | |
ratelimiter.h | File | 3497 bytes | February 20 2025 09:05:24. | |
refcount.h | File | 8193 bytes | February 20 2025 09:05:24. | |
regex.h | File | 767 bytes | February 20 2025 09:05:24. | |
region.h | File | 2034 bytes | February 20 2025 09:05:24. | |
resource.h | File | 2862 bytes | February 20 2025 09:05:24. | |
result.h | File | 4982 bytes | February 20 2025 09:05:24. | |
resultclass.h | File | 1599 bytes | February 20 2025 09:05:24. | |
rwlock.h | File | 3807 bytes | February 20 2025 09:05:24. | |
safe.h | File | 1352 bytes | February 20 2025 09:05:24. | |
serial.h | File | 1368 bytes | February 20 2025 09:05:24. | |
sha1.h | File | 1556 bytes | February 20 2025 09:05:24. | |
sha2.h | File | 5733 bytes | February 20 2025 09:05:24. | |
siphash.h | File | 734 bytes | February 20 2025 09:05:24. | |
sockaddr.h | File | 6039 bytes | February 20 2025 09:05:24. | |
socket.h | File | 36655 bytes | February 20 2025 09:05:24. | |
stat.h | File | 806 bytes | February 20 2025 09:05:24. | |
stats.h | File | 3709 bytes | February 20 2025 09:05:24. | |
stdatomic.h | File | 5250 bytes | February 20 2025 09:05:24. | |
stdio.h | File | 1787 bytes | February 20 2025 09:05:24. | |
stdlib.h | File | 704 bytes | February 20 2025 09:05:24. | |
stdtime.h | File | 1065 bytes | February 20 2025 09:05:24. | |
strerror.h | File | 777 bytes | February 20 2025 09:05:24. | |
string.h | File | 6019 bytes | February 20 2025 09:05:24. | |
symtab.h | File | 4326 bytes | February 20 2025 09:05:24. | |
syslog.h | File | 844 bytes | February 20 2025 09:05:24. | |
task.h | File | 21544 bytes | February 20 2025 09:05:24. | |
taskpool.h | File | 3709 bytes | February 20 2025 09:05:24. | |
thread.h | File | 1506 bytes | February 20 2025 09:05:24. | |
time.h | File | 8876 bytes | February 20 2025 09:05:24. | |
timer.h | File | 10795 bytes | February 20 2025 09:05:24. | |
tm.h | File | 895 bytes | February 20 2025 09:05:24. | |
types.h | File | 5780 bytes | February 20 2025 09:05:24. | |
utf8.h | File | 928 bytes | February 20 2025 09:05:24. | |
util.h | File | 10537 bytes | February 20 2025 09:05:24. | |
version.h | File | 689 bytes | February 20 2025 09:05:24. | |
xml.h | File | 1094 bytes | February 20 2025 09:05:24. |
/* * Copyright (C) Internet Systems Consortium, Inc. ("ISC") * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, you can obtain one at https://mozilla.org/MPL/2.0/. * * See the COPYRIGHT file distributed with this work for additional * information regarding copyright ownership. */ #ifndef ISC_HASH_H #define ISC_HASH_H 1 #include <stdbool.h> #include <isc/deprecated.h> #include <isc/types.h> /***** ***** Module Info *****/ /*! \file isc/hash.h * * \brief The hash API * provides an unpredictable hash value for variable length data. * A hash object contains a random vector (which is hidden from clients * of this API) to make the actual hash value unpredictable. * * The algorithm used in the API guarantees the probability of hash * collision; in the current implementation, as long as the values stored * in the random vector are unpredictable, the probability of hash * collision between arbitrary two different values is at most 1/2^16. * * Although the API is generic about the hash keys, it mainly expects * DNS names (and sometimes IPv4/v6 addresses) as inputs. It has an * upper limit of the input length, and may run slow to calculate the * hash values for large inputs. * * This API is designed to be general so that it can provide multiple * different hash contexts that have different random vectors. However, * it should be typical to have a single context for an entire system. * To support such cases, the API also provides a single-context mode. * * \li MP: * The hash object is almost read-only. Once the internal random vector * is initialized, no write operation will occur, and there will be no * need to lock the object to calculate actual hash values. * * \li Reliability: * In some cases this module uses low-level data copy to initialize the * random vector. Errors in this part are likely to crash the server or * corrupt memory. * * \li Resources: * A buffer, used as a random vector for calculating hash values. * * \li Security: * This module intends to provide unpredictable hash values in * adversarial environments in order to avoid denial of service attacks * to hash buckets. * Its unpredictability relies on the quality of entropy to build the * random vector. * * \li Standards: * None. */ /*** *** Imports ***/ #include <isc/types.h> /*** *** Functions ***/ ISC_LANG_BEGINDECLS LIBISC_EXTERNAL_DATA extern isc_hash_t *isc_hashctx; isc_result_t isc_hash_ctxcreate(isc_mem_t *mctx, isc_entropy_t *entropy, size_t limit, isc_hash_t **hctx); isc_result_t isc_hash_create(isc_mem_t *mctx, isc_entropy_t *entropy, size_t limit); /*!< * \brief Create a new hash object. * * isc_hash_ctxcreate() creates a different object. * * isc_hash_create() creates a module-internal object to support the * single-context mode. It should be called only once. * * 'entropy' must be NULL or a valid entropy object. If 'entropy' is NULL, * pseudo random values will be used to build the random vector, which may * weaken security. * * 'limit' specifies the maximum number of hash keys. If it is too large, * these functions may fail. */ void isc_hash_ctxattach(isc_hash_t *hctx, isc_hash_t **hctxp) ISC_DEPRECATED; /*!< * \brief Attach to a hash object. * * This function is only necessary for the multiple-context mode. */ void isc_hash_ctxdetach(isc_hash_t **hctxp) ISC_DEPRECATED; /*!< * \brief Detach from a hash object. * * This function is for the multiple-context mode, and takes a valid * hash object as an argument. */ void isc_hash_destroy(void); /*!< * \brief This function is for the single-context mode, and is expected to be used * as a counterpart of isc_hash_create(). * * A valid module-internal hash object must have been created, and this * function should be called only once. */ /*@{*/ void isc_hash_ctxinit(isc_hash_t *hctx); void isc_hash_init(void); /*!< * \brief Initialize a hash object. * * It fills in the random vector with a proper * source of entropy, which is typically from the entropy object specified * at the creation. Thus, it is desirable to call these functions after * initializing the entropy object with some good entropy sources. * * These functions should be called before the first hash calculation. * * isc_hash_ctxinit() is for the multiple-context mode, and takes a valid hash * object as an argument. * * isc_hash_init() is for the single-context mode. A valid module-internal * hash object must have been created, and this function should be called only * once. */ /*@}*/ /*@{*/ unsigned int isc_hash_ctxcalc(isc_hash_t *hctx, const unsigned char *key, unsigned int keylen, bool case_sensitive) ISC_DEPRECATED; unsigned int isc_hash_calc(const unsigned char *key, unsigned int keylen, bool case_sensitive) ISC_DEPRECATED; /*!< * \brief Calculate a hash value. * * isc_hash_ctxinit() is for the multiple-context mode, and takes a valid hash * object as an argument. * * isc_hash_init() is for the single-context mode. A valid module-internal * hash object must have been created. * * 'key' is the hash key, which is a variable length buffer. * * 'keylen' specifies the key length, which must not be larger than the limit * specified for the corresponding hash object. * * 'case_sensitive' specifies whether the hash key should be treated as * case_sensitive values. It should typically be false if the hash key * is a DNS name. */ /*@}*/ void isc__hash_setvec(const uint16_t *vec) ISC_DEPRECATED; /*!< * \brief Set the contents of the random vector used in hashing. * * WARNING: This function is meant to be used only in testing code. It * must not be used anywhere in normally running code. * * The hash context must have been created beforehand, otherwise this * function is a nop. * * 'vec' is not documented here on purpose. You should know what you are * doing before using this function. */ const void * isc_hash_get_initializer(void); void isc_hash_set_initializer(const void *initializer); uint32_t isc_hash_function(const void *data, size_t length, bool case_sensitive, const uint32_t *previous_hashp); uint32_t isc_hash_function_reverse(const void *data, size_t length, bool case_sensitive, const uint32_t *previous_hashp); /*!< * \brief Calculate a hash over data. * * This hash function is useful for hashtables. The hash function is * opaque and not important to the caller. The returned hash values are * non-deterministic and will have different mapping every time a * process using this library is run, but will have uniform * distribution. * * isc_hash_function() calculates the hash from start to end over the * input data. isc_hash_function_reverse() calculates the hash from the * end to the start over the input data. The difference in order is * useful in incremental hashing; for example, a previously hashed * value for 'com' can be used as input when hashing 'example.com'. * * This is a new variant of isc_hash_calc() and will supersede * isc_hash_calc() eventually. * * 'data' is the data to be hashed. * * 'length' is the size of the data to be hashed. * * 'case_sensitive' specifies whether the hash key should be treated as * case_sensitive values. It should typically be false if the hash key * is a DNS name. * * 'previous_hashp' is a pointer to a previous hash value returned by * this function. It can be used to perform incremental hashing. NULL * must be passed during first calls. */ ISC_LANG_ENDDECLS #endif /* ISC_HASH_H */
SILENT KILLER Tool