107 lines
4.3 KiB
Python
107 lines
4.3 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||
|
|
||
|
import base64
|
||
|
from cStringIO import StringIO
|
||
|
from werkzeug.utils import redirect
|
||
|
|
||
|
from odoo import http
|
||
|
from odoo.http import request
|
||
|
from odoo.addons.website_portal.controllers.main import website_account
|
||
|
from odoo.addons.website_sale.controllers.main import WebsiteSale
|
||
|
|
||
|
class WebsiteSaleDigitalConfirmation(WebsiteSale):
|
||
|
@http.route([
|
||
|
'/shop/confirmation',
|
||
|
], type='http', auth="public", website=True)
|
||
|
def payment_confirmation(self, **post):
|
||
|
response = super(WebsiteSaleDigitalConfirmation, self).payment_confirmation(**post)
|
||
|
order_lines = response.qcontext['order'].order_line
|
||
|
digital_content = map(lambda x: x.product_id.type == 'digital', order_lines)
|
||
|
response.qcontext.update(digital=any(digital_content))
|
||
|
return response
|
||
|
|
||
|
|
||
|
class WebsiteSaleDigital(website_account):
|
||
|
orders_page = '/my/orders'
|
||
|
|
||
|
@http.route([
|
||
|
'/my/orders/<int:order>',
|
||
|
], type='http', auth='user', website=True)
|
||
|
def orders_followup(self, order=None, **post):
|
||
|
response = super(WebsiteSaleDigital, self).orders_followup(order=order, **post)
|
||
|
if not 'order' in response.qcontext:
|
||
|
return response
|
||
|
order = response.qcontext['order']
|
||
|
invoiced_lines = request.env['account.invoice.line'].sudo().search([('invoice_id', 'in', order.invoice_ids.ids), ('invoice_id.state', '=', 'paid')])
|
||
|
products = invoiced_lines.mapped('product_id') | order.order_line.filtered(lambda r: not r.price_subtotal).mapped('product_id')
|
||
|
|
||
|
purchased_products_attachments = {}
|
||
|
for product in products:
|
||
|
# Search for product attachments
|
||
|
Attachment = request.env['ir.attachment']
|
||
|
product_id = product.id
|
||
|
template = product.product_tmpl_id
|
||
|
att = Attachment.search_read(
|
||
|
domain=['|', '&', ('res_model', '=', product._name), ('res_id', '=', product_id), '&', ('res_model', '=', template._name), '&', ('res_id', '=', template.id), ('product_downloadable', '=', True)],
|
||
|
fields=['name', 'write_date'],
|
||
|
order='write_date desc',
|
||
|
)
|
||
|
|
||
|
# Ignore products with no attachments
|
||
|
if not att:
|
||
|
continue
|
||
|
|
||
|
purchased_products_attachments[product_id] = att
|
||
|
|
||
|
response.qcontext.update({
|
||
|
'digital_attachments': purchased_products_attachments,
|
||
|
})
|
||
|
return response
|
||
|
|
||
|
@http.route([
|
||
|
'/my/download',
|
||
|
], type='http', auth='public')
|
||
|
def download_attachment(self, attachment_id):
|
||
|
# Check if this is a valid attachment id
|
||
|
attachment = request.env['ir.attachment'].sudo().search_read(
|
||
|
[('id', '=', int(attachment_id))],
|
||
|
["name", "datas", "file_type", "res_model", "res_id", "type", "url"]
|
||
|
)
|
||
|
|
||
|
if attachment:
|
||
|
attachment = attachment[0]
|
||
|
else:
|
||
|
return redirect(self.orders_page)
|
||
|
|
||
|
# Check if the user has bought the associated product
|
||
|
res_model = attachment['res_model']
|
||
|
res_id = attachment['res_id']
|
||
|
purchased_products = request.env['account.invoice.line'].get_digital_purchases()
|
||
|
|
||
|
if res_model == 'product.product':
|
||
|
if res_id not in purchased_products:
|
||
|
return redirect(self.orders_page)
|
||
|
|
||
|
# Also check for attachments in the product templates
|
||
|
elif res_model == 'product.template':
|
||
|
P = request.env['product.product'].sudo()
|
||
|
template_ids = map(lambda x: P.browse(x).product_tmpl_id.id, purchased_products)
|
||
|
if res_id not in template_ids:
|
||
|
return redirect(self.orders_page)
|
||
|
|
||
|
else:
|
||
|
return redirect(self.orders_page)
|
||
|
|
||
|
# The client has bought the product, otherwise it would have been blocked by now
|
||
|
if attachment["type"] == "url":
|
||
|
if attachment["url"]:
|
||
|
return redirect(attachment["url"])
|
||
|
else:
|
||
|
return request.not_found()
|
||
|
elif attachment["datas"]:
|
||
|
data = StringIO(base64.standard_b64decode(attachment["datas"]))
|
||
|
return http.send_file(data, filename=attachment['name'].encode('utf-8'), as_attachment=True)
|
||
|
else:
|
||
|
return request.not_found()
|