merge branch MAX-252 for bug-524
merge branch MAX-252 for bug-524
This commit is contained in:
		| @ -35,6 +35,7 @@ | ||||
|  * 23/05/14	Massimiliano Pinto	Added automatic set of maxscale-id: first listening ipv4_raw + port + pid | ||||
|  * 28/05/14	Massimiliano Pinto	Added detect_replication_lag parameter | ||||
|  * 28/08/14	Massimiliano Pinto	Added detect_stale_master parameter | ||||
|  * 09/09/14	Massimiliano Pinto	Added localhost_match_wildcard_host parameter | ||||
|  * 12/09/14	Mark Riddoch		Addition of checks on servers list and | ||||
|  *					internal router suppression of messages | ||||
|  * | ||||
| @ -291,6 +292,9 @@ int			error_count = 0; | ||||
| 					is_rwsplit = true; | ||||
| 				} | ||||
|  | ||||
| 				char *allow_localhost_match_wildcard_host = | ||||
|                                         config_get_value(obj->parameters, "localhost_match_wildcard_host"); | ||||
|  | ||||
|                                 if (obj->element == NULL) /*< if module load failed */ | ||||
|                                 { | ||||
| 					LOGIF(LE, (skygw_log_write_flush( | ||||
| @ -325,6 +329,11 @@ int			error_count = 0; | ||||
| 				if (weightby) | ||||
| 					serviceWeightBy(obj->element, weightby); | ||||
|  | ||||
| 				if (allow_localhost_match_wildcard_host) | ||||
| 					serviceEnableLocalhostMatchWildcardHost( | ||||
| 						obj->element, | ||||
| 						config_truth_value(allow_localhost_match_wildcard_host)); | ||||
|  | ||||
| 				if (!auth) | ||||
| 					auth = config_get_value(obj->parameters,  | ||||
|                                                                 "auth"); | ||||
| @ -1191,6 +1200,7 @@ SERVER			*server; | ||||
|                                         char* max_slave_conn_str; | ||||
|                                         char* max_slave_rlag_str; | ||||
| 					char *version_string; | ||||
| 					char *allow_localhost_match_wildcard_host; | ||||
|  | ||||
| 					enable_root_user = config_get_value(obj->parameters, "enable_root_user"); | ||||
|  | ||||
| @ -1201,6 +1211,8 @@ SERVER			*server; | ||||
|  | ||||
| 					version_string = config_get_value(obj->parameters, "version_string"); | ||||
|  | ||||
| 					allow_localhost_match_wildcard_host = config_get_value(obj->parameters, "localhost_match_wildcard_host"); | ||||
|  | ||||
| 					if (version_string) { | ||||
| 						if (service->version_string) { | ||||
| 							free(service->version_string); | ||||
| @ -1214,6 +1226,11 @@ SERVER			*server; | ||||
|                                                                auth); | ||||
| 						if (enable_root_user) | ||||
| 							serviceEnableRootUser(service, atoi(enable_root_user)); | ||||
|  | ||||
| 						if (allow_localhost_match_wildcard_host) | ||||
| 							serviceEnableLocalhostMatchWildcardHost( | ||||
| 								service, | ||||
| 								atoi(allow_localhost_match_wildcard_host)); | ||||
|                                                  | ||||
|                                                 /** Read, validate and set max_slave_connections */         | ||||
|                                                 max_slave_conn_str =  | ||||
| @ -1308,10 +1325,13 @@ SERVER			*server; | ||||
|                                         char *user; | ||||
| 					char *auth; | ||||
| 					char *enable_root_user; | ||||
| 					char *allow_localhost_match_wildcard_host; | ||||
|  | ||||
| 					enable_root_user =  | ||||
|                                                 config_get_value(obj->parameters,  | ||||
|                                                                  "enable_root_user"); | ||||
| 					allow_localhost_match_wildcard_host =  | ||||
| 						config_get_value(obj->parameters, "localhost_match_wildcard_host"); | ||||
|  | ||||
|                                         user = config_get_value(obj->parameters, | ||||
|                                                                 "user"); | ||||
| @ -1327,6 +1347,11 @@ SERVER			*server; | ||||
|                                                                auth); | ||||
| 						if (enable_root_user) | ||||
| 							serviceEnableRootUser(service, atoi(enable_root_user)); | ||||
|  | ||||
| 						if (allow_localhost_match_wildcard_host) | ||||
| 							serviceEnableLocalhostMatchWildcardHost( | ||||
| 								service, | ||||
| 								atoi(allow_localhost_match_wildcard_host)); | ||||
|                                         } | ||||
| 				} | ||||
| 			} | ||||
| @ -1544,6 +1569,7 @@ static char *service_params[] = | ||||
|                 "user", | ||||
|                 "passwd", | ||||
| 		"enable_root_user", | ||||
| 		"localhost_match_wildcard_host", | ||||
|                 "max_slave_connections", | ||||
|                 "max_slave_replication_lag", | ||||
| 		"use_sql_variables_in",		/*< rwsplit only */ | ||||
|  | ||||
| @ -31,6 +31,7 @@ | ||||
|  * 07/05/14	Massimiliano Pinto	Added: version_string initialized to NULL | ||||
|  * 23/05/14	Mark Riddoch		Addition of service validation call | ||||
|  * 29/05/14	Mark Riddoch		Filter API implementation | ||||
|  * 09/09/14	Massimiliano Pinto	Added service option for localhost authentication | ||||
|  * | ||||
|  * @endverbatim | ||||
|  */ | ||||
| @ -128,6 +129,7 @@ SERVICE 	*service; | ||||
| 	service->credentials.name = NULL; | ||||
| 	service->credentials.authdata = NULL; | ||||
| 	service->enable_root = 0; | ||||
| 	service->localhost_match_wildcard_host = 0; | ||||
| 	service->routerOptions = NULL; | ||||
| 	service->databases = NULL; | ||||
|         service->svc_config_param = NULL; | ||||
| @ -1288,3 +1290,23 @@ serviceGetWeightingParameter(SERVICE *service) | ||||
| { | ||||
| 	return service->weightby; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Enable/Disable localhost authentication match criteria | ||||
|  * associated with this service. | ||||
|  * | ||||
|  * @param service       The service we are setting the data for | ||||
|  * @param action        1 for enable, 0 for disable access | ||||
|  * @return              0 on failure | ||||
|  */ | ||||
|  | ||||
| int | ||||
| serviceEnableLocalhostMatchWildcardHost(SERVICE *service, int action) | ||||
| { | ||||
| 	if (action != 0 && action != 1) | ||||
| 		return 0; | ||||
|  | ||||
| 	service->localhost_match_wildcard_host = action; | ||||
|  | ||||
| 	return 1; | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 MassimilianoPinto
					MassimilianoPinto