mirror of
https://github.com/bringout/oca-ocb-core.git
synced 2026-04-20 13:32:04 +02:00
19.0 vanilla
This commit is contained in:
parent
d1963a3c3a
commit
2d3ee4855a
7430 changed files with 2687981 additions and 2965473 deletions
|
|
@ -0,0 +1,49 @@
|
|||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
from datetime import datetime
|
||||
from dateutil.relativedelta import relativedelta
|
||||
|
||||
from odoo import fields
|
||||
from odoo.http import request, route, Controller
|
||||
|
||||
|
||||
class DiscussSettingsController(Controller):
|
||||
@route("/discuss/settings/mute", methods=["POST"], type="jsonrpc", auth="user")
|
||||
def discuss_mute(self, minutes, channel_id):
|
||||
"""Mute notifications for the given number of minutes.
|
||||
:param minutes: (integer) number of minutes to mute notifications, -1 means mute until the user unmutes
|
||||
:param channel_id: (integer) id of the discuss.channel record
|
||||
"""
|
||||
channel = request.env["discuss.channel"].browse(channel_id)
|
||||
if not channel:
|
||||
raise request.not_found()
|
||||
member = channel._find_or_create_member_for_self()
|
||||
if not member:
|
||||
raise request.not_found()
|
||||
if minutes == -1:
|
||||
member.mute_until_dt = datetime.max
|
||||
elif minutes:
|
||||
member.mute_until_dt = fields.Datetime.now() + relativedelta(minutes=minutes)
|
||||
else:
|
||||
member.mute_until_dt = False
|
||||
member._notify_mute()
|
||||
|
||||
@route("/discuss/settings/custom_notifications", methods=["POST"], type="jsonrpc", auth="user")
|
||||
def discuss_custom_notifications(self, custom_notifications, channel_id=None):
|
||||
"""Set custom notifications for the given channel or general user settings.
|
||||
:param custom_notifications: (false|all|mentions|no_notif) custom notifications to set
|
||||
:param channel_id: (integer) id of the discuss.channel record, if not set, set for res.users.settings
|
||||
"""
|
||||
if channel_id:
|
||||
channel = request.env["discuss.channel"].search([("id", "=", channel_id)])
|
||||
if not channel:
|
||||
raise request.not_found()
|
||||
member = channel._find_or_create_member_for_self()
|
||||
if not member:
|
||||
raise request.not_found()
|
||||
member.custom_notifications = custom_notifications
|
||||
else:
|
||||
user_settings = request.env["res.users.settings"]._find_or_create_for_user(request.env.user)
|
||||
if not user_settings:
|
||||
raise request.not_found()
|
||||
user_settings.set_res_users_settings({"channel_notifications": custom_notifications})
|
||||
Loading…
Add table
Add a link
Reference in a new issue