diff options
author | Piotrek Zadroga <piotrek@isc.org> | 2024-01-15 11:44:15 +0100 |
---|---|---|
committer | Piotrek Zadroga <piotrek@isc.org> | 2024-01-15 11:47:41 +0100 |
commit | 4d4e87b1a3510cc3e097dead790715e063925575 (patch) | |
tree | 6ee2859b6c5f4cc3faf88cb57bace134889d436b | |
parent | [#3074] addressed review comments (diff) | |
download | kea-4d4e87b1a3510cc3e097dead790715e063925575.tar.xz kea-4d4e87b1a3510cc3e097dead790715e063925575.zip |
[#3074] internal opt type refactor
-rw-r--r-- | doc/examples/kea4/all-options.json | 2 | ||||
-rw-r--r-- | doc/sphinx/arm/dhcp4-srv.rst | 6 | ||||
-rw-r--r-- | src/lib/dhcp/option_data_types.cc | 4 | ||||
-rw-r--r-- | src/lib/dhcp/option_data_types.h | 3 | ||||
-rw-r--r-- | src/lib/dhcp/option_definition.cc | 33 | ||||
-rw-r--r-- | src/lib/dhcp/option_definition.h | 20 | ||||
-rw-r--r-- | src/lib/dhcp/std_option_defs.h | 2 | ||||
-rw-r--r-- | src/lib/dhcp/tests/option_definition_unittest.cc | 17 |
8 files changed, 43 insertions, 44 deletions
diff --git a/doc/examples/kea4/all-options.json b/doc/examples/kea4/all-options.json index 7f6d0d1d0e..a997a5ce16 100644 --- a/doc/examples/kea4/all-options.json +++ b/doc/examples/kea4/all-options.json @@ -1318,7 +1318,7 @@ Router 1...N The IP address of the router that should be used to reach that destination. */ - // Type: custom + // Type: internal { "code": 121, // please mind the convenience notation used: diff --git a/doc/sphinx/arm/dhcp4-srv.rst b/doc/sphinx/arm/dhcp4-srv.rst index b4393a8dcb..fd2fdb1b57 100644 --- a/doc/sphinx/arm/dhcp4-srv.rst +++ b/doc/sphinx/arm/dhcp4-srv.rst @@ -2022,7 +2022,7 @@ types are given in :ref:`dhcp-types`. +----------------------------------------+------+---------------------------+-------------+-------------+ | domain-search | 119 | fqdn | true | false | +----------------------------------------+------+---------------------------+-------------+-------------+ - | classless-static-route | 121 | custom | false | false | + | classless-static-route | 121 | internal | false | false | +----------------------------------------+------+---------------------------+-------------+-------------+ | vivco-suboptions | 124 | record (uint32, binary) | false | false | +----------------------------------------+------+---------------------------+-------------+-------------+ @@ -2121,10 +2121,6 @@ what values are accepted for them. | boolean | A boolean value with allowed | | | values true or false. | +-----------------+-------------------------------------------------------+ - | custom | A custom value which is intended to be used only | - | | internally. It is meant for options which provide | - | | custom configuration syntax for users convenience. | - +-----------------+-------------------------------------------------------+ | empty | No value; data is carried in | | | sub-options. | +-----------------+-------------------------------------------------------+ diff --git a/src/lib/dhcp/option_data_types.cc b/src/lib/dhcp/option_data_types.cc index 4e2a17b964..46e49bfd6d 100644 --- a/src/lib/dhcp/option_data_types.cc +++ b/src/lib/dhcp/option_data_types.cc @@ -50,7 +50,7 @@ OptionDataTypeUtil::OptionDataTypeUtil() { data_types_["string"] = OPT_STRING_TYPE; data_types_["tuple"] = OPT_TUPLE_TYPE; data_types_["fqdn"] = OPT_FQDN_TYPE; - data_types_["custom"] = OPT_CUSTOM_TYPE; + data_types_["internal"] = OPT_INTERNAL_TYPE; data_types_["record"] = OPT_RECORD_TYPE; data_type_names_[OPT_EMPTY_TYPE] = "empty"; @@ -69,7 +69,7 @@ OptionDataTypeUtil::OptionDataTypeUtil() { data_type_names_[OPT_STRING_TYPE] = "string"; data_type_names_[OPT_TUPLE_TYPE] = "tuple"; data_type_names_[OPT_FQDN_TYPE] = "fqdn"; - data_type_names_[OPT_CUSTOM_TYPE] = "custom"; + data_type_names_[OPT_INTERNAL_TYPE] = "internal"; data_type_names_[OPT_RECORD_TYPE] = "record"; // The "unknown" data type is declared here so as // it can be returned by reference by a getDataTypeName diff --git a/src/lib/dhcp/option_data_types.h b/src/lib/dhcp/option_data_types.h index 5ef1220b0f..021ec6ee5f 100644 --- a/src/lib/dhcp/option_data_types.h +++ b/src/lib/dhcp/option_data_types.h @@ -59,7 +59,8 @@ enum OptionDataType { OPT_STRING_TYPE, OPT_TUPLE_TYPE, OPT_FQDN_TYPE, - OPT_CUSTOM_TYPE, + // Type to be used only internally. Allows convenient notation of the option config. + OPT_INTERNAL_TYPE, OPT_RECORD_TYPE, OPT_UNKNOWN_TYPE }; diff --git a/src/lib/dhcp/option_definition.cc b/src/lib/dhcp/option_definition.cc index 2961faf222..5f111be162 100644 --- a/src/lib/dhcp/option_definition.cc +++ b/src/lib/dhcp/option_definition.cc @@ -187,7 +187,7 @@ OptionDefinition::optionFactory(Option::Universe u, uint16_t type, OptionBufferConstIter begin, OptionBufferConstIter end, - bool convenient_format) const { + bool convenient_notation) const { try { // Some of the options are represented by the specialized classes derived @@ -196,7 +196,7 @@ OptionDefinition::optionFactory(Option::Universe u, // type to be returned. Therefore, we first check that if we are dealing // with such an option. If the instance is returned we just exit at this // point. If not, we will search for a generic option type to return. - OptionPtr option = factorySpecialFormatOption(u, begin, end, convenient_format); + OptionPtr option = factorySpecialFormatOption(u, begin, end, convenient_notation); if (option) { return (option); } @@ -210,9 +210,9 @@ OptionDefinition::optionFactory(Option::Universe u, } case OPT_BINARY_TYPE: - // If this is Custom type, and it wasn't handled by factorySpecialFormatOption() before, + // If this is Internal type, and it wasn't handled by factorySpecialFormatOption() before, // let's treat it like normal Binary type. - case OPT_CUSTOM_TYPE: + case OPT_INTERNAL_TYPE: return (factoryGeneric(u, type, begin, end)); case OPT_UINT8_TYPE: @@ -312,10 +312,11 @@ OptionDefinition::optionFactory(Option::Universe u, uint16_t type, if (type_ != OPT_EMPTY_TYPE) { isc_throw(InvalidOptionValue, "no option value specified"); } - } else if (type_ == OPT_CUSTOM_TYPE) { - // If Custom type is used together with csv-format=true, let's treat it - // like String type. optionFactory() will be called with custom_data flag set to true, - // so that the factory will have a chance to handle it in a custom way. + } else if (type_ == OPT_INTERNAL_TYPE) { + // If an Option of type Internal is configured using csv-format=true, it means it is + // convenient notation option config that needs special parsing. Let's treat it like + // String type. optionFactory() will be called with convenient_notation flag set to + // true, so that the factory will have a chance to handle it in a special way. writeToBuffer(u, boost::algorithm::join(values, ","), OPT_STRING_TYPE, buf); } else { writeToBuffer(u, util::str::trim(values[0]), type_, buf); @@ -341,7 +342,7 @@ OptionDefinition::optionFactory(Option::Universe u, uint16_t type, } } } - return (optionFactory(u, type, buf.begin(), buf.end(), (type_ == OPT_CUSTOM_TYPE))); + return (optionFactory(u, type, buf.begin(), buf.end(), (type_ == OPT_INTERNAL_TYPE))); } void @@ -413,9 +414,9 @@ OptionDefinition::validate() const { << " an option record."; break; } - // Custom type is not allowed within a record. - if (*it == OPT_CUSTOM_TYPE) { - err_str << "custom data type can't be stored as a field in" + // Internal type is not allowed within a record. + if (*it == OPT_INTERNAL_TYPE) { + err_str << "internal data type can't be stored as a field in" << " an option record."; break; } @@ -448,8 +449,8 @@ OptionDefinition::validate() const { err_str << "array of empty value is not" << " a valid option definition."; - } else if (type_ == OPT_CUSTOM_TYPE) { - err_str << "array of custom type value is not" + } else if (type_ == OPT_INTERNAL_TYPE) { + err_str << "array of internal type value is not" << " a valid option definition."; } @@ -846,7 +847,7 @@ OptionPtr OptionDefinition::factorySpecialFormatOption(Option::Universe u, OptionBufferConstIter begin, OptionBufferConstIter end, - bool convenient_format) const { + bool convenient_notation) const { if ((u == Option::V6) && haveSpace(DHCP6_OPTION_SPACE)) { switch (getCode()) { case D6O_IA_NA: @@ -908,7 +909,7 @@ OptionDefinition::factorySpecialFormatOption(Option::Universe u, return (OptionPtr(new Option4ClientFqdn(begin, end))); case DHO_CLASSLESS_STATIC_ROUTE: - return (OptionPtr(new OptionClasslessStaticRoute(begin, end, convenient_format))); + return (OptionPtr(new OptionClasslessStaticRoute(begin, end, convenient_notation))); case DHO_VIVCO_SUBOPTIONS: // Record of uint32 followed by binary. diff --git a/src/lib/dhcp/option_definition.h b/src/lib/dhcp/option_definition.h index 12955308eb..f1208ca3dd 100644 --- a/src/lib/dhcp/option_definition.h +++ b/src/lib/dhcp/option_definition.h @@ -433,10 +433,10 @@ public: /// @param type option type. /// @param begin beginning of the option buffer. /// @param end end of the option buffer. - /// @param convenient_format flag which indicates that the buffer contains option data - /// as a string formatted in user-friendly, convenient way. - /// The flag is propagated to the option constructor, so that - /// the data could be parsed properly. Defaults to false. + /// @param convenient_notation flag which indicates that the buffer contains option data + /// as a string formatted in user-friendly, convenient way. + /// The flag is propagated to the option constructor, so that + /// the data could be parsed properly. Defaults to false. /// /// @return instance of the DHCP option. /// @throw InvalidOptionValue if data for the option is invalid. @@ -444,7 +444,7 @@ public: uint16_t type, OptionBufferConstIter begin, OptionBufferConstIter end, - bool convenient_format = false) const; + bool convenient_notation = false) const; /// @brief Option factory. /// @@ -676,10 +676,10 @@ private: /// @param u A universe (V4 or V6). /// @param begin beginning of the option buffer. /// @param end end of the option buffer. - /// @param convenient_format flag which indicates that the buffer contains option data - /// as a string formatted in user-friendly, convenient way. - /// The flag is propagated to the option constructor, so that - /// the data could be parsed properly. Defaults to false. + /// @param convenient_notation flag which indicates that the buffer contains option data + /// as a string formatted in user-friendly, convenient way. + /// The flag is propagated to the option constructor, so that + /// the data could be parsed properly. Defaults to false. /// /// @return An instance of the option having special format or NULL if /// such an option can't be created because an option with the given @@ -687,7 +687,7 @@ private: OptionPtr factorySpecialFormatOption(Option::Universe u, OptionBufferConstIter begin, OptionBufferConstIter end, - bool convenient_format = false) const; + bool convenient_notation = false) const; /// @brief Check if specified type matches option definition type. /// diff --git a/src/lib/dhcp/std_option_defs.h b/src/lib/dhcp/std_option_defs.h index db2bded0e5..5e8acec8b6 100644 --- a/src/lib/dhcp/std_option_defs.h +++ b/src/lib/dhcp/std_option_defs.h @@ -332,7 +332,7 @@ const OptionDefParams STANDARD_V4_OPTION_DEFINITIONS[] = { OPT_IPV4_ADDRESS_TYPE, false, NO_RECORD_DEF, "" }, { "domain-search", DHO_DOMAIN_SEARCH, DHCP4_OPTION_SPACE, OPT_FQDN_TYPE, true, NO_RECORD_DEF, "" }, - { "classless-static-route", DHO_CLASSLESS_STATIC_ROUTE, DHCP4_OPTION_SPACE, OPT_CUSTOM_TYPE, + { "classless-static-route", DHO_CLASSLESS_STATIC_ROUTE, DHCP4_OPTION_SPACE, OPT_INTERNAL_TYPE, false, NO_RECORD_DEF, "" }, { "vivco-suboptions", DHO_VIVCO_SUBOPTIONS, DHCP4_OPTION_SPACE, OPT_RECORD_TYPE, false, RECORD_DEF(VIVCO_RECORDS), "" }, diff --git a/src/lib/dhcp/tests/option_definition_unittest.cc b/src/lib/dhcp/tests/option_definition_unittest.cc index 647533da6a..f1f51add06 100644 --- a/src/lib/dhcp/tests/option_definition_unittest.cc +++ b/src/lib/dhcp/tests/option_definition_unittest.cc @@ -2106,13 +2106,14 @@ TEST_F(OptionDefinitionTest, tuple6ArrayTokenized) { EXPECT_EQ("world", tuple2.getText()); } -// The purpose of this test is to verify creation of OPT_CUSTOM_TYPE option +// The purpose of this test is to verify creation of OPT_INTERNAL_TYPE option // definition. OptionFactory is used which takes vector of string values as -// data for the option. This is special case for OPT_CUSTOM_TYPE because it means -// that custom data is provided in string values. Custom parsing is verified in this test. -TEST_F(OptionDefinitionTest, customOptionTypeString) { +// data for the option. This is special case for OPT_INTERNAL_TYPE because it means +// that convenient notation option config is provided as string that needs special parsing. +// Custom parsing is verified in this test. +TEST_F(OptionDefinitionTest, internalOptionTypeString) { OptionDefinition opt_def("classless-static-route", DHO_CLASSLESS_STATIC_ROUTE, - DHCP4_OPTION_SPACE, "custom", false); + DHCP4_OPTION_SPACE, "internal", false); OptionPtr option; @@ -2148,12 +2149,12 @@ TEST_F(OptionDefinitionTest, customOptionTypeString) { option_cast->toText()); } -// The purpose of this test is to verify creation of OPT_CUSTOM_TYPE option +// The purpose of this test is to verify creation of OPT_INTERNAL_TYPE option // definition. OptionFactory is used which takes OptionBuffer as // data for the option. Binary data unpack is verified in this test. -TEST_F(OptionDefinitionTest, customOptionTypeBinary) { +TEST_F(OptionDefinitionTest, internalOptionTypeBinary) { OptionDefinition opt_def("classless-static-route", DHO_CLASSLESS_STATIC_ROUTE, - DHCP4_OPTION_SPACE, "custom", false); + DHCP4_OPTION_SPACE, "internal", false); OptionPtr option; |