diff options
author | Benjamin Ford <bford@digium.com> | 2015-07-29 14:17:09 -0500 |
---|---|---|
committer | Benjamin Ford <bford@digium.com> | 2015-07-31 11:43:47 -0500 |
commit | 1ae762634c317fbcbd98a8c34d2474f7d4b654ed (patch) | |
tree | 84127e860a5d60a43d64d4a589546dfba157d323 /main/logger.c | |
parent | f78a4b52b8ed7b5b367c3465652a7ce98fe9175d (diff) |
ARI: Rotate log channels.
An http request can be sent to rotate a specified log channel.
If the channel does not exist, an error response will be
returned.
The command "curl -v -u user:pass -X PUT 'http://localhost:8088
/ari/asterisk/logging/logChannelName/rotate'" can be run in the
terminal to access this new functionality.
* Added the ability to rotate log files through ARI
ASTERISK-25252
Change-Id: Iaefa21cbbc1b29effb33004ee3d89c977e76ab01
Diffstat (limited to 'main/logger.c')
-rw-r--r-- | main/logger.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/main/logger.c b/main/logger.c index f84221f64..8fd8e50f8 100644 --- a/main/logger.c +++ b/main/logger.c @@ -933,6 +933,46 @@ int ast_logger_rotate() return reload_logger(1, NULL); } +int ast_logger_rotate_channel(const char *log_channel) +{ + struct logchannel *f; + int success = 0; + + struct ast_str *filename = ast_str_create(64); + if (!filename) { + return -1; + } + + ast_str_append(&filename, 0, "%s/%s", ast_config_AST_LOG_DIR, log_channel); + + AST_RWLIST_WRLOCK(&logchannels); + + ast_mkdir(ast_config_AST_LOG_DIR, 0644); + + AST_RWLIST_TRAVERSE(&logchannels, f, list) { + if (f->disabled) { + f->disabled = 0; /* Re-enable logging at reload */ + manager_event(EVENT_FLAG_SYSTEM, "LogChannel", "Channel: %s\r\nEnabled: Yes\r\n", + f->filename); + } + if (f->fileptr && (f->fileptr != stdout) && (f->fileptr != stderr)) { + fclose(f->fileptr); /* Close file */ + f->fileptr = NULL; + if (strcmp(ast_str_buffer(filename), f->filename) == 0) { + rotate_file(f->filename); + success = 1; + } + } + } + + init_logger_chain(1 /* locked */, NULL); + + AST_RWLIST_UNLOCK(&logchannels); + ast_free(filename); + + return success; +} + static char *handle_logger_set_level(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a) { int x; |