Skip to content

Commit

Permalink
cli: Add command to evaluate dialplan functions.
Browse files Browse the repository at this point in the history
Adds the dialplan eval function commands to evaluate a dialplan
function from the CLI. The return value and function result are
printed out and can be used for testing or debugging.

ASTERISK-29820 #close

Change-Id: I833e97ea54c49336aca145330a2adeebfad05209
  • Loading branch information
InterLinked1 authored and Friendly Automation committed Apr 26, 2022
1 parent 0c70d49 commit 92d408f
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 0 deletions.
5 changes: 5 additions & 0 deletions doc/CHANGES-staging/cli_eval_function.txt
@@ -0,0 +1,5 @@
Subject: cli

A new CLI command 'dialplan eval function' has been
added which allows users to test the behavior of
dialplan function calls directly from the CLI.
47 changes: 47 additions & 0 deletions main/pbx_variables.c
Expand Up @@ -924,6 +924,52 @@ static char *handle_show_chanvar(struct ast_cli_entry *e, int cmd, struct ast_cl
return CLI_SUCCESS;
}

/*! \brief CLI support for executing function */
static char *handle_eval_function(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
{
struct ast_channel *c = NULL;
char *fn, *substituted;
int ret;
char workspace[1024];

switch (cmd) {
case CLI_INIT:
e->command = "dialplan eval function";
e->usage =
"Usage: dialplan eval function <name(args)>\n"
" Evaluate a dialplan function call\n"
" A dummy channel is used to evaluate\n"
" the function call, so only global\n"
" variables should be used.\n";
return NULL;
case CLI_GENERATE:
return NULL;
}

if (a->argc != e->args + 1) {
return CLI_SHOWUSAGE;
}

c = ast_dummy_channel_alloc();
if (!c) {
ast_cli(a->fd, "Unable to allocate bogus channel for function evaluation.\n");
return CLI_FAILURE;
}

fn = (char *) a->argv[3];
pbx_substitute_variables_helper(c, fn, workspace, sizeof(workspace));
substituted = ast_strdupa(workspace);
workspace[0] = '\0';
ret = ast_func_read(c, substituted, workspace, sizeof(workspace));

c = ast_channel_unref(c);

ast_cli(a->fd, "Return Value: %s (%d)\n", ret ? "Failure" : "Success", ret);
ast_cli(a->fd, "Result: %s\n", workspace);

return CLI_SUCCESS;
}

static char *handle_set_global(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
{
switch (cmd) {
Expand Down Expand Up @@ -1218,6 +1264,7 @@ void pbx_builtin_clear_globals(void)
static struct ast_cli_entry vars_cli[] = {
AST_CLI_DEFINE(handle_show_globals, "Show global dialplan variables"),
AST_CLI_DEFINE(handle_show_chanvar, "Show channel variables"),
AST_CLI_DEFINE(handle_eval_function, "Evaluate dialplan function"),
AST_CLI_DEFINE(handle_set_global, "Set global dialplan variable"),
AST_CLI_DEFINE(handle_set_chanvar, "Set a channel variable"),
};
Expand Down

0 comments on commit 92d408f

Please sign in to comment.