0
0
mirror of https://github.com/Doodle3D/doodle3d-firmware.git synced 2025-01-05 09:13:48 +01:00

Handle errors in api:info/status. Use Disconnected state when there is no printer driver

This commit is contained in:
peteruithoven 2013-10-10 17:51:14 +02:00
parent 0956561064
commit 0667dfe070
2 changed files with 44 additions and 49 deletions

View File

@ -112,25 +112,32 @@ function M.access(request, response)
end end
else else
response:setError(msg) response:setError(msg)
return return false
end end
end end
local hasControl = accessManager.hasControl(request.remoteAddress) local hasControl = accessManager.hasControl(request.remoteAddress)
response:setSuccess() response:setSuccess()
response:addData('hasControl', hasControl) response:addData('has_control', hasControl)
return return true
end end
function M.status(request, response) function M.status(request, response)
printerAPI.temperature(request, response) local rv
printerAPI.progress(request, response) rv, state = printerAPI.state(request, response)
printerAPI.state(request, response) if(rv == false) then return end
M.access(request, response)
response:addData('v', 9) if(state ~= "disconnected") then
rv = printerAPI.temperature(request, response)
if(rv == false) then return end
rv = printerAPI.progress(request, response)
if(rv == false) then return end
rv = M.access(request, response)
if(rv == false) then return end
end
response:addData('v', 10)
end end

View File

@ -22,11 +22,10 @@ function M._global(request, response)
response:setSuccess() response:setSuccess()
end end
--requires id(string)
function M.temperature(request, response) function M.temperature(request, response)
local argId = request:get("id") local argId = request:get("id")
local printer,msg = printerUtils.createPrinterOrFail(argId, response) local printer,msg = printerUtils.createPrinterOrFail(argId, response)
if not printer then return end if not printer then return false end
local temperatures,msg = printer:getTemperatures() local temperatures,msg = printer:getTemperatures()
@ -39,66 +38,57 @@ function M.temperature(request, response)
response:addData('bed_target', temperatures.bed_target) response:addData('bed_target', temperatures.bed_target)
else else
response:setError(msg) response:setError(msg)
end return false;
end
return true;
end end
--requires id(string)
function M.progress(request, response) function M.progress(request, response)
local argId = request:get("id") local argId = request:get("id")
local printer,msg = printerUtils.createPrinterOrFail(argId, response) local printer,msg = printerUtils.createPrinterOrFail(argId, response)
if not printer then return end if not printer then return false end
-- NOTE: despite their names, `currentLine` is still the error indicator and `numLines` the message in such case. -- NOTE: despite their names, `currentLine` is still the error indicator and `numLines` the message in such case.
local currentLine,numLines = printer:getProgress() local currentLine,totalLines = printer:getProgress()
response:addData('id', argId) response:addData('id', argId)
if currentLine then if currentLine then
response:setSuccess() response:setSuccess()
response:addData('current_line', currentLine) response:addData('current_line', currentLine)
response:addData('num_lines', numLines) response:addData('total_lines', totalLines)
else else
response:setError(numLines) response:setError(totalLines)
end return false
end end
--TODO: remove busy function (client should use state function) return true;
--requires id(string)
function M.busy(request, response)
local argId = request:get("id")
local printer,msg = printerUtils.createPrinterOrFail(argId, response)
if not printer then return end
local rv,msg = printer:getState()
response:addData('id', argId)
if rv then
response:setSuccess()
response:addData('busy', (rv ~= 'idle'))
else
response:setError(msg)
end
end end
--requires id(string)
function M.state(request, response) function M.state(request, response)
local argId = request:get("id") local argId = request:get("id")
local printer,msg = printerUtils.createPrinterOrFail(argId, response)
if not printer then return end
local rv,msg = printer:getState()
response:addData('id', argId) response:addData('id', argId)
local printer,msg = printerUtils.createPrinterOrFail(argId, response)
if not printer then
response:setSuccess()
local printerState = "disconnected"
response:addData('state', printerState)
return true, printerState
else
local rv,msg = printer:getState()
if rv then if rv then
response:setSuccess() response:setSuccess()
response:addData('state', rv) response:addData('state', rv)
return true, rv
else else
response:setError(msg) response:setError(msg)
return false
end end
end end
return true;
end
--requires id(string)
function M.heatup_POST(request, response) function M.heatup_POST(request, response)
if not accessManager.hasControl(request.remoteAddress) then if not accessManager.hasControl(request.remoteAddress) then
@ -108,7 +98,7 @@ function M.heatup_POST(request, response)
local argId = request:get("id") local argId = request:get("id")
local printer,msg = printerUtils.createPrinterOrFail(argId, response) local printer,msg = printerUtils.createPrinterOrFail(argId, response)
if not printer then return end if not printer then return false end
local temperature = settings.get('printer.heatup.temperature') local temperature = settings.get('printer.heatup.temperature')
local rv,msg = printer:heatup(temperature) local rv,msg = printer:heatup(temperature)
@ -119,7 +109,6 @@ function M.heatup_POST(request, response)
end end
end end
--requires id(string)
function M.stop_POST(request, response) function M.stop_POST(request, response)
if not accessManager.hasControl(request.remoteAddress) then if not accessManager.hasControl(request.remoteAddress) then
@ -140,7 +129,6 @@ function M.stop_POST(request, response)
end end
end end
--requires id(string), gcode(string)
--accepts: first(bool) (chunks will be concatenated but output file will be cleared first if this argument is true) --accepts: first(bool) (chunks will be concatenated but output file will be cleared first if this argument is true)
--accepts: last(bool) (chunks will be concatenated and only when this argument is true will printing be started) --accepts: last(bool) (chunks will be concatenated and only when this argument is true will printing be started)
function M.print_POST(request, response) function M.print_POST(request, response)