std_option_defs.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. // Copyright (C) 2012 Internet Systems Consortium, Inc. ("ISC")
  2. //
  3. // Permission to use, copy, modify, and/or distribute this software for any
  4. // purpose with or without fee is hereby granted, provided that the above
  5. // copyright notice and this permission notice appear in all copies.
  6. //
  7. // THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  8. // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  9. // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  10. // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  11. // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  12. // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  13. // PERFORMANCE OF THIS SOFTWARE.
  14. #ifndef STD_OPTION_DEFS_H
  15. #define STD_OPTION_DEFS_H
  16. #include <dhcp/option_data_types.h>
  17. namespace {
  18. /// @brief Declare an array holding parameters used to create instance
  19. /// of a definition for option comprising a record of data fields.
  20. ///
  21. /// @param name name of the array being declared.
  22. /// @param types data types of fields that belong to the record.
  23. #ifndef RECORD_DECL
  24. #define RECORD_DECL(name, types...) static const OptionDataType name[] = { types }
  25. #endif
  26. /// @brief A pair of values: one pointing to the array holding types of
  27. /// data fields belonging to the record, and size of this array.
  28. ///
  29. /// @param name name of the array holding data fields' types.
  30. #ifndef RECORD_DEF
  31. #define RECORD_DEF(name) name, sizeof(name) / sizeof(name[0])
  32. #endif
  33. using namespace isc::dhcp;
  34. /// @brief Parameters being used to make up an option definition.
  35. struct OptionDefParams {
  36. const char* name; // option name
  37. uint16_t code; // option code
  38. OptionDataType type; // data type
  39. bool array; // is array
  40. const OptionDataType* records; // record fields
  41. size_t records_size; // number of fields in a record
  42. };
  43. // fqdn option record fields.
  44. //
  45. // Note that the flags field indicates the type of domain
  46. // name encoding. There is a choice between deprecated
  47. // ASCII encoding and compressed encoding described in
  48. // RFC 1035, section 3.1. The latter could be handled
  49. // by OPT_FQDN_TYPE but we can't use it here because
  50. // clients may request ASCII encoding.
  51. RECORD_DECL(FQDN_RECORDS, OPT_UINT8_TYPE, OPT_UINT8_TYPE, OPT_STRING_TYPE);
  52. /// @brief Definitions of standard DHCPv4 options.
  53. static const OptionDefParams OPTION_DEF_PARAMS4[] = {
  54. { "subnet-mask", DHO_SUBNET_MASK, OPT_IPV4_ADDRESS_TYPE, false },
  55. { "time-offset", DHO_TIME_OFFSET, OPT_UINT32_TYPE, false },
  56. { "routers", DHO_ROUTERS, OPT_IPV4_ADDRESS_TYPE, true },
  57. { "time-servers", DHO_TIME_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  58. { "name-servers", DHO_NAME_SERVERS, OPT_IPV4_ADDRESS_TYPE,
  59. false },
  60. { "domain-name-servers", DHO_DOMAIN_NAME_SERVERS,
  61. OPT_IPV4_ADDRESS_TYPE, true },
  62. { "log-servers", DHO_LOG_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  63. { "cookie-servers", DHO_COOKIE_SERVERS, OPT_IPV4_ADDRESS_TYPE,
  64. true },
  65. { "lpr-servers", DHO_LPR_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  66. { "impress-servers", DHO_IMPRESS_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  67. { "resource-location-servers", DHO_RESOURCE_LOCATION_SERVERS,
  68. OPT_IPV4_ADDRESS_TYPE, true },
  69. { "host-name", DHO_HOST_NAME, OPT_STRING_TYPE, false },
  70. { "boot-size", DHO_BOOT_SIZE, OPT_UINT16_TYPE, false },
  71. { "merit-dump", DHO_MERIT_DUMP, OPT_STRING_TYPE, false },
  72. { "domain-name", DHO_DOMAIN_NAME, OPT_FQDN_TYPE, false },
  73. { "swap-server", DHO_SWAP_SERVER, OPT_IPV4_ADDRESS_TYPE, false },
  74. { "root-path", DHO_ROOT_PATH, OPT_STRING_TYPE, false },
  75. { "extensions-path", DHO_EXTENSIONS_PATH, OPT_STRING_TYPE,
  76. false },
  77. { "ip-forwarding", DHO_IP_FORWARDING, OPT_BOOLEAN_TYPE, false },
  78. { "non-local-source-routing", DHO_NON_LOCAL_SOURCE_ROUTING,
  79. OPT_BOOLEAN_TYPE, false },
  80. { "policy-filter", DHO_POLICY_FILTER, OPT_IPV4_ADDRESS_TYPE, true },
  81. { "max-dgram-reassembly", DHO_MAX_DGRAM_REASSEMBLY,
  82. OPT_UINT16_TYPE, false },
  83. { "default-ip-ttl", DHO_DEFAULT_IP_TTL, OPT_UINT8_TYPE, false },
  84. { "path-mtu-aging-timeout", DHO_PATH_MTU_AGING_TIMEOUT,
  85. OPT_UINT32_TYPE, false },
  86. { "path-mtu-plateau-table", DHO_PATH_MTU_PLATEAU_TABLE,
  87. OPT_UINT16_TYPE, true },
  88. { "interface-mtu", DHO_INTERFACE_MTU, OPT_UINT16_TYPE, false },
  89. { "all-subnets-local", DHO_ALL_SUBNETS_LOCAL,
  90. OPT_BOOLEAN_TYPE, false },
  91. { "broadcast-address", DHO_BROADCAST_ADDRESS,
  92. OPT_IPV4_ADDRESS_TYPE, false },
  93. { "perform-mask-discovery", DHO_PERFORM_MASK_DISCOVERY,
  94. OPT_BOOLEAN_TYPE, false },
  95. { "mask-supplier", DHO_MASK_SUPPLIER, OPT_BOOLEAN_TYPE, false },
  96. { "router-discovery", DHO_ROUTER_DISCOVERY,
  97. OPT_BOOLEAN_TYPE, false },
  98. { "router-solicitation-address", DHO_ROUTER_SOLICITATION_ADDRESS,
  99. OPT_IPV4_ADDRESS_TYPE, false },
  100. { "static-routes", DHO_STATIC_ROUTES,
  101. OPT_IPV4_ADDRESS_TYPE, true },
  102. { "trailer-encapsulation", DHO_TRAILER_ENCAPSULATION,
  103. OPT_BOOLEAN_TYPE, false },
  104. { "arp-cache-timeout", DHO_ARP_CACHE_TIMEOUT,
  105. OPT_UINT32_TYPE, false },
  106. { "ieee802-3-encapsulation", DHO_IEEE802_3_ENCAPSULATION,
  107. OPT_BOOLEAN_TYPE, false },
  108. { "default-tcp-ttl", DHO_DEFAULT_TCP_TTL, OPT_UINT8_TYPE, false },
  109. { "tcp-keepalive-internal", DHO_TCP_KEEPALIVE_INTERVAL,
  110. OPT_UINT32_TYPE, false },
  111. { "tcp-keepalive-garbage", DHO_TCP_KEEPALIVE_GARBAGE,
  112. OPT_BOOLEAN_TYPE, false },
  113. { "nis-domain", DHO_NIS_DOMAIN, OPT_STRING_TYPE, false },
  114. { "nis-servers", DHO_NIS_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  115. { "ntp-servers", DHO_NTP_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  116. { "vendor-encapsulated-options", DHO_VENDOR_ENCAPSULATED_OPTIONS,
  117. OPT_BINARY_TYPE, false },
  118. { "netbios-name-servers", DHO_NETBIOS_NAME_SERVERS,
  119. OPT_IPV4_ADDRESS_TYPE, true },
  120. { "netbios-dd-server", DHO_NETBIOS_DD_SERVER,
  121. OPT_IPV4_ADDRESS_TYPE, true },
  122. { "netbios-node-type", DHO_NETBIOS_NODE_TYPE,
  123. OPT_UINT8_TYPE, false },
  124. { "netbios-scope", DHO_NETBIOS_SCOPE, OPT_STRING_TYPE, false },
  125. { "font-servers", DHO_FONT_SERVERS, OPT_IPV4_ADDRESS_TYPE, true },
  126. { "x-display-manager", DHO_X_DISPLAY_MANAGER,
  127. OPT_IPV4_ADDRESS_TYPE, true },
  128. { "dhcp-requested-address", DHO_DHCP_REQUESTED_ADDRESS,
  129. OPT_IPV4_ADDRESS_TYPE, false },
  130. { "dhcp-lease-time", DHO_DHCP_LEASE_TIME, OPT_UINT32_TYPE, false },
  131. { "dhcp-option-overload", DHO_DHCP_OPTION_OVERLOAD,
  132. OPT_UINT8_TYPE, false },
  133. { "dhcp-message-type", DHO_DHCP_MESSAGE_TYPE, OPT_UINT8_TYPE, false },
  134. { "dhcp-server-identifier", DHO_DHCP_SERVER_IDENTIFIER,
  135. OPT_IPV4_ADDRESS_TYPE, false },
  136. { "dhcp-parameter-request-list", DHO_DHCP_PARAMETER_REQUEST_LIST,
  137. OPT_UINT8_TYPE, true },
  138. { "dhcp-message", DHO_DHCP_MESSAGE, OPT_STRING_TYPE, false },
  139. { "dhcp-max-message-size", DHO_DHCP_MAX_MESSAGE_SIZE,
  140. OPT_UINT16_TYPE, false },
  141. { "dhcp-renewal-time", DHO_DHCP_RENEWAL_TIME, OPT_UINT32_TYPE, false },
  142. { "dhcp-rebinding-time", DHO_DHCP_REBINDING_TIME,
  143. OPT_UINT32_TYPE, false },
  144. { "vendor-class-identifier", DHO_VENDOR_CLASS_IDENTIFIER,
  145. OPT_BINARY_TYPE, false },
  146. { "dhcp-client-identifier", DHO_DHCP_CLIENT_IDENTIFIER,
  147. OPT_BINARY_TYPE, false },
  148. { "nwip-domain-name", DHO_NWIP_DOMAIN_NAME, OPT_STRING_TYPE, false },
  149. { "nwip-suboptions", DHO_NWIP_SUBOPTIONS, OPT_BINARY_TYPE, false },
  150. { "user-class", DHO_USER_CLASS, OPT_BINARY_TYPE, false },
  151. { "fqdn", DHO_FQDN, OPT_RECORD_TYPE, false, RECORD_DEF(FQDN_RECORDS) },
  152. { "dhcp-agent-options", DHO_DHCP_AGENT_OPTIONS,
  153. OPT_BINARY_TYPE, false },
  154. // Unfortunatelly the AUTHENTICATE option contains a 64-bit
  155. // data field called 'replay-detection' that can't be added
  156. // as a record field to a custom option. Also, there is no
  157. // dedicated option class to handle it so we simply return
  158. // binary option type for now.
  159. // @todo implement a class to handle AUTH option.
  160. { "authenticate", DHO_AUTHENTICATE, OPT_BINARY_TYPE, false },
  161. { "client-last-transaction-time", DHO_CLIENT_LAST_TRANSACTION_TIME,
  162. OPT_UINT32_TYPE, false },
  163. { "associated-ip", DHO_ASSOCIATED_IP, OPT_IPV4_ADDRESS_TYPE, true },
  164. { "subnet-selection", DHO_SUBNET_SELECTION,
  165. OPT_IPV4_ADDRESS_TYPE, false },
  166. // The following options need a special encoding of data
  167. // being carried by them. Therefore, there is no way they can
  168. // be handled by OptionCustom. We may need to implement
  169. // dedicated classes to handle them. Until that happens
  170. // let's treat them as 'binary' options.
  171. { "domain-search", DHO_DOMAIN_SEARCH, OPT_BINARY_TYPE, false },
  172. { "vivco-suboptions", DHO_VIVCO_SUBOPTIONS,
  173. OPT_BINARY_TYPE, false },
  174. { "vivso-suboptions", DHO_VIVSO_SUBOPTIONS, OPT_BINARY_TYPE,
  175. false }
  176. // @todo add definitions for all remaning options.
  177. };
  178. /// Number of option definitions defined.
  179. const int OPTION_DEF_PARAMS_SIZE4 =
  180. sizeof(OPTION_DEF_PARAMS4) / sizeof(OPTION_DEF_PARAMS4[0]);
  181. /// Start Definition of DHCPv6 options
  182. // client-fqdn
  183. RECORD_DECL(CLIENT_FQDN_RECORDS, OPT_UINT8_TYPE, OPT_FQDN_TYPE);
  184. // geoconf-civic
  185. RECORD_DECL(GEOCONF_CIVIC_RECORDS, OPT_UINT8_TYPE, OPT_UINT16_TYPE,
  186. OPT_BINARY_TYPE);
  187. // iaddr
  188. RECORD_DECL(IAADDR_RECORDS, OPT_IPV6_ADDRESS_TYPE, OPT_UINT32_TYPE,
  189. OPT_UINT32_TYPE);
  190. // ia-na
  191. RECORD_DECL(IA_NA_RECORDS, OPT_UINT32_TYPE, OPT_UINT32_TYPE, OPT_UINT32_TYPE);
  192. // ia-pd
  193. RECORD_DECL(IA_PD_RECORDS, OPT_UINT32_TYPE, OPT_UINT32_TYPE, OPT_UINT32_TYPE);
  194. // ia-prefix
  195. RECORD_DECL(IA_PREFIX_RECORDS, OPT_UINT32_TYPE, OPT_UINT32_TYPE,
  196. OPT_UINT8_TYPE, OPT_BINARY_TYPE);
  197. // lq-query
  198. RECORD_DECL(LQ_QUERY_RECORDS, OPT_UINT8_TYPE, OPT_IPV6_ADDRESS_TYPE);
  199. // lq-relay-data
  200. RECORD_DECL(LQ_RELAY_DATA_RECORDS, OPT_IPV6_ADDRESS_TYPE, OPT_BINARY_TYPE);
  201. // remote-id
  202. RECORD_DECL(REMOTE_ID_RECORDS, OPT_UINT32_TYPE, OPT_BINARY_TYPE);
  203. // status-code
  204. RECORD_DECL(STATUS_CODE_RECORDS, OPT_UINT16_TYPE, OPT_STRING_TYPE);
  205. // vendor-class
  206. RECORD_DECL(VENDOR_CLASS_RECORDS, OPT_UINT32_TYPE, OPT_BINARY_TYPE);
  207. // vendor-opts
  208. RECORD_DECL(VENDOR_OPTS_RECORDS, OPT_UINT32_TYPE, OPT_BINARY_TYPE);
  209. /// Standard DHCPv6 option definitions.
  210. static const OptionDefParams OPTION_DEF_PARAMS6[] = {
  211. { "clientid", D6O_CLIENTID, OPT_BINARY_TYPE, false },
  212. { "serverid", D6O_SERVERID, OPT_BINARY_TYPE, false },
  213. { "ia-na", D6O_IA_NA, OPT_RECORD_TYPE, false, RECORD_DEF(IA_NA_RECORDS) },
  214. { "ia-ta", D6O_IA_TA, OPT_UINT32_TYPE, false },
  215. { "iaaddr", D6O_IAADDR, OPT_RECORD_TYPE, false, RECORD_DEF(IAADDR_RECORDS) },
  216. { "oro", D6O_ORO, OPT_UINT16_TYPE, true },
  217. { "preference", D6O_PREFERENCE, OPT_UINT8_TYPE, false },
  218. { "elapsed-time", D6O_ELAPSED_TIME, OPT_UINT16_TYPE, false },
  219. { "relay-msg", D6O_RELAY_MSG, OPT_BINARY_TYPE, false },
  220. // Unfortunatelly the AUTH option contains a 64-bit data field
  221. // called 'replay-detection' that can't be added as a record
  222. // field to a custom option. Also, there is no dedicated
  223. // option class to handle it so we simply return binary
  224. // option type for now.
  225. // @todo implement a class to handle AUTH option.
  226. { "auth", D6O_AUTH, OPT_BINARY_TYPE, false },
  227. { "unicast", D6O_UNICAST, OPT_IPV6_ADDRESS_TYPE, false },
  228. { "status-code", D6O_STATUS_CODE, OPT_RECORD_TYPE, false,
  229. RECORD_DEF(STATUS_CODE_RECORDS) },
  230. { "rapid-commit", D6O_RAPID_COMMIT, OPT_EMPTY_TYPE, false },
  231. { "user-class", D6O_USER_CLASS, OPT_BINARY_TYPE, false },
  232. { "vendor-class", D6O_VENDOR_CLASS, OPT_RECORD_TYPE, false,
  233. RECORD_DEF(VENDOR_CLASS_RECORDS) },
  234. { "vendor-opts", D6O_VENDOR_OPTS, OPT_RECORD_TYPE, false,
  235. RECORD_DEF(VENDOR_OPTS_RECORDS) },
  236. { "interface-id", D6O_INTERFACE_ID, OPT_BINARY_TYPE, false },
  237. { "reconf-msg", D6O_RECONF_MSG, OPT_UINT8_TYPE, false },
  238. { "reconf-accept", D6O_RECONF_ACCEPT, OPT_EMPTY_TYPE, false },
  239. { "sip-server-dns", D6O_SIP_SERVERS_DNS, OPT_FQDN_TYPE, true },
  240. { "sip-server-addr", D6O_SIP_SERVERS_ADDR, OPT_IPV6_ADDRESS_TYPE, true },
  241. { "dns-servers", D6O_NAME_SERVERS, OPT_IPV6_ADDRESS_TYPE, true },
  242. { "domain-search", D6O_DOMAIN_SEARCH, OPT_FQDN_TYPE, true },
  243. { "ia-pd", D6O_IA_PD, OPT_RECORD_TYPE, false, RECORD_DEF(IA_PD_RECORDS) },
  244. { "iaprefix", D6O_IAPREFIX, OPT_RECORD_TYPE, false,
  245. RECORD_DEF(IA_PREFIX_RECORDS) },
  246. { "nis-servers", D6O_NIS_SERVERS, OPT_IPV6_ADDRESS_TYPE, true },
  247. { "nisp-servers", D6O_NISP_SERVERS, OPT_IPV6_ADDRESS_TYPE, true },
  248. { "nis-domain-name", D6O_NIS_DOMAIN_NAME, OPT_FQDN_TYPE, true },
  249. { "nisp-domain-name", D6O_NISP_DOMAIN_NAME, OPT_FQDN_TYPE, true },
  250. { "sntp-servers", D6O_SNTP_SERVERS, OPT_IPV6_ADDRESS_TYPE, true },
  251. { "information-refresh-time", D6O_INFORMATION_REFRESH_TIME,
  252. OPT_UINT32_TYPE, false },
  253. { "bcmcs-server-dns", D6O_BCMCS_SERVER_D, OPT_FQDN_TYPE, true },
  254. { "bcmcs-server-addr", D6O_BCMCS_SERVER_A, OPT_IPV6_ADDRESS_TYPE, true },
  255. { "geoconf-civic", D6O_GEOCONF_CIVIC, OPT_RECORD_TYPE, false,
  256. RECORD_DEF(GEOCONF_CIVIC_RECORDS) },
  257. { "remote-id", D6O_REMOTE_ID, OPT_RECORD_TYPE, false,
  258. RECORD_DEF(REMOTE_ID_RECORDS) },
  259. { "subscriber-id", D6O_SUBSCRIBER_ID, OPT_BINARY_TYPE, false },
  260. { "client-fqdn", D6O_CLIENT_FQDN, OPT_RECORD_TYPE, false,
  261. RECORD_DEF(CLIENT_FQDN_RECORDS) },
  262. { "pana-agent", D6O_PANA_AGENT, OPT_IPV6_ADDRESS_TYPE, true },
  263. { "new-posix-timezone", D6O_NEW_POSIX_TIMEZONE, OPT_STRING_TYPE, false },
  264. { "new-tzdb-timezone", D6O_NEW_TZDB_TIMEZONE, OPT_STRING_TYPE, false },
  265. { "ero", D6O_ERO, OPT_UINT16_TYPE, true },
  266. { "lq-query", D6O_LQ_QUERY, OPT_RECORD_TYPE, false,
  267. RECORD_DEF(LQ_QUERY_RECORDS) },
  268. { "client-data", D6O_CLIENT_DATA, OPT_EMPTY_TYPE, false },
  269. { "clt-time", D6O_CLT_TIME, OPT_UINT32_TYPE, false },
  270. { "lq-relay-data", D6O_LQ_RELAY_DATA, OPT_RECORD_TYPE, false,
  271. RECORD_DEF(LQ_RELAY_DATA_RECORDS) },
  272. { "lq-client-link", D6O_LQ_CLIENT_LINK, OPT_IPV6_ADDRESS_TYPE, true }
  273. // @todo There is still a bunch of options for which we have to provide
  274. // definitions but we don't do it because they are not really
  275. // critical right now.
  276. };
  277. /// Number of option definitions defined.
  278. const int OPTION_DEF_PARAMS_SIZE6 =
  279. sizeof(OPTION_DEF_PARAMS6) / sizeof(OPTION_DEF_PARAMS6[0]);
  280. }; // anonymous namespace
  281. #endif // STD_OPTION_DEFS_H