Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 
 
 
 
 

325 wiersze
28 KiB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  6. <title>webnotes &mdash; WNFramework v1.8 documentation</title>
  7. <link rel="stylesheet" href="../_static/default.css" type="text/css" />
  8. <link rel="stylesheet" href="../_static/pygments.css" type="text/css" />
  9. <script type="text/javascript">
  10. var DOCUMENTATION_OPTIONS = {
  11. URL_ROOT: '../',
  12. VERSION: '1.8',
  13. COLLAPSE_INDEX: false,
  14. FILE_SUFFIX: '.html',
  15. HAS_SOURCE: true
  16. };
  17. </script>
  18. <script type="text/javascript" src="../_static/jquery.js"></script>
  19. <script type="text/javascript" src="../_static/underscore.js"></script>
  20. <script type="text/javascript" src="../_static/doctools.js"></script>
  21. <link rel="top" title="WNFramework v1.8 documentation" href="../index.html" />
  22. <link rel="up" title="Module code" href="index.html" />
  23. </head>
  24. <body>
  25. <div class="related">
  26. <h3>Navigation</h3>
  27. <ul>
  28. <li class="right" style="margin-right: 10px">
  29. <a href="../genindex.html" title="General Index"
  30. accesskey="I">index</a></li>
  31. <li class="right" >
  32. <a href="../py-modindex.html" title="Python Module Index"
  33. >modules</a> |</li>
  34. <li><a href="../index.html">WNFramework v1.8 documentation</a> &raquo;</li>
  35. <li><a href="index.html" accesskey="U">Module code</a> &raquo;</li>
  36. </ul>
  37. </div>
  38. <div class="document">
  39. <div class="documentwrapper">
  40. <div class="bodywrapper">
  41. <div class="body">
  42. <h1>Source code for webnotes</h1><div class="highlight"><pre>
  43. <span class="c">#</span>
  44. <span class="c"># import modules path</span>
  45. <span class="c"># </span>
  46. <span class="kn">import</span> <span class="nn">os</span><span class="o">,</span> <span class="nn">sys</span>
  47. <span class="k">try</span><span class="p">:</span>
  48. <span class="kn">import</span> <span class="nn">webnotes.defs</span>
  49. <span class="n">m</span> <span class="o">=</span> <span class="nb">getattr</span><span class="p">(</span><span class="n">webnotes</span><span class="o">.</span><span class="n">defs</span><span class="p">,</span><span class="s">&#39;modules_path&#39;</span><span class="p">,</span><span class="bp">None</span><span class="p">)</span>
  50. <span class="n">m</span> <span class="ow">and</span> <span class="n">sys</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">m</span><span class="p">)</span>
  51. <span class="k">except</span> <span class="ne">Exception</span><span class="p">,</span><span class="n">e</span><span class="p">:</span>
  52. <span class="k">raise</span> <span class="n">e</span>
  53. <span class="c">#</span>
  54. <span class="c"># map for identifying which field values come from files</span>
  55. <span class="c">#</span>
  56. <span class="n">code_fields_dict</span> <span class="o">=</span> <span class="p">{</span>
  57. <span class="s">&#39;Page&#39;</span><span class="p">:[(</span><span class="s">&#39;script&#39;</span><span class="p">,</span> <span class="s">&#39;js&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;content&#39;</span><span class="p">,</span> <span class="s">&#39;html&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;style&#39;</span><span class="p">,</span> <span class="s">&#39;css&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;static_content&#39;</span><span class="p">,</span> <span class="s">&#39;html&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;server_code&#39;</span><span class="p">,</span> <span class="s">&#39;py&#39;</span><span class="p">)],</span>
  58. <span class="s">&#39;DocType&#39;</span><span class="p">:[(</span><span class="s">&#39;server_code_core&#39;</span><span class="p">,</span> <span class="s">&#39;py&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;client_script_core&#39;</span><span class="p">,</span> <span class="s">&#39;js&#39;</span><span class="p">)],</span>
  59. <span class="s">&#39;Search Criteria&#39;</span><span class="p">:[(</span><span class="s">&#39;report_script&#39;</span><span class="p">,</span> <span class="s">&#39;js&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;server_script&#39;</span><span class="p">,</span> <span class="s">&#39;py&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;custom_query&#39;</span><span class="p">,</span> <span class="s">&#39;sql&#39;</span><span class="p">)],</span>
  60. <span class="s">&#39;Patch&#39;</span><span class="p">:[(</span><span class="s">&#39;patch_code&#39;</span><span class="p">,</span> <span class="s">&#39;py&#39;</span><span class="p">)],</span>
  61. <span class="s">&#39;Stylesheet&#39;</span><span class="p">:[</span><span class="s">&#39;stylesheet&#39;</span><span class="p">,</span> <span class="s">&#39;css&#39;</span><span class="p">],</span>
  62. <span class="s">&#39;Page Template&#39;</span><span class="p">:[</span><span class="s">&#39;template&#39;</span><span class="p">,</span> <span class="s">&#39;html&#39;</span><span class="p">],</span>
  63. <span class="s">&#39;Control Panel&#39;</span><span class="p">:[(</span><span class="s">&#39;startup_code&#39;</span><span class="p">,</span> <span class="s">&#39;js&#39;</span><span class="p">),</span> <span class="p">(</span><span class="s">&#39;startup_css&#39;</span><span class="p">,</span> <span class="s">&#39;css&#39;</span><span class="p">)]</span>
  64. <span class="p">}</span>
  65. <span class="c">#</span>
  66. <span class="c"># globals</span>
  67. <span class="c">#</span>
  68. <span class="c">#: &quot;v170&quot; </span>
  69. <span class="n">version</span> <span class="o">=</span> <span class="s">&#39;v170&#39;</span>
  70. <span class="n">form_dict</span> <span class="o">=</span> <span class="p">{}</span>
  71. <span class="n">auth_obj</span> <span class="o">=</span> <span class="bp">None</span>
  72. <span class="c">#: The database connection :class:`webnotes.db.Database` setup by :mod:`auth`</span>
  73. <span class="n">conn</span> <span class="o">=</span> <span class="bp">None</span>
  74. <span class="c">#: The cgi.FieldStorage() object (Dictionary representing the formdata from the URL)</span>
  75. <span class="n">form</span> <span class="o">=</span> <span class="bp">None</span>
  76. <span class="n">session</span> <span class="o">=</span> <span class="bp">None</span>
  77. <span class="sd">&quot;&quot;&quot;</span>
  78. <span class="sd"> Global session dictionary.</span>
  79. <span class="sd"> * session[&#39;user&#39;] - Current user </span>
  80. <span class="sd"> * session[&#39;data&#39;] - Returns a dictionary of the session cache</span>
  81. <span class="sd">&quot;&quot;&quot;</span>
  82. <span class="n">user</span> <span class="o">=</span> <span class="bp">None</span>
  83. <span class="n">is_testing</span> <span class="o">=</span> <span class="bp">None</span>
  84. <span class="sd">&quot;&quot;&quot; Flag to identify if system is in :term:`Testing Mode` &quot;&quot;&quot;</span>
  85. <span class="n">incoming_cookies</span> <span class="o">=</span> <span class="p">{}</span>
  86. <span class="n">add_cookies</span> <span class="o">=</span> <span class="p">{}</span>
  87. <span class="sd">&quot;&quot;&quot; Dictionary of additional cookies appended by custom code &quot;&quot;&quot;</span>
  88. <span class="n">cookies</span> <span class="o">=</span> <span class="p">{}</span>
  89. <span class="n">auto_masters</span> <span class="o">=</span> <span class="p">{}</span>
  90. <span class="n">tenant_id</span> <span class="o">=</span> <span class="bp">None</span>
  91. <span class="c">#</span>
  92. <span class="c"># Custom Class (no traceback)</span>
  93. <span class="c">#</span>
  94. <div class="viewcode-block" id="ValidationError"><a class="viewcode-back" href="../webnotes.html#webnotes.ValidationError">[docs]</a><span class="k">class</span> <span class="nc">ValidationError</span><span class="p">(</span><span class="ne">Exception</span><span class="p">):</span>
  95. <span class="k">pass</span>
  96. <span class="c">#</span>
  97. <span class="c"># HTTP standard response</span>
  98. <span class="c">#</span></div>
  99. <span class="n">response</span> <span class="o">=</span> <span class="p">{</span><span class="s">&#39;message&#39;</span><span class="p">:</span><span class="s">&#39;&#39;</span><span class="p">,</span> <span class="s">&#39;exc&#39;</span><span class="p">:</span><span class="s">&#39;&#39;</span><span class="p">}</span>
  100. <span class="sd">&quot;&quot;&quot;</span>
  101. <span class="sd"> The JSON response object. Default is::</span>
  102. <span class="sd"> </span>
  103. <span class="sd"> {&#39;message&#39;:&#39;&#39;, &#39;exc&#39;:&#39;&#39;}</span>
  104. <span class="sd">&quot;&quot;&quot;</span>
  105. <span class="c">#</span>
  106. <span class="c"># the logs</span>
  107. <span class="c">#</span>
  108. <span class="n">debug_log</span> <span class="o">=</span> <span class="p">[]</span>
  109. <span class="sd">&quot;&quot;&quot; List of exceptions to be shown in the :term:`Error Console` &quot;&quot;&quot;</span>
  110. <span class="n">message_log</span> <span class="o">=</span> <span class="p">[]</span>
  111. <span class="sd">&quot;&quot;&quot; List of messages to be shown to the user in a popup box at the end of the request &quot;&quot;&quot;</span>
  112. <div class="viewcode-block" id="getTraceback"><a class="viewcode-back" href="../webnotes.html#webnotes.getTraceback">[docs]</a><span class="k">def</span> <span class="nf">getTraceback</span><span class="p">():</span>
  113. <span class="kn">import</span> <span class="nn">webnotes.utils</span>
  114. <span class="k">return</span> <span class="n">webnotes</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">getTraceback</span><span class="p">()</span>
  115. </div>
  116. <div class="viewcode-block" id="errprint"><a class="viewcode-back" href="../webnotes.html#webnotes.errprint">[docs]</a><span class="k">def</span> <span class="nf">errprint</span><span class="p">(</span><span class="n">msg</span><span class="p">):</span>
  117. <span class="sd">&quot;&quot;&quot;</span>
  118. <span class="sd"> Append to the :data:`debug log`</span>
  119. <span class="sd"> &quot;&quot;&quot;</span>
  120. <span class="n">debug_log</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">msg</span> <span class="ow">or</span> <span class="s">&#39;&#39;</span><span class="p">))</span>
  121. </div>
  122. <div class="viewcode-block" id="msgprint"><a class="viewcode-back" href="../webnotes.html#webnotes.msgprint">[docs]</a><span class="k">def</span> <span class="nf">msgprint</span><span class="p">(</span><span class="n">msg</span><span class="p">,</span> <span class="n">small</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">raise_exception</span><span class="o">=</span><span class="mi">0</span><span class="p">):</span>
  123. <span class="sd">&quot;&quot;&quot;</span>
  124. <span class="sd"> Append to the :data:`message_log`</span>
  125. <span class="sd"> &quot;&quot;&quot;</span>
  126. <span class="n">message_log</span><span class="o">.</span><span class="n">append</span><span class="p">((</span><span class="n">small</span> <span class="ow">and</span> <span class="s">&#39;__small:&#39;</span> <span class="ow">or</span> <span class="s">&#39;&#39;</span><span class="p">)</span><span class="o">+</span><span class="nb">str</span><span class="p">(</span><span class="n">msg</span> <span class="ow">or</span> <span class="s">&#39;&#39;</span><span class="p">))</span>
  127. <span class="k">if</span> <span class="n">raise_exception</span><span class="p">:</span>
  128. <span class="k">raise</span> <span class="n">ValidationError</span>
  129. </div>
  130. <div class="viewcode-block" id="is_apache_user"><a class="viewcode-back" href="../webnotes.html#webnotes.is_apache_user">[docs]</a><span class="k">def</span> <span class="nf">is_apache_user</span><span class="p">():</span>
  131. <span class="kn">import</span> <span class="nn">os</span>
  132. <span class="k">if</span> <span class="n">os</span><span class="o">.</span><span class="n">environ</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s">&#39;USER&#39;</span><span class="p">)</span> <span class="o">==</span> <span class="s">&#39;apache&#39;</span><span class="p">:</span>
  133. <span class="k">return</span> <span class="bp">True</span>
  134. <span class="k">else</span><span class="p">:</span>
  135. <span class="k">return</span> <span class="p">(</span><span class="ow">not</span> <span class="n">os</span><span class="o">.</span><span class="n">environ</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s">&#39;USER&#39;</span><span class="p">))</span>
  136. <span class="c"># os.environ does not have user, so allows a security vulnerability,fixed now. </span>
  137. </div>
  138. <div class="viewcode-block" id="get_index_path"><a class="viewcode-back" href="../webnotes.html#webnotes.get_index_path">[docs]</a><span class="k">def</span> <span class="nf">get_index_path</span><span class="p">():</span>
  139. <span class="kn">import</span> <span class="nn">os</span>
  140. <span class="k">return</span> <span class="n">os</span><span class="o">.</span><span class="n">sep</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">dirname</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">abspath</span><span class="p">(</span><span class="n">__file__</span><span class="p">))</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">sep</span><span class="p">)[:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span>
  141. </div>
  142. <div class="viewcode-block" id="get_files_path"><a class="viewcode-back" href="../webnotes.html#webnotes.get_files_path">[docs]</a><span class="k">def</span> <span class="nf">get_files_path</span><span class="p">():</span>
  143. <span class="k">global</span> <span class="n">conn</span>
  144. <span class="kn">import</span> <span class="nn">defs</span><span class="o">,</span> <span class="nn">os</span>
  145. <span class="k">if</span> <span class="ow">not</span> <span class="n">conn</span><span class="p">:</span>
  146. <span class="k">raise</span> <span class="ne">Exception</span><span class="p">,</span> <span class="s">&#39;You must login first&#39;</span>
  147. <span class="k">if</span> <span class="n">defs</span><span class="o">.</span><span class="n">files_path</span><span class="p">:</span>
  148. <span class="k">return</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">defs</span><span class="o">.</span><span class="n">files_path</span><span class="p">,</span> <span class="n">conn</span><span class="o">.</span><span class="n">cur_db_name</span><span class="p">)</span>
  149. <span class="k">else</span><span class="p">:</span>
  150. <span class="k">return</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">get_index_path</span><span class="p">(),</span> <span class="s">&#39;user_files&#39;</span><span class="p">,</span> <span class="n">conn</span><span class="o">.</span><span class="n">cur_db_name</span><span class="p">)</span>
  151. </div>
  152. <div class="viewcode-block" id="create_folder"><a class="viewcode-back" href="../webnotes.html#webnotes.create_folder">[docs]</a><span class="k">def</span> <span class="nf">create_folder</span><span class="p">(</span><span class="n">path</span><span class="p">):</span>
  153. <span class="sd">&quot;&quot;&quot;</span>
  154. <span class="sd"> Wrapper function for os.makedirs (does not throw exception if directory exists)</span>
  155. <span class="sd"> &quot;&quot;&quot;</span>
  156. <span class="kn">import</span> <span class="nn">os</span>
  157. <span class="k">try</span><span class="p">:</span>
  158. <span class="n">os</span><span class="o">.</span><span class="n">makedirs</span><span class="p">(</span><span class="n">path</span><span class="p">)</span>
  159. <span class="k">except</span> <span class="ne">Exception</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span>
  160. <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">==</span><span class="mi">17</span><span class="p">:</span>
  161. <span class="k">pass</span>
  162. <span class="k">else</span><span class="p">:</span>
  163. <span class="k">raise</span> <span class="n">e</span>
  164. <span class="c">###############################################################################</span>
  165. <span class="c"># BEGIN: TENTATIVE CODE FEELS LIKE A CLASS/TEMPLATE IS A BETTER IDEA FOR THESE VARIABLES.</span>
  166. <span class="c"># Bad idea combining/using one function to set conn,user,session variables.</span>
  167. <span class="c"># Need to split up.</span>
  168. <span class="c">###############################################################################</span>
  169. </div>
  170. <div class="viewcode-block" id="set_as_account_master"><a class="viewcode-back" href="../webnotes.html#webnotes.set_as_account_master">[docs]</a><span class="k">def</span> <span class="nf">set_as_account_master</span><span class="p">():</span>
  171. <span class="kn">import</span> <span class="nn">webnotes.db</span>
  172. <span class="k">global</span> <span class="n">conn</span>
  173. <span class="n">conn</span> <span class="o">=</span> <span class="n">webnotes</span><span class="o">.</span><span class="n">db</span><span class="o">.</span><span class="n">Database</span><span class="p">(</span><span class="n">use_default</span> <span class="o">=</span> <span class="mi">1</span><span class="p">)</span>
  174. </div>
  175. <div class="viewcode-block" id="set_as_administrator"><a class="viewcode-back" href="../webnotes.html#webnotes.set_as_administrator">[docs]</a><span class="k">def</span> <span class="nf">set_as_administrator</span><span class="p">():</span>
  176. <span class="k">global</span> <span class="n">user</span>
  177. <span class="k">if</span> <span class="n">is_apache_user</span><span class="p">():</span>
  178. <span class="k">raise</span> <span class="ne">Exception</span><span class="p">,</span> <span class="s">&#39;Not for web users!&#39;</span>
  179. <span class="kn">import</span> <span class="nn">webnotes.profile</span>
  180. <span class="n">user</span> <span class="o">=</span> <span class="n">webnotes</span><span class="o">.</span><span class="n">profile</span><span class="o">.</span><span class="n">Profile</span><span class="p">(</span><span class="s">&#39;Administrator&#39;</span><span class="p">)</span>
  181. </div>
  182. <div class="viewcode-block" id="set_as_admin_session"><a class="viewcode-back" href="../webnotes.html#webnotes.set_as_admin_session">[docs]</a><span class="k">def</span> <span class="nf">set_as_admin_session</span><span class="p">():</span>
  183. <span class="k">global</span> <span class="n">session</span>
  184. <span class="n">session</span> <span class="o">=</span> <span class="p">{</span><span class="s">&#39;user&#39;</span><span class="p">:</span><span class="s">&#39;Administrator&#39;</span><span class="p">}</span>
  185. <span class="c">###############################################################################</span>
  186. <span class="c">#END </span>
  187. <span class="c">###############################################################################</span>
  188. </div>
  189. <div class="viewcode-block" id="set_as_admin"><a class="viewcode-back" href="../webnotes.html#webnotes.set_as_admin">[docs]</a><span class="k">def</span> <span class="nf">set_as_admin</span><span class="p">(</span><span class="n">db_name</span><span class="o">=</span><span class="bp">None</span><span class="p">,</span> <span class="n">ac_name</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
  190. <span class="kn">import</span> <span class="nn">os</span>
  191. <span class="k">if</span> <span class="n">is_apache_user</span><span class="p">():</span>
  192. <span class="k">raise</span> <span class="ne">Exception</span><span class="p">,</span> <span class="s">&#39;Not for web users!&#39;</span>
  193. <span class="k">global</span> <span class="n">conn</span>
  194. <span class="k">global</span> <span class="n">session</span>
  195. <span class="k">global</span> <span class="n">user</span>
  196. <span class="kn">import</span> <span class="nn">webnotes.db</span>
  197. <span class="k">if</span> <span class="n">ac_name</span><span class="p">:</span>
  198. <span class="n">conn</span> <span class="o">=</span> <span class="n">webnotes</span><span class="o">.</span><span class="n">db</span><span class="o">.</span><span class="n">Database</span><span class="p">(</span><span class="n">ac_name</span> <span class="o">=</span> <span class="n">ac_name</span><span class="p">)</span>
  199. <span class="k">else</span><span class="p">:</span>
  200. <span class="n">set_as_account_master</span><span class="p">()</span>
  201. <span class="k">if</span> <span class="n">db_name</span><span class="p">:</span>
  202. <span class="n">conn</span><span class="o">.</span><span class="n">use</span><span class="p">(</span><span class="n">db_name</span><span class="p">)</span>
  203. <span class="n">session</span> <span class="o">=</span> <span class="p">{</span><span class="s">&#39;user&#39;</span><span class="p">:</span><span class="s">&#39;Administrator&#39;</span><span class="p">}</span>
  204. <span class="kn">import</span> <span class="nn">webnotes.profile</span>
  205. <span class="n">user</span> <span class="o">=</span> <span class="n">webnotes</span><span class="o">.</span><span class="n">profile</span><span class="o">.</span><span class="n">Profile</span><span class="p">(</span><span class="s">&#39;Administrator&#39;</span><span class="p">)</span>
  206. <span class="c"># Environment Variables</span>
  207. <span class="c">#-----------------------------------------------------------</span></div>
  208. <div class="viewcode-block" id="get_env_vars"><a class="viewcode-back" href="../webnotes.html#webnotes.get_env_vars">[docs]</a><span class="k">def</span> <span class="nf">get_env_vars</span><span class="p">(</span><span class="n">env_var</span><span class="p">):</span>
  209. <span class="k">return</span> <span class="n">os</span><span class="o">.</span><span class="n">environ</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">env_var</span><span class="p">,</span><span class="s">&#39;None&#39;</span><span class="p">)</span>
  210. </div>
  211. <span class="n">remote_ip</span> <span class="o">=</span> <span class="n">get_env_vars</span><span class="p">(</span><span class="s">&#39;REMOTE_ADDR&#39;</span><span class="p">)</span> <span class="c">#Required for login from python shell</span>
  212. <span class="c"># Logging</span>
  213. <span class="c"># -----------------------------------------------------------</span>
  214. <span class="n">logger</span> <span class="o">=</span> <span class="bp">None</span>
  215. <div class="viewcode-block" id="setup_logging"><a class="viewcode-back" href="../webnotes.html#webnotes.setup_logging">[docs]</a><span class="k">def</span> <span class="nf">setup_logging</span><span class="p">():</span>
  216. <span class="kn">import</span> <span class="nn">logging</span>
  217. <span class="kn">import</span> <span class="nn">logging.handlers</span>
  218. <span class="c"># Also please set umask for apache to 002.</span>
  219. <span class="k">global</span> <span class="n">logger</span>
  220. <span class="k">try</span><span class="p">:</span>
  221. <span class="n">logger</span> <span class="o">=</span> <span class="n">logging</span><span class="o">.</span><span class="n">getLogger</span><span class="p">(</span><span class="s">&#39;WNLogger&#39;</span><span class="p">)</span>
  222. <span class="n">logger</span><span class="o">.</span><span class="n">setLevel</span><span class="p">(</span><span class="nb">eval</span><span class="p">(</span><span class="n">defs</span><span class="o">.</span><span class="n">log_level</span><span class="p">))</span>
  223. <span class="n">log_handler</span> <span class="o">=</span> <span class="n">logging</span><span class="o">.</span><span class="n">handlers</span><span class="o">.</span><span class="n">RotatingFileHandler</span><span class="p">(</span><span class="n">defs</span><span class="o">.</span><span class="n">log_file_name</span><span class="p">,</span> <span class="n">maxBytes</span> <span class="o">=</span> <span class="n">defs</span><span class="o">.</span><span class="n">log_file_size</span><span class="p">,</span> <span class="n">backupCount</span> <span class="o">=</span> <span class="n">defs</span><span class="o">.</span><span class="n">log_file_backup_count</span><span class="p">)</span>
  224. <span class="n">formatter</span> <span class="o">=</span> <span class="n">logging</span><span class="o">.</span><span class="n">Formatter</span><span class="p">(</span><span class="s">&#39;</span><span class="si">%(name)s</span><span class="s"> - </span><span class="si">%(asctime)s</span><span class="s"> - </span><span class="si">%(levelname)s</span><span class="se">\n</span><span class="si">%(message)s</span><span class="se">\n</span><span class="s">-------------------&#39;</span><span class="p">)</span>
  225. <span class="n">log_handler</span><span class="o">.</span><span class="n">setFormatter</span><span class="p">(</span><span class="n">formatter</span><span class="p">)</span>
  226. <span class="n">logger</span><span class="o">.</span><span class="n">addHandler</span><span class="p">(</span><span class="n">log_handler</span><span class="p">)</span>
  227. <span class="k">except</span> <span class="ne">IOError</span><span class="p">,</span><span class="n">e</span><span class="p">:</span>
  228. <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span> <span class="o">==</span> <span class="mi">13</span><span class="p">:</span>
  229. <span class="nb">open</span><span class="p">(</span><span class="n">defs</span><span class="o">.</span><span class="n">log_file_name</span><span class="p">)</span><span class="o">.</span><span class="n">close</span><span class="p">()</span>
  230. </div>
  231. <span class="k">if</span> <span class="nb">getattr</span><span class="p">(</span><span class="n">defs</span><span class="p">,</span> <span class="s">&#39;log_file_name&#39;</span><span class="p">,</span> <span class="bp">None</span><span class="p">):</span>
  232. <span class="n">setup_logging</span><span class="p">()</span>
  233. </pre></div>
  234. </div>
  235. </div>
  236. </div>
  237. <div class="sphinxsidebar">
  238. <div class="sphinxsidebarwrapper">
  239. <p class="logo"><a href="../index.html">
  240. <img class="logo" src="../_static/wnflogo200.gif" alt="Logo"/>
  241. </a></p>
  242. <div id="searchbox" style="display: none">
  243. <h3>Quick search</h3>
  244. <form class="search" action="../search.html" method="get">
  245. <input type="text" name="q" size="18" />
  246. <input type="submit" value="Go" />
  247. <input type="hidden" name="check_keywords" value="yes" />
  248. <input type="hidden" name="area" value="default" />
  249. </form>
  250. <p class="searchtip" style="font-size: 90%">
  251. Enter search terms or a module, class or function name.
  252. </p>
  253. </div>
  254. <script type="text/javascript">$('#searchbox').show(0);</script>
  255. </div>
  256. </div>
  257. <div class="clearer"></div>
  258. </div>
  259. <div class="related">
  260. <h3>Navigation</h3>
  261. <ul>
  262. <li class="right" style="margin-right: 10px">
  263. <a href="../genindex.html" title="General Index"
  264. >index</a></li>
  265. <li class="right" >
  266. <a href="../py-modindex.html" title="Python Module Index"
  267. >modules</a> |</li>
  268. <li><a href="../index.html">WNFramework v1.8 documentation</a> &raquo;</li>
  269. <li><a href="index.html" >Module code</a> &raquo;</li>
  270. </ul>
  271. </div>
  272. <div class="footer">
  273. &copy; Copyright 2011, Rushabh Mehta, Web Notes Technologies.
  274. Created using <a href="http://sphinx.pocoo.org/">Sphinx</a> 1.0.7.
  275. </div>
  276. </body>
  277. </html>