Odoo18-Base/addons/partner_autocomplete/models/res_partner_autocomplete_sync.py
2025-01-06 10:57:38 +07:00

45 lines
1.6 KiB
Python

# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
import logging
from odoo import api, fields, models
_logger = logging.getLogger(__name__)
class ResPartnerAutocompleteSync(models.Model):
_name = 'res.partner.autocomplete.sync'
_description = 'Partner Autocomplete Sync'
partner_id = fields.Many2one('res.partner', string="Partner", ondelete='cascade')
synched = fields.Boolean('Is synched', default=False)
@api.model
def start_sync(self, batch_size=1000):
to_sync_items = self.search([('synched', '=', False)], limit=batch_size)
for to_sync_item in to_sync_items:
partner = to_sync_item.partner_id
params = {
'partner_gid': partner.partner_gid,
}
if partner.vat and partner._is_vat_syncable(partner.vat):
params['vat'] = partner.vat
_, error = self.env['iap.autocomplete.api']._request_partner_autocomplete('update', params)
if error:
_logger.warning('Send Partner to sync failed: %s', str(error))
to_sync_item.write({'synched': True})
done = len(to_sync_items)
self.env['ir.cron']._notify_progress(
done=done,
remaining=0 if done < batch_size else self.search_count([('synched', '=', False)])
)
def add_to_queue(self, partner_id):
to_sync = self.search([('partner_id', '=', partner_id)])
if not to_sync:
to_sync = self.create({'partner_id': partner_id})
return to_sync