You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

579 lines
20 KiB

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  6. <meta name="generator" content="Docutils 0.15.1: http://docutils.sourceforge.net/" />
  7. <title>Sentry</title>
  8. <style type="text/css">
  9. /*
  10. :Author: David Goodger (goodger@python.org)
  11. :Id: $Id: html4css1.css 7952 2016-07-26 18:15:59Z milde $
  12. :Copyright: This stylesheet has been placed in the public domain.
  13. Default cascading style sheet for the HTML output of Docutils.
  14. See http://docutils.sf.net/docs/howto/html-stylesheets.html for how to
  15. customize this style sheet.
  16. */
  17. /* used to remove borders from tables and images */
  18. .borderless, table.borderless td, table.borderless th {
  19. border: 0 }
  20. table.borderless td, table.borderless th {
  21. /* Override padding for "table.docutils td" with "! important".
  22. The right padding separates the table cells. */
  23. padding: 0 0.5em 0 0 ! important }
  24. .first {
  25. /* Override more specific margin styles with "! important". */
  26. margin-top: 0 ! important }
  27. .last, .with-subtitle {
  28. margin-bottom: 0 ! important }
  29. .hidden {
  30. display: none }
  31. .subscript {
  32. vertical-align: sub;
  33. font-size: smaller }
  34. .superscript {
  35. vertical-align: super;
  36. font-size: smaller }
  37. a.toc-backref {
  38. text-decoration: none ;
  39. color: black }
  40. blockquote.epigraph {
  41. margin: 2em 5em ; }
  42. dl.docutils dd {
  43. margin-bottom: 0.5em }
  44. object[type="image/svg+xml"], object[type="application/x-shockwave-flash"] {
  45. overflow: hidden;
  46. }
  47. /* Uncomment (and remove this text!) to get bold-faced definition list terms
  48. dl.docutils dt {
  49. font-weight: bold }
  50. */
  51. div.abstract {
  52. margin: 2em 5em }
  53. div.abstract p.topic-title {
  54. font-weight: bold ;
  55. text-align: center }
  56. div.admonition, div.attention, div.caution, div.danger, div.error,
  57. div.hint, div.important, div.note, div.tip, div.warning {
  58. margin: 2em ;
  59. border: medium outset ;
  60. padding: 1em }
  61. div.admonition p.admonition-title, div.hint p.admonition-title,
  62. div.important p.admonition-title, div.note p.admonition-title,
  63. div.tip p.admonition-title {
  64. font-weight: bold ;
  65. font-family: sans-serif }
  66. div.attention p.admonition-title, div.caution p.admonition-title,
  67. div.danger p.admonition-title, div.error p.admonition-title,
  68. div.warning p.admonition-title, .code .error {
  69. color: red ;
  70. font-weight: bold ;
  71. font-family: sans-serif }
  72. /* Uncomment (and remove this text!) to get reduced vertical space in
  73. compound paragraphs.
  74. div.compound .compound-first, div.compound .compound-middle {
  75. margin-bottom: 0.5em }
  76. div.compound .compound-last, div.compound .compound-middle {
  77. margin-top: 0.5em }
  78. */
  79. div.dedication {
  80. margin: 2em 5em ;
  81. text-align: center ;
  82. font-style: italic }
  83. div.dedication p.topic-title {
  84. font-weight: bold ;
  85. font-style: normal }
  86. div.figure {
  87. margin-left: 2em ;
  88. margin-right: 2em }
  89. div.footer, div.header {
  90. clear: both;
  91. font-size: smaller }
  92. div.line-block {
  93. display: block ;
  94. margin-top: 1em ;
  95. margin-bottom: 1em }
  96. div.line-block div.line-block {
  97. margin-top: 0 ;
  98. margin-bottom: 0 ;
  99. margin-left: 1.5em }
  100. div.sidebar {
  101. margin: 0 0 0.5em 1em ;
  102. border: medium outset ;
  103. padding: 1em ;
  104. background-color: #ffffee ;
  105. width: 40% ;
  106. float: right ;
  107. clear: right }
  108. div.sidebar p.rubric {
  109. font-family: sans-serif ;
  110. font-size: medium }
  111. div.system-messages {
  112. margin: 5em }
  113. div.system-messages h1 {
  114. color: red }
  115. div.system-message {
  116. border: medium outset ;
  117. padding: 1em }
  118. div.system-message p.system-message-title {
  119. color: red ;
  120. font-weight: bold }
  121. div.topic {
  122. margin: 2em }
  123. h1.section-subtitle, h2.section-subtitle, h3.section-subtitle,
  124. h4.section-subtitle, h5.section-subtitle, h6.section-subtitle {
  125. margin-top: 0.4em }
  126. h1.title {
  127. text-align: center }
  128. h2.subtitle {
  129. text-align: center }
  130. hr.docutils {
  131. width: 75% }
  132. img.align-left, .figure.align-left, object.align-left, table.align-left {
  133. clear: left ;
  134. float: left ;
  135. margin-right: 1em }
  136. img.align-right, .figure.align-right, object.align-right, table.align-right {
  137. clear: right ;
  138. float: right ;
  139. margin-left: 1em }
  140. img.align-center, .figure.align-center, object.align-center {
  141. display: block;
  142. margin-left: auto;
  143. margin-right: auto;
  144. }
  145. table.align-center {
  146. margin-left: auto;
  147. margin-right: auto;
  148. }
  149. .align-left {
  150. text-align: left }
  151. .align-center {
  152. clear: both ;
  153. text-align: center }
  154. .align-right {
  155. text-align: right }
  156. /* reset inner alignment in figures */
  157. div.align-right {
  158. text-align: inherit }
  159. /* div.align-center * { */
  160. /* text-align: left } */
  161. .align-top {
  162. vertical-align: top }
  163. .align-middle {
  164. vertical-align: middle }
  165. .align-bottom {
  166. vertical-align: bottom }
  167. ol.simple, ul.simple {
  168. margin-bottom: 1em }
  169. ol.arabic {
  170. list-style: decimal }
  171. ol.loweralpha {
  172. list-style: lower-alpha }
  173. ol.upperalpha {
  174. list-style: upper-alpha }
  175. ol.lowerroman {
  176. list-style: lower-roman }
  177. ol.upperroman {
  178. list-style: upper-roman }
  179. p.attribution {
  180. text-align: right ;
  181. margin-left: 50% }
  182. p.caption {
  183. font-style: italic }
  184. p.credits {
  185. font-style: italic ;
  186. font-size: smaller }
  187. p.label {
  188. white-space: nowrap }
  189. p.rubric {
  190. font-weight: bold ;
  191. font-size: larger ;
  192. color: maroon ;
  193. text-align: center }
  194. p.sidebar-title {
  195. font-family: sans-serif ;
  196. font-weight: bold ;
  197. font-size: larger }
  198. p.sidebar-subtitle {
  199. font-family: sans-serif ;
  200. font-weight: bold }
  201. p.topic-title {
  202. font-weight: bold }
  203. pre.address {
  204. margin-bottom: 0 ;
  205. margin-top: 0 ;
  206. font: inherit }
  207. pre.literal-block, pre.doctest-block, pre.math, pre.code {
  208. margin-left: 2em ;
  209. margin-right: 2em }
  210. pre.code .ln { color: grey; } /* line numbers */
  211. pre.code, code { background-color: #eeeeee }
  212. pre.code .comment, code .comment { color: #5C6576 }
  213. pre.code .keyword, code .keyword { color: #3B0D06; font-weight: bold }
  214. pre.code .literal.string, code .literal.string { color: #0C5404 }
  215. pre.code .name.builtin, code .name.builtin { color: #352B84 }
  216. pre.code .deleted, code .deleted { background-color: #DEB0A1}
  217. pre.code .inserted, code .inserted { background-color: #A3D289}
  218. span.classifier {
  219. font-family: sans-serif ;
  220. font-style: oblique }
  221. span.classifier-delimiter {
  222. font-family: sans-serif ;
  223. font-weight: bold }
  224. span.interpreted {
  225. font-family: sans-serif }
  226. span.option {
  227. white-space: nowrap }
  228. span.pre {
  229. white-space: pre }
  230. span.problematic {
  231. color: red }
  232. span.section-subtitle {
  233. /* font-size relative to parent (h1..h6 element) */
  234. font-size: 80% }
  235. table.citation {
  236. border-left: solid 1px gray;
  237. margin-left: 1px }
  238. table.docinfo {
  239. margin: 2em 4em }
  240. table.docutils {
  241. margin-top: 0.5em ;
  242. margin-bottom: 0.5em }
  243. table.footnote {
  244. border-left: solid 1px black;
  245. margin-left: 1px }
  246. table.docutils td, table.docutils th,
  247. table.docinfo td, table.docinfo th {
  248. padding-left: 0.5em ;
  249. padding-right: 0.5em ;
  250. vertical-align: top }
  251. table.docutils th.field-name, table.docinfo th.docinfo-name {
  252. font-weight: bold ;
  253. text-align: left ;
  254. white-space: nowrap ;
  255. padding-left: 0 }
  256. /* "booktabs" style (no vertical lines) */
  257. table.docutils.booktabs {
  258. border: 0px;
  259. border-top: 2px solid;
  260. border-bottom: 2px solid;
  261. border-collapse: collapse;
  262. }
  263. table.docutils.booktabs * {
  264. border: 0px;
  265. }
  266. table.docutils.booktabs th {
  267. border-bottom: thin solid;
  268. text-align: left;
  269. }
  270. h1 tt.docutils, h2 tt.docutils, h3 tt.docutils,
  271. h4 tt.docutils, h5 tt.docutils, h6 tt.docutils {
  272. font-size: 100% }
  273. ul.auto-toc {
  274. list-style-type: none }
  275. </style>
  276. </head>
  277. <body>
  278. <div class="document" id="sentry">
  279. <h1 class="title">Sentry</h1>
  280. <!-- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
  281. !! This file is generated by oca-gen-addon-readme !!
  282. !! changes will be overwritten. !!
  283. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
  284. <p><a class="reference external" href="https://odoo-community.org/page/development-status"><img alt="Beta" src="https://img.shields.io/badge/maturity-Beta-yellow.png" /></a> <a class="reference external" href="http://www.gnu.org/licenses/agpl-3.0-standalone.html"><img alt="License: AGPL-3" src="https://img.shields.io/badge/licence-AGPL--3-blue.png" /></a> <a class="reference external" href="https://github.com/OCA/server-tools/tree/12.0/sentry"><img alt="OCA/server-tools" src="https://img.shields.io/badge/github-OCA%2Fserver--tools-lightgray.png?logo=github" /></a> <a class="reference external" href="https://translation.odoo-community.org/projects/server-tools-12-0/server-tools-12-0-sentry"><img alt="Translate me on Weblate" src="https://img.shields.io/badge/weblate-Translate%20me-F47D42.png" /></a> <a class="reference external" href="https://runbot.odoo-community.org/runbot/149/12.0"><img alt="Try me on Runbot" src="https://img.shields.io/badge/runbot-Try%20me-875A7B.png" /></a></p>
  285. <p>This module allows painless <a class="reference external" href="https://sentry.io/">Sentry</a> integration with
  286. Odoo.</p>
  287. <table border="1" class="docutils">
  288. <colgroup>
  289. <col width="19%" />
  290. <col width="44%" />
  291. <col width="37%" />
  292. </colgroup>
  293. <thead valign="bottom">
  294. <tr><th class="head">Option</th>
  295. <th class="head">Description</th>
  296. <th class="head">Default</th>
  297. </tr>
  298. </thead>
  299. <tbody valign="top">
  300. <tr><td><tt class="docutils literal">sentry_dsn</tt></td>
  301. <td>Sentry <em>Data Source Name</em>. You can find this value in your Sentry
  302. project configuration. Typically it looks something like this:
  303. <em>https://&lt;public_key&gt;:&lt;secret_key&gt;&#64;sentry.example.com/&lt;project id&gt;</em>
  304. This is the only required option in order to use the module.</td>
  305. <td><tt class="docutils literal">''</tt></td>
  306. </tr>
  307. <tr><td><tt class="docutils literal">sentry_enabled</tt></td>
  308. <td>Whether or not Sentry logging is enabled.</td>
  309. <td><tt class="docutils literal">False</tt></td>
  310. </tr>
  311. <tr><td><tt class="docutils literal">sentry_logging_level</tt></td>
  312. <td>The minimal logging level for which to send reports to Sentry.
  313. Possible values: <em>notset</em>, <em>debug</em>, <em>info</em>, <em>warn</em>, <em>error</em>,
  314. <em>critical</em>. It is recommended to have this set to at least <em>warn</em>,
  315. to avoid spamming yourself with Sentry events.</td>
  316. <td><tt class="docutils literal">warn</tt></td>
  317. </tr>
  318. <tr><td><tt class="docutils literal">sentry_exclude_loggers</tt></td>
  319. <td>A string of comma-separated logger names which should be excluded
  320. from Sentry.</td>
  321. <td><tt class="docutils literal">werkzeug</tt></td>
  322. </tr>
  323. <tr><td><tt class="docutils literal">sentry_ignored_exceptions</tt></td>
  324. <td>A string of comma-separated exceptions which should be ignored.
  325. You can use a star symbol (*) at the end, to ignore all exceptions
  326. from a module, eg.: <em>odoo.exceptions.*</em>.</td>
  327. <td><tt class="docutils literal">odoo.exceptions.AccessDenied,
  328. odoo.exceptions.AccessError,
  329. odoo.exceptions.DeferredException,
  330. odoo.exceptions.MissingError,
  331. odoo.exceptions.RedirectWarning,
  332. odoo.exceptions.UserError,
  333. odoo.exceptions.ValidationError,
  334. odoo.exceptions.Warning,
  335. odoo.exceptions.except_orm</tt></td>
  336. </tr>
  337. <tr><td><tt class="docutils literal">sentry_include_context</tt></td>
  338. <td>If enabled, additional context data will be extracted from current
  339. HTTP request and user session (if available). This has no effect
  340. for Cron jobs, as no request/session is available inside a Cron job.</td>
  341. <td><tt class="docutils literal">True</tt></td>
  342. </tr>
  343. <tr><td><tt class="docutils literal">sentry_release</tt></td>
  344. <td>Explicitly define a version to be sent as the release version to
  345. Sentry. Useful in conjuntion with Sentry’s “Resolve in the next
  346. release”-functionality. Also useful if your production deployment
  347. does not include any Git context from which a commit might be read.
  348. Overrides <em>sentry_odoo_dir</em>.</td>
  349. <td>&nbsp;</td>
  350. </tr>
  351. <tr><td><tt class="docutils literal">sentry_odoo_dir</tt></td>
  352. <td>Absolute path to your Odoo installation directory. This is optional
  353. and will only be used to extract the Odoo Git commit, which will be
  354. sent to Sentry, to allow to distinguish between Odoo updates.
  355. Overridden by <em>sentry_release</em></td>
  356. <td>&nbsp;</td>
  357. </tr>
  358. </tbody>
  359. </table>
  360. <p>Other <a class="reference external" href="https://docs.sentry.io/platforms/python/configuration/">client arguments</a> can be
  361. configured by prepending the argument name with <em>sentry_</em> in your Odoo config
  362. file. Currently supported additional client arguments are: <tt class="docutils literal">with_locals,
  363. max_breadcrumbs, release, environment, server_name, shutdown_timeout,
  364. in_app_include, in_app_exclude, default_integrations, dist, sample_rate,
  365. send_default_pii, http_proxy, https_proxy, request_bodies, debug,
  366. attach_stacktrace, ca_certs, propagate_traces, traces_sample_rate,
  367. auto_enabling_integrations</tt>.</p>
  368. <div class="section" id="example-odoo-configuration">
  369. <h1>Example Odoo configuration</h1>
  370. <p>Below is an example of Odoo configuration file with <em>Odoo Sentry</em> options:</p>
  371. <pre class="literal-block">
  372. [options]
  373. sentry_dsn = https://&lt;public_key&gt;:&lt;secret_key&gt;&#64;sentry.example.com/&lt;project id&gt;
  374. sentry_enabled = true
  375. sentry_logging_level = warn
  376. sentry_exclude_loggers = werkzeug
  377. sentry_ignore_exceptions = odoo.exceptions.AccessDenied,
  378. odoo.exceptions.AccessError,odoo.exceptions.MissingError,
  379. odoo.exceptions.RedirectWarning,odoo.exceptions.UserError,
  380. odoo.exceptions.ValidationError,odoo.exceptions.Warning,
  381. odoo.exceptions.except_orm
  382. sentry_include_context = true
  383. sentry_environment = production
  384. sentry_release = 1.3.2
  385. sentry_odoo_dir = /home/odoo/odoo/
  386. </pre>
  387. <p><strong>Table of contents</strong></p>
  388. <div class="contents local topic" id="contents">
  389. <ul class="simple">
  390. <li><a class="reference internal" href="#installation" id="id1">Installation</a></li>
  391. <li><a class="reference internal" href="#configuration" id="id2">Configuration</a></li>
  392. <li><a class="reference internal" href="#usage" id="id3">Usage</a></li>
  393. <li><a class="reference internal" href="#known-issues-roadmap" id="id4">Known issues / Roadmap</a></li>
  394. <li><a class="reference internal" href="#bug-tracker" id="id5">Bug Tracker</a></li>
  395. <li><a class="reference internal" href="#credits" id="id6">Credits</a><ul>
  396. <li><a class="reference internal" href="#authors" id="id7">Authors</a></li>
  397. <li><a class="reference internal" href="#contributors" id="id8">Contributors</a></li>
  398. <li><a class="reference internal" href="#other-credits" id="id9">Other credits</a></li>
  399. <li><a class="reference internal" href="#maintainers" id="id10">Maintainers</a></li>
  400. </ul>
  401. </li>
  402. </ul>
  403. </div>
  404. <div class="section" id="installation">
  405. <h2><a class="toc-backref" href="#id1">Installation</a></h2>
  406. <p>The module can be installed just like any other Odoo module, by adding the
  407. module’s directory to Odoo <em>addons_path</em>. In order for the module to correctly
  408. wrap the Odoo WSGI application, it also needs to be loaded as a server-wide
  409. module. This can be done with the <tt class="docutils literal">server_wide_modules</tt> parameter in your
  410. Odoo config file or with the <tt class="docutils literal"><span class="pre">--load</span></tt> command-line parameter.</p>
  411. <p>This module additionally requires the sentry-sdk Python package to be available on
  412. the system. It can be installed using pip:</p>
  413. <pre class="literal-block">
  414. pip install sentry-sdk
  415. </pre>
  416. </div>
  417. <div class="section" id="configuration">
  418. <h2><a class="toc-backref" href="#id2">Configuration</a></h2>
  419. <p>The following additional configuration options can be added to your Odoo
  420. configuration file:</p>
  421. </div>
  422. <div class="section" id="usage">
  423. <h2><a class="toc-backref" href="#id3">Usage</a></h2>
  424. <p>Once configured and installed, the module will report any logging event at and
  425. above the configured Sentry logging level, no additional actions are necessary.</p>
  426. <a class="reference external image-reference" href="https://runbot.odoo-community.org/runbot/149/10.0"><img alt="Try me on Runbot" src="https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas" /></a>
  427. </div>
  428. <div class="section" id="known-issues-roadmap">
  429. <h2><a class="toc-backref" href="#id4">Known issues / Roadmap</a></h2>
  430. <ul class="simple">
  431. <li><strong>No database separation</strong> – This module functions by intercepting all Odoo
  432. logging records in a running Odoo process. This means that once installed in
  433. one database, it will intercept and report errors for all Odoo databases,
  434. which are used on that Odoo server.</li>
  435. <li><strong>Frontend integration</strong> – In the future, it would be nice to add
  436. Odoo client-side error reporting to this module as well, by integrating
  437. <a class="reference external" href="https://github.com/getsentry/raven-js">raven-js</a>. Additionally, <a class="reference external" href="https://docs.sentry.io/learn/user-feedback/">Sentry user
  438. feedback form</a> could be
  439. integrated into the Odoo client error dialog window to allow users shortly
  440. describe what they were doing when things went wrong.</li>
  441. </ul>
  442. </div>
  443. <div class="section" id="bug-tracker">
  444. <h2><a class="toc-backref" href="#id5">Bug Tracker</a></h2>
  445. <p>Bugs are tracked on <a class="reference external" href="https://github.com/OCA/server-tools/issues">GitHub Issues</a>.
  446. In case of trouble, please check there if your issue has already been reported.
  447. If you spotted it first, help us smashing it by providing a detailed and welcomed
  448. <a class="reference external" href="https://github.com/OCA/server-tools/issues/new?body=module:%20sentry%0Aversion:%2012.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**">feedback</a>.</p>
  449. <p>Do not contact contributors directly about support or help with technical issues.</p>
  450. </div>
  451. <div class="section" id="credits">
  452. <h2><a class="toc-backref" href="#id6">Credits</a></h2>
  453. <div class="section" id="authors">
  454. <h3><a class="toc-backref" href="#id7">Authors</a></h3>
  455. <ul class="simple">
  456. <li>Mohammed Barsi</li>
  457. <li>Versada</li>
  458. <li>Nicolas JEUDY</li>
  459. <li>Vauxoo</li>
  460. </ul>
  461. </div>
  462. <div class="section" id="contributors">
  463. <h3><a class="toc-backref" href="#id8">Contributors</a></h3>
  464. <ul class="simple">
  465. <li>Mohammed Barsi &lt;<a class="reference external" href="mailto:barsintod&#64;gmail.com">barsintod&#64;gmail.com</a>&gt;</li>
  466. <li>Andrius Preimantas &lt;<a class="reference external" href="mailto:andrius&#64;versada.eu">andrius&#64;versada.eu</a>&gt;</li>
  467. <li>Naglis Jonaitis &lt;<a class="reference external" href="mailto:naglis&#64;versada.eu">naglis&#64;versada.eu</a>&gt;</li>
  468. <li>Atte Isopuro &lt;<a class="reference external" href="mailto:atte.isopuro&#64;avoin.systems">atte.isopuro&#64;avoin.systems</a>&gt;</li>
  469. </ul>
  470. </div>
  471. <div class="section" id="other-credits">
  472. <h3><a class="toc-backref" href="#id9">Other credits</a></h3>
  473. <ul class="simple">
  474. <li>Vauxoo</li>
  475. </ul>
  476. </div>
  477. <div class="section" id="maintainers">
  478. <h3><a class="toc-backref" href="#id10">Maintainers</a></h3>
  479. <p>This module is maintained by the OCA.</p>
  480. <a class="reference external image-reference" href="https://odoo-community.org"><img alt="Odoo Community Association" src="https://odoo-community.org/logo.png" /></a>
  481. <p>OCA, or the Odoo Community Association, is a nonprofit organization whose
  482. mission is to support the collaborative development of Odoo features and
  483. promote its widespread use.</p>
  484. <p>Current <a class="reference external" href="https://odoo-community.org/page/maintainer-role">maintainers</a>:</p>
  485. <p><a class="reference external" href="https://github.com/barsi"><img alt="barsi" src="https://github.com/barsi.png?size=40px" /></a> <a class="reference external" href="https://github.com/naglis"><img alt="naglis" src="https://github.com/naglis.png?size=40px" /></a> <a class="reference external" href="https://github.com/versada"><img alt="versada" src="https://github.com/versada.png?size=40px" /></a> <a class="reference external" href="https://github.com/moylop260"><img alt="moylop260" src="https://github.com/moylop260.png?size=40px" /></a> <a class="reference external" href="https://github.com/fernandahf"><img alt="fernandahf" src="https://github.com/fernandahf.png?size=40px" /></a></p>
  486. <p>This module is part of the <a class="reference external" href="https://github.com/OCA/server-tools/tree/12.0/sentry">OCA/server-tools</a> project on GitHub.</p>
  487. <p>You are welcome to contribute. To learn how please visit <a class="reference external" href="https://odoo-community.org/page/Contribute">https://odoo-community.org/page/Contribute</a>.</p>
  488. </div>
  489. </div>
  490. </div>
  491. </div>
  492. </body>
  493. </html>