/* * 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/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. */ #include "schemarouter.hh" #include namespace schemarouter { Config::Config(MXS_CONFIG_PARAMETER* conf) : refresh_min_interval(conf->get_integer("refresh_interval")) , refresh_databases(conf->get_bool("refresh_databases")) , debug(conf->get_bool("debug")) , ignore_regex(config_get_compiled_regex(conf, "ignore_databases_regex", 0, NULL)) , ignore_match_data(ignore_regex ? pcre2_match_data_create_from_pattern(ignore_regex, NULL) : NULL) , preferred_server(conf->get_server("preferred_server")) { ignored_dbs.insert("mysql"); ignored_dbs.insert("information_schema"); ignored_dbs.insert("performance_schema"); // TODO: Don't process this in the router std::string ignored_dbs_str = conf->get_string("ignore_databases"); if (!ignored_dbs_str.empty()) { for (const auto& a : mxs::strtok(ignored_dbs_str, ", \t")) { ignored_dbs.insert(a); } } } void SRBackend::set_mapped(bool value) { m_mapped = value; } bool SRBackend::is_mapped() const { return m_mapped; } }