Add module l10n_fr_infogreffe_connector.
This commit is contained in:
23
l10n_fr_infogreffe_connector/__init__.py
Normal file
23
l10n_fr_infogreffe_connector/__init__.py
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# L10n FR infogreffe connector module for OpenERP
|
||||||
|
# Copyright (C) 2014 Akretion (http://www.akretion.com/)
|
||||||
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as
|
||||||
|
# published by the Free Software Foundation, either version 3 of the
|
||||||
|
# License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
from . import infogreffe
|
||||||
49
l10n_fr_infogreffe_connector/__openerp__.py
Normal file
49
l10n_fr_infogreffe_connector/__openerp__.py
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# L10n FR Infogreffe connector module for OpenERP
|
||||||
|
# Copyright (C) 2014 Akretion (http://www.akretion.com/)
|
||||||
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as
|
||||||
|
# published by the Free Software Foundation, either version 3 of the
|
||||||
|
# License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
{
|
||||||
|
'name': 'Infogreffe connector',
|
||||||
|
'version': '0.1',
|
||||||
|
'category': 'French Localization',
|
||||||
|
'license': 'AGPL-3',
|
||||||
|
'summary': 'Download info from infogreffe.fr',
|
||||||
|
'description': """
|
||||||
|
Infogreffe connector
|
||||||
|
====================
|
||||||
|
|
||||||
|
This module adds a button on Partner form view in the *Accounting* tab to download data from Infogreffe. If the Partner has a SIREN in OpenERP, it will check if the company has *Key Figures* in Infogreffe, get the latest *Key Figures* and copy to OpenERP :
|
||||||
|
|
||||||
|
* Turnover
|
||||||
|
|
||||||
|
* Profit
|
||||||
|
|
||||||
|
* Headcount
|
||||||
|
|
||||||
|
Please contact Alexis de Lattre from Akretion <alexis.delattre@akretion.com> for any help or question about this module.
|
||||||
|
""",
|
||||||
|
'author': 'Akretion',
|
||||||
|
'website': 'http://www.akretion.com/',
|
||||||
|
'depends': ['l10n_fr_siret'],
|
||||||
|
'external_dependencies': {'python': ['requests', 'bs4']},
|
||||||
|
'data': ['partner_view.xml'],
|
||||||
|
'active': False,
|
||||||
|
}
|
||||||
151
l10n_fr_infogreffe_connector/infogreffe.py
Normal file
151
l10n_fr_infogreffe_connector/infogreffe.py
Normal file
@@ -0,0 +1,151 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# L10n FR infogreffe connector module for OpenERP
|
||||||
|
# Copyright (C) 2014 Akretion (http://www.akretion.com/)
|
||||||
|
# Copyright (C) 2014 Kiplink (http://www.kiplink.fr/)
|
||||||
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# @author: Alexandre Fournier <alexandre.fournier@kiplink.fr>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as
|
||||||
|
# published by the Free Software Foundation, either version 3 of the
|
||||||
|
# License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
from openerp.osv import orm, fields
|
||||||
|
from openerp.tools.translate import _
|
||||||
|
import requests
|
||||||
|
from bs4 import BeautifulSoup
|
||||||
|
from datetime import datetime
|
||||||
|
import logging
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
URL = 'https://www.infogreffe.fr'
|
||||||
|
|
||||||
|
|
||||||
|
class res_partner(orm.Model):
|
||||||
|
_inherit = 'res.partner'
|
||||||
|
|
||||||
|
_columns = {
|
||||||
|
'infogreffe_date': fields.date('Date', readonly=True),
|
||||||
|
'infogreffe_turnover': fields.integer('Turnover', readonly=True),
|
||||||
|
'infogreffe_profit': fields.integer('Profit', readonly=True),
|
||||||
|
'infogreffe_headcount': fields.integer('Headcount', readonly=True),
|
||||||
|
}
|
||||||
|
|
||||||
|
def copy(self, cr, uid, id, default=None, context=None):
|
||||||
|
if default is None:
|
||||||
|
default = {}
|
||||||
|
default.update({
|
||||||
|
'infogreffe_date': False,
|
||||||
|
'infogreffe_turnover': False,
|
||||||
|
'infogreffe_profit': False,
|
||||||
|
'infogreffe_headcount': False,
|
||||||
|
})
|
||||||
|
return super(res_partner, self).copy(
|
||||||
|
cr, uid, id, default=default, context=context)
|
||||||
|
|
||||||
|
def get_json_company_from_siren(self, cr, uid, siren, context=None):
|
||||||
|
params = {
|
||||||
|
'sirenOuSiret': siren,
|
||||||
|
'etabSecondaire': 'false',
|
||||||
|
'etsRadiees': 'false',
|
||||||
|
'typeEntreprise': 'TOUS'
|
||||||
|
}
|
||||||
|
|
||||||
|
url = URL + '/services/entreprise/rest/recherche/parEntreprise'
|
||||||
|
resp = requests.get(url=url, params=params)
|
||||||
|
data = resp.json()
|
||||||
|
return data
|
||||||
|
|
||||||
|
def get_soup_extrait_from_siren(self, cr, uid, siren, context=None):
|
||||||
|
data = self.get_json_company_from_siren(
|
||||||
|
cr, uid, siren, context=context)
|
||||||
|
data = data['entrepRCSStoreResponse']['items'][0]
|
||||||
|
name = data['libelleEntreprise']['denomination'].lower()
|
||||||
|
url = URL + '/societes/entreprise-societe/%s-%s-%s.html' % (
|
||||||
|
data['siren'], name, data['etablissementChrono'])
|
||||||
|
resp = requests.get(url=url)
|
||||||
|
soup = BeautifulSoup(resp.text)
|
||||||
|
return soup
|
||||||
|
|
||||||
|
def convert_to_integer(self, cr, uid, raw_value, context=None):
|
||||||
|
if not raw_value:
|
||||||
|
return False
|
||||||
|
val1 = raw_value.strip()
|
||||||
|
#print "val1=", val1
|
||||||
|
# Remove short spaces
|
||||||
|
val2 = val1.replace(u'\xA0', '')
|
||||||
|
#print "val2=", val2
|
||||||
|
val3 = val2.replace('K', '000')
|
||||||
|
#print "val3=", val3
|
||||||
|
# Remove euro symbol
|
||||||
|
val4 = val3.replace(u'\u20ac', '')
|
||||||
|
#print "val4=", val4
|
||||||
|
val5 = val4.replace(' ', '')
|
||||||
|
#print "val5=", val5
|
||||||
|
return int(val5)
|
||||||
|
|
||||||
|
def button_get_from_infogreffe(self, cr, uid, ids, context=None):
|
||||||
|
assert len(ids) == 1, 'Only 1 ID'
|
||||||
|
partner = self.browse(cr, uid, ids[0], context=context)
|
||||||
|
if not partner.siren:
|
||||||
|
raise orm.except_orm(
|
||||||
|
_('Error:'),
|
||||||
|
_("Missing SIREN on partner '%s'. It is needed to download "
|
||||||
|
"data from Infogreffe") % partner.name)
|
||||||
|
|
||||||
|
logger.info("Connecting to infogreffe with SIREN %s" % partner.siren)
|
||||||
|
soup = self.get_soup_extrait_from_siren(
|
||||||
|
cr, uid, partner.siren, context=context)
|
||||||
|
trs = soup.find(id='chiffresCles').find('tbody').find_all('tr')
|
||||||
|
vals = {
|
||||||
|
'infogreffe_date': False,
|
||||||
|
'infogreffe_turnover': False,
|
||||||
|
'infogreffe_profit': False,
|
||||||
|
'infogreffe_headcount': False,
|
||||||
|
}
|
||||||
|
|
||||||
|
for tr in trs:
|
||||||
|
tds = tr.find_all('td')
|
||||||
|
if len(tds) != 4:
|
||||||
|
continue
|
||||||
|
try:
|
||||||
|
date = datetime.strptime(tds[0].text.strip(), '%d/%m/%Y')
|
||||||
|
raw_turnover = tds[1].text
|
||||||
|
turnover = self.convert_to_integer(
|
||||||
|
cr, uid, raw_turnover, context=context)
|
||||||
|
raw_profit = tds[2].text
|
||||||
|
profit = self.convert_to_integer(
|
||||||
|
cr, uid, raw_profit, context=context)
|
||||||
|
headcount_raw = tds[3].text.strip()
|
||||||
|
headcount = self.convert_to_integer(
|
||||||
|
cr, uid, headcount_raw, context=context)
|
||||||
|
except:
|
||||||
|
logger.warning('Cannot parse infogreffe results')
|
||||||
|
continue
|
||||||
|
if not vals['infogreffe_date'] or vals['infogreffe_date'] < date:
|
||||||
|
vals = {
|
||||||
|
'infogreffe_date': date,
|
||||||
|
'infogreffe_turnover': turnover,
|
||||||
|
'infogreffe_profit': profit,
|
||||||
|
'infogreffe_headcount': headcount,
|
||||||
|
}
|
||||||
|
logger.debug('Infogreffe result line = %s' % vals)
|
||||||
|
|
||||||
|
self.write(cr, uid, ids[0], vals, context=context)
|
||||||
|
logger.debug(
|
||||||
|
u'Partner %s updated with Infogreffe data %s'
|
||||||
|
% (partner.name, vals))
|
||||||
|
return True
|
||||||
30
l10n_fr_infogreffe_connector/partner_view.xml
Normal file
30
l10n_fr_infogreffe_connector/partner_view.xml
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright (C) 2014 Akretion (http://www.akretion.com/)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
The licence is in the file __openerp__.py
|
||||||
|
-->
|
||||||
|
|
||||||
|
<openerp>
|
||||||
|
<data>
|
||||||
|
|
||||||
|
<record id="view_partner_form" model="ir.ui.view">
|
||||||
|
<field name="name">infogreffe.partner.form</field>
|
||||||
|
<field name="model">res.partner</field>
|
||||||
|
<field name="inherit_id" ref="l10n_fr_siret.view_partner_add"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<xpath expr="//field[@name='company_registry']/../.." position="after">
|
||||||
|
<group name="infogreffe" string="Infogreffe" attrs="{'invisible': [('is_company', '=', False)]}">
|
||||||
|
<button colspan="2" string="Update from Infogreffe"
|
||||||
|
name="button_get_from_infogreffe" type="object"/>
|
||||||
|
<field name="infogreffe_date"/>
|
||||||
|
<field name="infogreffe_turnover"/>
|
||||||
|
<field name="infogreffe_profit"/>
|
||||||
|
<field name="infogreffe_headcount"/>
|
||||||
|
</group>
|
||||||
|
</xpath>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</data>
|
||||||
|
</openerp>
|
||||||
Reference in New Issue
Block a user