[MERGE] forward port of branch 7.0 up to de07c64
[odoo/odoo.git] / addons / account / wizard / account_fiscalyear_close_state.py
1 # -*- coding: utf-8 -*-
2 ##############################################################################
3 #
4 #    OpenERP, Open Source Management Solution
5 #    Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
6 #
7 #    This program is free software: you can redistribute it and/or modify
8 #    it under the terms of the GNU Affero General Public License as
9 #    published by the Free Software Foundation, either version 3 of the
10 #    License, or (at your option) any later version.
11 #
12 #    This program is distributed in the hope that it will be useful,
13 #    but WITHOUT ANY WARRANTY; without even the implied warranty of
14 #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 #    GNU Affero General Public License for more details.
16 #
17 #    You should have received a copy of the GNU Affero General Public License
18 #    along with this program.  If not, see <http://www.gnu.org/licenses/>.
19 #
20 ##############################################################################
21
22 from openerp.osv import fields, osv
23 from openerp.tools.translate import _
24
25 class account_fiscalyear_close_state(osv.osv_memory):
26     """
27     Closes  Account Fiscalyear
28     """
29     _name = "account.fiscalyear.close.state"
30     _description = "Fiscalyear Close state"
31     _columns = {
32        'fy_id': fields.many2one('account.fiscalyear', \
33                                  'Fiscal Year to Close', required=True, help="Select a fiscal year to close"),
34     }
35
36     def data_save(self, cr, uid, ids, context=None):
37         """
38         This function close account fiscalyear
39         @param cr: the current row, from the database cursor,
40         @param uid: the current user’s ID for security checks,
41         @param ids: List of Account fiscalyear close state’s IDs
42
43         """
44         account_move_obj = self.pool.get('account.move')
45
46         for data in  self.read(cr, uid, ids, context=context):
47             fy_id = data['fy_id'][0]
48
49             account_move_ids = account_move_obj.search(cr, uid, [('period_id.fiscalyear_id', '=', fy_id), ('state', '=', "draft")], context=context)
50             if account_move_ids:
51                 raise osv.except_osv(_('Invalid Action!'), _('In order to close a fiscalyear, you must first post related journal entries.'))
52
53             cr.execute('UPDATE account_journal_period ' \
54                         'SET state = %s ' \
55                         'WHERE period_id IN (SELECT id FROM account_period \
56                         WHERE fiscalyear_id = %s)',
57                     ('done', fy_id))
58             cr.execute('UPDATE account_period SET state = %s ' \
59                     'WHERE fiscalyear_id = %s', ('done', fy_id))
60             cr.execute('UPDATE account_fiscalyear ' \
61                     'SET state = %s WHERE id = %s', ('done', fy_id))
62
63             return {'type': 'ir.actions.act_window_close'}
64
65
66 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: