2013-05-22 02:37:43 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
2013-05-25 05:05:45 +08:00
|
|
|
// Copyright (C) 2013 m h swende <martin at swende.se>
|
2013-05-22 02:37:43 +08:00
|
|
|
//
|
|
|
|
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
|
|
|
|
// at your option, any later version. See the LICENSE.txt file for the text of
|
|
|
|
// the license.
|
|
|
|
//-----------------------------------------------------------------------------
|
2013-05-25 05:05:45 +08:00
|
|
|
// Some lua scripting glue to proxmark core.
|
2013-05-22 02:37:43 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
2020-05-26 17:30:17 +08:00
|
|
|
// 2020, added Python support (@iceman100)
|
|
|
|
|
2013-05-22 02:37:43 +08:00
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2020-05-26 18:00:42 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-26 17:49:26 +08:00
|
|
|
//#define PY_SSIZE_T_CLEAN
|
2020-05-26 17:30:17 +08:00
|
|
|
#include <Python.h>
|
|
|
|
#include <wchar.h>
|
2020-05-26 17:49:26 +08:00
|
|
|
#endif
|
2020-05-26 17:30:17 +08:00
|
|
|
|
|
|
|
|
2019-08-08 22:57:33 +08:00
|
|
|
#include "cmdparser.h" // command_t
|
2013-05-25 05:05:45 +08:00
|
|
|
#include "scripting.h"
|
2018-09-07 03:43:20 +08:00
|
|
|
#include "comms.h"
|
2013-05-22 02:37:43 +08:00
|
|
|
#include "cmdscript.h"
|
|
|
|
#include "cmdhfmf.h"
|
2013-05-27 04:05:13 +08:00
|
|
|
#include "pm3_binlib.h"
|
2013-11-07 02:34:10 +08:00
|
|
|
#include "pm3_bitlib.h"
|
2019-08-08 22:57:33 +08:00
|
|
|
#include "lualib.h"
|
|
|
|
#include "lauxlib.h"
|
|
|
|
#include "proxmark3.h"
|
|
|
|
#include "ui.h"
|
2019-08-23 03:18:37 +08:00
|
|
|
#include "fileutils.h"
|
2013-05-22 02:37:43 +08:00
|
|
|
|
2020-05-26 17:30:17 +08:00
|
|
|
typedef enum {
|
2020-05-27 06:40:01 +08:00
|
|
|
PM3_UNSPECIFIED,
|
2020-05-26 17:30:17 +08:00
|
|
|
PM3_LUA,
|
|
|
|
PM3_CMD,
|
2020-05-27 16:19:22 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-26 17:30:17 +08:00
|
|
|
PM3_PY
|
2020-05-27 06:40:01 +08:00
|
|
|
#endif
|
2020-05-26 17:30:17 +08:00
|
|
|
} pm3_scriptfile_t;
|
|
|
|
|
2013-05-22 02:37:43 +08:00
|
|
|
static int CmdHelp(const char *Cmd);
|
|
|
|
|
2020-05-26 19:09:18 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-26 20:41:58 +08:00
|
|
|
|
|
|
|
#define PYTHON_LIBRARIES_WILDCARD "?.py"
|
|
|
|
|
2020-05-26 19:09:18 +08:00
|
|
|
static int split(char *str, char **arr) {
|
|
|
|
int begin_index = 0;
|
|
|
|
int word_cnt = 0;
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
while (isspace(str[begin_index])) {
|
|
|
|
++begin_index;
|
|
|
|
}
|
|
|
|
if (str[begin_index] == '\0') {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
int end_index = begin_index;
|
|
|
|
while (str[end_index] && !isspace(str[end_index])) {
|
|
|
|
++end_index;
|
|
|
|
}
|
|
|
|
int len = end_index - begin_index;
|
|
|
|
char *tmp = calloc(len + 1, sizeof(char));
|
|
|
|
memcpy(tmp, &str[begin_index], len);
|
|
|
|
arr[word_cnt++] = tmp;
|
|
|
|
begin_index = end_index;
|
|
|
|
}
|
|
|
|
return word_cnt;
|
|
|
|
}
|
2020-05-26 20:41:58 +08:00
|
|
|
|
|
|
|
static void set_python_path(char *path) {
|
|
|
|
PyObject *syspath = PySys_GetObject("path");
|
|
|
|
if (syspath == 0) {
|
|
|
|
PrintAndLogEx(WARNING, "Python failed to getobject");
|
|
|
|
}
|
2020-05-27 16:19:22 +08:00
|
|
|
|
2020-05-26 20:41:58 +08:00
|
|
|
PyObject *pName = PyUnicode_FromString(path);
|
|
|
|
if (PyList_Insert(syspath, 0, pName)) {
|
|
|
|
PrintAndLogEx(WARNING, "Error inserting extra path into sys.path list");
|
|
|
|
}
|
2020-05-27 16:19:22 +08:00
|
|
|
|
2020-05-26 20:41:58 +08:00
|
|
|
if (PySys_SetObject("path", syspath)) {
|
|
|
|
PrintAndLogEx(WARNING,"Error setting sys.path object");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void set_python_paths(void) {
|
|
|
|
//--add to the LUA_PATH (package.path in lua)
|
|
|
|
// so we can load scripts from various places:
|
|
|
|
const char *exec_path = get_my_executable_directory();
|
|
|
|
if (exec_path != NULL) {
|
|
|
|
// from the ./luascripts/ directory
|
|
|
|
char scripts_path[strlen(exec_path) + strlen(PYTHON_SCRIPTS_SUBDIR) + strlen(PYTHON_LIBRARIES_WILDCARD) + 1];
|
|
|
|
strcpy(scripts_path, exec_path);
|
|
|
|
strcat(scripts_path, PYTHON_SCRIPTS_SUBDIR);
|
|
|
|
// strcat(scripts_path, PYTHON_LIBRARIES_WILDCARD);
|
|
|
|
set_python_path(scripts_path);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *user_path = get_my_user_directory();
|
|
|
|
if (user_path != NULL) {
|
|
|
|
// from the $HOME/.proxmark3/luascripts/ directory
|
|
|
|
char scripts_path[strlen(user_path) + strlen(PM3_USER_DIRECTORY) + strlen(PYTHON_SCRIPTS_SUBDIR) + strlen(PYTHON_LIBRARIES_WILDCARD) + 1];
|
|
|
|
strcpy(scripts_path, user_path);
|
|
|
|
strcat(scripts_path, PM3_USER_DIRECTORY);
|
|
|
|
strcat(scripts_path, PYTHON_SCRIPTS_SUBDIR);
|
|
|
|
// strcat(scripts_path, PYTHON_LIBRARIES_WILDCARD);
|
|
|
|
set_python_path(scripts_path);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (exec_path != NULL) {
|
|
|
|
// from the $PREFIX/share/proxmark3/luascripts/ directory
|
|
|
|
char scripts_path[strlen(exec_path) + strlen(PM3_SHARE_RELPATH) + strlen(PYTHON_SCRIPTS_SUBDIR) + strlen(PYTHON_LIBRARIES_WILDCARD) + 1];
|
|
|
|
strcpy(scripts_path, exec_path);
|
|
|
|
strcat(scripts_path, PM3_SHARE_RELPATH);
|
|
|
|
strcat(scripts_path, PYTHON_SCRIPTS_SUBDIR);
|
|
|
|
// strcat(scripts_path, PYTHON_LIBRARIES_WILDCARD);
|
|
|
|
set_python_path(scripts_path);
|
|
|
|
}
|
|
|
|
}
|
2020-05-26 19:09:18 +08:00
|
|
|
#endif
|
|
|
|
|
2019-08-22 06:32:15 +08:00
|
|
|
/**
|
|
|
|
* Generate a sorted list of available commands, what it does is
|
|
|
|
* generate a file listing of the script-directory for files
|
|
|
|
* ending with .lua
|
|
|
|
*/
|
|
|
|
static int CmdScriptList(const char *Cmd) {
|
|
|
|
(void)Cmd; // Cmd is not used so far
|
2019-09-10 05:46:38 +08:00
|
|
|
int ret = searchAndList(LUA_SCRIPTS_SUBDIR, ".lua");
|
|
|
|
if (ret != PM3_SUCCESS)
|
|
|
|
return ret;
|
2020-05-27 16:19:22 +08:00
|
|
|
|
2020-05-26 17:30:17 +08:00
|
|
|
ret = searchAndList(CMD_SCRIPTS_SUBDIR, ".cmd");
|
|
|
|
if (ret != PM3_SUCCESS)
|
|
|
|
return ret;
|
2020-05-27 07:15:20 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-26 17:30:17 +08:00
|
|
|
return searchAndList(PYTHON_SCRIPTS_SUBDIR, ".py");
|
2020-05-27 07:15:20 +08:00
|
|
|
#else
|
|
|
|
return ret;
|
|
|
|
#endif
|
2013-05-22 02:37:43 +08:00
|
|
|
}
|
2017-02-08 05:26:42 +08:00
|
|
|
|
2013-05-22 02:37:43 +08:00
|
|
|
/**
|
2017-10-20 20:37:50 +08:00
|
|
|
* @brief CmdScriptRun - executes a script file.
|
2013-05-22 02:37:43 +08:00
|
|
|
* @param argc
|
|
|
|
* @param argv
|
|
|
|
* @return
|
|
|
|
*/
|
2019-04-12 06:38:54 +08:00
|
|
|
static int CmdScriptRun(const char *Cmd) {
|
2013-09-17 03:04:29 +08:00
|
|
|
|
2019-08-24 05:07:05 +08:00
|
|
|
char preferredName[128] = {0};
|
2013-09-20 03:21:12 +08:00
|
|
|
char arguments[256] = {0};
|
2013-09-17 03:04:29 +08:00
|
|
|
|
|
|
|
int name_len = 0;
|
|
|
|
int arg_len = 0;
|
2019-09-10 18:32:01 +08:00
|
|
|
static uint8_t luascriptfile_idx = 0;
|
2019-08-24 05:07:05 +08:00
|
|
|
sscanf(Cmd, "%127s%n %255[^\n\r]%n", preferredName, &name_len, arguments, &arg_len);
|
2020-05-27 07:15:20 +08:00
|
|
|
if (strlen(preferredName) == 0) {
|
|
|
|
PrintAndLogEx(FAILED, "no script name provided");
|
2020-05-27 16:19:22 +08:00
|
|
|
PrintAndLogEx(HINT, "Hint: try " _YELLOW_("`script list`") " to see available scripts");
|
2020-05-27 07:15:20 +08:00
|
|
|
return PM3_EINVARG;
|
|
|
|
}
|
2020-05-26 17:30:17 +08:00
|
|
|
char *extension_chk;
|
|
|
|
extension_chk = str_dup(preferredName);
|
|
|
|
str_lower(extension_chk);
|
2020-05-27 06:40:01 +08:00
|
|
|
pm3_scriptfile_t ext = PM3_UNSPECIFIED;
|
|
|
|
if (str_endswith(extension_chk, ".lua")) {
|
|
|
|
ext = PM3_LUA;
|
|
|
|
} else if (str_endswith(extension_chk, ".cmd")) {
|
2020-05-26 17:30:17 +08:00
|
|
|
ext = PM3_CMD;
|
2020-05-26 18:00:42 +08:00
|
|
|
}
|
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-27 06:40:01 +08:00
|
|
|
else if (str_endswith(extension_chk, ".py")) {
|
2020-05-26 17:30:17 +08:00
|
|
|
ext = PM3_PY;
|
2020-05-26 18:00:42 +08:00
|
|
|
}
|
2020-05-26 17:49:26 +08:00
|
|
|
#endif
|
2020-05-27 03:58:50 +08:00
|
|
|
|
2019-10-09 18:46:01 +08:00
|
|
|
char *script_path = NULL;
|
2020-05-27 06:40:01 +08:00
|
|
|
if (((ext == PM3_LUA) || (ext == PM3_UNSPECIFIED)) && (searchFile(&script_path, LUA_SCRIPTS_SUBDIR, preferredName, ".lua", true) == PM3_SUCCESS)) {
|
2019-09-10 05:46:38 +08:00
|
|
|
int error;
|
2019-09-10 18:32:01 +08:00
|
|
|
if (luascriptfile_idx == MAX_NESTED_LUASCRIPT) {
|
2020-03-02 18:12:13 +08:00
|
|
|
PrintAndLogEx(ERR, "too many nested scripts, skipping %s\n", script_path);
|
2019-10-06 07:18:04 +08:00
|
|
|
free(script_path);
|
2019-09-10 18:32:01 +08:00
|
|
|
return PM3_EMALLOC;
|
|
|
|
}
|
2020-03-02 18:12:13 +08:00
|
|
|
PrintAndLogEx(SUCCESS, "executing lua " _YELLOW_("%s"), script_path);
|
|
|
|
PrintAndLogEx(SUCCESS, "args " _YELLOW_("'%s'"), arguments);
|
|
|
|
|
2019-09-10 18:32:01 +08:00
|
|
|
luascriptfile_idx++;
|
2019-09-10 05:46:38 +08:00
|
|
|
|
|
|
|
// create new Lua state
|
|
|
|
lua_State *lua_state;
|
|
|
|
lua_state = luaL_newstate();
|
|
|
|
|
|
|
|
// load Lua libraries
|
|
|
|
luaL_openlibs(lua_state);
|
|
|
|
|
|
|
|
//Sets the pm3 core libraries, that go a bit 'under the hood'
|
|
|
|
set_pm3_libraries(lua_state);
|
|
|
|
|
|
|
|
//Add the 'bin' library
|
|
|
|
set_bin_library(lua_state);
|
|
|
|
|
|
|
|
//Add the 'bit' library
|
|
|
|
set_bit_library(lua_state);
|
|
|
|
|
|
|
|
error = luaL_loadfile(lua_state, script_path);
|
|
|
|
free(script_path);
|
|
|
|
if (!error) {
|
|
|
|
lua_pushstring(lua_state, arguments);
|
|
|
|
lua_setglobal(lua_state, "args");
|
|
|
|
|
|
|
|
//Call it with 0 arguments
|
|
|
|
error = lua_pcall(lua_state, 0, LUA_MULTRET, 0); // once again, returns non-0 on error,
|
|
|
|
}
|
|
|
|
if (error) { // if non-0, then an error
|
|
|
|
// the top of the stack should be the error string
|
|
|
|
if (!lua_isstring(lua_state, lua_gettop(lua_state)))
|
2020-03-02 18:12:13 +08:00
|
|
|
PrintAndLogEx(FAILED, "error - but no error (?!)");
|
2019-09-10 05:46:38 +08:00
|
|
|
|
|
|
|
// get the top of the stack as the error and pop it off
|
|
|
|
const char *str = lua_tostring(lua_state, lua_gettop(lua_state));
|
|
|
|
lua_pop(lua_state, 1);
|
|
|
|
puts(str);
|
|
|
|
}
|
|
|
|
|
|
|
|
//luaL_dofile(lua_state, buf);
|
|
|
|
// close the Lua state
|
|
|
|
lua_close(lua_state);
|
2019-09-10 18:32:01 +08:00
|
|
|
luascriptfile_idx--;
|
2020-03-02 18:12:13 +08:00
|
|
|
PrintAndLogEx(SUCCESS, "\nfinished " _YELLOW_("%s"), preferredName);
|
2019-09-10 05:46:38 +08:00
|
|
|
return PM3_SUCCESS;
|
2013-05-25 05:05:45 +08:00
|
|
|
}
|
2020-03-02 18:12:13 +08:00
|
|
|
|
2020-05-27 06:40:01 +08:00
|
|
|
if (((ext == PM3_CMD) || (ext == PM3_UNSPECIFIED)) && (searchFile(&script_path, CMD_SCRIPTS_SUBDIR, preferredName, ".cmd", true) == PM3_SUCCESS)) {
|
2020-03-02 18:12:13 +08:00
|
|
|
|
|
|
|
PrintAndLogEx(SUCCESS, "executing Cmd " _YELLOW_("%s"), script_path);
|
|
|
|
PrintAndLogEx(SUCCESS, "args " _YELLOW_("'%s'"), arguments);
|
|
|
|
|
2019-09-10 05:46:38 +08:00
|
|
|
int ret = push_cmdscriptfile(script_path, true);
|
|
|
|
if (ret != PM3_SUCCESS)
|
|
|
|
PrintAndLogEx(ERR, "could not open " _YELLOW_("%s") "...", script_path);
|
|
|
|
free(script_path);
|
|
|
|
return ret;
|
2013-05-25 05:05:45 +08:00
|
|
|
}
|
2020-05-27 03:58:50 +08:00
|
|
|
|
|
|
|
/*
|
2020-05-26 17:30:17 +08:00
|
|
|
For apt (Ubuntu, Debian...):
|
|
|
|
sudo apt-get install python3-dev # for python3.x installs
|
|
|
|
|
|
|
|
For yum (CentOS, RHEL...):
|
|
|
|
sudo yum install python3-devel # for python3.x installs
|
|
|
|
|
|
|
|
For dnf (Fedora...):
|
|
|
|
sudo dnf install python3-devel # for python3.x installs
|
|
|
|
|
|
|
|
For zypper (openSUSE...):
|
|
|
|
sudo zypper in python3-devel # for python3.x installs
|
|
|
|
|
|
|
|
For apk (Alpine...):
|
|
|
|
|
|
|
|
# This is a departure from the normal Alpine naming
|
|
|
|
# scheme, which uses py2- and py3- prefixes
|
|
|
|
|
|
|
|
sudo apk add python3-dev # for python3.x installs
|
|
|
|
|
|
|
|
For apt-cyg (Cygwin...):
|
|
|
|
apt-cyg install python3-devel # for python3.x installs
|
|
|
|
*/
|
|
|
|
|
2020-05-26 18:00:42 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-27 03:58:50 +08:00
|
|
|
|
2020-05-27 06:40:01 +08:00
|
|
|
if (((ext == PM3_PY) || (ext == PM3_UNSPECIFIED)) && (searchFile(&script_path, PYTHON_SCRIPTS_SUBDIR, preferredName, ".py", true) == PM3_SUCCESS)) {
|
2020-05-27 03:58:50 +08:00
|
|
|
|
2020-05-26 19:09:18 +08:00
|
|
|
PrintAndLogEx(SUCCESS, "executing python " _YELLOW_("%s"), script_path);
|
2020-05-26 17:30:17 +08:00
|
|
|
PrintAndLogEx(SUCCESS, "args " _YELLOW_("'%s'"), arguments);
|
|
|
|
|
2020-05-26 18:35:26 +08:00
|
|
|
wchar_t *program = Py_DecodeLocale(preferredName, NULL);
|
2020-05-26 17:30:17 +08:00
|
|
|
if (program == NULL) {
|
2020-05-26 18:35:26 +08:00
|
|
|
PrintAndLogEx(ERR, "could not decode " _YELLOW_("%s"), preferredName);
|
2020-05-26 17:30:17 +08:00
|
|
|
free(script_path);
|
|
|
|
return PM3_ESOFT;
|
|
|
|
}
|
|
|
|
|
|
|
|
// optional but recommended
|
|
|
|
Py_SetProgramName(program);
|
|
|
|
Py_Initialize();
|
2020-05-26 18:35:26 +08:00
|
|
|
|
2020-05-26 19:09:18 +08:00
|
|
|
//int argc, char ** argv
|
|
|
|
char *argv[128];
|
|
|
|
int argc = split(arguments, argv);
|
|
|
|
wchar_t *py_args[argc];
|
|
|
|
py_args[0] = Py_DecodeLocale(preferredName, NULL);
|
|
|
|
for (int i = 0; i < argc; i++) {
|
|
|
|
py_args[i+1] = Py_DecodeLocale(argv[i], NULL);
|
|
|
|
}
|
2020-05-26 18:35:26 +08:00
|
|
|
|
2020-05-26 19:37:28 +08:00
|
|
|
PySys_SetArgv(argc+1, py_args);
|
2020-05-27 03:58:50 +08:00
|
|
|
|
2020-05-26 19:09:18 +08:00
|
|
|
// clean up
|
|
|
|
for (int i = 0; i < argc; ++i) {
|
|
|
|
free(argv[i]);
|
|
|
|
}
|
2020-05-27 03:58:50 +08:00
|
|
|
|
2020-05-26 20:41:58 +08:00
|
|
|
// setup search paths.
|
|
|
|
set_python_paths();
|
2020-05-27 03:58:50 +08:00
|
|
|
|
2020-05-26 17:30:17 +08:00
|
|
|
FILE *f = fopen(script_path, "r");
|
|
|
|
if (f == NULL) {
|
2020-05-26 18:00:42 +08:00
|
|
|
PrintAndLogEx(ERR, "Could open file " _YELLOW_("%s"), script_path);
|
2020-05-26 17:30:17 +08:00
|
|
|
free(script_path);
|
2020-05-27 03:58:50 +08:00
|
|
|
return PM3_ESOFT;
|
2020-05-26 17:30:17 +08:00
|
|
|
}
|
|
|
|
|
2020-05-26 19:09:18 +08:00
|
|
|
PyRun_SimpleFileExFlags(f, preferredName, 1, NULL);
|
2020-05-26 23:35:27 +08:00
|
|
|
Py_Finalize();
|
2020-05-26 17:30:17 +08:00
|
|
|
PyMem_RawFree(program);
|
|
|
|
free(script_path);
|
|
|
|
PrintAndLogEx(SUCCESS, "\nfinished " _YELLOW_("%s"), preferredName);
|
|
|
|
return PM3_SUCCESS;
|
|
|
|
}
|
2020-05-26 17:49:26 +08:00
|
|
|
#endif
|
2020-03-02 18:12:13 +08:00
|
|
|
|
2019-09-10 05:46:38 +08:00
|
|
|
// file not found, let's search again to display the error messages
|
|
|
|
int ret = PM3_EUNDEF;
|
2020-05-26 17:30:17 +08:00
|
|
|
if (ext == PM3_LUA)
|
|
|
|
ret = searchFile(&script_path, LUA_SCRIPTS_SUBDIR, preferredName, ".lua", false);
|
2020-05-27 06:40:01 +08:00
|
|
|
else if (ext == PM3_CMD)
|
2020-05-26 17:30:17 +08:00
|
|
|
ret = searchFile(&script_path, CMD_SCRIPTS_SUBDIR, preferredName, ".cmd", false);
|
2020-05-26 18:00:42 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
2020-05-27 06:40:01 +08:00
|
|
|
else if (ext == PM3_PY)
|
2020-05-26 17:30:17 +08:00
|
|
|
ret = searchFile(&script_path, PYTHON_SCRIPTS_SUBDIR, preferredName, ".py", false);
|
2020-05-27 06:40:01 +08:00
|
|
|
else if (ext == PM3_UNSPECIFIED)
|
|
|
|
PrintAndLogEx(FAILED, "Error - can't find %s.[lua|cmd|py]", preferredName);
|
2020-05-27 07:15:20 +08:00
|
|
|
#else
|
|
|
|
else if (ext == PM3_UNSPECIFIED)
|
|
|
|
PrintAndLogEx(FAILED, "Error - can't find %s.[lua|cmd]", preferredName);
|
|
|
|
#endif
|
2019-10-09 17:47:56 +08:00
|
|
|
free(script_path);
|
2019-09-10 05:46:38 +08:00
|
|
|
return ret;
|
2013-05-22 02:37:43 +08:00
|
|
|
}
|
|
|
|
|
2017-10-20 20:37:50 +08:00
|
|
|
static command_t CommandTable[] = {
|
2020-05-27 07:15:20 +08:00
|
|
|
{"help", CmdHelp, AlwaysAvailable, "Usage info"},
|
2019-05-02 02:48:15 +08:00
|
|
|
{"list", CmdScriptList, AlwaysAvailable, "List available scripts"},
|
2020-05-26 17:30:17 +08:00
|
|
|
{"run", CmdScriptRun, AlwaysAvailable, "<name> -- execute a script"},
|
2019-05-02 02:48:15 +08:00
|
|
|
{NULL, NULL, NULL, NULL}
|
2017-10-20 20:37:50 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2019-04-12 06:38:54 +08:00
|
|
|
* Shows some basic help
|
|
|
|
* @brief CmdHelp
|
2017-10-20 20:37:50 +08:00
|
|
|
* @param Cmd
|
|
|
|
* @return
|
|
|
|
*/
|
2019-04-12 06:38:54 +08:00
|
|
|
static int CmdHelp(const char *Cmd) {
|
|
|
|
(void)Cmd; // Cmd is not used so far
|
2020-05-27 07:15:20 +08:00
|
|
|
#ifdef HAVE_PYTHON
|
|
|
|
PrintAndLogEx(NORMAL, "This is a feature to run Lua/Cmd/Python scripts. You can place scripts within the luascripts/cmdscripts/pyscripts folders. ");
|
|
|
|
#else
|
|
|
|
PrintAndLogEx(NORMAL, "This is a feature to run Lua/Cmd scripts. You can place scripts within the luascripts/cmdscripts folders. ");
|
|
|
|
#endif
|
2020-03-02 18:12:13 +08:00
|
|
|
return PM3_SUCCESS;
|
2017-10-20 20:37:50 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-04-12 06:38:54 +08:00
|
|
|
* Finds a matching script-file
|
|
|
|
* @brief CmdScript
|
2017-10-20 20:37:50 +08:00
|
|
|
* @param Cmd
|
|
|
|
* @return
|
|
|
|
*/
|
2019-04-12 06:38:54 +08:00
|
|
|
int CmdScript(const char *Cmd) {
|
|
|
|
clearCommandBuffer();
|
2019-04-19 06:47:51 +08:00
|
|
|
return CmdsParse(CommandTable, Cmd);
|
2019-03-12 07:12:26 +08:00
|
|
|
}
|
2019-04-12 06:38:54 +08:00
|
|
|
|