当我尝试更新当前发票时将 Odoo v8 模块移植到 Odoo v12 时出错我正在从向导表单中添加借方通知单

Error porting Odoo v8 module to Odoo v12 when i try to update the current invoice i'm adding a debit note from wizard form

我正在将 odoo v8 模块移植到 odoo v12,当我尝试更新当前发票时添加借方通知单。

这是我的代码:

2019-08-01 19:14:42,390 6827 INFO ? odoo: Odoo version 12.0 
2019-08-01 19:14:42,390 6827 INFO ? odoo: Using configuration file at /home/desarrollo/.odoorc 
2019-08-01 19:14:42,391 6827 INFO ? odoo: addons paths: ['/home/desarrollo/.local/share/Odoo/addons/12.0', '/home/desarrollo/Documentos/odoo-12/odoo-12.0/addons', '/home/desarrollo/Documentos/odoo-12/custom/l10n-ve', '/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/addons'] 
2019-08-01 19:14:42,391 6827 INFO ? odoo: database: desarrollo@default:default 
2019-08-01 19:14:42,511 6827 INFO ? odoo.addons.base.models.ir_actions_report: You need Wkhtmltopdf to print a pdf version of the reports. 
2019-08-01 19:14:42,603 6827 WARNING ? odoo.addons.base.models.res_currency: The num2words python library is not installed, amount-to-text features won't be fully available. 
2019-08-01 19:14:42,638 6827 INFO ? odoo.service.server: HTTP service (werkzeug) running on desarrollo-Inspiron-3542:8069 
2019-08-01 19:14:42,651 6827 INFO l10n_three odoo.modules.loading: loading 1 modules... 
2019-08-01 19:14:42,673 6827 INFO l10n_three odoo.modules.loading: 1 modules loaded in 0.02s, 0 queries 
2019-08-01 19:14:42,798 6827 INFO l10n_three odoo.modules.loading: updating modules list 
2019-08-01 19:14:42,801 6827 INFO l10n_three odoo.addons.base.models.ir_module: ALLOW access to module.update_list on [] to user __system__ #1 via n/a 
2019-08-01 19:14:43,877 6827 INFO l10n_three odoo.addons.base.models.ir_module: ALLOW access to module.button_upgrade on ['l10n_vzla_dcnote'] to user __system__ #1 via n/a 
2019-08-01 19:14:43,878 6827 INFO l10n_three odoo.addons.base.models.ir_module: ALLOW access to module.update_list on ['l10n_vzla_dcnote'] to user __system__ #1 via n/a 
2019-08-01 19:14:44,407 6827 INFO l10n_three odoo.addons.base.models.ir_module: ALLOW access to module.button_install on [] to user __system__ #1 via n/a 
2019-08-01 19:14:44,461 6827 INFO l10n_three odoo.modules.loading: loading 39 modules... 
2019-08-01 19:14:44,645 6827 INFO l10n_three odoo.addons.sms.wizard.send_sms: The `phonenumbers` Python module is not available. Phone number validation will be skipped. Try `pip3 install phonenumbers` to install it. 
2019-08-01 19:14:44,745 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_partnerledger has no _description 
2019-08-01 19:14:44,745 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_generalledger has no _description 
2019-08-01 19:14:44,745 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_trialbalance has no _description 
2019-08-01 19:14:44,745 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_tax has no _description 
2019-08-01 19:14:44,746 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_agedpartnerbalance has no _description 
2019-08-01 19:14:44,746 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_journal has no _description 
2019-08-01 19:14:44,746 6827 WARNING l10n_three odoo.models: The model report.accounting_pdf_reports.report_financial has no _description 
2019-08-01 19:14:45,217 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceDebit._get_journal in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_debit 
2019-08-01 19:14:45,217 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceDebit._get_period in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_debit 
2019-08-01 19:14:45,217 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceDebit._get_orig in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_debit 
2019-08-01 19:14:45,218 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent._get_partner in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,218 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.fields_view_get in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,218 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.default_get in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,218 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.get_window in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.check_sure in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.check_recursion in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.check_grandfather in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.action_assigned in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.action_unlink in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.action_modify in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,219 6827 WARNING l10n_three odoo.api: Deprecated method AccountInvoiceParent.invoice_operation in module odoo.addons.l10n_vzla_dcnote.wizard.account_invoice_parent 
2019-08-01 19:14:45,287 6827 WARNING l10n_three odoo.fields: Field account.invoice.debit.period with unknown comodel_name 'account.period' 
2019-08-01 19:14:45,367 6827 INFO l10n_three odoo.modules.registry: module l10n_vzla_dcnote: creating or updating database tables 
2019-08-01 19:14:45,577 6827 INFO l10n_three odoo.modules.loading: loading l10n_vzla_dcnote/account_invoice_view.xml 
2019-08-01 19:14:46,076 6827 INFO l10n_three odoo.modules.loading: loading l10n_vzla_dcnote/wizard/account_invoice_debit_view.xml 
2019-08-01 19:14:46,130 6827 INFO l10n_three odoo.modules.loading: loading l10n_vzla_dcnote/wizard/account_invoice_parent_view.xml 
2019-08-01 19:14:46,176 6827 INFO l10n_three odoo.modules.loading: Module l10n_vzla_dcnote: loading demo 
2019-08-01 19:14:46,291 6827 INFO l10n_three odoo.modules.loading: 39 modules loaded in 1.83s, 14 queries 
2019-08-01 19:14:46,818 6827 INFO l10n_three odoo.modules.registry: verifying fields for every extended model 
2019-08-01 19:14:47,187 6827 INFO l10n_three odoo.modules.loading: Modules loaded. 
2019-08-01 19:14:54,830 6827 INFO ? odoo.http: HTTP Configuring static files 
2019-08-01 19:14:54,838 6827 INFO l10n_three odoo.addons.base.models.ir_http: Generating routing map 
2019-08-01 19:14:54,991 6827 ERROR l10n_three odoo.http: Exception during JSON request handling. 
Traceback (most recent call last):
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 654, in _handle_exception
    return super(JsonRequest, self)._handle_exception(exception)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 312, in _handle_exception
    raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/tools/pycompat.py", line 87, in reraise
    raise value
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 696, in dispatch
    result = self._call_function(**self.params)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 344, in _call_function
    return checked_call(self.db, *args, **kwargs)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/service/model.py", line 97, in wrapper
    return f(dbname, *args, **kwargs)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 337, in checked_call
    result = self.endpoint(*a, **kw)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 939, in __call__
    return self.method(*args, **kw)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/http.py", line 517, in response_wrap
    response = f(*args, **kw)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/addons/web/controllers/main.py", line 966, in call_button
    action = self._call_kw(model, method, args, {})
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/addons/web/controllers/main.py", line 954, in _call_kw
    return call_kw(request.env[model], method, args, kwargs)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/api.py", line 749, in call_kw
    return _call_kw_multi(method, model, args, kwargs)
  File "/home/desarrollo/Documentos/odoo-12/odoo-12.0/odoo/api.py", line 736, in _call_kw_multi
    result = method(recs, *args, **kwargs)
  File "/home/desarrollo/Documentos/odoo-12/custom/l10n-ve/l10n_vzla_dcnote/wizard/account_invoice_debit.py", line 218, in invoice_debit
    return self.compute_debit()
  File "/home/desarrollo/Documentos/odoo-12/custom/l10n-ve/l10n_vzla_dcnote/wizard/account_invoice_debit.py", line 207, in compute_debit
    result = mod_obj.get_object_reference(self,'account', xml_id)
TypeError: get_object_reference() takes 3 positional arguments but 4 were given

下面是我的account_invoice_debit.py

的代码
# coding: utf-8
import time

from odoo import api, fields, models, _
from odoo.tools.translate import _

class AccountInvoiceDebit(models.TransientModel):

    """Debits Note from Invoice"""

    _name = "account.invoice.debit"
    _description = "Invoice Debit Note"

    date = fields.Date('Operation date',
                        help='This date will be used as the invoice date '
                                'for Refund Invoice and Period will be '
                                'chosen accordingly!')
    period = fields.Many2one('account.period', 'Force period')
    journal_id = fields.Many2one('account.journal',
                                    'Refund Journal',
                                    help='You can select here the journal '
                                        'to use for the refund invoice '
                                        'that will be created. If you '
                                        'leave that field empty, it will '
                                        'use the same journal as the '
                                        'current invoice.')
    description = fields.Char('Description', size=128, required=True)
    comment = fields.Text('Comment', required=True)

    def _get_journal(self, cr, uid, context=None):
        obj_journal = self.pool.get('account.journal')
        user_obj = self.pool.get('res.users')
        if context is None:
            context = {}
        inv_type = context.get('type', 'out_invoice')
        company_id = user_obj.browse(
            cr, uid, uid, context=context).company_id.id
        type = (inv_type == 'out_invoice') and 'sale_refund' or \
               (inv_type == 'out_refund') and 'sale' or \
               (inv_type == 'in_invoice') and 'purchase_refund' or \
               (inv_type == 'in_refund') and 'purchase'
        journal = obj_journal.search(cr, uid, [('type', '=', type), (
            'company_id', '=', company_id)], limit=1, context=context)
        return journal and journal[0] or False

    _defaults = {
        'date': lambda *a: time.strftime('%Y-%m-%d'),
        'journal_id': _get_journal,
    }

    def _get_period(self, cr, uid, context={}):
        """
        Return  default account period value
        """
        account_period_obj = self.pool.get('account.period')
        ids = account_period_obj.find(cr, uid, context=context)
        period_id = False
        if ids:
            period_id = ids[0]
        return period_id

    def _get_orig(self, cr, uid, inv, ref, context={}):
        """
        Return  default origin value
        """
        nro_ref = ref
        if inv.type == 'out_invoice':
            nro_ref = inv.number
        orig = _('INV:') + (nro_ref or '') + _('- DATE:') + (
            inv.date_invoice or '') + (' TOTAL:' + str(inv.amount_total) or '')
        return orig

    def compute_debit(self, context=None):
        """
        @param cr: the current row, from the database cursor,
        @param uid: the current user’s ID for security checks,
        @param ids: the account invoice refund’s ID or list of IDs

        """
        inv_obj = self.env['account.invoice']
        mod_obj = self.env['ir.model.data']
        act_obj = self.env['ir.actions.act_window']
        inv_tax_obj = self.pool.get('account.invoice.tax')
        inv_line_obj = self.pool.get('account.invoice.line')
        res_users_obj = self.pool.get('res.users')
        if context is None:
            context = {}

        for form in self.browse(self):
            created_inv = []
            date = False
            period = False
            description = False
            company = res_users_obj.company_id
            journal_id = self.journal_id
            for inv in inv_obj:
                if inv.state in ['draft', 'proforma2', 'cancel']:
                    raise osv.except_osv(_('Error !'), _(
                        'Can not create a debit note from '
                        'draft/proforma/cancel invoice.'))
                if inv.reconciled and mode in ('cancel', 'modify'):
                    raise osv.except_osv(_('Error!'), _(
                        'Cannot %s invoice which is already reconciled, '
                        'invoice should be unreconciled first. You can only '
                        'refund this invoice.') % (mode))
                if form.period.id:
                    period = form.period.id
                else:
                    # Take period from the current date
                    # period = inv.period_id and inv.period_id.id or False
                    period = self._get_period(cr, uid, context)

                if not journal_id:
                    journal_id = inv.journal_id.id

                if form.date:
                    date = form.date
                    if not form.period.id:
                        cr.execute("select name from ir_model_fields \
                                            where model = 'account.period' \
                                            and name = 'company_id'")
                        result_query = cr.fetchone()
                        if result_query:
                            # in multi company mode
                            cr.execute("""select p.id from account_fiscalyear \
                            y, account_period p where y.id=p.fiscalyear_id \
                                and date(%s) between p.date_start AND \
                                p.date_stop and y.company_id = %s limit 1""",
                                       (date, company.id,))
                        else:
                            # in mono company mode
                            cr.execute("""SELECT id
                                    from account_period where date(%s)
                                    between date_start AND  date_stop  \
                                    limit 1 """, (date,))
                        res = cr.fetchone()
                        if res:
                            period = res[0]
                else:
                    date = inv.date_invoice
                if form.description:
                    description = form.description
                else:
                    description = inv.name

                if not period:
                    raise osv.except_osv(_('Insufficient Data!'),
                                         _('No period found on the invoice.'))

                # we get original data of invoice to create a new invoice that
                # is the copy of the original
                invoice = inv_obj.read(cr, uid, [inv.id],
                                       ['name', 'type', 'number', 'reference',
                                        'comment', 'date_due', 'partner_id',
                                        'partner_insite', 'partner_contact',
                                        'partner_ref', 'payment_term',
                                        'account_id', 'currency_id',
                                        'invoice_line', 'tax_line',
                                        'journal_id', 'period_id'],
                                       context=context)
                invoice = invoice[0]
                del invoice['id']
                invoice_lines = inv_line_obj.browse(
                    cr, uid, invoice['invoice_line'], context=context)
                invoice_lines = inv_obj._refund_cleanup_lines(
                    cr, uid, invoice_lines, context=context)
                tax_lines = inv_tax_obj.browse(
                    cr, uid, invoice['tax_line'], context=context)
                tax_lines = inv_obj._refund_cleanup_lines(
                    cr, uid, tax_lines, context=context)
                # Add origin, parent and comment values
                orig = self._get_orig(cr, uid, inv, invoice[
                                      'reference'], context)
                invoice.update({
                    'type': inv.type == 'in_invoice' and 'in_refund' or
                    inv.type == 'out_invoice' and 'out_refund',
                    'date_invoice': date,
                    'state': 'draft',
                    'number': False,
                    'invoice_line': invoice_lines,
                    'tax_line': tax_lines,
                    'period_id': period,
                    'parent_id': inv.id,
                    'name': description,
                    'origin': orig,
                    'comment': form['comment']
                })
                # take the id part of the tuple returned for many2one fields
                for field in ('partner_id', 'account_id', 'currency_id',
                              'payment_term', 'journal_id'):
                    invoice[field] = invoice[field] and invoice[field][0]
                # create the new invoice
                inv_id = inv_obj.create(cr, uid, invoice, {})
                # we compute due date
                if inv.payment_term.id:
                    data = inv_obj.onchange_payment_term_date_invoice(
                        cr, uid, [inv_id], inv.payment_term.id, date)
                    if 'value' in data and data['value']:
                        inv_obj.write(cr, uid, [inv_id], data['value'])
                created_inv.append(inv_id)
            # we get the view id
            xml_id = (inv_obj.type == 'out_refund') and 'action_invoice_tree1' or \
                     (inv_obj.type == 'in_refund') and 'action_invoice_tree2' or \
                     (inv_obj.type == 'out_invoice') and 'action_invoice_tree3' or \
                     (inv_obj.type == 'in_invoice') and 'action_invoice_tree4'
            # we get the model
            result = mod_obj.get_object_reference(self,'account', xml_id)
            id = result and result[1] or False
            # we read the act window
            result = act_obj.read(cr, uid, id, context=context)
            # we add the new invoices into domain list
            invoice_domain = eval(result['domain'])
            invoice_domain.append(('id', 'in', created_inv))
            result['domain'] = invoice_domain
            return result

    def invoice_debit(self):
        return self.compute_debit()

我期望获得视图的 xml id 以最终更新我尝试从向导表单添加借方通知单的发票

除了您尝试执行的操作之外,错误很明显。您使用 3 个参数调用 get_object_reference(),这会产生 4 个参数,因为它是一个实例方法,并且会自行处理 self。只需在通话中删除 self