mirror of
https://github.com/bringout/oca-ocb-security.git
synced 2026-04-24 23:02:01 +02:00
Initial commit: Security packages
This commit is contained in:
commit
bb469e4763
1399 changed files with 278378 additions and 0 deletions
|
|
@ -0,0 +1,67 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
from odoo import fields, models
|
||||
|
||||
from odoo.addons.google_calendar.models.google_sync import google_calendar_token
|
||||
from odoo.addons.google_calendar.utils.google_calendar import GoogleCalendarService
|
||||
|
||||
|
||||
class ResetGoogleAccount(models.TransientModel):
|
||||
_name = 'google.calendar.account.reset'
|
||||
_description = 'Google Calendar Account Reset'
|
||||
|
||||
user_id = fields.Many2one('res.users', required=True)
|
||||
delete_policy = fields.Selection(
|
||||
[('dont_delete', "Leave them untouched"),
|
||||
('delete_google', "Delete from the current Google Calendar account"),
|
||||
('delete_odoo', "Delete from Odoo"),
|
||||
('delete_both', "Delete from both"),
|
||||
], string="User's Existing Events", required=True, default='dont_delete',
|
||||
help="This will only affect events for which the user is the owner")
|
||||
sync_policy = fields.Selection([
|
||||
('new', "Synchronize only new events"),
|
||||
('all', "Synchronize all existing events"),
|
||||
], string="Next Synchronization", required=True, default='new')
|
||||
|
||||
def reset_account(self):
|
||||
google = GoogleCalendarService(self.env['google.service'])
|
||||
|
||||
events = self.env['calendar.event'].search([
|
||||
('user_id', '=', self.user_id.id),
|
||||
('google_id', '!=', False)])
|
||||
recurrences = self.env['calendar.recurrence'].search([
|
||||
('base_event_id', 'in', events.ids),
|
||||
('google_id', '!=', False)])
|
||||
|
||||
if self.delete_policy in ('delete_google', 'delete_both'):
|
||||
with google_calendar_token(self.user_id) as token:
|
||||
for event in events:
|
||||
google.delete(event.google_id, token=token)
|
||||
|
||||
# Delete events according to the selected policy. If the deletion is only in
|
||||
# Google, we won't keep track of the 'google_id' field for events and recurrences.
|
||||
if self.delete_policy in ('delete_odoo', 'delete_both', 'delete_google'):
|
||||
events.google_id = False
|
||||
recurrences.google_id = False
|
||||
if self.delete_policy != 'delete_google':
|
||||
events.unlink()
|
||||
|
||||
# Define which events must be synchronized in the next synchronization:
|
||||
# in 'all' sync policy we activate the sync for all events and in the 'new'
|
||||
# sync policy we set it as False for skipping existing events synchronization.
|
||||
next_sync_update = {}
|
||||
if self.sync_policy == 'all':
|
||||
next_sync_update['need_sync'] = True
|
||||
elif self.sync_policy == 'new':
|
||||
next_sync_update['need_sync'] = False
|
||||
|
||||
# Write the next sync update attribute on the existing events.
|
||||
if self.delete_policy not in ('delete_odoo', 'delete_both'):
|
||||
events.write(next_sync_update)
|
||||
|
||||
self.user_id.google_calendar_account_id._set_auth_tokens(False, False, 0)
|
||||
self.user_id.write({
|
||||
'google_calendar_sync_token': False,
|
||||
'google_calendar_cal_id': False,
|
||||
})
|
||||
Loading…
Add table
Add a link
Reference in a new issue