2016-05-29 13:08:39 -04:00
|
|
|
--[[
|
2016-08-23 00:16:32 -04:00
|
|
|
bindings.lua (rev. 2016/08/20)
|
2016-08-13 22:46:18 -04:00
|
|
|
otouto's bindings for the Telegram bot API.
|
|
|
|
https://core.telegram.org/bots/api
|
|
|
|
See the "Bindings" section of README.md for usage information.
|
2016-05-29 13:08:39 -04:00
|
|
|
|
2016-08-23 00:16:32 -04:00
|
|
|
Copyright 2016 topkecleon <drew@otou.to>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it
|
|
|
|
under the terms of the GNU Affero General Public License version 3 as
|
|
|
|
published by the Free Software Foundation.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
|
|
|
|
for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program; if not, write to the Free Software Foundation,
|
|
|
|
Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2016-05-29 13:08:39 -04:00
|
|
|
]]--
|
2016-01-14 22:39:24 -05:00
|
|
|
|
2016-04-08 14:12:02 -07:00
|
|
|
local bindings = {}
|
2016-01-14 22:39:24 -05:00
|
|
|
|
2016-08-26 23:25:55 -04:00
|
|
|
local https = require('ssl.https')
|
2016-08-27 16:12:46 +02:00
|
|
|
https.timeout = 10
|
2016-08-26 23:25:55 -04:00
|
|
|
local json = require('dkjson')
|
2016-05-29 13:08:39 -04:00
|
|
|
local ltn12 = require('ltn12')
|
2016-08-26 23:25:55 -04:00
|
|
|
local mp_encode = require('multipart-post').encode
|
2016-05-29 13:08:39 -04:00
|
|
|
|
2016-08-23 00:16:32 -04:00
|
|
|
function bindings.init(token)
|
|
|
|
bindings.BASE_URL = 'https://api.telegram.org/bot' .. token .. '/'
|
|
|
|
return bindings
|
|
|
|
end
|
|
|
|
|
2016-05-29 13:08:39 -04:00
|
|
|
-- Build and send a request to the API.
|
|
|
|
-- Expecting self, method, and parameters, where method is a string indicating
|
|
|
|
-- the API method and parameters is a key/value table of parameters with their
|
|
|
|
-- values.
|
|
|
|
-- Returns the table response with success. Returns false and the table
|
|
|
|
-- response with failure. Returns false and false with a connection error.
|
|
|
|
-- To mimic old/normal behavior, it errs if used with an invalid method.
|
2016-08-23 00:16:32 -04:00
|
|
|
function bindings.request(method, parameters, file)
|
2016-05-29 13:08:39 -04:00
|
|
|
parameters = parameters or {}
|
|
|
|
for k,v in pairs(parameters) do
|
|
|
|
parameters[k] = tostring(v)
|
|
|
|
end
|
|
|
|
if file and next(file) ~= nil then
|
2016-07-03 01:20:04 +02:00
|
|
|
local file_type, file_name = next(file)
|
2016-07-04 01:29:51 +02:00
|
|
|
if not file_name then return false end
|
2016-07-03 01:20:04 +02:00
|
|
|
if string.match(file_name, '/tmp/') then
|
|
|
|
local file_file = io.open(file_name, 'r')
|
|
|
|
local file_data = {
|
|
|
|
filename = file_name,
|
2016-05-29 13:08:39 -04:00
|
|
|
data = file_file:read('*a')
|
2016-07-03 01:20:04 +02:00
|
|
|
}
|
|
|
|
file_file:close()
|
|
|
|
parameters[file_type] = file_data
|
|
|
|
else
|
|
|
|
local file_type, file_name = next(file)
|
|
|
|
parameters[file_type] = file_name
|
|
|
|
end
|
2016-05-29 13:08:39 -04:00
|
|
|
end
|
|
|
|
if next(parameters) == nil then
|
|
|
|
parameters = {''}
|
|
|
|
end
|
|
|
|
local response = {}
|
2016-08-27 16:12:46 +02:00
|
|
|
local body, boundary = mp_encode(parameters)
|
|
|
|
local success, code = https.request{
|
2016-08-24 15:38:29 +02:00
|
|
|
url = bindings.BASE_URL .. method,
|
2016-05-29 13:08:39 -04:00
|
|
|
method = 'POST',
|
|
|
|
headers = {
|
|
|
|
["Content-Type"] = "multipart/form-data; boundary=" .. boundary,
|
|
|
|
["Content-Length"] = #body,
|
|
|
|
},
|
|
|
|
source = ltn12.source.string(body),
|
|
|
|
sink = ltn12.sink.table(response)
|
|
|
|
}
|
|
|
|
local data = table.concat(response)
|
|
|
|
if not success then
|
2016-08-14 16:30:06 +02:00
|
|
|
print(method .. ': Connection error. [' .. code .. ']')
|
2016-05-29 13:08:39 -04:00
|
|
|
return false, false
|
2016-05-20 20:47:13 -04:00
|
|
|
else
|
2016-08-27 16:12:46 +02:00
|
|
|
local result = json.decode(data)
|
2016-05-29 13:08:39 -04:00
|
|
|
if not result then
|
|
|
|
return false, false
|
|
|
|
elseif result.ok then
|
|
|
|
return result
|
|
|
|
else
|
|
|
|
assert(result.description ~= 'Method not found', method .. ': Method not found.')
|
|
|
|
return false, result
|
|
|
|
end
|
2016-02-26 13:10:43 +03:30
|
|
|
end
|
2015-11-24 21:22:04 -05:00
|
|
|
end
|
|
|
|
|
2016-05-29 13:08:39 -04:00
|
|
|
function bindings.gen(_, key)
|
2016-08-24 15:38:29 +02:00
|
|
|
return function(params, file)
|
|
|
|
return bindings.request(key, params, file)
|
2016-02-26 13:10:43 +03:30
|
|
|
end
|
2015-07-19 16:46:06 -04:00
|
|
|
end
|
2016-05-29 13:08:39 -04:00
|
|
|
setmetatable(bindings, { __index = bindings.gen })
|
2016-04-08 14:12:02 -07:00
|
|
|
|
2016-08-14 16:34:25 +02:00
|
|
|
return bindings
|