Created
June 8, 2020 18:11
-
-
Save moylop260/97cece8c80ca4c6ed168ae38704c42df to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
====== | |
Sentry | |
====== | |
.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | |
!! This file is generated by oca-gen-addon-readme !! | |
!! changes will be overwritten. !! | |
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | |
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png | |
:target: https://odoo-community.org/page/development-status | |
:alt: Beta | |
.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png | |
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html | |
:alt: License: AGPL-3 | |
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fserver--tools-lightgray.png?logo=github | |
:target: https://github.com/OCA/server-tools/tree/13.0/sentry | |
:alt: OCA/server-tools | |
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png | |
:target: https://translation.odoo-community.org/projects/server-tools-13-0/server-tools-13-0-sentry | |
:alt: Translate me on Weblate | |
.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png | |
:target: https://runbot.odoo-community.org/runbot/149/13.0 | |
:alt: Try me on Runbot | |
|badge1| |badge2| |badge3| |badge4| |badge5| | |
This module allows painless `Sentry <https://sentry.io/>`__ integration with | |
Odoo. | |
**Table of contents** | |
.. contents:: | |
:local: | |
Configuration | |
============= | |
The following additional configuration options can be added to your Odoo | |
configuration file: | |
============================= ==================================================================== ========================================================== | |
Option Description Default | |
============================= ==================================================================== ========================================================== | |
``sentry_dsn`` Sentry *Data Source Name*. You can find this value in your Sentry ``''`` | |
project configuration. Typically it looks something like this: | |
*https://<public_key>:<secret_key>@sentry.example.com/<project id>* | |
This is the only required option in order to use the module. | |
``sentry_enabled`` Whether or not Sentry logging is enabled. ``False`` | |
``sentry_logging_level`` The minimal logging level for which to send reports to Sentry. ``warn`` | |
Possible values: *notset*, *debug*, *info*, *warn*, *error*, | |
*critical*. It is recommended to have this set to at least *warn*, | |
to avoid spamming yourself with Sentry events. | |
``sentry_exclude_loggers`` A string of comma-separated logger names which should be excluded ``werkzeug`` | |
from Sentry. | |
``sentry_ignored_exceptions`` A string of comma-separated exceptions which should be ignored. ``odoo.exceptions.AccessDenied, | |
You can use a star symbol (*) at the end, to ignore all exceptions odoo.exceptions.AccessError, | |
from a module, eg.: *odoo.exceptions.**. odoo.exceptions.DeferredException, | |
odoo.exceptions.MissingError, | |
odoo.exceptions.RedirectWarning, | |
odoo.exceptions.UserError, | |
odoo.exceptions.ValidationError, | |
odoo.exceptions.Warning, | |
odoo.exceptions.except_orm`` | |
``sentry_processors`` A string of comma-separated processor classes which will be applied ``raven.processors.SanitizePasswordsProcessor, | |
on an event before sending it to Sentry. odoo.addons.sentry.logutils.SanitizeOdooCookiesProcessor`` | |
``sentry_transport`` Transport class which will be used to send events to Sentry. ``threaded`` | |
Possible values: *threaded*: spawns an async worker for processing | |
messages, *synchronous*: a synchronous blocking transport; | |
*requests_threaded*: an asynchronous transport using the *requests* | |
library; *requests_synchronous* - blocking transport using the | |
*requests* library. | |
``sentry_include_context`` If enabled, additional context data will be extracted from current ``True`` | |
HTTP request and user session (if available). This has no effect | |
for Cron jobs, as no request/session is available inside a Cron job. | |
``sentry_release`` Explicitly define a version to be sent as the release version to | |
Sentry. Useful in conjuntion with Sentry's "Resolve in the next | |
release"-functionality. Also useful if your production deployment | |
does not include any Git context from which a commit might be read. | |
Overrides *sentry_odoo_dir*. | |
``sentry_odoo_dir`` Absolute path to your Odoo installation directory. This is optional | |
and will only be used to extract the Odoo Git commit, which will be | |
sent to Sentry, to allow to distinguish between Odoo updates. | |
Overridden by *sentry_release* | |
============================= ==================================================================== ========================================================== | |
Other `client arguments | |
<https://docs.sentry.io/clients/python/advanced/#client-arguments>`_ can be | |
configured by prepending the argument name with *sentry_* in your Odoo config | |
file. Currently supported additional client arguments are: ``install_sys_hook, | |
include_paths, exclude_paths, machine, auto_log_stacks, capture_locals, | |
string_max_length, list_max_length, site, include_versions, environment``. | |
Example Odoo configuration | |
-------------------------- | |
Below is an example of Odoo configuration file with *Odoo Sentry* options:: | |
[options] | |
sentry_dsn = https://<public_key>:<secret_key>@sentry.example.com/<project id> | |
sentry_enabled = true | |
sentry_logging_level = warn | |
sentry_exclude_loggers = werkzeug | |
sentry_ignore_exceptions = odoo.exceptions.AccessDenied,odoo.exceptions.AccessError,odoo.exceptions.MissingError,odoo.exceptions.RedirectWarning,odoo.exceptions.UserError,odoo.exceptions.ValidationError,odoo.exceptions.Warning,odoo.exceptions.except_orm | |
sentry_processors = raven.processors.SanitizePasswordsProcessor,odoo.addons.sentry.logutils.SanitizeOdooCookiesProcessor | |
sentry_transport = threaded | |
sentry_include_context = true | |
sentry_environment = production | |
sentry_auto_log_stacks = false | |
sentry_odoo_dir = /home/odoo/odoo/ | |
sentry_release = 1.3.2 | |
Usage | |
===== | |
Once configured and installed, the module will report any logging event at and | |
above the configured Sentry logging level, no additional actions are necessary. | |
.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas | |
:alt: Try me on Runbot | |
:target: https://runbot.odoo-community.org/runbot/149/13.0 | |
Known issues / Roadmap | |
====================== | |
* **No database separation** -- This module functions by intercepting all Odoo | |
logging records in a running Odoo process. This means that once installed in | |
one database, it will intercept and report errors for all Odoo databases, | |
which are used on that Odoo server. | |
* **Frontend integration** -- In the future, it would be nice to add | |
Odoo client-side error reporting to this module as well, by integrating | |
`raven-js <https://github.com/getsentry/raven-js>`_. Additionally, `Sentry user | |
feedback form <https://docs.sentry.io/learn/user-feedback/>`_ could be | |
integrated into the Odoo client error dialog window to allow users shortly | |
describe what they were doing when things went wrong. | |
Bug Tracker | |
=========== | |
Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-tools/issues>`_. | |
In case of trouble, please check there if your issue has already been reported. | |
If you spotted it first, help us smashing it by providing a detailed and welcomed | |
`feedback <https://github.com/OCA/server-tools/issues/new?body=module:%20sentry%0Aversion:%2013.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_. | |
Do not contact contributors directly about support or help with technical issues. | |
Credits | |
======= | |
Authors | |
~~~~~~~ | |
* Mohammed Barsi | |
* Versada | |
* Nicolas JEUDY | |
Contributors | |
~~~~~~~~~~~~ | |
* Mohammed Barsi <[email protected]> | |
* Andrius Preimantas <[email protected]> | |
* Naglis Jonaitis <[email protected]> | |
* Atte Isopuro <[email protected]> | |
Maintainers | |
~~~~~~~~~~~ | |
This module is maintained by the OCA. | |
.. image:: https://odoo-community.org/logo.png | |
:alt: Odoo Community Association | |
:target: https://odoo-community.org | |
OCA, or the Odoo Community Association, is a nonprofit organization whose | |
mission is to support the collaborative development of Odoo features and | |
promote its widespread use. | |
This module is part of the `OCA/server-tools <https://github.com/OCA/server-tools/tree/13.0/sentry>`_ project on GitHub. | |
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment