This commit is contained in:
Andreas Bielawski 2016-09-08 00:29:35 +02:00
commit 9e66527008
5 changed files with 29 additions and 22 deletions

View File

@ -23,7 +23,7 @@
local bindings = {}
local https = require('ssl.https')
https.timeout = 10
https.TIMEOUT = 10
local json = require('dkjson')
local ltn12 = require('ltn12')
local mp_encode = require('multipart-post').encode

View File

@ -62,7 +62,6 @@ end
function bot:on_msg_receive(msg, config) -- The fn run whenever a message is received.
-- remove comment to enable debugging
-- vardump(msg)
-- Cache user info for those involved.
-- print messages
msg_time = '\27[36m'..convert_timestamp(msg.date, '[%H:%M:%S]')..'\27[0m'

View File

@ -22,6 +22,8 @@ function banhammer:init(config)
"^/(block) (delete)$",
"^/(kick) (%d+)$",
"^/(kick)$",
"^/(leave) (%-?%d+)",
"^/(leave) (@[A-Za-z0-9-_-]+)",
"^/(leave)$"
}
banhammer.doc = [[*
@ -183,12 +185,20 @@ function banhammer:action(msg, config, matches)
end
if matches[1] == 'leave' then
if msg.chat.type == 'group' or msg.chat.type == 'supergroup' then
bindings.request('leaveChat', {
if matches[2] then
chat_id = matches[2]
else
chat_id = msg.chat.id
} )
return
end
local result = bindings.request('leaveChat', {
chat_id = chat_id
} )
if matches[2] and result then
utilities.send_reply(msg, 'Chat verlassen!')
elseif matches[2] and not result then
utilities.send_reply(msg, 'Chat konnte nicht verlassen werden, ist die ID/der Name korrekt?')
end
return
end
if matches[1] == 'ban' then

View File

@ -23,9 +23,9 @@ end
function github:send_github_data(data)
if not data.owner then return nil end
local name = '*'..utilities.md_escape(data.name)..'*'
local description = '_'..utilities.md_escape(data.description)..'_'
local owner = utilities.md_escape(data.owner.login)
local name = '<b>'..data.name..'</b>'
local description = '<i>'..data.description..'</i>'
local owner = data.owner.login
local clone_url = data.clone_url
if data.language == nil or data.language == "" then
language = ''
@ -40,17 +40,17 @@ function github:send_github_data(data)
if data.homepage == nil or data.homepage == "" then
homepage = ''
else
homepage = '\n[Homepage besuchen]('..data.homepage..')'
homepage = '\n<a href="'..data.homepage..'">Homepage besuchen</a>'
end
local text = name..' von '..owner..'\n'..description..'\n`git clone '..clone_url..'`'..language..issues..homepage
local text = name..' von '..owner..'\n'..description..'\n<pre>git clone '..clone_url..'</pre>'..language..issues..homepage
return text
end
function github:send_gh_commit_data(gh_code, gh_commit_sha, data)
if not data.committer then return nil end
local committer = data.committer.name
if not data.author then return nil end
local author = data.author.name
local message = utilities.md_escape(data.message)
local text = '`'..gh_code..'@'..gh_commit_sha..'` von *'..committer..'*:\n'..message
local text = '<code>'..gh_code..'@'..gh_commit_sha..'</code> von <b>'..author..'</b>:\n'..message
return text
end
@ -63,7 +63,7 @@ function github:action(msg, config, matches)
else
output = github:send_gh_commit_data(gh_code, gh_commit_sha, data)
end
utilities.send_reply(msg, output, true)
utilities.send_reply(msg, output, 'HTML')
end
return github

View File

@ -35,8 +35,8 @@ OAuth = require 'OAuth'
helpers = require 'OAuth.helpers'
require('/miku/encoding')
http.timeout = 5
https.timeout = 5
http.TIMEOUT = 7
https.TIMEOUT = 7
-- For the sake of ease to new contributors and familiarity to old contributors,
-- we'll provide a couple of aliases to real bindings here.
@ -388,10 +388,8 @@ function run_command(str)
return result
end
function convert_timestamp(timestamp, format)
local converted_date = run_command('date -d @'..timestamp..' +"'..format..'"')
local converted_date = string.gsub(converted_date, '%\n', '')
return converted_date
function convert_timestamp(timestamp, date_format)
return os.date(date_format, timestamp)
end
function string.starts(String, Start)