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.

54 lines
2.4 KiB

  1. # -*- coding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # This module copyright (C) 2015 Therp BV <http://therp.nl>.
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU Affero General Public License as
  8. # published by the Free Software Foundation, either version 3 of the
  9. # License, or (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU Affero General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU Affero General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. #
  19. ##############################################################################
  20. from openerp import _, SUPERUSER_ID, exceptions
  21. def post_init_hook(cr, pool):
  22. '''check if your constraint was actually inserted, raise otherwise'''
  23. if not pool['ir.model.constraint'].search(cr, SUPERUSER_ID, [
  24. ('name', '=', 'res_partner_bank_unique_number'),
  25. ('model.model', '=', 'res.partner.bank'),
  26. ]):
  27. max_account_numbers = 10
  28. cr.execute(
  29. """
  30. with
  31. res_partner_bank_sanitized as
  32. (select id, acc_number, regexp_replace(acc_number, '\\W+', '', 'g')
  33. acc_number_sanitized from res_partner_bank),
  34. res_partner_bank_sanitized_grouped as
  35. (select array_agg(id) ids, acc_number_sanitized, count(*) amount
  36. from res_partner_bank_sanitized group by acc_number_sanitized)
  37. select acc_number_sanitized from res_partner_bank_sanitized_grouped
  38. where amount > 1 limit %s;
  39. """,
  40. (max_account_numbers,))
  41. duplicates = [acc_number for acc_number, in cr.fetchall()]
  42. message = _(
  43. "Module installation can't proceed as you have duplicate "
  44. "account numbers in your system already. Please clean that up "
  45. "and try again.\n"
  46. "The following shows the first %d duplicate account numbers\n"
  47. "%s\n"
  48. "(if you see less than %d, those are the only duplicates)") % (
  49. max_account_numbers, '\n'.join(duplicates),
  50. max_account_numbers,
  51. )
  52. raise exceptions.Warning(message)