106 lines
3.4 KiB
C
106 lines
3.4 KiB
C
#ifndef _CONFIG_H
|
|
#define _CONFIG_H
|
|
/*
|
|
* This file is distributed as part of the SkySQL Gateway. It is free
|
|
* software: you can redistribute it and/or modify it under the terms of the
|
|
* GNU General Public License as published by the Free Software Foundation,
|
|
* version 2.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program; if not, write to the Free Software Foundation, Inc., 51
|
|
* Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Copyright SkySQL Ab 2013
|
|
*/
|
|
#include <skygw_utils.h>
|
|
|
|
/**
|
|
* @file config.h The configuration handling elements
|
|
*
|
|
* @verbatim
|
|
* Revision History
|
|
*
|
|
* Date Who Description
|
|
* 21/06/13 Mark Riddoch Initial implementation
|
|
* 07/05/14 Massimiliano Pinto Added version_string to global configuration
|
|
* 23/05/14 Massimiliano Pinto Added id to global configuration
|
|
*
|
|
* @endverbatim
|
|
*/
|
|
|
|
/**
|
|
* Maximum length for configuration parameter value.
|
|
*/
|
|
enum {MAX_PARAM_LEN=256};
|
|
|
|
typedef enum {
|
|
UNDEFINED_TYPE = 0x00,
|
|
STRING_TYPE = 0x01,
|
|
COUNT_TYPE = 0x02,
|
|
PERCENT_TYPE = 0x04,
|
|
BOOL_TYPE = 0x08
|
|
} config_param_type_t;
|
|
|
|
#define PARAM_IS_TYPE(p,t) ((p) & (t))
|
|
|
|
/**
|
|
* The config parameter
|
|
*/
|
|
typedef struct config_parameter {
|
|
char *name; /**< The name of the parameter */
|
|
char *value; /**< The value of the parameter */
|
|
union { /*< qualified parameter value by type */
|
|
char* valstr; /*< terminated char* array */
|
|
int valcount; /*< int */
|
|
int valpercent; /*< int */
|
|
bool valbool; /*< bool */
|
|
} qfd;
|
|
config_param_type_t qfd_param_type;
|
|
struct config_parameter *next; /**< Next pointer in the linked list */
|
|
} CONFIG_PARAMETER;
|
|
|
|
/**
|
|
* The config context structure, used to build the configuration
|
|
* data during the parse process
|
|
*/
|
|
typedef struct config_context {
|
|
char *object; /**< The name of the object being configured */
|
|
CONFIG_PARAMETER *parameters; /**< The list of parameter values */
|
|
void *element; /**< The element created from the data */
|
|
struct config_context *next; /**< Next pointer in the linked list */
|
|
} CONFIG_CONTEXT;
|
|
|
|
/**
|
|
* The gateway global configuration data
|
|
*/
|
|
typedef struct {
|
|
int n_threads; /**< Number of polling threads */
|
|
char *version_string; /**< The version string of embedded database library */
|
|
unsigned long id; /**< MaxScale ID */
|
|
} GATEWAY_CONF;
|
|
|
|
extern int config_load(char *);
|
|
extern int config_reload();
|
|
extern int config_threadcount();
|
|
CONFIG_PARAMETER* config_get_param(CONFIG_PARAMETER* params, const char* name);
|
|
config_param_type_t config_get_paramtype(CONFIG_PARAMETER* param);
|
|
CONFIG_PARAMETER* config_clone_param(CONFIG_PARAMETER* param);
|
|
|
|
bool config_set_qualified_param(
|
|
CONFIG_PARAMETER* param,
|
|
void* val,
|
|
config_param_type_t type);
|
|
|
|
|
|
int config_get_valint(
|
|
CONFIG_PARAMETER* param,
|
|
const char* name, /*< if NULL examine current param only */
|
|
config_param_type_t ptype);
|
|
|
|
#endif
|