mirror of
https://github.com/Doodle3D/doodle3d-firmware.git
synced 2025-01-05 09:13:48 +01:00
Merge branch 'feature/printerdriver' of github.com:Doodle3D/doodle3d-firmware into feature/printerdriver
Conflicts: src/network/netconfig.lua
This commit is contained in:
commit
5c199eca94
@ -46,7 +46,18 @@ M.network_ap_address = {
|
|||||||
M.network_ap_key = {
|
M.network_ap_key = {
|
||||||
default = '',
|
default = '',
|
||||||
type = 'string',
|
type = 'string',
|
||||||
description = 'Access Point security key'
|
description = 'Access Point security key',
|
||||||
|
isValid = function(value)
|
||||||
|
if value == "" then
|
||||||
|
return true;
|
||||||
|
elseif value:len() < 8 then
|
||||||
|
return false, "too short"
|
||||||
|
elseif value:len() > 63 then
|
||||||
|
return false, "too long"
|
||||||
|
else
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
M.network_ap_netmask = {
|
M.network_ap_netmask = {
|
||||||
@ -184,13 +195,13 @@ M.printer_enableTraveling = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
M.printer_startgcode = {
|
M.printer_startgcode = {
|
||||||
default = ';Generated with Doodle3D\nG21 ;metric values\nG91 ;relative positioning\nM107 ;start with the fan off\nG28 X0 Y0 ;move X/Y to min endstops\nG28 Z0 ;move Z to min endstops\nG1 Z15 F9000 ;move the platform down 15mm\nG92 E0 ;zero the extruded length\nG1 F200 E10 ;extrude 10mm of feed stock\nG92 E0 ;zero the extruded length again\nG92 E0 ;zero the extruded length again\nG1 F9000\nG90 ;absolute positioning\nM117 Printing Doodle... ;display message (20 characters to clear whole screen)',
|
default = ';Generated with Doodle3D\nM109 S{printingTemp} ;set target temperature \nG21 ;metric values\nG91 ;relative positioning\nM107 ;start with the fan off\nG28 X0 Y0 ;move X/Y to min endstops\nG28 Z0 ;move Z to min endstops\nG1 Z15 F9000 ;move the platform down 15mm\nG92 E0 ;zero the extruded length\nG1 F200 E10 ;extrude 10mm of feed stock\nG92 E0 ;zero the extruded length again\nG92 E0 ;zero the extruded length again\nG1 F9000\nG90 ;absolute positioning\nM117 Printing Doodle... ;display message (20 characters to clear whole screen)',
|
||||||
type = 'string',
|
type = 'string',
|
||||||
description = ''
|
description = ''
|
||||||
}
|
}
|
||||||
|
|
||||||
M.printer_endgcode = {
|
M.printer_endgcode = {
|
||||||
default = 'M107 ;fan off\nG91 ;relative positioning\nG1 E-1 F300 ;retract the filament a bit before lifting the nozzle, to release some of the pressure\nG1 Z+0.5 E-5 X-20 Y-20 F9000 ;move Z up a bit and retract filament even more\nG28 X0 Y0 ;move X/Y to min endstops, so the head is out of the way\nM84 ;disable axes / steppers\nG90 ;absolute positioning\nM104 S180\nM117 Done ;display message (20 characters to clear whole screen)',
|
default = 'M107 ;fan off\nG91 ;relative positioning\nG1 E-1 F300 ;retract the filament a bit before lifting the nozzle, to release some of the pressure\nG1 Z+0.5 E-5 X-20 Y-20 F9000 ;move Z up a bit and retract filament even more\nG28 X0 Y0 ;move X/Y to min endstops, so the head is out of the way\nM84 ;disable axes / steppers\nG90 ;absolute positioning\nM104 {preheatTemp}\nM117 Done ;display message (20 characters to clear whole screen)',
|
||||||
type = 'string',
|
type = 'string',
|
||||||
description = ''
|
description = ''
|
||||||
}
|
}
|
||||||
|
@ -77,8 +77,14 @@ end
|
|||||||
|
|
||||||
function M.reloadComponent(c, silent)
|
function M.reloadComponent(c, silent)
|
||||||
log:info("reloading component '" .. c .. "'")
|
log:info("reloading component '" .. c .. "'")
|
||||||
if silent ~= nil and silent then os.execute('/etc/init.d/' .. c .. ' reload &> /dev/null')
|
local cmd = '/etc/init.d/' .. c .. ' reload'
|
||||||
else os.execute('/etc/init.d/' .. c .. ' reload') end
|
if silent ~= nil and silent then
|
||||||
|
cmd = cmd .. ' &> /dev/null'
|
||||||
|
os.execute(cmd)
|
||||||
|
else
|
||||||
|
rv = utils.captureCommandOutput(cmd)
|
||||||
|
log:info(" result reloading component '" .. c .. "': "..utils.dump(rv))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.uciTableSet(config, section, options)
|
function M.uciTableSet(config, section, options)
|
||||||
@ -260,7 +266,7 @@ end
|
|||||||
-- @return True on success or nil+msg on error.
|
-- @return True on success or nil+msg on error.
|
||||||
function M.setupAccessPoint(ssid)
|
function M.setupAccessPoint(ssid)
|
||||||
|
|
||||||
M.setStatus(M.CREATING,"Creating access point...");
|
M.setStatus(M.CREATING,"Creating access point '"..ssid.."'...");
|
||||||
|
|
||||||
M.switchConfiguration{apnet="add_noreload"}
|
M.switchConfiguration{apnet="add_noreload"}
|
||||||
wifi.activateConfig(ssid)
|
wifi.activateConfig(ssid)
|
||||||
@ -270,6 +276,23 @@ function M.setupAccessPoint(ssid)
|
|||||||
|
|
||||||
M.setStatus(M.CREATED,"Access point created");
|
M.setStatus(M.CREATED,"Access point created");
|
||||||
|
|
||||||
|
local ds = wifi.getDeviceState()
|
||||||
|
--log:info(" network/status: ")
|
||||||
|
log:info(" ssid: ".. utils.dump(ds.ssid))
|
||||||
|
--[[log:info(" bssid: ".. utils.dump(ds.bssid))
|
||||||
|
log:info(" channel: ".. utils.dump(ds.channel))
|
||||||
|
log:info(" mode: ".. utils.dump(ds.mode))
|
||||||
|
log:info(" encryption: ".. utils.dump(ds.encryption))
|
||||||
|
log:info(" quality: ".. utils.dump(ds.quality))
|
||||||
|
log:info(" quality_max: ".. utils.dump(ds.quality_max))
|
||||||
|
log:info(" txpower: ".. utils.dump(ds.txpower))
|
||||||
|
log:info(" signal: ".. utils.dump(ds.signal))
|
||||||
|
log:info(" noise: ".. utils.dump(ds.noise))
|
||||||
|
log:info(" raw: ".. utils.dump(ds))
|
||||||
|
|
||||||
|
local localip = wifi.getLocalIP()
|
||||||
|
log:info(" localip: "..utils.dump(localip))]]--
|
||||||
|
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
local log = require('util.logger')
|
local log = require('util.logger')
|
||||||
|
local utils = require('util.utils')
|
||||||
local settings = require('util.settings')
|
local settings = require('util.settings')
|
||||||
local printer = require('util.printer')
|
local printer = require('util.printer')
|
||||||
local signin = require('network.signin')
|
local signin = require('network.signin')
|
||||||
|
local wifi = require('network.wlanconfig')
|
||||||
|
|
||||||
local M = {
|
local M = {
|
||||||
isApi = true
|
isApi = true
|
||||||
@ -19,14 +21,27 @@ function M._global_GET(request, response)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function M._global_POST(request, response)
|
function M._global_POST(request, response)
|
||||||
|
--log:info("API:config:set")
|
||||||
response:setSuccess()
|
response:setSuccess()
|
||||||
|
|
||||||
|
local validation = {}
|
||||||
for k,v in pairs(request:getAll()) do
|
for k,v in pairs(request:getAll()) do
|
||||||
|
--log:info(" "..k..": "..v);
|
||||||
local r,m = settings.set(k, v)
|
local r,m = settings.set(k, v)
|
||||||
|
|
||||||
if r then response:addData(k, "ok")
|
if r then
|
||||||
else response:addData(k, "could not set key ('" .. m .. "')")
|
--response:addData(k, "ok")
|
||||||
|
validation[k] = "ok"
|
||||||
|
else
|
||||||
|
--response:addData(k, "could not save setting ('" .. m .. "')")
|
||||||
|
validation[k] = "could not save setting ('" .. m .. "')"
|
||||||
|
log:info(" m: "..utils.dump(m))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
response:addData("validation",validation)
|
||||||
|
|
||||||
|
local substitutedSsid = wifi.getSubstitutedSsid(settings.get('network.ap.ssid'))
|
||||||
|
response:addData("substituted_ssid",substitutedSsid)
|
||||||
|
|
||||||
log:info("API:Network:try signing in")
|
log:info("API:Network:try signing in")
|
||||||
if signin.signin() then
|
if signin.signin() then
|
||||||
|
@ -13,6 +13,8 @@
|
|||||||
local uci = require('uci').cursor()
|
local uci = require('uci').cursor()
|
||||||
local utils = require('util.utils')
|
local utils = require('util.utils')
|
||||||
local baseconfig = require('conf_defaults')
|
local baseconfig = require('conf_defaults')
|
||||||
|
local utils = require('util.utils')
|
||||||
|
local log = require('util.logger')
|
||||||
|
|
||||||
local M = {}
|
local M = {}
|
||||||
|
|
||||||
@ -98,8 +100,9 @@ local function isValid(value, baseTable)
|
|||||||
local varType, min, max, regex, isValid = baseTable.type, baseTable.min, baseTable.max, baseTable.regex, baseTable.isValid
|
local varType, min, max, regex, isValid = baseTable.type, baseTable.min, baseTable.max, baseTable.regex, baseTable.isValid
|
||||||
|
|
||||||
if isValid then
|
if isValid then
|
||||||
local ok = isValid(value)
|
local ok,msg = isValid(value)
|
||||||
return ok or nil,"invalid value"
|
if msg == nil then msg = "invalid value" end
|
||||||
|
return ok or nil,msg
|
||||||
end
|
end
|
||||||
|
|
||||||
if varType == 'bool' then
|
if varType == 'bool' then
|
||||||
@ -107,18 +110,25 @@ local function isValid(value, baseTable)
|
|||||||
|
|
||||||
elseif varType == 'int' or varType == 'float' then
|
elseif varType == 'int' or varType == 'float' then
|
||||||
local numValue = tonumber(value)
|
local numValue = tonumber(value)
|
||||||
local ok = numValue and true or false
|
if numValue == nil then
|
||||||
ok = ok and (varType == 'float' or math.floor(numValue) == numValue)
|
return nil, "invalid number"
|
||||||
if min then ok = ok and numValue >= min end
|
elseif varType == 'int' and math.floor(numValue) ~= numValue then
|
||||||
if max then ok = ok and numValue <= max end
|
return nil, "invalid int"
|
||||||
return ok or nil,"invalid int/float value or out of range"
|
elseif min and numValue < min then
|
||||||
|
return nil, "too low"
|
||||||
|
elseif max and numValue > max then
|
||||||
|
return nil, "too high"
|
||||||
|
end
|
||||||
|
|
||||||
elseif varType == 'string' then
|
elseif varType == 'string' then
|
||||||
local ok = true
|
local ok = true
|
||||||
if min then ok = ok and value:len() >= min end
|
if min and value:len() < min then
|
||||||
if max then ok = ok and value:len() <= max end
|
return nil,"too short"
|
||||||
if regex then ok = ok and value:match(regex) ~= nil end
|
elseif max and value:len() > max then
|
||||||
return ok or nil,"invalid string value"
|
return nil,"too long"
|
||||||
|
elseif regex and value:match(regex) == nil then
|
||||||
|
return nil,"invalid value"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return true
|
return true
|
||||||
@ -191,6 +201,7 @@ end
|
|||||||
-- @treturn bool|nil True if everything went well, nil in case of error.
|
-- @treturn bool|nil True if everything went well, nil in case of error.
|
||||||
-- @treturn ?string Error message in case first return value is nil (invalid key).
|
-- @treturn ?string Error message in case first return value is nil (invalid key).
|
||||||
function M.set(key, value)
|
function M.set(key, value)
|
||||||
|
--log:info("settings:set: "..utils.dump(key))
|
||||||
key = replaceDots(key)
|
key = replaceDots(key)
|
||||||
|
|
||||||
local r = utils.create(UCI_CONFIG_FILE)
|
local r = utils.create(UCI_CONFIG_FILE)
|
||||||
@ -200,9 +211,9 @@ function M.set(key, value)
|
|||||||
if not base then return nil,ERR_NO_SUCH_KEY end
|
if not base then return nil,ERR_NO_SUCH_KEY end
|
||||||
|
|
||||||
if M.isDefault(key) and value == nil then return true end -- key is default already
|
if M.isDefault(key) and value == nil then return true end -- key is default already
|
||||||
|
--log:info(" not default")
|
||||||
local current = uci:get(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key)
|
local current = uci:get(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key)
|
||||||
|
--log:info(" base.type: "..utils.dump(base.type))
|
||||||
if base.type == 'bool' then
|
if base.type == 'bool' then
|
||||||
if value ~= "" then
|
if value ~= "" then
|
||||||
value = utils.toboolean(value)
|
value = utils.toboolean(value)
|
||||||
@ -216,15 +227,16 @@ function M.set(key, value)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
local valid,m = isValid(value, base)
|
||||||
|
if not valid then
|
||||||
|
return nil,m
|
||||||
|
end
|
||||||
|
|
||||||
if fromUciValue(current, base.type) == value then return true end
|
if fromUciValue(current, base.type) == value then return true end
|
||||||
|
|
||||||
if value ~= nil then
|
if value ~= nil then
|
||||||
local valid,m = isValid(value, base)
|
|
||||||
if (valid) then
|
|
||||||
uci:set(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key, toUciValue(value, base.type))
|
uci:set(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key, toUciValue(value, base.type))
|
||||||
else
|
|
||||||
return nil,m
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
uci:delete(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key)
|
uci:delete(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key)
|
||||||
end
|
end
|
||||||
|
2
src/www
2
src/www
@ -1 +1 @@
|
|||||||
Subproject commit b1ded5d41bb4b234c0715dfdf28a54486658b393
|
Subproject commit 10724b17469371570f49804a7aed5ee2c0641ce6
|
Loading…
Reference in New Issue
Block a user