diff --git a/otouto/bot.lua b/otouto/bot.lua index b7dcae8..416ee4f 100644 --- a/otouto/bot.lua +++ b/otouto/bot.lua @@ -3,7 +3,7 @@ local bot = {} bindings = require('otouto.bindings') utilities = require('otouto.utilities') -bot.version = '2.2.5.1' +bot.version = '2.2.5.1b' function bot:init(config) -- The function run when the bot is started or reloaded. cred_data = load_cred() diff --git a/otouto/plugins/gMaps.lua b/otouto/plugins/gMaps.lua index 186784c..dcdd03e 100644 --- a/otouto/plugins/gMaps.lua +++ b/otouto/plugins/gMaps.lua @@ -19,7 +19,7 @@ function gMaps:get_staticmap(area, lat, lon) return file end -function gMaps:inline_callback(inline_query, config) +function gMaps:inline_callback(inline_query, config, matches) local place = matches[1] local coords = utilities.get_coords(place, config) if type(coords) == 'string' then utilities.answer_inline_query(self, inline_query) return end diff --git a/otouto/plugins/gps.lua b/otouto/plugins/gps.lua index 86baac8..66a3add 100644 --- a/otouto/plugins/gps.lua +++ b/otouto/plugins/gps.lua @@ -21,7 +21,7 @@ function gps:init(config) ]]..config.cmd_pat..[[gps* __,__: Sendet Karte mit diesen Koordinaten]] end -function gps:inline_callback(inline_query, config) +function gps:inline_callback(inline_query, config, matches) local lat = matches[1] local lon = matches[2] diff --git a/otouto/plugins/help.lua b/otouto/plugins/help.lua index e8c635d..7ded719 100644 --- a/otouto/plugins/help.lua +++ b/otouto/plugins/help.lua @@ -6,14 +6,19 @@ local help = {} local help_text function help:init(config) - help.triggers = utilities.triggers(self.info.username, config.cmd_pat):t('hilfe', true):t('help', true).table + help.triggers = { + "^/hilfe (.+)", + "^/help (.+)", + "^/(hilfe)_(.+)", + "^/hilfe" + } help.inline_triggers = { "^hilfe (.+)", "^help (.+)" } end -function help:inline_callback(inline_query, config) +function help:inline_callback(inline_query, config, matches) local query = matches[1] for _,plugin in ipairs(self.plugins) do @@ -23,51 +28,56 @@ function help:inline_callback(inline_query, config) local doc = doc:gsub('\\n', '\\\n') local chosen_plugin = utilities.get_word(plugin.command, 1) local results = '[{"type":"article","id":"'..math.random(100000000000000000)..'","title":"Hilfe für '..chosen_plugin..'","description":"Hilfe für das Plugin \\"'..chosen_plugin..'\\" wird gepostet.","thumb_url":"https://anditest.perseus.uberspace.de/inlineQuerys/help/hilfe.jpg","input_message_content":{"message_text":"'..doc..'","parse_mode":"Markdown"}}]' - local results, err = utilities.answer_inline_query(self, inline_query, results, 600) + utilities.answer_inline_query(self, inline_query, results, 600, nil, nil, 'Hilfe anzeigen', 'hilfe_'..chosen_plugin) end end utilities.answer_inline_query(self, inline_query) end -function help:action(msg, config) - local commandlist = {} - help_text = '*Verfügbare Befehle:*\n• '..config.cmd_pat +function help:action(msg, config, matches) + if matches[2] then + input = matches[2] + elseif matches[1] ~= '/hilfe' then + input = matches[1] + else + input = nil + end + + -- Attempts to send the help message via PM. + -- If msg is from a group, it tells the group whether the PM was successful. + if not input then + local commandlist = {} + local help_text = '*Verfügbare Befehle:*\n• '..config.cmd_pat for _,plugin in ipairs(self.plugins) do - if plugin.command then - - table.insert(commandlist, plugin.command) - end + if plugin.command then + table.insert(commandlist, plugin.command) + end end table.insert(commandlist, 'hilfe [Befehl]') table.sort(commandlist) - help_text = help_text .. table.concat(commandlist, '\n• '..config.cmd_pat) .. '\nParameter: [optional]' + local help_text = help_text .. table.concat(commandlist, '\n• '..config.cmd_pat) .. '\nParameter: [optional]' + local help_text = help_text:gsub('%[', '\\[') - help_text = help_text:gsub('%[', '\\[') - local input = utilities.input(msg.text_lower) - - -- Attempts to send the help message via PM. - -- If msg is from a group, it tells the group whether the PM was successful. - if not input then - local res = utilities.send_message(self, msg.from.id, help_text, true, nil, true) - if not res then - utilities.send_reply(self, msg, 'Bitte schreibe mir zuerst [privat](http://telegram.me/' .. self.info.username .. '?start=help) für eine Hilfe.', true) - elseif msg.chat.type ~= 'private' then - utilities.send_reply(self, msg, 'Ich habe dir die Hilfe per PN gesendet!.') - end - return + local res = utilities.send_message(self, msg.from.id, help_text, true, nil, true) + if not res then + utilities.send_reply(self, msg, 'Bitte schreibe mir zuerst [privat](http://telegram.me/' .. self.info.username .. '?start=help) für eine Hilfe.', true) + elseif msg.chat.type ~= 'private' then + utilities.send_reply(self, msg, 'Ich habe dir die Hilfe privat gesendet!.') end + return + end - for _,plugin in ipairs(self.plugins) do - if plugin.command and utilities.get_word(plugin.command, 1) == input and plugin.doc then - local output = '*Hilfe für* _' .. utilities.get_word(plugin.command, 1) .. '_ *:*' .. plugin.doc - utilities.send_message(self, msg.chat.id, output, true, nil, true) - return - end + for _,plugin in ipairs(self.plugins) do + if plugin.command and utilities.get_word(plugin.command, 1) == input and plugin.doc then + local output = '*Hilfe für* _' .. utilities.get_word(plugin.command, 1) .. '_ *:*' .. plugin.doc + utilities.send_message(self, msg.chat.id, output, true, nil, true) + return end + end - utilities.send_reply(self, msg, 'Für diesen Befehl gibt es keine Hilfe.') + utilities.send_reply(self, msg, 'Für diesen Befehl gibt es keine Hilfe.') end -return help +return help \ No newline at end of file diff --git a/otouto/plugins/time.lua b/otouto/plugins/time.lua index 779e2cf..5226495 100644 --- a/otouto/plugins/time.lua +++ b/otouto/plugins/time.lua @@ -4,6 +4,10 @@ time.command = 'time ' function time:init(config) time.triggers = utilities.triggers(self.info.username, config.cmd_pat):t('time', true).table + time.inline_triggers = { + "^time (.+)", + "^time" + } time.doc = [[* ]]..config.cmd_pat..[[time*: Aktuelle Zeit in Deutschland *]]..config.cmd_pat..[[time* __: Gibt Zeit an diesem Ort aus]] @@ -45,6 +49,47 @@ function time:localize(output) return output end +function time:get_time(coords) + local now = os.time() + local utc = os.time(os.date("!*t", now)) + + local url = 'https://maps.googleapis.com/maps/api/timezone/json?location=' .. coords.lat ..','.. coords.lon .. '×tamp='..utc..'&language=de' + local jstr, res = https.request(url) + if res ~= 200 then return nil end + + local jdat = json.decode(jstr) + local place = string.gsub(jdat.timeZoneId, '_', ' ' ) + local place = time:localize(place) + local timezoneid = '*'..place..'*' + local timestamp = now + jdat.rawOffset + jdat.dstOffset + local utcoff = (jdat.rawOffset + jdat.dstOffset) / 3600 + if utcoff == math.abs(utcoff) then + utcoff = '+'.. utilities.pretty_float(utcoff) + else + utcoff = utilities.pretty_float(utcoff) + end + -- "%A, %d. %B %Y, %H:%M:%S Uhr" + local time_there = os.date('!%A, %d. %B %Y, %H:%M:%S Uhr',timestamp) + local output = timezoneid..':\n'..time_there + + return output..'\n_'..jdat.timeZoneName .. ' (UTC' .. utcoff .. ')_', place, time_there +end + +function time:inline_callback(inline_query, config, matches) + if matches[1] == 'time' then + local desc_time = os.date("%A, %d. %B %Y, %H:%M:%S Uhr") + local cur_time = time:localize(os.date("%A, %d. %B %Y, *%H:%M:%S Uhr*")) + results = '[{"type":"article","id":"'..math.random(100000000000000000)..'","title":"Europa/Berlin","description":"'..desc_time..'","thumb_url":"https://anditest.perseus.uberspace.de/inlineQuerys/time/clock.jpg","input_message_content":{"message_text":"'..cur_time..'","parse_mode":"Markdown"}}]' + else + local coords = utilities.get_coords(matches[1], config) + if type(coords) == 'string' then utilities.answer_inline_query(self, inline_query) return end + local output, place, desc_time = time:get_time(coords) + if not output then utilities.answer_inline_query(self, inline_query) return end + results = '[{"type":"article","id":"'..math.random(100000000000000000)..'","title":"'..place..'","description":"'..desc_time..'","thumb_url":"https://anditest.perseus.uberspace.de/inlineQuerys/time/clock.jpg","input_message_content":{"message_text":"'..output..'","parse_mode":"Markdown"}}]' + end + utilities.answer_inline_query(self, inline_query, results, 1) +end + function time:action(msg, config) local input = utilities.input(msg.text) if not input then @@ -58,31 +103,8 @@ function time:action(msg, config) utilities.send_reply(self, msg, coords) return end - - local now = os.time() - local utc = os.time(os.date("!*t", now)) - - local url = 'https://maps.googleapis.com/maps/api/timezone/json?location=' .. coords.lat ..','.. coords.lon .. '×tamp='..utc..'&language=de' - local jstr, res = https.request(url) - if res ~= 200 then - utilities.send_reply(self, msg, config.errors.connection) - return - end - - local jdat = json.decode(jstr) - local timezoneid = '*'..string.gsub(jdat.timeZoneId, '_', ' ' )..'*' - local timestamp = now + jdat.rawOffset + jdat.dstOffset - local utcoff = (jdat.rawOffset + jdat.dstOffset) / 3600 - if utcoff == math.abs(utcoff) then - utcoff = '+'.. utilities.pretty_float(utcoff) - else - utcoff = utilities.pretty_float(utcoff) - end - -- "%A, %d. %B %Y, %H:%M:%S Uhr" - local output = timezoneid..':\n'..os.date('!%A, %d. %B %Y, %H:%M:%S Uhr',timestamp) - local output = time:localize(output) - - local output = output..'\n_'..jdat.timeZoneName .. ' (UTC' .. utcoff .. ')_' + local output = time:get_time(coords) + if not output then utilities.send_reply(self, msg, config.errors.connection) return end utilities.send_reply(self, msg, output, true) end