
Where it exists, the @file comment has now been moved to be consistently right after the license blurb.
172 lines
6.8 KiB
C
172 lines
6.8 KiB
C
#pragma once
|
|
#ifndef _MAXSCALE_CONFIG_H
|
|
#define _MAXSCALE_CONFIG_H
|
|
/*
|
|
* Copyright (c) 2016 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/bsl.
|
|
*
|
|
* Change Date: 2019-07-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.
|
|
*/
|
|
|
|
/**
|
|
* @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
|
|
* 17/10/14 Mark Riddoch Added poll tuning configuration parameters
|
|
* 05/03/15 Massimiliano Pinto Added sysname, release, sha1_mac to gateway struct
|
|
*
|
|
* @endverbatim
|
|
*/
|
|
|
|
#include <maxscale/cdefs.h>
|
|
#include <maxscale/skygw_utils.h>
|
|
#include <sys/utsname.h>
|
|
#include <stdint.h>
|
|
#include <openssl/sha.h>
|
|
#include <maxscale/spinlock.h>
|
|
|
|
MXS_BEGIN_DECLS
|
|
|
|
#define DEFAULT_NBPOLLS 3 /**< Default number of non block polls before we block */
|
|
#define DEFAULT_POLLSLEEP 1000 /**< Default poll wait time (milliseconds) */
|
|
#define _RELEASE_STR_LENGTH 256 /**< release len */
|
|
#define DEFAULT_NTHREADS 1 /**< Default number of polling threads */
|
|
/**
|
|
* 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,
|
|
SQLVAR_TARGET_TYPE = 0x10
|
|
} config_param_type_t;
|
|
|
|
typedef enum
|
|
{
|
|
TYPE_UNDEFINED = 0,
|
|
TYPE_MASTER,
|
|
TYPE_ALL
|
|
} target_t;
|
|
|
|
enum
|
|
{
|
|
MAX_RLAG_NOT_AVAILABLE = -1,
|
|
MAX_RLAG_UNDEFINED = -2
|
|
};
|
|
|
|
#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 */
|
|
target_t valtarget; /*< sql variable route target */
|
|
} 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 db library */
|
|
char release_string[_RELEASE_STR_LENGTH]; /**< The release name string of the system */
|
|
char sysname[_UTSNAME_SYSNAME_LENGTH]; /**< The OS name of the system */
|
|
uint8_t mac_sha1[SHA_DIGEST_LENGTH]; /**< The SHA1 digest of an interface MAC address */
|
|
unsigned long id; /**< MaxScale ID */
|
|
unsigned int n_nbpoll; /**< Tune number of non-blocking polls */
|
|
unsigned int pollsleep; /**< Wait time in blocking polls */
|
|
int syslog; /**< Log to syslog */
|
|
int maxlog; /**< Log to MaxScale's own logs */
|
|
int log_to_shm; /**< Write log-file to shared memory */
|
|
unsigned int auth_conn_timeout; /**< Connection timeout for the user authentication */
|
|
unsigned int auth_read_timeout; /**< Read timeout for the user authentication */
|
|
unsigned int auth_write_timeout; /**< Write timeout for the user authentication */
|
|
bool skip_permission_checks; /**< Skip service and monitor permission checks */
|
|
char qc_name[PATH_MAX]; /**< The name of the query classifier to load */
|
|
char* qc_args; /**< Arguments for the query classifier */
|
|
} GATEWAY_CONF;
|
|
|
|
|
|
char* config_clean_string_list(char* str);
|
|
CONFIG_PARAMETER* config_clone_param(CONFIG_PARAMETER* param);
|
|
void config_enable_feedback_task(void);
|
|
void config_disable_feedback_task(void);
|
|
unsigned long config_get_gateway_id(void);
|
|
GATEWAY_CONF* config_get_global_options();
|
|
CONFIG_PARAMETER* config_get_param(CONFIG_PARAMETER* params, const char* name);
|
|
config_param_type_t config_get_paramtype(CONFIG_PARAMETER* param);
|
|
bool config_get_valint(int* val,
|
|
CONFIG_PARAMETER* param,
|
|
const char* name, /*< if NULL examine current param only */
|
|
config_param_type_t ptype);
|
|
bool config_get_valbool(bool* val,
|
|
CONFIG_PARAMETER* param,
|
|
const char* name, /*< if NULL examine current param only */
|
|
config_param_type_t ptype);
|
|
bool config_get_valtarget(target_t* val,
|
|
CONFIG_PARAMETER* param,
|
|
const char* name, /*< if NULL examine current param only */
|
|
config_param_type_t ptype);
|
|
bool config_load(char *);
|
|
unsigned int config_nbpolls();
|
|
double config_percentage_value(char *str);
|
|
unsigned int config_pollsleep();
|
|
int config_reload();
|
|
bool config_set_qualified_param(CONFIG_PARAMETER* param,
|
|
void* val,
|
|
config_param_type_t type);
|
|
int config_threadcount();
|
|
int config_truth_value(char *);
|
|
void free_config_parameter(CONFIG_PARAMETER* p1);
|
|
bool is_internal_service(const char *router);
|
|
|
|
MXS_END_DECLS
|
|
|
|
#endif
|