You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

361 lines
15 KiB

6 years ago
6 years ago
  1. # -*- coding: utf-8 -*-
  2. import base64
  3. from datetime import datetime
  4. import re
  5. from openerp import http
  6. from openerp.http import request
  7. from openerp.tools.translate import _
  8. # Only use for behavior, don't stock it
  9. _TECHNICAL = ['view_from', 'view_callback']
  10. # Allow in description
  11. _BLACKLIST = ['id', 'create_uid', 'create_date', 'write_uid', 'write_date',
  12. 'user_id', 'active']
  13. _COOP_FORM_FIELD = ['email', 'firstname', 'lastname', 'birthdate', 'iban',
  14. 'share_product_id', 'no_registre', 'address', 'city',
  15. 'zip_code', 'country_id', 'phone', 'lang', 'nb_parts',
  16. 'total_parts', 'error_msg']
  17. _COMPANY_FORM_FIELD = ['is_company', 'company_register_number', 'company_name',
  18. 'company_email', 'company_type', 'email', 'firstname',
  19. 'lastname', 'birthdate', 'iban', 'share_product_id',
  20. 'no_registre', 'address', 'city', 'zip_code',
  21. 'country_id', 'phone', 'lang', 'nb_parts',
  22. 'total_parts', 'error_msg']
  23. class WebsiteSubscription(http.Controller):
  24. @http.route(['/page/become_cooperator',
  25. '/become_cooperator'],
  26. type='http', auth="public", website=True)
  27. def display_become_cooperator_page(self, **kwargs):
  28. values = {}
  29. if request.env.user.login != 'public':
  30. partner = request.env.user.partner_id
  31. if partner.is_company:
  32. return request.website.render("easy_my_coop.becomecompanycooperator", values)
  33. values = self.fill_values(values, False, True)
  34. for field in _COOP_FORM_FIELD:
  35. if kwargs.get(field):
  36. values[field] = kwargs.pop(field)
  37. values.update(kwargs=kwargs.items())
  38. return request.website.render("easy_my_coop.becomecooperator", values)
  39. @http.route(['/page/become_company_cooperator',
  40. '/become_company_cooperator'],
  41. type='http', auth="public", website=True)
  42. def display_become_company_cooperator_page(self, **kwargs):
  43. values = {}
  44. values = self.fill_values(values, True, True)
  45. for field in _COMPANY_FORM_FIELD:
  46. if kwargs.get(field):
  47. values[field] = kwargs.pop(field)
  48. values.update(kwargs=kwargs.items())
  49. return request.website.render("easy_my_coop.becomecompanycooperator", values)
  50. def preRenderThanks(self, values, kwargs):
  51. """ Allow to be overrided """
  52. return {
  53. '_values': values,
  54. '_kwargs': kwargs,
  55. }
  56. def get_subscription_response(self, values, kwargs):
  57. values = self.preRenderThanks(values, kwargs)
  58. return request.website.render("easy_my_coop.cooperator_thanks", values)
  59. def get_date_string(self, birthdate):
  60. if birthdate:
  61. birthdate = datetime.strptime(birthdate, "%Y-%m-%d")
  62. return datetime.strftime(birthdate, "%d/%m/%Y")
  63. return False
  64. def get_values_from_user(self, values, is_company):
  65. # the subscriber is connected
  66. if request.env.user.login != 'public':
  67. values['logged'] = 'on'
  68. partner = request.env.user.partner_id
  69. if partner.member or partner.old_member:
  70. values['already_cooperator'] = 'on'
  71. if partner.bank_ids:
  72. values['iban'] = partner.bank_ids[0].acc_number
  73. values['address'] = partner.street
  74. values['zip_code'] = partner.zip
  75. values['city'] = partner.city
  76. values['country_id'] = partner.country_id.id
  77. if is_company:
  78. # company values
  79. values['company_register_number'] = partner.company_register_number
  80. values['company_name'] = partner.name
  81. values['company_email'] = partner.email
  82. # contact person values
  83. representative = partner.get_representative()
  84. values['firstname'] = representative.firstname
  85. values['lastname'] = representative.lastname
  86. values['gender'] = representative.gender
  87. values['email'] = representative.email
  88. values['contact_person_function'] = representative.function
  89. values['no_registre'] = representative.national_register_number
  90. values['birthdate'] = self.get_date_string(representative.birthdate)
  91. values['lang'] = representative.lang
  92. values['phone'] = representative.phone
  93. else:
  94. values['firstname'] = partner.firstname
  95. values['lastname'] = partner.lastname
  96. values['email'] = partner.email
  97. values['gender'] = partner.gender
  98. values['no_registre'] = partner.national_register_number
  99. values['birthdate'] = self.get_date_string(partner.birthdate)
  100. values['lang'] = partner.lang
  101. values['phone'] = partner.phone
  102. return values
  103. def fill_values(self, values, is_company, load_from_user=False):
  104. sub_req_obj = request.env['subscription.request']
  105. company = request.website.company_id
  106. products = self.get_products_share(is_company)
  107. if load_from_user:
  108. values = self.get_values_from_user(values, is_company)
  109. if is_company:
  110. values['is_company'] = 'on'
  111. values['countries'] = self.get_countries()
  112. values['langs'] = self.get_langs()
  113. values['products'] = products
  114. fields_desc = sub_req_obj.sudo().fields_get(['company_type', 'gender'])
  115. values['company_types'] = fields_desc['company_type']['selection']
  116. values['genders'] = fields_desc['gender']['selection']
  117. values['company'] = company
  118. if not values.get('share_product_id'):
  119. for product in products:
  120. if product.default_share_product is True:
  121. values['share_product_id'] = product.id
  122. break
  123. if not values.get('share_product_id', False) and products:
  124. values['share_product_id'] = products[0].id
  125. if not values.get('country_id'):
  126. if company.default_country_id:
  127. values['country_id'] = company.default_country_id.id
  128. else:
  129. values['country_id'] = '21'
  130. if not values.get('activities_country_id'):
  131. if company.default_country_id:
  132. values['activities_country_id'] = company.default_country_id.id
  133. else:
  134. values['activities_country_id'] = '21'
  135. if not values.get('lang'):
  136. if company.default_lang_id:
  137. values['lang'] = company.default_lang_id.code
  138. return values
  139. def get_products_share(self, is_company):
  140. product_obj = request.env['product.template']
  141. products = product_obj.sudo().get_web_share_products(is_company)
  142. return products
  143. def get_countries(self):
  144. countries = request.env['res.country'].sudo().search([])
  145. return countries
  146. def get_langs(self):
  147. langs = request.env['res.lang'].sudo().search([])
  148. return langs
  149. def validation(self, kwargs, logged, values, post_file):
  150. user_obj = request.env['res.users']
  151. sub_req_obj = request.env['subscription.request']
  152. redirect = "easy_my_coop.becomecooperator"
  153. email = kwargs.get('email')
  154. is_company = kwargs.get("is_company") == 'on'
  155. if is_company:
  156. is_company = True
  157. redirect = "easy_my_coop.becomecompanycooperator"
  158. email = kwargs.get('company_email')
  159. if ('g-recaptcha-response' not in kwargs
  160. or not request.website.is_captcha_valid(
  161. kwargs['g-recaptcha-response'])):
  162. values = self.fill_values(values, is_company)
  163. values["error_msg"] = _("the captcha has not been validated,"
  164. " please fill in the captcha")
  165. return request.website.render(redirect, values)
  166. # Check that required field from model subscription_request exists
  167. required_fields = sub_req_obj.sudo().get_required_field()
  168. error = set(field for field in required_fields if not values.get(field)) #noqa
  169. if error:
  170. values = self.fill_values(values, is_company)
  171. values["error_msg"] = _("Some mandatory fields have not "
  172. "been filled")
  173. values = dict(values, error=error, kwargs=kwargs.items())
  174. return request.website.render(redirect, values)
  175. if not logged and email:
  176. user = user_obj.sudo().search([('login', '=', email)])
  177. if user:
  178. values = self.fill_values(values, is_company)
  179. values.update(kwargs)
  180. values["error_msg"] = _("There is an existing account for this"
  181. " mail address. Please login before "
  182. "fill in the form")
  183. return request.website.render(redirect, values)
  184. company = request.website.company_id
  185. if company.allow_id_card_upload:
  186. if not post_file:
  187. values = self.fill_values(values, is_company)
  188. values.update(kwargs)
  189. values["error_msg"] = _("You need to upload a"
  190. " scan of your id card")
  191. return request.website.render(redirect, values)
  192. iban = kwargs.get("iban")
  193. valid = sub_req_obj.check_iban(iban)
  194. if not valid:
  195. values = self.fill_values(values, is_company)
  196. values["error_msg"] = _("You iban account number"
  197. "is not valid")
  198. return request.website.render(redirect, values)
  199. if not is_company:
  200. no_registre = re.sub('[^0-9a-zA-Z]+', '',
  201. kwargs.get("no_registre"))
  202. valid = sub_req_obj.check_belgian_identification_id(no_registre)
  203. if not valid:
  204. values = self.fill_values(values, is_company)
  205. values["error_msg"] = _("You national register number "
  206. "is not valid")
  207. return request.website.render(redirect, values)
  208. values["no_registre"] = no_registre
  209. # check the subscription's amount
  210. max_amount = company.subscription_maximum_amount
  211. total_amount = float(kwargs.get('total_parts'))
  212. if max_amount > 0 and total_amount > max_amount:
  213. values = self.fill_values(values, is_company)
  214. values["error_msg"] = (_("You can't subscribe for an amount that "
  215. "exceed ")
  216. + str(max_amount)
  217. + company.currency_id.symbol)
  218. return request.website.render(redirect, values)
  219. return True
  220. @http.route(['/subscription/get_share_product'],
  221. type='json',
  222. auth="public",
  223. methods=['POST'], website=True)
  224. def get_share_product(self, share_product_id, **kw):
  225. product_template = request.env['product.template']
  226. product = product_template.sudo().browse(int(share_product_id))
  227. return {
  228. product.id: {
  229. 'list_price': product.list_price,
  230. 'min_qty': product.minimum_quantity,
  231. 'force_min_qty': product.force_min_qty
  232. }
  233. }
  234. @http.route(['/subscription/subscribe_share'],
  235. type='http',
  236. auth="public", website=True)
  237. def share_subscription(self, **kwargs):
  238. sub_req_obj = request.env['subscription.request']
  239. product_obj = request.env['product.template']
  240. attach_obj = request.env['ir.attachment']
  241. # List of file to add to ir_attachment once we have the ID
  242. post_file = []
  243. # Info to add after the message
  244. post_description = []
  245. values = {}
  246. for field_name, field_value in kwargs.items():
  247. if hasattr(field_value, 'filename'):
  248. post_file.append(field_value)
  249. elif (field_name in sub_req_obj._fields
  250. and field_name not in _BLACKLIST):
  251. values[field_name] = field_value
  252. # allow to add some free fields or blacklisted field like ID
  253. elif field_name not in _TECHNICAL:
  254. post_description.append("%s: %s" % (field_name, field_value))
  255. logged = kwargs.get("logged") == 'on'
  256. is_company = kwargs.get("is_company") == 'on'
  257. response = self.validation(kwargs, logged, values, post_file)
  258. if response is not True:
  259. return response
  260. already_coop = False
  261. if logged:
  262. partner = request.env.user.partner_id
  263. values['partner_id'] = partner.id
  264. already_coop = partner.member
  265. elif kwargs.get("already_cooperator") == 'on':
  266. already_coop = True
  267. values["already_cooperator"] = already_coop
  268. values["is_company"] = is_company
  269. if is_company:
  270. if kwargs.get("company_register_number", is_company):
  271. values["company_register_number"] = re.sub('[^0-9a-zA-Z]+',
  272. '',
  273. kwargs.get("company_register_number"))
  274. subscription_id = sub_req_obj.sudo().create_comp_sub_req(values)
  275. else:
  276. no_registre = re.sub('[^0-9a-zA-Z]+', '',
  277. kwargs.get("no_registre"))
  278. values["no_registre"] = no_registre
  279. lastname = kwargs.get("lastname").upper()
  280. firstname = kwargs.get("firstname").title()
  281. values["name"] = firstname + " " + lastname
  282. values["lastname"] = lastname
  283. values["firstname"] = firstname
  284. values["birthdate"] = datetime.strptime(kwargs.get("birthdate"),
  285. "%d/%m/%Y").date()
  286. values["source"] = "website"
  287. if kwargs.get("share_product_id"):
  288. product_id = kwargs.get("share_product_id")
  289. product = product_obj.sudo().browse(int(product_id)).product_variant_ids[0]
  290. values["share_product_id"] = product.id
  291. subscription_id = sub_req_obj.sudo().create(values)
  292. values.update(subscription_id=subscription_id)
  293. if subscription_id:
  294. for field_value in post_file:
  295. attachment_value = {
  296. 'name': field_value.filename,
  297. 'res_name': field_value.filename,
  298. 'res_model': 'subscription.request',
  299. 'res_id': subscription_id,
  300. 'datas': base64.encodestring(field_value.read()),
  301. 'datas_fname': field_value.filename,
  302. }
  303. attach_obj.sudo().create(attachment_value)
  304. return self.get_subscription_response(values, kwargs)