From: Jo-Philipp Wich Date: Wed, 20 Jul 2011 23:57:32 +0000 (+0000) Subject: libs/web: make dispatcher faults more verbose X-Git-Tag: 0.11.0~1911 X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=d970d7bd27cf9f4b6cdbec5737ed72291c0896d2;p=project%2Fluci.git libs/web: make dispatcher faults more verbose --- diff --git a/libs/web/luasrc/dispatcher.lua b/libs/web/luasrc/dispatcher.lua index 4cbbe58ce0..8da10812b9 100644 --- a/libs/web/luasrc/dispatcher.lua +++ b/libs/web/luasrc/dispatcher.lua @@ -269,7 +269,12 @@ function dispatch(request) end track.dependent = (track.dependent ~= false) - assert(not track.dependent or not track.auto, "Access Violation") + assert(not track.dependent or not track.auto, + "Access Violation\nThe page at '" .. table.concat(request, "/") .. "/' " .. + "has no parent node so the access to this location has been denied.\n" .. + "This is a software bug, please report this message at " .. + "http://luci.subsignal.org/trac/newticket" + ) if track.sysauth then local sauth = require "luci.sauth" @@ -386,7 +391,16 @@ function dispatch(request) target(unpack(args)) end else - error404() + local root = node() + if not root or not root.target then + error404("No root node was registered, this usually happens if no module was installed.\n" .. + "Install luci-admin-full and retry. " .. + "If the module is already installed, try removing the /tmp/luci-indexcache file.") + else + error404("No page is registered at '" .. table.concat(request, "/") .. "/'.\n" .. + "If this url belongs to an extension, make sure it is properly installed.\n" .. + "If the extension was recently installed, try removing the /tmp/luci-indexcache file.") + end end end