 6f8bfd7d11
			
		
	
	6f8bfd7d11
	
	
	
		
			
			The helper function makes it easier to convert enum values at runtime to their integer representation. Also changed the configuration processing code to use the new function.
		
			
				
	
	
		
			271 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			271 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018 MariaDB Corporation Ab
 | |
|  *
 | |
|  * Use of this software is governed by the Business Source License included
 | |
|  * in the LICENSE.TXT file and at www.mariadb.com/bsl11.
 | |
|  *
 | |
|  * Change Date: 2022-01-01
 | |
|  *
 | |
|  * On the date above, in accordance with the Business Source License, use
 | |
|  * of this software will be governed by version 2 or later of the General
 | |
|  * Public License.
 | |
|  */
 | |
| #pragma once
 | |
| 
 | |
| /**
 | |
|  * @file core/maxscale/config.h - The private config interface
 | |
|  */
 | |
| 
 | |
| #include <maxscale/config.hh>
 | |
| 
 | |
| #include <sstream>
 | |
| #include <initializer_list>
 | |
| #include <unordered_set>
 | |
| 
 | |
| #include <maxbase/jansson.h>
 | |
| #include <maxscale/ssl.hh>
 | |
| 
 | |
| #define DEFAULT_NBPOLLS             3       /**< Default number of non block polls before we block */
 | |
| #define DEFAULT_POLLSLEEP           1000    /**< Default poll wait time (milliseconds) */
 | |
| #define DEFAULT_NTHREADS            1       /**< Default number of polling threads */
 | |
| #define DEFAULT_QUERY_RETRIES       1       /**< Number of retries for interrupted queries */
 | |
| #define DEFAULT_QUERY_RETRY_TIMEOUT 5       /**< Timeout for query retries */
 | |
| #define MIN_WRITEQ_HIGH_WATER       4096UL  /**< Min high water mark of dcb write queue */
 | |
| #define MIN_WRITEQ_LOW_WATER        512UL   /**< Min low water mark of dcb write queue */
 | |
| 
 | |
| /**
 | |
|  * Maximum length for configuration parameter value.
 | |
|  */
 | |
| enum
 | |
| {
 | |
|     MAX_PARAM_LEN = 256
 | |
| };
 | |
| 
 | |
| /** Object type specific parameter lists */
 | |
| extern const MXS_MODULE_PARAM config_service_params[];
 | |
| extern const MXS_MODULE_PARAM config_listener_params[];
 | |
| extern const MXS_MODULE_PARAM config_monitor_params[];
 | |
| extern const MXS_MODULE_PARAM config_filter_params[];
 | |
| extern const MXS_MODULE_PARAM config_server_params[];
 | |
| extern const char* config_pre_parse_global_params[];
 | |
| 
 | |
| /**
 | |
|  * Finalize the configuration subsystem
 | |
|  */
 | |
| void config_finish();
 | |
| 
 | |
| /**
 | |
|  * Set the defaults for the global configuration options
 | |
|  */
 | |
| void config_set_global_defaults();
 | |
| 
 | |
| /**
 | |
|  * @brief Generate default module parameters
 | |
|  *
 | |
|  * Adds any default parameters to @c ctx that aren't already in it.
 | |
|  *
 | |
|  * @param ctx    Configuration context where the parameters are added
 | |
|  * @param params Module parameters
 | |
|  */
 | |
| void config_add_defaults(CONFIG_CONTEXT* ctx, const MXS_MODULE_PARAM* params);
 | |
| 
 | |
| char*                 config_clean_string_list(const char* str);
 | |
| bool                  config_load(const char*);
 | |
| bool                  config_load_global(const char* filename);
 | |
| 
 | |
| /**
 | |
|  * @brief Creates an empty configuration context
 | |
|  *
 | |
|  * @param section Context name
 | |
|  * @return New context or NULL on memory allocation failure
 | |
|  */
 | |
| CONFIG_CONTEXT* config_context_create(const char* section);
 | |
| 
 | |
| /**
 | |
|  * @brief Free a configuration context
 | |
|  *
 | |
|  * @param context The context to free
 | |
|  */
 | |
| void config_context_free(CONFIG_CONTEXT* context);
 | |
| 
 | |
| /**
 | |
|  * @brief Add a parameter to a configuration context
 | |
|  *
 | |
|  * @param obj Context where the parameter should be added
 | |
|  * @param key Key to add
 | |
|  * @param value Value for the key
 | |
|  * @return True on success, false on memory allocation error
 | |
|  */
 | |
| bool config_add_param(CONFIG_CONTEXT* obj, const char* key, const char* value);
 | |
| 
 | |
| /**
 | |
|  * @brief Append to an existing parameter
 | |
|  *
 | |
|  * @param obj Configuration context
 | |
|  * @param key Parameter name
 | |
|  * @param value Value to append to the parameter
 | |
|  * @return True on success, false on memory allocation error
 | |
|  */
 | |
| bool config_append_param(CONFIG_CONTEXT* obj, const char* key, const char* value);
 | |
| 
 | |
| /**
 | |
|  * @brief Replace an existing parameter
 | |
|  *
 | |
|  * @param obj Configuration context
 | |
|  * @param key Parameter name
 | |
|  * @param value Parameter value
 | |
|  * @return True on success, false on memory allocation error
 | |
|  */
 | |
| bool config_replace_param(CONFIG_CONTEXT* obj, const char* key, const char* value);
 | |
| 
 | |
| /**
 | |
|  * @brief Remove a parameter
 | |
|  *
 | |
|  * @param obj Configuration context
 | |
|  * @param key Name of the parameter to remove
 | |
|  */
 | |
| void config_remove_param(CONFIG_CONTEXT* obj, const char* name);
 | |
| 
 | |
| /**
 | |
|  * @brief Construct an SSL structure
 | |
|  *
 | |
|  * The SSL structure is used by both listeners and servers.
 | |
|  *
 | |
|  * @param name         Name of object being created (usually server or listener name)
 | |
|  * @param params       Parameters to create SSL from
 | |
|  * @param require_cert Whether certificates are required
 | |
|  * @param dest         Pointer where initialized SSL structure is stored
 | |
|  *
 | |
|  * @return True on success, false on error
 | |
|  */
 | |
| bool config_create_ssl(const char* name,
 | |
|                        MXS_CONFIG_PARAMETER* params,
 | |
|                        bool require_cert,
 | |
|                        SSL_LISTENER** dest);
 | |
| 
 | |
| /**
 | |
|  * @brief Check if all SSL parameters are defined
 | |
|  *
 | |
|  * Helper function to check whether all of the required SSL parameters are defined
 | |
|  * in the configuration context. The checked parameters are 'ssl', 'ssl_key',
 | |
|  * 'ssl_cert' and 'ssl_ca_cert'. The 'ssl' parameter must also have a value of
 | |
|  * 'required'.
 | |
|  *
 | |
|  * @param obj Configuration context
 | |
|  * @return True if all required parameters are present
 | |
|  */
 | |
| bool config_have_required_ssl_params(CONFIG_CONTEXT* obj);
 | |
| 
 | |
| /**
 | |
|  * @brief Add non-standard configuration parameters to a JSON object
 | |
|  *
 | |
|  * @param parameters List of configuration parameter values
 | |
|  * @param param_info Configuration parameter type information
 | |
|  * @param ignored_params Set of parameters which should not be added to the output
 | |
|  * @param output Output JSON object where the parameters are added
 | |
|  */
 | |
| void config_add_module_params_json(const MXS_CONFIG_PARAMETER* parameters,
 | |
|                                    const std::unordered_set<std::string>& ignored_params,
 | |
|                                    const MXS_MODULE_PARAM* basic_params,
 | |
|                                    const MXS_MODULE_PARAM* module_params,
 | |
|                                    json_t* output);
 | |
| 
 | |
| /**
 | |
|  * @brief Convert object names to correct format
 | |
|  *
 | |
|  * Check that object name contains no whitespace. If the name contains
 | |
|  * whitespace, trim it, squeeze it and replace the remaining whitespace with
 | |
|  * hyphens.
 | |
|  *
 | |
|  * @param name Object name to fix
 | |
|  */
 | |
| void fix_object_name(char* name);
 | |
| void fix_object_name(std::string& name);
 | |
| 
 | |
| /**
 | |
|  * @brief Serialize global options
 | |
|  *
 | |
|  * @return True if options were serialized successfully
 | |
|  */
 | |
| bool config_global_serialize();
 | |
| 
 | |
| /**
 | |
|  * Export the configuration to a file
 | |
|  *
 | |
|  * @param filename Filename where the configuration will be written
 | |
|  *
 | |
|  * @return True if configuration was successfully exported
 | |
|  */
 | |
| bool export_config_file(const char* filename);
 | |
| 
 | |
| bool is_normal_server_parameter(const char* param);
 | |
| 
 | |
| /**
 | |
|  * Converts a string into the corresponding value, interpreting
 | |
|  * IEC or SI prefixes used as suffixes appropriately.
 | |
|  *
 | |
|  * @param value A numerical string, possibly suffixed by a IEC binary prefix or
 | |
|  *              SI prefix.
 | |
|  * @param dest  Pointer where the result is stored. If set to NULL, only the
 | |
|  *              validity of value is checked.
 | |
|  *
 | |
|  * @return True on success, false on invalid input in which case contents of
 | |
|  *         `dest` are left in an undefined state
 | |
|  */
 | |
| bool get_suffixed_size(const char* value, uint64_t* dest);
 | |
| 
 | |
| /**
 | |
|  * Converts a string into a duration, intepreting in a case-insensitive manner
 | |
|  * an 'h'-suffix to indicate hours, an 'm'-suffix to indicate minutes, an
 | |
|  * 's'-suffix to indicate seconds and an 'ms'-suffix to indicate milliseconds.
 | |
|  *
 | |
|  * @param zValue          A numerical string, possibly suffixed by 'h', 'm',
 | |
|  *                        's' or 'ms'.
 | |
|  * @param interpretation  How a value lacking a specific suffix should be interpreted.
 | |
|  * @param pDuration       Pointer, if non-NULL, where the result is stored.
 | |
|  * @param pUnit           Pointer, if non-NULL, where the detected unit is stored.
 | |
|  *
 | |
|  * @return True on success, false on invalid input in which case @c pUnit and
 | |
|  *         @c pDuration will not be modified.
 | |
|  */
 | |
| bool get_suffixed_duration(const char* zValue,
 | |
|                            mxs::config::DurationInterpretation interpretation,
 | |
|                            std::chrono::milliseconds* pDuration,
 | |
|                            mxs::config::DurationUnit* pUnit = nullptr);
 | |
| 
 | |
| /**
 | |
|  * Generate configuration file contents out of module configuration parameters. Only parameters defined
 | |
|  * in the parameter definition arrays are printed. Printing is in the order the parameters are given in
 | |
|  * the definitions.
 | |
|  *
 | |
|  * @param instance_name The module instance name
 | |
|  * @param parameters Configuration parameter values
 | |
|  * @param common_param_defs Common module parameter definitions. These are printed first.
 | |
|  * @param module_param_defs Module-specific parameter definitions.
 | |
|  */
 | |
| std::string generate_config_string(const std::string& instance_name, const MXS_CONFIG_PARAMETER& parameters,
 | |
|                                    const MXS_MODULE_PARAM* common_param_defs,
 | |
|                                    const MXS_MODULE_PARAM* module_param_defs);
 | |
| 
 | |
| /**
 | |
|  * Check whether a parameter can be modified at runtime
 | |
|  *
 | |
|  * @param name Name of the parameter
 | |
|  *
 | |
|  * @return True if the parameter can be modified at runtime
 | |
|  */
 | |
| bool config_can_modify_at_runtime(const char* name);
 | |
| 
 | |
| // Value returned for unknown enumeration values
 | |
| constexpr int64_t MXS_UNKNOWN_ENUM_VALUE {-1};
 | |
| 
 | |
| /**
 | |
|  * Convert enum name to integer value
 | |
|  *
 | |
|  * @param key    The enum name to convert
 | |
|  * @param values The list of enum values
 | |
|  *
 | |
|  * @return The enum value or MXS_UNKNOWN_ENUM_VALUE on unknown value
 | |
|  */
 | |
| int64_t config_enum_to_value(const std::string& key, const MXS_ENUM_VALUE* values);
 |