prosodyctl: The install, remove and list commands now work by calling the execute_command function
authorJoão Duarte <jvsDuarte08@gmail.com>
Wed, 31 Jul 2019 11:01:36 -0700
changeset 10192 dbd9880bf5c6
parent 10191 85725e11c509
child 10193 d311168c71d1
prosodyctl: The install, remove and list commands now work by calling the execute_command function
prosodyctl
--- a/prosodyctl	Wed Jul 31 11:00:20 2019 -0700
+++ b/prosodyctl	Wed Jul 31 11:01:36 2019 -0700
@@ -76,9 +76,7 @@
 local show_yesno = prosodyctl.show_yesno;
 local show_prompt = prosodyctl.show_prompt;
 local read_password = prosodyctl.read_password;
-local check_flags = prosodyctl.check_flags;
-local call_luarocks = prosodyctl.call_luarocks;
-local get_path_custom_plugins = prosodyctl.get_path_custom_plugins;
+local execute_command = prosodyctl.execute_command;
 
 local jid_split = require "util.jid".prepped_split;
 
@@ -92,16 +90,8 @@
 		show_usage([[install]], [[Installs a prosody/luarocks plugin]]);
 		return 1;
 	end
-	local operation = "install";
-	local tree, mod, dir = check_flags(arg);
-	if tree then
-		call_luarocks(operation, mod, dir);
-		return 0;
-	else
-		dir = get_path_custom_plugins(prosody.paths.plugins);
-		call_luarocks(operation, mod, dir);
-		return 0;
-	end
+	table.insert(arg, "install");
+	execute_command(arg);
 end
 
 function commands.remove(arg)
@@ -109,16 +99,8 @@
 		show_usage([[remove]], [[Removes a module installed in the wroking directory's plugins folder]]);
 		return 1;
 	end
-	local operation = "remove";
-	local tree, mod, dir = check_flags(arg);
-	if tree then
-		call_luarocks(operation, mod, dir);
-		return 0;
-	else
-		dir = get_path_custom_plugins(prosody.paths.plugins);
-		call_luarocks(operation, mod, dir);
-		return 0;
-	end
+	table.insert(arg, "remove");
+	execute_command(arg);
 end
 
 function commands.list(arg)
@@ -126,16 +108,8 @@
 		show_usage([[list]], [[Shows installed rocks]]);
 		return 1;
 	end
-	local operation = "list";
-	local tree, mod, dir = check_flags(arg);
-	if tree then
-		call_luarocks(operation, mod, dir);
-		return 0;
-	else
-		dir = get_path_custom_plugins(prosody.paths.plugins);
-		call_luarocks(operation, mod, dir);
-		return 0;
-	end
+	table.insert(arg, "list");
+	execute_command(arg);
 end
 
 function commands.enabled_plugins(arg)