32#if defined (FAILOVER_PROTOCOL)
43 { 0,
"unused", FT_UNDEF, 0, 0, 0 },
44 { FTO_ADDRESSES_TRANSFERRED,
"addresses-transferred", FT_UINT32, 1,
45 FM_OFFSET(addresses_transferred), FTB_ADDRESSES_TRANSFERRED },
46 { FTO_ASSIGNED_IP_ADDRESS,
"assigned-IP-address", FT_IPADDR, 1,
47 FM_OFFSET(assigned_addr), FTB_ASSIGNED_IP_ADDRESS },
48 { FTO_BINDING_STATUS,
"binding-status", FT_UINT8, 1,
49 FM_OFFSET(binding_status), FTB_BINDING_STATUS },
50 { FTO_CLIENT_IDENTIFIER,
"client-identifier", FT_BYTES, 0,
51 FM_OFFSET(client_identifier), FTB_CLIENT_IDENTIFIER },
52 { FTO_CHADDR,
"client-hardware-address", FT_BYTES, 0,
53 FM_OFFSET(chaddr), FTB_CHADDR },
54 { FTO_CLTT,
"client-last-transaction-time", FT_UINT32, 1,
55 FM_OFFSET(cltt), FTB_CLTT },
56 { FTO_REPLY_OPTIONS,
"client-reply-options", FT_BYTES, 0,
57 FM_OFFSET(reply_options), FTB_REPLY_OPTIONS },
58 { FTO_REQUEST_OPTIONS,
"client-request-options", FT_BYTES, 0,
59 FM_OFFSET(request_options), FTB_REQUEST_OPTIONS },
60 { FTO_DDNS,
"DDNS", FT_DDNS, 1, FM_OFFSET(ddns), FTB_DDNS },
61 { FTO_DELAYED_SERVICE,
"delayed-service", FT_UINT8, 1,
62 FM_OFFSET(delayed_service), FTB_DELAYED_SERVICE },
63 { FTO_HBA,
"hash-bucket-assignment", FT_BYTES, 0,
64 FM_OFFSET(hba), FTB_HBA },
65 { FTO_IP_FLAGS,
"IP-flags", FT_UINT16, 1,
66 FM_OFFSET(ip_flags), FTB_IP_FLAGS },
67 { FTO_LEASE_EXPIRY,
"lease-expiration-time", FT_UINT32, 1,
68 FM_OFFSET(expiry), FTB_LEASE_EXPIRY },
69 { FTO_MAX_UNACKED,
"max-unacked-bndupd", FT_UINT32, 1,
70 FM_OFFSET(max_unacked), FTB_MAX_UNACKED },
71 { FTO_MCLT,
"MCLT", FT_UINT32, 1, FM_OFFSET(mclt), FTB_MCLT },
72 { FTO_MESSAGE,
"message", FT_TEXT, 0,
73 FM_OFFSET(message), FTB_MESSAGE },
74 { FTO_MESSAGE_DIGEST,
"message-digest", FT_BYTES, 0,
75 FM_OFFSET(message_digest), FTB_MESSAGE_DIGEST },
76 { FTO_POTENTIAL_EXPIRY,
"potential-expiration-time", FT_UINT32, 1,
77 FM_OFFSET(potential_expiry), FTB_POTENTIAL_EXPIRY },
78 { FTO_RECEIVE_TIMER,
"receive-timer", FT_UINT32, 1,
79 FM_OFFSET(receive_timer), FTB_RECEIVE_TIMER },
80 { FTO_PROTOCOL_VERSION,
"protocol-version", FT_UINT8, 1,
81 FM_OFFSET(protocol_version), FTB_PROTOCOL_VERSION },
82 { FTO_REJECT_REASON,
"reject-reason", FT_UINT8, 1,
83 FM_OFFSET(reject_reason), FTB_REJECT_REASON },
84 { FTO_RELATIONSHIP_NAME,
"relationship-name", FT_BYTES, 0,
85 FM_OFFSET(relationship_name), FTB_RELATIONSHIP_NAME },
86 { FTO_SERVER_FLAGS,
"server-flags", FT_UINT8, 1,
87 FM_OFFSET(server_flags), FTB_SERVER_FLAGS },
88 { FTO_SERVER_STATE,
"server-state", FT_UINT8, 1,
89 FM_OFFSET(server_state), FTB_SERVER_STATE },
90 { FTO_STOS,
"start-time-of-state", FT_UINT32, 1,
91 FM_OFFSET(stos), FTB_STOS },
92 { FTO_TLS_REPLY,
"TLS-reply", FT_UINT8, 1,
93 FM_OFFSET(tls_reply), FTB_TLS_REPLY },
94 { FTO_TLS_REQUEST,
"TLS-request", FT_UINT8, 1,
95 FM_OFFSET(tls_request), FTB_TLS_REQUEST },
96 { FTO_VENDOR_CLASS,
"vendor-class-identifier", FT_BYTES, 0,
97 FM_OFFSET(vendor_class), FTB_VENDOR_CLASS },
98 { FTO_VENDOR_OPTIONS,
"vendor-specific-options", FT_BYTES, 0,
99 FM_OFFSET(vendor_options), FTB_VENDOR_OPTIONS }
111 FTB_ADDRESSES_TRANSFERRED,
112 (FTB_ASSIGNED_IP_ADDRESS | FTB_BINDING_STATUS | FTB_CLIENT_IDENTIFIER |
113 FTB_CHADDR | FTB_DDNS | FTB_IP_FLAGS | FTB_LEASE_EXPIRY |
114 FTB_POTENTIAL_EXPIRY | FTB_STOS | FTB_CLTT | FTB_REQUEST_OPTIONS |
116 (FTB_ASSIGNED_IP_ADDRESS | FTB_BINDING_STATUS | FTB_CLIENT_IDENTIFIER |
117 FTB_CHADDR | FTB_DDNS | FTB_IP_FLAGS | FTB_LEASE_EXPIRY |
118 FTB_POTENTIAL_EXPIRY | FTB_STOS | FTB_CLTT | FTB_REQUEST_OPTIONS |
119 FTB_REPLY_OPTIONS | FTB_REJECT_REASON | FTB_MESSAGE),
120 (FTB_RELATIONSHIP_NAME | FTB_MAX_UNACKED | FTB_RECEIVE_TIMER |
121 FTB_VENDOR_CLASS | FTB_PROTOCOL_VERSION | FTB_TLS_REQUEST |
123 (FTB_RELATIONSHIP_NAME | FTB_MAX_UNACKED | FTB_RECEIVE_TIMER |
124 FTB_VENDOR_CLASS | FTB_PROTOCOL_VERSION | FTB_TLS_REPLY |
125 FTB_REJECT_REASON | FTB_MESSAGE),
129 (FTB_SERVER_STATE | FTB_SERVER_FLAGS | FTB_STOS),
131 (FTB_REJECT_REASON | FTB_MESSAGE)
153 "message length wait",
162 "free",
"active",
"expired",
"released",
"abandoned",
173 { NULL, NULL, NULL, 0, 0 }
177static struct option server_options[] = {
190 {
"use-lease-addr-for-default-route",
"f",
222 {
"log-facility",
"Nsyslog-facilities.",
238#if defined(DELAYED_ACK)
242#if defined(LDAP_CONFIGURATION)
252#if defined(LDAP_USE_SSL)
259 {
"ldap-tls-crlcheck",
"Nldap-tls-crlcheck.", &
server_universe, 75, 1 },
264#if defined(LDAP_USE_GSSAPI)
265 {
"ldap-gssapi-keytab",
"t", &
server_universe, SV_LDAP_GSSAPI_KEYTAB, 1},
266 {
"ldap-gssapi-principal",
"t", &
server_universe, SV_LDAP_GSSAPI_PRINCIPAL, 1},
283 {
"persist-eui-64-leases",
"f", &
server_universe, SV_PERSIST_EUI_64_LEASES, 1 },
285#if defined (FAILOVER_PROTOCOL)
296 { NULL, NULL, NULL, 0, 0 }
299#if defined(LDAP_CONFIGURATION)
301 {
"static", LDAP_METHOD_STATIC },
302 {
"dynamic", LDAP_METHOD_DYNAMIC },
312#if defined(LDAP_USE_SSL)
314 {
"off", LDAP_SSL_OFF },
315 {
"on",LDAP_SSL_ON },
316 {
"ldaps", LDAP_SSL_LDAPS },
317 {
"start_tls", LDAP_SSL_TLS },
324 ldap_ssl_usage_values
328 {
"never", LDAP_OPT_X_TLS_NEVER },
329 {
"hard", LDAP_OPT_X_TLS_HARD },
330 {
"demand", LDAP_OPT_X_TLS_DEMAND},
331 {
"allow", LDAP_OPT_X_TLS_ALLOW },
332 {
"try", LDAP_OPT_X_TLS_TRY },
337 "ldap-tls-reqcert", 1,
338 ldap_tls_reqcert_values
342 {
"none", LDAP_OPT_X_TLS_CRL_NONE},
343 {
"peer", LDAP_OPT_X_TLS_CRL_PEER},
344 {
"all", LDAP_OPT_X_TLS_CRL_ALL },
349 "ldap-tls-crlcheck", 1,
350 ldap_tls_crlcheck_values
380 "prefix_length_modes", 1,
385#if defined (LOG_KERN)
386 {
"kern", LOG_KERN },
388#if defined (LOG_USER)
389 {
"user", LOG_USER },
391#if defined (LOG_MAIL)
392 {
"mail", LOG_MAIL },
394#if defined (LOG_DAEMON)
395 {
"daemon", LOG_DAEMON },
397#if defined (LOG_AUTH)
398 {
"auth", LOG_AUTH },
400#if defined (LOG_SYSLOG)
401 {
"syslog", LOG_SYSLOG },
406#if defined (LOG_NEWS)
407 {
"news", LOG_NEWS },
409#if defined (LOG_UUCP)
410 {
"uucp", LOG_UUCP },
412#if defined (LOG_CRON)
413 {
"cron", LOG_CRON },
415#if defined (LOG_AUTHPRIV)
416 {
"authpriv", LOG_AUTHPRIV },
421#if defined (LOG_LOCAL0)
422 {
"local0", LOG_LOCAL0 },
424#if defined (LOG_LOCAL1)
425 {
"local1", LOG_LOCAL1 },
427#if defined (LOG_LOCAL2)
428 {
"local2", LOG_LOCAL2 },
430#if defined (LOG_LOCAL3)
431 {
"local3", LOG_LOCAL3 },
433#if defined (LOG_LOCAL4)
434 {
"local4", LOG_LOCAL4 },
436#if defined (LOG_LOCAL5)
437 {
"local5", LOG_LOCAL5 },
439#if defined (LOG_LOCAL6)
440 {
"local6", LOG_LOCAL6 },
442#if defined (LOG_LOCAL7)
443 {
"local7", LOG_LOCAL7 },
450 "syslog-facilities", 1,
484 log_fatal (
"Can't allocate agent option hash table.");
493#if defined(REPORT_HASH_PERFORMANCE)
494 log_info(
"Relay Agent name hash: %s",
496 log_info(
"Relay Agent code hash: %s",
525 log_fatal (
"Can't allocate server option hash table.");
526 for (i = 0 ; server_options[i].name ; i++) {
528 &server_options[i].code, 0,
529 &server_options[i],
MDL);
531 server_options[i].name, 0,
532 &server_options[i],
MDL);
534#if defined(REPORT_HASH_PERFORMANCE)
535 log_info(
"Server-Config Option name hash: %s",
537 log_info(
"Server-Config Option code hash: %s",
void save_hashed_option(struct universe *universe, struct option_state *options, struct option_cache *oc, isc_boolean_t appendp)
int hashed_option_space_encapsulate(struct data_string *result, struct packet *packet, struct lease *lease, struct client_state *client_state, struct option_state *in_options, struct option_state *cfg_options, struct binding_scope **scope, struct universe *universe)
int hashed_option_state_dereference(struct universe *universe, struct option_state *state, const char *file, int line)
int linked_option_state_dereference(struct universe *universe, struct option_state *state, const char *file, int line)
void hashed_option_space_foreach(struct packet *packet, struct lease *lease, struct client_state *client_state, struct option_state *in_options, struct option_state *cfg_options, struct binding_scope **scope, struct universe *u, void *stuff, void(*func)(struct option_cache *, struct packet *, struct lease *, struct client_state *, struct option_state *, struct option_state *, struct binding_scope **, struct universe *, void *))
int linked_option_space_encapsulate(struct data_string *result, struct packet *packet, struct lease *lease, struct client_state *client_state, struct option_state *in_options, struct option_state *cfg_options, struct binding_scope **scope, struct universe *universe)
void linked_option_space_foreach(struct packet *packet, struct lease *lease, struct client_state *client_state, struct option_state *in_options, struct option_state *cfg_options, struct binding_scope **scope, struct universe *u, void *stuff, void(*func)(struct option_cache *, struct packet *, struct lease *, struct client_state *, struct option_state *, struct option_state *, struct binding_scope **, struct universe *, void *))
struct option_cache * lookup_hashed_option(struct universe *universe, struct option_state *options, unsigned code)
struct option_cache * lookup_linked_option(struct universe *universe, struct option_state *options, unsigned code)
void delete_hashed_option(struct universe *universe, struct option_state *options, int code)
struct option * vendor_cfg_option
void save_linked_option(struct universe *universe, struct option_state *options, struct option_cache *oc, isc_boolean_t appendp)
int parse_option_buffer(struct option_state *options, const unsigned char *buffer, unsigned length, struct universe *universe)
void delete_linked_option(struct universe *universe, struct option_state *options, int code)
void putUChar(unsigned char *, u_int32_t)
u_int32_t getUChar(const unsigned char *)
#define DHO_DHCP_AGENT_OPTIONS
failover_option_t null_failover_option
#define SV_ECHO_CLIENT_ID
#define SV_ABANDON_LEASE_TIME
#define SV_CHECK_SECS_BYTE_ORDER
struct enumeration prefix_length_modes
#define SV_SERVER_ID_CHECK
#define SV_DHCPV6_SET_TEE_TIMES
struct enumeration ddns_styles
#define SV_RELEASE_ON_ROAM
const char * dhcp_flink_state_names[]
struct universe agent_universe
struct failover_option_info ft_options[]
#define SV_VENDOR_OPTION_SPACE
#define SV_BIND_LOCAL_ADDRESS6
#define SV_PING_CLTT_SECS
#define SV_DDNS_GUARD_ID_MUST_MATCH
failover_option_t skip_failover_option
struct universe server_universe
struct universe dhcp_universe
struct enumeration syslog_enum
#define SV_LOCAL_ADDRESS6
#define SV_DDNS_OTHER_GUARD_IS_DYNAMIC
#define SV_DDNS_DUAL_STACK_MIXED_MODE
const char * binding_state_names[]
#define SV_PREFIX_LEN_MODE
#define SV_PING_TIMEOUT_MS
void log_fatal(const char *,...) __attribute__((__format__(__printf__
int int log_info(const char *,...) __attribute__((__format__(__printf__
struct enumeration_value ddns_styles_values[]
struct enumeration_value syslog_values[]
void initialize_server_option_spaces()
struct enumeration_value prefix_length_modes_values[]
struct universe * config_universe
universe_hash_t * universe_hash
struct universe ** universes