Fix to MXS-63: https://mariadb.atlassian.net/browse/MXS-63
Maxkeys and maxpasswd now use MAXSCALE_HOME or the default installation directory if MAXSCALE_HOME is not set. If all else fails, /tmp/ is used for logging.
This commit is contained in:
@ -826,6 +826,7 @@ static bool file_is_readable(
|
|||||||
absolute_pathname,
|
absolute_pathname,
|
||||||
eno,
|
eno,
|
||||||
strerror(eno))));
|
strerror(eno))));
|
||||||
|
LOGIF(LE,(skygw_log_sync_all()));
|
||||||
succp = false;
|
succp = false;
|
||||||
}
|
}
|
||||||
return succp;
|
return succp;
|
||||||
|
|||||||
@ -29,19 +29,60 @@
|
|||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <secrets.h>
|
#include <secrets.h>
|
||||||
|
#include <skygw_utils.h>
|
||||||
|
#include <log_manager.h>
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
int arg_count = 3;
|
||||||
|
char *home;
|
||||||
|
char** arg_vector;
|
||||||
|
|
||||||
|
|
||||||
if (argc != 2)
|
if (argc != 2)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Usage: %s <filename>\n", argv[0]);
|
fprintf(stderr, "Usage: %s <filename>\n", argv[0]);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
arg_vector = malloc(sizeof(char*)*4);
|
||||||
|
|
||||||
|
if(arg_vector == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr,"Error: Memory allocation failed.\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
arg_vector[0] = strdup("logmanager");
|
||||||
|
arg_vector[1] = strdup("-j");
|
||||||
|
|
||||||
|
if ((home = getenv("MAXSCALE_HOME")) != NULL)
|
||||||
|
{
|
||||||
|
arg_vector[2] = (char*)malloc((strlen(home) + strlen("/log"))*sizeof(char));
|
||||||
|
sprintf(arg_vector[2],"%s/log",home);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
arg_vector[2] = strdup("/usr/local/mariadb-maxscale/log");
|
||||||
|
}
|
||||||
|
|
||||||
|
arg_vector[3] = NULL;
|
||||||
|
skygw_logmanager_init(arg_count,arg_vector);
|
||||||
|
skygw_log_enable(LOGFILE_TRACE);
|
||||||
|
skygw_log_enable(LOGFILE_DEBUG);
|
||||||
|
free(arg_vector[0]);
|
||||||
|
free(arg_vector[1]);
|
||||||
|
free(arg_vector[2]);
|
||||||
|
free(arg_vector);
|
||||||
|
|
||||||
|
|
||||||
if (secrets_writeKeys(argv[1]))
|
if (secrets_writeKeys(argv[1]))
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Failed to encode the password\n");
|
fprintf(stderr, "Failed to encode the password\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
exit(0);
|
|
||||||
|
skygw_log_sync_all();
|
||||||
|
skygw_logmanager_done();
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -29,7 +29,8 @@
|
|||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <secrets.h>
|
#include <secrets.h>
|
||||||
|
#include <skygw_utils.h>
|
||||||
|
#include <log_manager.h>
|
||||||
/**
|
/**
|
||||||
* Encrypt a password for storing in the MaxScale.cnf file
|
* Encrypt a password for storing in the MaxScale.cnf file
|
||||||
*
|
*
|
||||||
@ -40,6 +41,10 @@ int
|
|||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
char *enc, *pw;
|
char *enc, *pw;
|
||||||
|
int arg_count = 3;
|
||||||
|
char *home;
|
||||||
|
char** arg_vector;
|
||||||
|
|
||||||
|
|
||||||
if (argc != 2)
|
if (argc != 2)
|
||||||
{
|
{
|
||||||
@ -47,6 +52,36 @@ main(int argc, char **argv)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
arg_vector = malloc(sizeof(char*)*4);
|
||||||
|
|
||||||
|
if(arg_vector == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr,"Error: Memory allocation failed.\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
arg_vector[0] = strdup("logmanager");
|
||||||
|
arg_vector[1] = strdup("-j");
|
||||||
|
|
||||||
|
if ((home = getenv("MAXSCALE_HOME")) != NULL)
|
||||||
|
{
|
||||||
|
arg_vector[2] = (char*)malloc((strlen(home) + strlen("/log"))*sizeof(char));
|
||||||
|
sprintf(arg_vector[2],"%s/log",home);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
arg_vector[2] = strdup("/usr/local/mariadb-maxscale/log");
|
||||||
|
}
|
||||||
|
|
||||||
|
arg_vector[3] = NULL;
|
||||||
|
skygw_logmanager_init(arg_count,arg_vector);
|
||||||
|
skygw_log_enable(LOGFILE_TRACE);
|
||||||
|
skygw_log_enable(LOGFILE_DEBUG);
|
||||||
|
free(arg_vector[0]);
|
||||||
|
free(arg_vector[1]);
|
||||||
|
free(arg_vector[2]);
|
||||||
|
free(arg_vector);
|
||||||
|
|
||||||
pw = calloc(81,sizeof(char));
|
pw = calloc(81,sizeof(char));
|
||||||
|
|
||||||
if(pw == NULL){
|
if(pw == NULL){
|
||||||
@ -63,5 +98,7 @@ main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
free(pw);
|
free(pw);
|
||||||
|
skygw_log_sync_all();
|
||||||
|
skygw_logmanager_done();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user