0
0
mirror of https://github.com/Doodle3D/doodle3d-firmware.git synced 2025-01-03 08:13:49 +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:
Wouter R 2013-10-21 13:49:45 +02:00
commit 5c199eca94
5 changed files with 107 additions and 46 deletions

View File

@ -44,9 +44,20 @@ 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 = ''
} }

View File

@ -17,9 +17,9 @@ M.WWW_RENAME_NAME = '/www-regular'
M.CONNECTING_FAILED = -1 M.CONNECTING_FAILED = -1
M.NOT_CONNECTED = 0 M.NOT_CONNECTED = 0
M.CONNECTING = 1 M.CONNECTING = 1
M.CONNECTED = 2 M.CONNECTED = 2
M.CREATING = 3 M.CREATING = 3
M.CREATED = 4 M.CREATED = 4
local function reloadBit(dlist, itemname) local function reloadBit(dlist, itemname)
if dlist[itemname] == nil then dlist[itemname] = '' end if dlist[itemname] == nil then dlist[itemname] = '' end
@ -76,9 +76,15 @@ function M.commitComponent(c)
end 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)
@ -259,17 +265,34 @@ end
-- @tparam string ssid The SSID to use for the access point. -- @tparam string ssid The SSID to use for the access point.
-- @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)
-- NOTE: dnsmasq must be reloaded after network or it will be unable to serve IP addresses -- NOTE: dnsmasq must be reloaded after network or it will be unable to serve IP addresses
M.switchConfiguration{ wifiiface="add", network="reload", staticaddr="add", dhcppool="add_noreload", wwwredir="add", dnsredir="add" } M.switchConfiguration{ wifiiface="add", network="reload", staticaddr="add", dhcppool="add_noreload", wwwredir="add", dnsredir="add" }
M.switchConfiguration{dhcp="reload"} M.switchConfiguration{dhcp="reload"}
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
@ -282,9 +305,9 @@ end
-- @return True on success or nil+msg on error. -- @return True on success or nil+msg on error.
function M.associateSsid(ssid, passphrase, recreate) function M.associateSsid(ssid, passphrase, recreate)
log:info("netconfig:associateSsid: "..(ssid or "<nil>")..", "..(passphrase or "<nil>")..", "..(recreate or "<nil>")) log:info("netconfig:associateSsid: "..(ssid or "<nil>")..", "..(passphrase or "<nil>")..", "..(recreate or "<nil>"))
M.setStatus(M.CONNECTING,"Connecting..."); M.setStatus(M.CONNECTING,"Connecting...");
-- see if previously configured network for given ssid exists -- see if previously configured network for given ssid exists
local cfg = nil local cfg = nil
for _, net in ipairs(wifi.getConfigs()) do for _, net in ipairs(wifi.getConfigs()) do
@ -293,7 +316,7 @@ function M.associateSsid(ssid, passphrase, recreate)
break break
end end
end end
-- if not, or if newly created configuration is requested, create a new configuration -- if not, or if newly created configuration is requested, create a new configuration
if cfg == nil or recreate ~= nil then if cfg == nil or recreate ~= nil then
local scanResult = wifi.getScanInfo(ssid) local scanResult = wifi.getScanInfo(ssid)
@ -320,14 +343,14 @@ function M.associateSsid(ssid, passphrase, recreate)
M.setStatus(M.CONNECTING_FAILED,msg); M.setStatus(M.CONNECTING_FAILED,msg);
return nil,msg return nil,msg
end end
M.setStatus(M.CONNECTED,"Connected"); M.setStatus(M.CONNECTED,"Connected");
-- signin to connect.doodle3d.com -- signin to connect.doodle3d.com
local success, output = signin.signin() local success, output = signin.signin()
if success then if success then
log:info("Signed in") log:info("Signed in")
else else
log:info("Signing in failed") log:info("Signing in failed")
end end
@ -340,7 +363,7 @@ end
function M.disassociate() function M.disassociate()
M.setStatus(M.NOT_CONNECTED,"Not connected"); M.setStatus(M.NOT_CONNECTED,"Not connected");
wifi.activateConfig() wifi.activateConfig()
return wifi.restart() return wifi.restart()
end end

View File

@ -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

View File

@ -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)
@ -198,11 +209,11 @@ function M.set(key, value)
local base = getBaseKeyTable(key) local base = getBaseKeyTable(key)
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) uci:set(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key, toUciValue(value, base.type))
if (valid) then
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

@ -1 +1 @@
Subproject commit b1ded5d41bb4b234c0715dfdf28a54486658b393 Subproject commit 10724b17469371570f49804a7aed5ee2c0641ce6