2013-08-16 20:03:53 +02:00
|
|
|
local lfs = require('lfs')
|
2013-10-10 12:11:16 +02:00
|
|
|
local log = require('util.logger')
|
|
|
|
local utils = require('util.utils')
|
|
|
|
local accessManager = require('util.access')
|
|
|
|
local printDriver = require('print3d')
|
|
|
|
local printerUtils = require('util.printer')
|
2013-10-10 15:03:42 +02:00
|
|
|
local printerAPI = require('rest.api.api_printer')
|
2013-08-16 20:03:53 +02:00
|
|
|
|
|
|
|
local TMP_DIR = '/tmp'
|
|
|
|
local LOG_COLLECT_DIRNAME = 'wifibox-logs'
|
|
|
|
local LOG_COLLECT_DIR = TMP_DIR .. '/' .. LOG_COLLECT_DIRNAME
|
|
|
|
local WIFIBOX_LOG_FILENAME = 'wifibox.log'
|
|
|
|
local WIFIBOX_LOG_FILE = TMP_DIR .. '/' .. WIFIBOX_LOG_FILENAME
|
|
|
|
local ULTIFI_PATH = '/tmp/UltiFi'
|
|
|
|
local SYSLOG_FILENAME = 'syslog'
|
|
|
|
local ULTIFI_LOG_FILENAME = 'server.log'
|
|
|
|
local LOG_COLLECT_ARCHIVE_FILENAME = LOG_COLLECT_DIRNAME .. '.tgz'
|
|
|
|
local LOG_COLLECT_ARCHIVE_FILE = TMP_DIR .. '/' .. LOG_COLLECT_ARCHIVE_FILENAME
|
|
|
|
|
|
|
|
local function redirectedExecute(cmd)
|
|
|
|
return os.execute(cmd .. " > /dev/null 2>&1")
|
|
|
|
end
|
|
|
|
|
2013-07-24 16:36:27 +02:00
|
|
|
local M = {
|
|
|
|
isApi = true
|
|
|
|
}
|
|
|
|
|
|
|
|
function M._global(request, response)
|
|
|
|
response:setSuccess()
|
|
|
|
end
|
|
|
|
|
|
|
|
function M.firmware(request, response)
|
|
|
|
--response:setSuccess()
|
|
|
|
-- can return (essentially all wraps ipkg output):
|
|
|
|
-- available (list)
|
|
|
|
-- current
|
|
|
|
-- latest
|
|
|
|
-- upgradable
|
|
|
|
end
|
|
|
|
|
2013-08-16 20:03:53 +02:00
|
|
|
-- TODO: redirect stdout+stderr; handle errors
|
|
|
|
function M.logfiles(request, response)
|
|
|
|
local rv,msg = lfs.mkdir(LOG_COLLECT_DIR)
|
|
|
|
local rv,msg = lfs.chdir(TMP_DIR)
|
|
|
|
|
2013-08-21 13:39:45 +02:00
|
|
|
local ultip,msg = lfs.attributes(ULTIFI_PATH, 'mode')
|
|
|
|
|
2013-08-16 20:03:53 +02:00
|
|
|
|
|
|
|
--[[ create temporary files ]]--
|
|
|
|
|
|
|
|
local rv,sig,code = redirectedExecute('cp ' .. WIFIBOX_LOG_FILE .. ' ' .. LOG_COLLECT_DIR)
|
|
|
|
|
|
|
|
local rv,sig,code = os.execute('logread > ' .. LOG_COLLECT_DIR .. '/' .. SYSLOG_FILENAME)
|
|
|
|
|
2013-08-21 13:39:45 +02:00
|
|
|
if ultip and ultip == 'directory' then
|
|
|
|
for file in lfs.dir(ULTIFI_PATH) do
|
|
|
|
if file ~= '.' and file ~= '..' then
|
|
|
|
local srcLogFile = ULTIFI_PATH .. '/' .. file .. '/' .. ULTIFI_LOG_FILENAME
|
|
|
|
local tgtLogFile = LOG_COLLECT_DIR .. '/' .. file .. '-' .. ULTIFI_LOG_FILENAME
|
|
|
|
local rv,sig,code = redirectedExecute('cp ' .. srcLogFile .. ' ' .. tgtLogFile)
|
|
|
|
end
|
2013-08-16 20:03:53 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local rv,sig,code = redirectedExecute('tar czf ' .. LOG_COLLECT_ARCHIVE_FILE .. ' ' .. LOG_COLLECT_DIRNAME) --returns 0 success, 1 error
|
|
|
|
|
|
|
|
|
|
|
|
--[[ add response content ]]--
|
|
|
|
|
|
|
|
local rv,msg = response:setBinaryFileData(LOG_COLLECT_ARCHIVE_FILE, LOG_COLLECT_ARCHIVE_FILENAME, 'application/x-compressed')
|
|
|
|
if not rv then
|
|
|
|
response:setError("could not set binary data from file '" .. LOG_COLLECT_ARCHIVE_FILE .. "' (" .. msg .. ")")
|
|
|
|
else
|
|
|
|
response:setSuccess()
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
--[[ remove temporary files ]]--
|
|
|
|
|
2013-08-21 13:39:45 +02:00
|
|
|
if ultip and ultip == 'directory' then
|
|
|
|
for file in lfs.dir(ULTIFI_PATH) do
|
|
|
|
if file ~= '.' and file ~= '..' then
|
|
|
|
local tgtLogFile = LOG_COLLECT_DIR .. '/' .. file .. '-' .. ULTIFI_LOG_FILENAME
|
|
|
|
local rv,sig,code = redirectedExecute('rm ' .. tgtLogFile)
|
|
|
|
end
|
2013-08-16 20:03:53 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local rv,sig,code = redirectedExecute('rm ' .. LOG_COLLECT_DIR .. '/' .. WIFIBOX_LOG_FILENAME)
|
|
|
|
|
|
|
|
local rv,sig,code = redirectedExecute('rm ' .. LOG_COLLECT_DIR .. '/' .. SYSLOG_FILENAME)
|
|
|
|
|
|
|
|
local rv,msg = lfs.rmdir(LOG_COLLECT_DIR)
|
|
|
|
|
|
|
|
local rv,sig,code = redirectedExecute('rm ' .. LOG_COLLECT_ARCHIVE_FILE)
|
|
|
|
end
|
|
|
|
|
2013-10-10 12:11:16 +02:00
|
|
|
function M.access(request, response)
|
|
|
|
--log:info(" remoteAddress: |"..utils.dump(request.remoteAddress).."|");
|
|
|
|
--log:info(" controller: |"..utils.dump(accessManager.getController()).."|");
|
|
|
|
|
|
|
|
-- when there is a controller we check if the printer is idle,
|
|
|
|
-- if so, it should be done printing and we can clear the controller
|
|
|
|
if accessManager.getController() ~= "" then
|
|
|
|
local argId = request:get("id")
|
|
|
|
local printer,msg = printerUtils.createPrinterOrFail(argId, response)
|
|
|
|
local rv,msg = printer:getState()
|
|
|
|
if rv then
|
|
|
|
response:setSuccess()
|
|
|
|
if(state == "idle") then -- TODO: define in constants somewhere
|
|
|
|
accessManager.setController("") -- clear controller
|
|
|
|
end
|
|
|
|
else
|
|
|
|
response:setError(msg)
|
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local hasControl = accessManager.hasControl(request.remoteAddress)
|
|
|
|
response:setSuccess()
|
|
|
|
response:addData('hasControl', hasControl)
|
|
|
|
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
function M.status(request, response)
|
|
|
|
|
2013-10-10 15:03:42 +02:00
|
|
|
printerAPI.temperature(request, response)
|
|
|
|
printerAPI.progress(request, response)
|
|
|
|
printerAPI.state(request, response)
|
2013-10-10 12:11:16 +02:00
|
|
|
M.access(request, response)
|
|
|
|
|
2013-10-10 15:03:42 +02:00
|
|
|
response:addData('v', 9)
|
2013-10-10 12:11:16 +02:00
|
|
|
|
|
|
|
end
|
|
|
|
|
2013-07-24 16:36:27 +02:00
|
|
|
return M
|