new sendfilecontent plugin

Wed, 20 Aug 2014 12:05:46 +0200

author
Marc Fauser
date
Wed, 20 Aug 2014 12:05:46 +0200
changeset 102
f1166645a56c
parent 101
956242b7d5df
child 103
45843df81db0

new sendfilecontent plugin
- todo: add full or relative path possibility. not only current path

clix.lua file | annotate | diff | comparison | revisions
clix/sendfilecontent.lua file | annotate | diff | comparison | revisions
squishy file | annotate | diff | comparison | revisions
--- a/clix.lua	Sun Mar 31 02:56:39 2013 +0100
+++ b/clix.lua	Wed Aug 20 12:05:46 2014 +0200
@@ -10,7 +10,8 @@
 
 -- Global to allow commands to add to it
 short_opts = { v = "verbose", q = "quiet", t = "to", f = "from", e = "type",
-	a = "account", p = "password", r = "resource", o = "presence", c = "chatroom", i = "interactive" }
+	a = "account", p = "password", r = "resource", o = "presence", c = "chatroom", i = "interactive",
+    f = "file" }
 
 if #arg < 1 then
 	print("Command Line XMPP, available commands:");
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/clix/sendfilecontent.lua	Wed Aug 20 12:05:46 2014 +0200
@@ -0,0 +1,25 @@
+return function (opts, arg)
+	if opts.short_help then
+		print("Send file content");
+		return;
+	end
+	local function on_connect(conn)
+		local function send_message(text)
+			conn:send(verse.message({ to = opts.to,
+				type = opts.type or (opts.chatroom and "groupchat") or "chat" })
+				:body(text));
+		end
+		if opts.file then
+            local f = io.open(opts.file, "rb")
+            local content = f:read("*all")
+            f:close()
+            if content:len() < 2000 then
+                send_message(content);
+            else
+                conn:error("File size too large. Cannot send file"); 
+            end
+            conn:close();
+		end
+	end
+	clix_connect(opts, on_connect);
+end
--- a/squishy	Sun Mar 31 02:56:39 2013 +0100
+++ b/squishy	Wed Aug 20 12:05:46 2014 +0200
@@ -1,5 +1,6 @@
 local commands = {
 	"send";
+	"sendfilecontent";
 	"receive";
 	"version";
 	"bounce";

mercurial