118 lines
3.9 KiB
Python
Raw Normal View History

2018-03-19 16:41:26 +01:00
# Copyright 2016 Antonio Espinosa - <antonio.espinosa@tecnativa.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
2019-11-18 11:46:59 +01:00
import base64
import logging
from contextlib import contextmanager
import werkzeug
2019-11-18 11:46:59 +01:00
import odoo
2019-11-18 11:46:59 +01:00
from odoo import SUPERUSER_ID, api, http
2022-03-25 17:01:13 +05:30
from odoo.addons.mail.controllers.discuss import DiscussController
from odoo.addons.mail.controllers.mail import MailController
2019-11-18 11:46:59 +01:00
_logger = logging.getLogger(__name__)
2019-11-18 11:46:59 +01:00
BLANK = "R0lGODlhAQABAIAAANvf7wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw=="
@contextmanager
def db_env(dbname):
if not http.db_filter([dbname]):
raise werkzeug.exceptions.BadRequest()
cr = None
if dbname == http.request.db:
cr = http.request.cr
if not cr:
cr = odoo.sql_db.db_connect(dbname).cursor()
2022-03-25 17:01:13 +05:30
yield api.Environment(cr, SUPERUSER_ID, {})
2022-03-25 17:01:13 +05:30
class MailTrackingController(MailController, DiscussController):
def _request_metadata(self):
"""Prepare remote info metadata"""
request = http.request.httprequest
return {
2019-11-18 11:46:59 +01:00
"ip": request.remote_addr or False,
"user_agent": request.user_agent or False,
"os_family": request.user_agent.platform or False,
"ua_family": request.user_agent.browser or False,
}
2019-11-18 11:46:59 +01:00
@http.route(
[
"/mail/tracking/all/<string:db>",
"/mail/tracking/event/<string:db>/<string:event_type>",
],
type="http",
auth="none",
csrf=False,
)
def mail_tracking_event(self, db, event_type=None, **kw):
"""Route used by external mail service"""
metadata = self._request_metadata()
res = None
with db_env(db) as env:
try:
2019-11-18 11:46:59 +01:00
res = env["mail.tracking.email"].event_process(
http.request, kw, metadata, event_type=event_type
)
2022-03-25 17:01:13 +05:30
except Exception as e:
_logger.warning(e)
2019-11-18 11:46:59 +01:00
if not res or res == "NOT FOUND":
return werkzeug.exceptions.NotAcceptable()
return res
2019-11-18 11:46:59 +01:00
@http.route(
[
"/mail/tracking/open/<string:db>" "/<int:tracking_email_id>/blank.gif",
"/mail/tracking/open/<string:db>"
"/<int:tracking_email_id>/<string:token>/blank.gif",
],
type="http",
auth="none",
methods=["GET"],
)
def mail_tracking_open(self, db, tracking_email_id, token=False, **kw):
"""Route used to track mail openned (With & Without Token)"""
metadata = self._request_metadata()
with db_env(db) as env:
try:
2019-11-18 11:46:59 +01:00
tracking_email = env["mail.tracking.email"].search(
[("id", "=", tracking_email_id), ("token", "=", token)]
2019-11-18 11:46:59 +01:00
)
if not tracking_email:
_logger.warning(
2019-11-18 11:46:59 +01:00
"MailTracking email '%s' not found", tracking_email_id
)
elif tracking_email.state in ("sent", "delivered"):
tracking_email.event_create("open", metadata)
2022-03-25 17:01:13 +05:30
except Exception as e:
_logger.warning(e)
# Always return GIF blank image
response = werkzeug.wrappers.Response()
2019-11-18 11:46:59 +01:00
response.mimetype = "image/gif"
response.data = base64.b64decode(BLANK)
return response
@http.route()
def mail_init_messaging(self):
"""Route used to initial values of Discuss app"""
values = super().mail_init_messaging()
2019-11-18 11:46:59 +01:00
values.update(
{"failed_counter": http.request.env["mail.message"].get_failed_count()}
)
return values
2022-03-25 17:01:13 +05:30
@http.route("/mail/failed/messages", methods=["POST"], type="json", auth="user")
def discuss_failed_messages(self, max_id=None, min_id=None, limit=30, **kwargs):
return http.request.env["mail.message"]._message_fetch(
domain=[("is_failed_message", "=", True)],
max_id=max_id,
min_id=min_id,
limit=limit,
)