commit
0483edb0c3
@ -8,15 +8,15 @@ local triggers = {
|
|||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
|
|
||||||
-- Filthy hack, but here is where we'll stop forwarded messages from hitting
|
-- Filthy hack, but here is where we'll stop forwarded messages from hitting
|
||||||
-- other plugins.
|
-- Other plugins.
|
||||||
if msg.forward_from then return end
|
if msg.forward_from then return end
|
||||||
|
|
||||||
local message = config.about_text .. '\nBased on @otouto v'..version..' by topkecleon.'
|
local output = config.about_text .. '\nBased on @otouto v'..version..' by topkecleon.'
|
||||||
|
|
||||||
if (msg.new_chat_participant and msg.new_chat_participant.id == bot.id)
|
if (msg.new_chat_participant and msg.new_chat_participant.id == bot.id)
|
||||||
or msg.text_lower:match('^/about[@'..bot.username..']*')
|
or msg.text_lower:match('^/about[@'..bot.username..']*')
|
||||||
or msg.text_lower:match('^/start') then
|
or msg.text_lower:match('^/start') then
|
||||||
sendMessage(msg.chat.id, message, true)
|
sendMessage(msg.chat.id, output, true)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,18 +20,18 @@ local action = function(msg)
|
|||||||
local message
|
local message
|
||||||
|
|
||||||
if math.random(10) == 10 then
|
if math.random(10) == 10 then
|
||||||
message = fullnames[math.random(#fullnames)]
|
output = fullnames[math.random(#fullnames)]
|
||||||
else
|
else
|
||||||
message = firstnames[math.random(#firstnames)] .. ' ' .. lastnames[math.random(#lastnames)]
|
output = firstnames[math.random(#firstnames)] .. ' ' .. lastnames[math.random(#lastnames)]
|
||||||
end
|
end
|
||||||
|
|
||||||
sendReply(msg, message)
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
return {
|
return {
|
||||||
action = action,
|
action = action,
|
||||||
triggers = triggers,
|
triggers = triggers,
|
||||||
command = command,
|
doc = doc,
|
||||||
desc = desc
|
command = command
|
||||||
}
|
}
|
||||||
|
@ -27,22 +27,22 @@ local action = function(msg)
|
|||||||
|
|
||||||
local url = 'http://api.biblia.com/v1/bible/content/ASV.txt?key=' .. config.biblia_api_key .. '&passage=' .. URL.escape(input)
|
local url = 'http://api.biblia.com/v1/bible/content/ASV.txt?key=' .. config.biblia_api_key .. '&passage=' .. URL.escape(input)
|
||||||
|
|
||||||
local message, res = HTTP.request(url)
|
local output, res = HTTP.request(url)
|
||||||
|
|
||||||
if not message or res ~= 200 or message:len() == 0 then
|
if not output or res ~= 200 or output:len() == 0 then
|
||||||
url = 'http://api.biblia.com/v1/bible/content/KJVAPOC.txt?key=' .. config.biblia_api_key .. '&passage=' .. URL.escape(input)
|
url = 'http://api.biblia.com/v1/bible/content/KJVAPOC.txt?key=' .. config.biblia_api_key .. '&passage=' .. URL.escape(input)
|
||||||
message, res = HTTP.request(url)
|
output, res = HTTP.request(url)
|
||||||
end
|
end
|
||||||
|
|
||||||
if not message or res ~= 200 or message:len() == 0 then
|
if not output or res ~= 200 or output:len() == 0 then
|
||||||
message = config.errors.results
|
output = config.errors.results
|
||||||
end
|
end
|
||||||
|
|
||||||
if message:len() > 4000 then
|
if output:len() > 4000 then
|
||||||
message = 'The text is too long to post here. Try being more specific.'
|
output = 'The text is too long to post here. Try being more specific.'
|
||||||
end
|
end
|
||||||
|
|
||||||
sendReply(msg, message)
|
sendMessage(msg.chat.id, output, true, msg.message_id, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ local action = function(msg)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
output = '`' .. output .. '`'
|
output = '*Result:* `' .. output .. '`'
|
||||||
|
|
||||||
sendMessage(msg.chat.id, output, true, msg.message_id, true)
|
sendMessage(msg.chat.id, output, true, msg.message_id, true)
|
||||||
|
|
||||||
|
@ -53,10 +53,10 @@ local action = function(msg)
|
|||||||
sendMessage(msg.chat.id, config.errors.chatter_response)
|
sendMessage(msg.chat.id, config.errors.chatter_response)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local message = jdat.response
|
local output = jdat.response
|
||||||
|
|
||||||
if message:match('^I HAVE NO RESPONSE.') then
|
if output:match('^I HAVE NO RESPONSE.') then
|
||||||
message = config.errors.chatter_response
|
output = config.errors.chatter_response
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Let's clean up the response a little. Capitalization & punctuation.
|
-- Let's clean up the response a little. Capitalization & punctuation.
|
||||||
@ -68,14 +68,14 @@ local action = function(msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
for k,v in pairs(filter) do
|
for k,v in pairs(filter) do
|
||||||
message = string.gsub(message, k, v)
|
output = string.gsub(output, k, v)
|
||||||
end
|
end
|
||||||
|
|
||||||
if not string.match(message, '%p$') then
|
if not string.match(output, '%p$') then
|
||||||
message = message .. '.'
|
output = output .. '.'
|
||||||
end
|
end
|
||||||
|
|
||||||
sendMessage(msg.chat.id, message)
|
sendMessage(msg.chat.id, output)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -418,7 +418,8 @@ local commits = {
|
|||||||
|
|
||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
|
|
||||||
sendMessage(msg.chat.id, '`'..commits[math.random(#commits)]..'`', true, nil, true)
|
local output = '*Commit:* '..commits[math.random(#commits)]
|
||||||
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -45,9 +45,8 @@ local action = function(msg)
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local output = amount .. ' ' .. from .. ' = ' .. result .. ' ' .. to .. '\n\n'
|
local output = '*' .. amount .. ' ' .. from .. ' = ' .. result .. ' ' .. to .. '*\n\n'
|
||||||
output = output .. os.date('!%F %T UTC') .. '\nSource: Google Finance'
|
output = output .. '`' .. os.date('!%F %T UTC') .. '\nSource: Google Finance`'
|
||||||
output = '`' .. output .. '`'
|
|
||||||
|
|
||||||
sendMessage(msg.chat.id, output, true, nil, true)
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ local action = function(msg)
|
|||||||
else
|
else
|
||||||
local output
|
local output
|
||||||
if msg.chat.type == 'supergroup' then
|
if msg.chat.type == 'supergroup' then
|
||||||
output = 'Echo:\n"' .. input .. '"'
|
output = 'Echo:\n"' .. markdown_escape(input) .. '"'
|
||||||
else
|
else
|
||||||
output = latcyr(input)
|
output = latcyr(input)
|
||||||
end
|
end
|
||||||
|
@ -39,15 +39,15 @@ local yesno_answers = {
|
|||||||
|
|
||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
|
|
||||||
local message
|
local output
|
||||||
|
|
||||||
if msg.text_lower:match('y/n%p?$') then
|
if msg.text_lower:match('y/n%p?$') then
|
||||||
message = yesno_answers[math.random(#yesno_answers)]
|
output = yesno_answers[math.random(#yesno_answers)]
|
||||||
else
|
else
|
||||||
message = ball_answers[math.random(#ball_answers)]
|
output = ball_answers[math.random(#ball_answers)]
|
||||||
end
|
end
|
||||||
|
|
||||||
sendReply(msg, message)
|
sendReply(msg, output)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -16,8 +16,8 @@ local triggers = {
|
|||||||
|
|
||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
|
|
||||||
local message = io.popen('fortune'):read('*all')
|
local output = io.popen('fortune'):read('*all')
|
||||||
sendMessage(msg.chat.id, message)
|
sendMessage(msg.chat.id, output)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -64,7 +64,8 @@ local action = function(msg)
|
|||||||
|
|
||||||
|
|
||||||
if msg.text:match('nsfw') then
|
if msg.text:match('nsfw') then
|
||||||
sendReply(msg, result)
|
output = 'NSFW Image ' .. output
|
||||||
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
else
|
else
|
||||||
sendMessage(msg.chat.id, output, false, nil, true)
|
sendMessage(msg.chat.id, output, false, nil, true)
|
||||||
end
|
end
|
||||||
|
@ -13,6 +13,8 @@ local triggers = {
|
|||||||
|
|
||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
|
|
||||||
|
sendChatAction(msg.chat.id, "find_location")
|
||||||
|
|
||||||
local input = msg.text:input()
|
local input = msg.text:input()
|
||||||
if not input then
|
if not input then
|
||||||
if msg.reply_to_message and msg.reply_to_message.text then
|
if msg.reply_to_message and msg.reply_to_message.text then
|
||||||
|
@ -11,8 +11,6 @@ local triggers = {
|
|||||||
|
|
||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
|
|
||||||
sendChatAction(msg.chat.id, 'typing')
|
|
||||||
|
|
||||||
local jstr, res = HTTPS.request('https://hacker-news.firebaseio.com/v0/topstories.json')
|
local jstr, res = HTTPS.request('https://hacker-news.firebaseio.com/v0/topstories.json')
|
||||||
if res ~= 200 then
|
if res ~= 200 then
|
||||||
sendReply(msg, config.errors.connection)
|
sendReply(msg, config.errors.connection)
|
||||||
|
@ -38,7 +38,7 @@ local action = function(msg)
|
|||||||
local output = '[' .. jdat.Title .. '](http://imdb.com/title/'
|
local output = '[' .. jdat.Title .. '](http://imdb.com/title/'
|
||||||
output = output .. jdat.imdbID .. ') ('.. jdat.Year ..')\n'
|
output = output .. jdat.imdbID .. ') ('.. jdat.Year ..')\n'
|
||||||
output = output .. jdat.imdbRating ..'/10 | '.. jdat.Runtime ..' | '.. jdat.Genre ..'\n'
|
output = output .. jdat.imdbRating ..'/10 | '.. jdat.Runtime ..' | '.. jdat.Genre ..'\n'
|
||||||
output = output .. jdat.Plot
|
output = output .. '`' .. jdat.Plot .. '`'
|
||||||
|
|
||||||
sendMessage(msg.chat.id, output, true, nil, true)
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
|
|
||||||
|
@ -45,14 +45,14 @@ local action = function(msg)
|
|||||||
local url = 'http://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&format=json&limit=1&api_key=' .. config.lastfm_api_key .. '&user='
|
local url = 'http://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&format=json&limit=1&api_key=' .. config.lastfm_api_key .. '&user='
|
||||||
|
|
||||||
local username
|
local username
|
||||||
local output = ''
|
local alert = ''
|
||||||
if input then
|
if input then
|
||||||
username = input
|
username = input
|
||||||
elseif database.users[msg.from.id_str].lastfm then
|
elseif database.users[msg.from.id_str].lastfm then
|
||||||
username = database.users[msg.from.id_str].lastfm
|
username = database.users[msg.from.id_str].lastfm
|
||||||
elseif msg.from.username then
|
elseif msg.from.username then
|
||||||
username = msg.from.username
|
username = msg.from.username
|
||||||
output = '\n\nYour username has been set to ' .. username .. '.\nTo change it, use /fmset <username>.'
|
alert = '\n\nYour username has been set to ' .. username .. '.\nTo change it, use /fmset <username>.'
|
||||||
database.users[msg.from.id_str].lastfm = username
|
database.users[msg.from.id_str].lastfm = username
|
||||||
else
|
else
|
||||||
sendReply(msg, 'Please specify your last.fm username or set it with /fmset.')
|
sendReply(msg, 'Please specify your last.fm username or set it with /fmset.')
|
||||||
@ -75,17 +75,17 @@ local action = function(msg)
|
|||||||
|
|
||||||
local jdat = jdat.recenttracks.track[1] or jdat.recenttracks.track
|
local jdat = jdat.recenttracks.track[1] or jdat.recenttracks.track
|
||||||
if not jdat then
|
if not jdat then
|
||||||
sendReply(msg, 'No history for this user.' .. output)
|
sendReply(msg, 'No history for this user.' .. alert)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local message = input or msg.from.first_name
|
local output = input or msg.from.first_name
|
||||||
message = '🎵 ' .. message
|
output = '🎵 ' .. output
|
||||||
|
|
||||||
if jdat['@attr'] and jdat['@attr'].nowplaying then
|
if jdat['@attr'] and jdat['@attr'].nowplaying then
|
||||||
message = message .. ' is currently listening to:\n'
|
output = output .. ' is currently listening to:\n'
|
||||||
else
|
else
|
||||||
message = message .. ' last listened to:\n'
|
output = output .. ' last listened to:\n'
|
||||||
end
|
end
|
||||||
|
|
||||||
local title = jdat.name or 'Unknown'
|
local title = jdat.name or 'Unknown'
|
||||||
@ -94,8 +94,8 @@ local action = function(msg)
|
|||||||
artist = jdat.artist['#text']
|
artist = jdat.artist['#text']
|
||||||
end
|
end
|
||||||
|
|
||||||
message = message .. title .. ' - ' .. artist .. output
|
output = output .. title .. ' - ' .. artist .. alert
|
||||||
sendMessage(msg.chat.id, message)
|
sendMessage(msg.chat.id, output)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -28,10 +28,10 @@ local action = function(msg)
|
|||||||
if not input then
|
if not input then
|
||||||
sendMessage(msg.chat.id, doc, true, msg.message_id, true)
|
sendMessage(msg.chat.id, doc, true, msg.message_id, true)
|
||||||
elseif input == '-' then
|
elseif input == '-' then
|
||||||
database.lastfm[msg.from.id_str] = nil
|
database.librefm[msg.from.id_str] = nil
|
||||||
sendReply(msg, 'Your libre.fm username has been forgotten.')
|
sendReply(msg, 'Your libre.fm username has been forgotten.')
|
||||||
else
|
else
|
||||||
database.lastfm[msg.from.id_str] = input
|
database.librefm[msg.from.id_str] = input
|
||||||
sendReply(msg, 'Your libre.fm username has been set to "' .. input .. '".')
|
sendReply(msg, 'Your libre.fm username has been set to "' .. input .. '".')
|
||||||
end
|
end
|
||||||
return
|
return
|
||||||
@ -40,15 +40,15 @@ local action = function(msg)
|
|||||||
local url = 'http://alpha.libre.fm/2.0/?method=user.getrecenttracks&format=json&limit=1&api_key=0&user='
|
local url = 'http://alpha.libre.fm/2.0/?method=user.getrecenttracks&format=json&limit=1&api_key=0&user='
|
||||||
|
|
||||||
local username
|
local username
|
||||||
local output = ''
|
local alert = ''
|
||||||
if input then
|
if input then
|
||||||
username = input
|
username = input
|
||||||
elseif database.lastfm[msg.from.id_str] then
|
elseif database.librefm[msg.from.id_str] then
|
||||||
username = database.lastfm[msg.from.id_str]
|
username = database.librefm[msg.from.id_str]
|
||||||
elseif msg.from.username then
|
elseif msg.from.username then
|
||||||
username = msg.from.username
|
username = msg.from.username
|
||||||
output = '\n\nYour username has been set to ' .. username .. '.\nTo change it, use /lfmset <username>.'
|
alert = '\n\nYour username has been set to ' .. username .. '.\nTo change it, use /lfmset <username>.'
|
||||||
database.lastfm[msg.from.id_str] = username
|
database.librefm[msg.from.id_str] = username
|
||||||
else
|
else
|
||||||
sendReply(msg, 'Please specify your libre.fm username or set it with /lfmset.')
|
sendReply(msg, 'Please specify your libre.fm username or set it with /lfmset.')
|
||||||
return
|
return
|
||||||
@ -70,17 +70,17 @@ local action = function(msg)
|
|||||||
|
|
||||||
local jdat = jdat.recenttracks.track[1] or jdat.recenttracks.track
|
local jdat = jdat.recenttracks.track[1] or jdat.recenttracks.track
|
||||||
if not jdat then
|
if not jdat then
|
||||||
sendReply(msg, 'No history for this user.' .. output)
|
sendReply(msg, 'No history for this user.' .. alert)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local message = input or msg.from.first_name
|
local output = input or msg.from.first_name
|
||||||
message = '🎵 ' .. message
|
output = '🎵 ' .. output
|
||||||
|
|
||||||
if jdat['@attr'] and jdat['@attr'].nowplaying then
|
if jdat['@attr'] and jdat['@attr'].nowplaying then
|
||||||
message = message .. ' is currently listening to:\n'
|
output = output .. ' is currently listening to:\n'
|
||||||
else
|
else
|
||||||
message = message .. ' last listened to:\n'
|
output = output .. ' last listened to:\n'
|
||||||
end
|
end
|
||||||
|
|
||||||
local title = jdat.name or 'Unknown'
|
local title = jdat.name or 'Unknown'
|
||||||
@ -89,8 +89,8 @@ local action = function(msg)
|
|||||||
artist = jdat.artist['#text']
|
artist = jdat.artist['#text']
|
||||||
end
|
end
|
||||||
|
|
||||||
message = message .. title .. ' - ' .. artist .. output
|
output = output .. title .. ' - ' .. artist .. alert
|
||||||
sendMessage(msg.chat.id, message)
|
sendMessage(msg.chat.id, output)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ local action = function(msg)
|
|||||||
output = target.name .. '\'s nickname has been set to "' .. input .. '".'
|
output = target.name .. '\'s nickname has been set to "' .. input .. '".'
|
||||||
end
|
end
|
||||||
|
|
||||||
sendReply(msg, output)
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -12,8 +12,8 @@ local action = function(msg)
|
|||||||
local m1, m2 = msg.text:match('^/?s/(.-)/(.-)/?$')
|
local m1, m2 = msg.text:match('^/?s/(.-)/(.-)/?$')
|
||||||
if not m2 then return true end
|
if not m2 then return true end
|
||||||
output = output:gsub(m1, m2)
|
output = output:gsub(m1, m2)
|
||||||
output = 'Did you mean:\n"' .. output:sub(1, 4000) .. '"'
|
output = '*Did you mean:*\n"' .. output:sub(1, 4000) .. '"'
|
||||||
sendReply(msg.reply_to_message, output)
|
sendMessage(msg.chat.id, output, true, msg.message_id, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ local triggers = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
local action = function(msg)
|
local action = function(msg)
|
||||||
sendMessage(msg.chat.id, msg.text_lower:match('^/ping') and 'Pong!' or 'Annyong.')
|
sendMessage(msg.chat.id, msg.text_lower:match('^/ping') and '*Pong!*' or '*Annyong.*', true, nil, true)
|
||||||
end
|
end
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
@ -71,8 +71,8 @@ local cron = function()
|
|||||||
-- If the reminder is past-due, send it and nullify it.
|
-- If the reminder is past-due, send it and nullify it.
|
||||||
-- Otherwise, add it to the replacement table.
|
-- Otherwise, add it to the replacement table.
|
||||||
if time > reminder.time then
|
if time > reminder.time then
|
||||||
local output = 'Reminder:\n"' .. reminder.message .. '"'
|
local output = '*Reminder:*\n"' .. markdown_escape(reminder.message) .. '"'
|
||||||
local res = sendMessage(chat_id, output, true)
|
local res = sendMessage(chat_id, output, true, nil, true)
|
||||||
-- If the message fails to send, save it for later.
|
-- If the message fails to send, save it for later.
|
||||||
if res then
|
if res then
|
||||||
reminder = nil
|
reminder = nil
|
||||||
|
@ -41,9 +41,9 @@ local action = function(msg)
|
|||||||
if utcoff == math.abs(utcoff) then
|
if utcoff == math.abs(utcoff) then
|
||||||
utcoff = '+' .. utcoff
|
utcoff = '+' .. utcoff
|
||||||
end
|
end
|
||||||
local message = os.date('%I:%M %p\n', timestamp) .. os.date('%A, %B %d, %Y\n', timestamp) .. jdat.timeZoneName .. ' (UTC' .. utcoff .. ')'
|
local output = '`' .. os.date('%I:%M %p\n', timestamp) .. os.date('%A, %B %d, %Y\n', timestamp) .. jdat.timeZoneName .. ' (UTC' .. utcoff .. ')' .. '`'
|
||||||
|
|
||||||
sendReply(msg, message)
|
sendMessage(msg.chat.id, output, true, nil, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -36,9 +36,9 @@ local action = function(msg)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local output = jdat.text[1]
|
local output = jdat.text[1]
|
||||||
output = 'Translation:\n"' .. output .. '"'
|
output = '*Translation:*\n"' .. output .. '"'
|
||||||
|
|
||||||
sendReply(msg.reply_to_message or msg, output)
|
sendMessage(msg.chat.id, output, true, msg.message_id, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -48,9 +48,9 @@ local action = function(msg)
|
|||||||
|
|
||||||
local celsius = string.format('%.2f', jdat.main.temp - 273.15)
|
local celsius = string.format('%.2f', jdat.main.temp - 273.15)
|
||||||
local fahrenheit = string.format('%.2f', celsius * (9/5) + 32)
|
local fahrenheit = string.format('%.2f', celsius * (9/5) + 32)
|
||||||
local message = celsius .. '°C | ' .. fahrenheit .. '°F, ' .. jdat.weather[1].description .. '.'
|
local output = celsius .. '°C | ' .. fahrenheit .. '°F, ' .. jdat.weather[1].description .. '.'
|
||||||
|
|
||||||
sendReply(msg, message)
|
sendMessage(msg.chat.id, output, true, msg.message_id, true)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user