/src/models/m_req.erl

http://github.com/zotonic/zotonic · Erlang · 91 lines · 49 code · 16 blank · 26 comment · 1 complexity · 87c4ffa3a086f0fc07786e602157fae1 MD5 · raw file

  1. %% @author Marc Worrell <marc@worrell.nl>
  2. %% @copyright 2010 Marc Worrell
  3. %% Date: 2010-07-22
  4. %%
  5. %% @doc Model for the accessing the request fields. Exposes Webmachine's wrq.erl
  6. %% Copyright 2010 Marc Worrell
  7. %%
  8. %% Licensed under the Apache License, Version 2.0 (the "License");
  9. %% you may not use this file except in compliance with the License.
  10. %% You may obtain a copy of the License at
  11. %%
  12. %% http://www.apache.org/licenses/LICENSE-2.0
  13. %%
  14. %% Unless required by applicable law or agreed to in writing, software
  15. %% distributed under the License is distributed on an "AS IS" BASIS,
  16. %% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  17. %% See the License for the specific language governing permissions and
  18. %% limitations under the License.
  19. -module(m_req).
  20. -author("Marc Worrell <marc@worrell.nl").
  21. -behaviour(gen_model).
  22. %% interface functions
  23. -export([
  24. m_find_value/3,
  25. m_to_list/2,
  26. m_value/2,
  27. get/2
  28. ]).
  29. -include_lib("zotonic.hrl").
  30. -include_lib("webzmachine/include/webmachine_logger.hrl").
  31. %% @doc Fetch the value for the key from a model source
  32. %% @spec m_find_value(Key, Source, Context) -> term()
  33. m_find_value(Key, #m{value=undefined}, Context) ->
  34. get(Key, Context).
  35. %% @doc Transform a m_config value to a list, used for template loops
  36. %% @spec m_to_list(Source, Context) -> List
  37. m_to_list(#m{value=undefined}, Context) ->
  38. values(Context).
  39. %% @doc Transform a model value so that it can be formatted or piped through filters
  40. %% @spec m_value(Source, Context) -> term()
  41. m_value(#m{value=undefined}, Context) ->
  42. values(Context).
  43. %% @doc Fetch the field from the wrq interface.
  44. -spec get(atom(), #context{} | #wm_reqdata{} | undefined) -> any().
  45. get(undefined, _) -> undefined;
  46. get(_, undefined) -> undefined;
  47. get(site, #context{} = Context) -> z_context:site(Context);
  48. get(timezone, #context{} = Context) -> z_context:tz(Context);
  49. get(language, #context{} = Context) -> z_context:language(Context);
  50. get(is_crawler, #context{} = Context) -> z_user_agent:is_crawler(Context);
  51. get(What, #context{} = Context) -> get_req(What, z_context:get_reqdata(Context));
  52. get(What, #wm_reqdata{} = RD) -> get_req(What, RD).
  53. get_req(_What, undefined) -> undefined;
  54. get_req(method, RD) -> wrq:method(RD);
  55. get_req(version, RD) -> wrq:version(RD);
  56. get_req(peer, RD) -> wrq:peer(RD);
  57. get_req(is_ssl, RD) -> wrq:is_ssl(RD);
  58. get_req(host, RD) -> wrq:get_req_header_lc("host", RD);
  59. get_req(raw_path, RD) -> wrq:raw_path(RD);
  60. get_req(path, RD) -> wrq:path(RD);
  61. get_req(qs, RD) -> wrq:req_qs(RD);
  62. get_req(headers, RD) -> wrq:req_headers(RD);
  63. get_req(user_agent, RD) -> wrq:get_req_header_lc("user-agent", RD);
  64. get_req(referer, RD) -> wrq:get_req_header_lc("referer", RD);
  65. get_req(referrer, RD) -> wrq:get_req_header_lc("referer", RD);
  66. get_req(req_id, #wm_reqdata{log_data=#wm_log_data{req_id=ReqId}}) -> ReqId;
  67. get_req(is_crawler, RD) -> z_user_agent:is_crawler(RD);
  68. get_req(_Key, _RD) -> undefined.
  69. -spec values(#context{}) -> list({atom(), any()}).
  70. values(Context) ->
  71. [ {K, get(K, Context)} || K <- [
  72. method, version, peer, is_ssl, host, raw_path, path, qs, referrer, user_agent, is_crawler,
  73. req_id, headers, timezone, language
  74. ]
  75. ].