Merge branch 'master' of github.com:EiffelWebFramework/EWF

This commit is contained in:
Jocelyn Fiat
2013-03-18 16:24:58 +01:00
6 changed files with 62 additions and 3 deletions

View File

@@ -24,7 +24,12 @@ inherit
WSF_METHOD_HANDLER WSF_METHOD_HANDLER
rename rename
do_method as do_put do_method as do_post
end
WSF_METHOD_HANDLER
rename
do_method as do_delete
end end
WSF_METHOD_HANDLER WSF_METHOD_HANDLER

View File

@@ -26,14 +26,27 @@ create
feature {NONE} -- Initialization feature {NONE} -- Initialization
make (a_router: WSF_ROUTER) make (a_router: WSF_ROUTER)
-- Initialize `router'.
require
a_router_attached: a_router /= Void
do do
router := a_router router := a_router
ensure
router_aliased: router = a_router
not_hidden: not is_hidden
end end
make_hidden (a_router: WSF_ROUTER) make_hidden (a_router: WSF_ROUTER)
-- Initialize `router'.
-- Do not display documentation for `a_router'.
require
a_router_attached: a_router /= Void
do do
make (a_router) make (a_router)
is_hidden := True is_hidden := True
ensure
router_aliased: router = a_router
hidden: is_hidden
end end
router: WSF_ROUTER router: WSF_ROUTER
@@ -46,6 +59,7 @@ feature {NONE} -- Initialization
feature -- Documentation feature -- Documentation
mapping_documentation (m: WSF_ROUTER_MAPPING; a_request_methods: detachable WSF_REQUEST_METHODS): WSF_ROUTER_MAPPING_DOCUMENTATION mapping_documentation (m: WSF_ROUTER_MAPPING; a_request_methods: detachable WSF_REQUEST_METHODS): WSF_ROUTER_MAPPING_DOCUMENTATION
-- <Precursor>
do do
create Result.make (m) create Result.make (m)
Result.set_is_hidden (is_hidden) Result.set_is_hidden (is_hidden)
@@ -76,4 +90,8 @@ feature -- Execution
res.send (m) res.send (m)
end end
invariant
router_attached: router /= Void
end end

View File

@@ -12,7 +12,12 @@ feature -- Documentation
mapping_documentation (m: WSF_ROUTER_MAPPING; a_request_methods: detachable WSF_REQUEST_METHODS): WSF_ROUTER_MAPPING_DOCUMENTATION mapping_documentation (m: WSF_ROUTER_MAPPING; a_request_methods: detachable WSF_REQUEST_METHODS): WSF_ROUTER_MAPPING_DOCUMENTATION
-- Documentation associated with Current handler, in the context of the mapping `m' and methods `a_request_methods'. -- Documentation associated with Current handler, in the context of the mapping `m' and methods `a_request_methods'.
--| `m' and `a_request_methods' are useful to produce specific documentation when the handler is used for multiple mapping. --| `m' and `a_request_methods' are useful to produce specific documentation when the handler is used for multiple mapping.
require
m_attached: m /= Void
a_request_methods_attached: a_request_methods /= Void
deferred deferred
ensure
mapping_documentation_attached: Result /= Void
end end
end end

View File

@@ -15,12 +15,19 @@ inherit
feature -- Execution feature -- Execution
execute (a_start_path: READABLE_STRING_8; req: WSF_REQUEST; res: WSF_RESPONSE) execute (a_start_path: READABLE_STRING_8; req: WSF_REQUEST; res: WSF_RESPONSE)
-- Handle `req' responding into `res'.
require
a_start_path_attached: a_start_path /= Void
req_attached: req /= Void
res_attached: res /= Void
path_start_with_a_start_path: req.path_info.starts_with (a_start_path)
deferred deferred
end end
feature {WSF_ROUTER} -- Mapping feature {WSF_ROUTER} -- Mapping
new_mapping (a_uri: READABLE_STRING_8): WSF_ROUTER_MAPPING new_mapping (a_uri: READABLE_STRING_8): WSF_ROUTER_MAPPING
-- <Precursor>
do do
create {WSF_STARTS_WITH_MAPPING} Result.make (a_uri, Current) create {WSF_STARTS_WITH_MAPPING} Result.make (a_uri, Current)
end end

View File

@@ -33,7 +33,12 @@ feature -- Access
feature -- Change feature -- Change
set_handler (h: like handler) set_handler (h: like handler)
-- Set `handler' to `h'.
require
h_attached: h /= Void
deferred deferred
ensure
h_aliased: handler = h
end end
feature -- Documentation feature -- Documentation
@@ -72,14 +77,23 @@ feature -- Status
feature {NONE} -- Execution feature {NONE} -- Execution
execute_handler (h: like handler; a_start_path: like uri; req: WSF_REQUEST; res: WSF_RESPONSE) execute_handler (h: like handler; a_start_path: like uri; req: WSF_REQUEST; res: WSF_RESPONSE)
-- Execute handler `h' with `req' and `res' for Current mapping -- Execute handler `h' with `req' and `res' for Current mapping.
require
h_attached: h /= Void
a_start_path_attached: a_start_path /= Void
req_attached: req /= Void
res_attached: res /= Void
path_start_with_a_start_path: req.path_info.starts_with (a_start_path)
deferred deferred
end end
feature {NONE} -- Implementation feature {NONE} -- Implementation
based_uri (a_uri: like uri; a_router: WSF_ROUTER): like uri based_uri (a_uri: like uri; a_router: WSF_ROUTER): like uri
-- `uri' prefixed by the `WSF_ROUTER.base_url' if any -- `a_uri' prefixed by the `WSF_ROUTER.base_url' if any
require
a_uri_attached: a_uri /= Void
a_router_attached: a_router /= Void
local local
s: STRING_8 s: STRING_8
do do
@@ -90,8 +104,14 @@ feature {NONE} -- Implementation
else else
Result := a_uri Result := a_uri
end end
ensure
based_uri_attached: Result /= Void
end end
invariant
uri_attached: uri /= Void
note note
copyright: "2011-2012, Jocelyn Fiat, Javier Velilla, Olivier Ligot, Eiffel Software and others" copyright: "2011-2012, Jocelyn Fiat, Javier Velilla, Olivier Ligot, Eiffel Software and others"
license: "Eiffel Forum License v2 (see http://www.eiffel.com/licensing/forum.txt)" license: "Eiffel Forum License v2 (see http://www.eiffel.com/licensing/forum.txt)"

View File

@@ -11,6 +11,8 @@ feature -- Status report
is_valid_context (req: WSF_REQUEST): BOOLEAN is_valid_context (req: WSF_REQUEST): BOOLEAN
-- Is `req' valid context for current handler? -- Is `req' valid context for current handler?
require
req_attached: req /= Void
do do
Result := True Result := True
end end
@@ -19,6 +21,8 @@ feature {WSF_ROUTER} -- Mapping
on_mapped (a_mapping: WSF_ROUTER_MAPPING; a_rqst_methods: detachable WSF_REQUEST_METHODS) on_mapped (a_mapping: WSF_ROUTER_MAPPING; a_rqst_methods: detachable WSF_REQUEST_METHODS)
-- Callback called when a router map a route to Current handler -- Callback called when a router map a route to Current handler
require
a_mapping_attached: a_mapping /= Void
do do
end end