Skip to main content

Get companies info by using INPI api.

Project description

Django INPI

Django INPI allows you to use the INPI API to to get information about companies.

Features

  • Siren/Siret fields (django_inpi.fields.SIRETField, django_inpi.fields.SIRENField) which ensure that submitted Siren/Siret are numbers, and that their lenght is respectively 14 & 9 chars.
  • Forms with those custom fields (django_inpi.forms.SIRETForm, django_inpi.forms.SIRENForm)
  • An API (django_inpi.api.INPIApi) which allows you to get a token and make your own requests to the INSE API. Available functions:
    • login(): send a login POST request to INPI API, stores the Bearer token in your api instance (automatically called in INPIApi.__init__(), call INPIApi(skip_init=True) to skip login (if so, you will not have a token, and will need to login yourself)).
    • get(siret=None, siren=None): get company details using it's siret/siren. Returns the whole json from INPI API.
    • get_generic_company_data(siret=None, siren=None): get company details using it's siret/siren. Returns a formatted json containing only a few values (see examples below).
  • 4 Mixins that you can use in your views:
    • django_inpi.views.SIRETFormGetAllJsonMixin: Uses SIRETForm, and calls INPIApi.get(siret).
    • django_inpi.views.SIRETFormGetGenericCompanyDataMixin Uses SIRETForm, and calls INPIApi.get_generic_company_data(siret).
    • django_inpi.views.SIRENFormGetAllJsonMixin: Uses SIRENForm, and calls INPIApi.get(siren).
    • django_inpi.views.SIRENFormGetGenericCompanyDataMixin Uses SIRENForm, and calls INPIApi.get_generic_company_data(siren).

Install

  1. Install the package:
    python3 -m pip install django-inpi
    
  2. Add those apps to your INSTALLED_APPS:
    "django_inpi",
    
  3. Add your user/pass in your env vars & project settings:
    DJANGO_INPI_USERNAME = "username"
    DJANGO_INPI_PASSWORD = "username"
    
    from os import getenv
    
    DJANGO_INPI_USERNAME = getenv("DJANGO_INPI_USERNAME", None)
    DJANGO_INPI_PASSWORD = getenv("DJANGO_INPI_PASSWORD", None)
    
  4. That's all folks!

Examples

View

# my_app/urls.py

urlpatterns = [
    # ...
    path(
        "get-company-infos-from-siret/",
        views.GetCompanyInfosView.as_view(),
        name="get_company_infos",
    ),
]
# my_app/views.py
from django_inpi.views import SIRENFormGetAllJsonMixin

# ...
class GetCompanyInfosView(
    SIRENFormGetAllJsonMixin,  # <-- our mixin here
    FormView,  # required, our mixin does not inherit from any *View
):
    def get_success_url(self):
        return reverse(
            "my_app:get_company_infos",
        )

API

This package comes with an API that you can use independently from the Field or Form. Here's how to use it:

from django_inpi.api import INPIApi

inpi_api = INPIApi()
# use `inpi_api = INPIApi(skip_init=True)` if you want to call the login function yourself

# Get full json
siret = "01234567891234"
company_infos = inpi_api.get(siret=siret)
# OR
siren = "123456789"
company_infos = inpi_api.get(siren=siren)
from django_inpi.api import INPIApi

inpi_api = INPIApi()

# Get partial json
siret = "01234567891234"
generic_company_infos = inpi_api.get_generic_company_data(siret=siret)
# OR
siren = "123456789"
generic_company_infos = inpi_api.get_generic_company_data(siren=siren)

generic_company_infos wil contains those data:

{
  "siren": 123456789,
  "data": {
    "name": "NAME",
    "legal_status": {
      "full_name": "Full legal status name",
      "acronym": "FLSN"
    },
    "address": {
      "street_number": "1",
      "street_type": "STREET TYPE",
      "street_name": "STREET NAME",
      "postal_code": "01234",
      "city": "CITY NAME",
      "full_address": "1 STREET TYPE STREET NAME 01234 CITY NAME",
      "country": "FR"
    },
    "manager": {
      "first_name": "MANAGER FIRST NAME",
      "last_name": "MANAGER LAST NAME"
    },
  }
}

Config

  • DJANGO_INPI_USERNAME (no default, required): You must set this value in your settings in order to be able to access the INPI API.
  • DJANGO_INPI_PASSWORD (no default, required): You must set this value in your settings in order to be able to access the INPI API.

You must have an account on the INPI website in order to set your credentials, see here for registering a new account or here to login.

  • DJANGO_INPI_LOGIN_URL (default https://registre-national-entreprises.inpi.fr/api/sso/login): Set this var in your settings if you want to use a custom (selfhosted?) api.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_inpi-0.4.3.tar.gz (29.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_inpi-0.4.3-py3-none-any.whl (30.2 kB view details)

Uploaded Python 3

File details

Details for the file django_inpi-0.4.3.tar.gz.

File metadata

  • Download URL: django_inpi-0.4.3.tar.gz
  • Upload date:
  • Size: 29.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.10

File hashes

Hashes for django_inpi-0.4.3.tar.gz
Algorithm Hash digest
SHA256 b4388ce542f5ef746f3d5524e3a40f477a427a4953c1e44443cd2d2b4285d9a8
MD5 c8f217f9996d466dd3c1c4d4258c060a
BLAKE2b-256 b39c24f04c8f93c32e7c95382d7fb643ca9ca6444f724cf45b1c5fe13bb5070a

See more details on using hashes here.

File details

Details for the file django_inpi-0.4.3-py3-none-any.whl.

File metadata

  • Download URL: django_inpi-0.4.3-py3-none-any.whl
  • Upload date:
  • Size: 30.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.10

File hashes

Hashes for django_inpi-0.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 57069181f3f9cc0b8c682341346f10bdfc9631c277590728dba5b2eaf0ca5818
MD5 2e473d3e3ee8c0c96c76af6fc25797a5
BLAKE2b-256 2940100cd8690de17a0047e56b41b13380fc48fc397739d28c21e3873bed07b7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page