webmcp

view framework/env/request/redirect.lua @ 11:d76a8857ba62

Added ui.partial and other functions, which allow partial content replacement using XMLHttpRequests; Image support for ui.link

Also includes following changes:
- Fix for rocketcgi library to accept POST data content-types, which contain additional charset information.
- Support arrays passed as params to encode.url (only for keys ending with "[]")
- Version information changed to "1.0.7"

Documentation for added functions is not yet complete.
author jbe/bsw
date Fri Feb 12 18:40:22 2010 +0100 (2010-02-12)
parents 9fdfb27f8e67
children ca88032cb37c
line source
1 --[[--
2 request.redirect{
3 module = module, -- module name
4 view = view, -- view name
5 id = id, -- optional id for view
6 params = params -- optional view parameters
7 }
9 Calling this function causes the WebMCP to do a 303 HTTP redirect after the current view or action and all filters have finished execution. If routing mode "redirect" has been chosen, then this function is called automatically after an action and all its filters have finished execution. Calling request.redirect{...} (or request.forward{...}) explicitly inside an action will cause routing information from the browser to be ignored. To preserve GET/POST parameters of an action, use request.forward{...} instead. Currently no redirects to external (absolute) URLs are possible, there will be an implementation in future though.
11 --]]--
13 function request.redirect(args)
14 -- TODO: support redirects to external URLs too
15 -- (needs fixes in the trace system as well)
16 local module = args.module
17 local view = args.view
18 local id = args.id
19 local params = args.params or {}
20 if type(module) ~= "string" then
21 error("No module string passed to request.redirect{...}.")
22 end
23 if type(view) ~= "string" then
24 error("No view string passed to request.redirect{...}.")
25 end
26 if type(params) ~= "table" then
27 error("Params array passed to request.redirect{...} is not a table.")
28 end
29 if request.is_rerouted() then
30 error("Tried to redirect after another forward or redirect.")
31 end
32 request._redirect = {
33 module = module,
34 view = view,
35 id = id,
36 params = params
37 }
38 trace.redirect{ module = args.module, view = args.view }
39 end

Impressum / About Us