4

这个问题让我开始使用 C# Odoo API 实现。我有使用 CookComputing.XmlRpcV2 检索发票列表的工作代码。

我想要实现的是检索/下载所选发票的 PDF 的选项。有人知道我需要什么来完成这项工作吗?

当我搜索时,我发现论坛帖子声明自 V11 以来报告不起作用,例如这个。我也没有在 V12 的在线文档中看到它,尽管在 V10 的页面底部提到了它。

更新

有人提到要构造一个 URL:

http://localhost:8069/my/invoices/1?report_type=pdf&download=true&access_token=<ACCESSTOKEN>

1发票 ID在哪里。从技术上讲,这是可行的,但需要我使用浏览器登录到门户。即使我可以从我的 C# 服务登录到门户,我也不知道在哪里/如何检索正确的访问令牌。我可以看到这是 GUID 形式的。有人知道这是否与我可以从 OAuth2 REST API(顺便说一句是付费模块)检索到的令牌相同吗?

4

4 回答 4

4

正确的。您可以通过放入 access_token 来下载 PDF。

这是我设法为 Odoo v.12 弄明白的唯一方法。在反复将我的头撞在砖墙上之后。我的示例编程语言是 Python 3,而不是 C#,但我相信你可以适应它。

odoo_url_host = "https://company.odoo.com"

可以在发票的 JSON 响应中找到access_token

invoice_id = 1234
models = xmlrpcclient.ServerProxy('{}/xmlrpc/2/object'.format(odoo_url_host))
invoice = models.execute_kw(db, uid, password, "account.invoice", read, [[invoice_id]])

如果您取回找到的发票,您可以像这样使用响应:

print(invoice["access_token"])

download_url = "%s/%s/my/invoices/%d?report_type=pdf&download=true&access_token=%s" % (odoo_url_host, invoice_id, invoice["access_token"])

如果您只是想自动下载,可以这样做:

import urllib.request

pdf_destination = "./invoices/invoice-%d.pdf" % invoice_id

urllib.request.urlretrieve(download_url, pdf_destination)

您需要更改为 Python 2.7 编写的方式。

此外,请确保您单击发票上的“共享”(在 odoo 内),因为有时不会为该发票生成 access_token,否则返回 false。

或者,如果您想无缝生成 access_token,请在尝试获取访问令牌之前执行此操作:

ctx = {'active_model': 'account.invoice', 'active_id': invoice_id}
print(models.execute_kw(db, uid, password, 'portal.share', 'default_get',[{}],{'context': ctx}))

这应该会为您提供整个文档的 share_link,但您只需要生成 access_token。如果您愿意,可以从 JSON 响应中的 share_link 值中提取 access_token。无论如何:) 快乐编码。

于 2019-09-04T15:14:45.343 回答
1

我会尝试使用/xmlrpc/2/objectmodelir.actions.report和 method render_qweb_pdf。请记住,您需要ir.actions.report记录,因为render_qweb_pdf它不是“模型方法”(在 OOP 类方法中)。

于 2019-01-30T13:17:59.637 回答
1

我目前正在测试类似的功能,但stock.picking我需要从远程Odoo实例下载交付表单并保存为attachment另一个实例。我所做的是将此功能添加到stock.picking远程Odoo

@api.model
def sd_get_delivery_form(self, uid):
    picking = self.env['stock.picking'].sudo().search([('sd_uid', 'like', uid)], limit=1)
    if picking and picking.sale_id:
        pdf = self.env.ref('sale.action_report_saleorder').sudo().render_qweb_pdf([picking.sale_id.id])
        b64_pdf = base64.b64encode(pdf[0])
        order_pdf = b64_pdf.decode('utf-8')
        return {'file': order_pdf}
    else:
        return False

然后调用它xmlrpc并保存为附件

attachment_name = "delivery_order_({})".format(self.id)
self.env['ir.attachment'].create({
    'name': attachment_name,
    'type': 'binary',
    'datas': dt['file'],
    'datas_fname': attachment_name + '.pdf',
    'store_fname': attachment_name,
    'res_model': self._name,
    'res_id': self.id,
    'mimetype': 'application/x-pdf'
})

如果您想以类似的方式进行操作,您可以做的C#是获取并将其保存为 PDF。base64

于 2020-02-10T18:30:11.223 回答
0

最简单的方法是使用 OdooRPC 库:https ://pythonhosted.org/OdooRPC/ref_report.html

于 2020-02-10T10:12:57.260 回答