mirror of
https://gitlab.com/hibou-io/hibou-odoo/suite.git
synced 2025-01-20 12:37:31 +02:00
[IMP] rma_sale: add post-migration script to update sale_line_id
This commit is contained in:
31
rma_sale/migrations/15.0.1.0.1/post-migration.py
Normal file
31
rma_sale/migrations/15.0.1.0.1/post-migration.py
Normal file
@@ -0,0 +1,31 @@
|
||||
# Part of Hibou Suite Professional. See LICENSE_PROFESSIONAL file for full copyright and licensing details.
|
||||
|
||||
import odoo
|
||||
|
||||
|
||||
def migrate(cr, version):
|
||||
"""
|
||||
Update sale_line_id on existing RMA lines to allow completing the RMA
|
||||
"""
|
||||
cr.execute("""
|
||||
UPDATE rma_line AS rl
|
||||
SET sale_line_id = order_line.id
|
||||
FROM (
|
||||
SELECT rma_line.id, rma_line.rma_id, rma_line.product_id,
|
||||
rank() OVER (PARTITION BY rma_line.rma_id, rma_line.product_id ORDER BY rma_line.id) AS rline
|
||||
FROM rma_line
|
||||
WHERE rma_line.sale_line_id IS NULL
|
||||
) AS rma_line
|
||||
INNER JOIN rma_rma rma
|
||||
ON rma.id = rma_line.rma_id
|
||||
INNER JOIN (
|
||||
SELECT ol.id, ol.order_id, ol.product_id,
|
||||
rank() OVER (PARTITION BY ol.order_id, ol.product_id ORDER BY ol.id) AS oline
|
||||
FROM sale_order_line ol
|
||||
) AS order_line
|
||||
ON order_line.order_id = rma.sale_order_id
|
||||
AND order_line.product_id = rma_line.product_id
|
||||
AND order_line.oline = rma_line.rline
|
||||
WHERE rma.sale_order_id IS NOT NULL
|
||||
AND rma_line.id = rl.id
|
||||
""")
|
||||
Reference in New Issue
Block a user