Documentation Index
Fetch the complete documentation index at: https://docs.topograph.co/llms.txt
Use this file to discover all available pages before exploring further.
Data Sources
The Netherlands uses a single official registry — the KVK (Kamer van Koophandel / Chamber of Commerce) — accessed through multiple channels. Data retrieval follows a two-phase model: basic structured data from the KVK Search API, and detailed data (legal representatives, shareholders, capital, RSIN) from the HTML trade register extract via AI parsing.- KVK Search API (
web-api.kvk.nl/zoeken) — Provides basic company data in structured JSON: legal name, legal form, status, address, activity description, and trade names. This is a free, fast API that returns data immediately. Used for search results and base company profile data. - KVK Trade Register Extract (Uittreksel Handelsregister) — The official HTML extract from the KVK online trade register. Contains detailed data including legal representatives (
Bestuurders,Gevolmachtigden), shareholders (Aandeelhouders,Vennoten), SBI activity codes, RSIN, share capital, and employee count. This HTML is AI-parsed to extract structured data.
Two-phase data retrieval: Basic company data comes from the KVK Search API
(fast, structured JSON). Detailed data (legal representatives, shareholders,
capital, RSIN, SBI codes) requires fetching and AI-parsing the HTML trade
register extract, which takes longer but provides comprehensive information.
The trade register HTML is fetched once and reused by multiple data
sources (company enrichment, legal representatives, shareholders) via document
factorization.
Company Identifiers
Query Identifiers
| Company Type | Source | Format | Example | Notes |
|---|---|---|---|---|
| All entities | KVK | 8 digits (KVK number) | 53781066 | Kamer van Koophandel number — the universal Dutch business identifier |
Identifiers in API Response
Once you retrieve company data, theidentifiers object contains all available identifiers for that entity:
| Identifier Type | Format | Example | Found In |
|---|---|---|---|
KVK | 8 digits | 53781066 | All entities (from Search API) |
RSIN | 9 digits | 123456789 | Tax/fiscal identification number (from trade register extract, AI-parsed) |
Search Capabilities
| Search Type | Pattern | Example | Match Type | Expected Results |
|---|---|---|---|---|
| By KVK Number | 8 digits | 53781066 | Exact | Single company (1 result) |
| By Name | Text string | "Philips" | Fuzzy | Multiple results |
Quirks & Gotchas
| Quirk | Details |
|---|---|
| Two-phase data retrieval | Basic company data comes from the KVK Search API (fast, free); detailed data (legal reps, shareholders, capital) requires fetching and AI-parsing the HTML trade register extract. Legal reps and shareholders take longer to return. |
| KVK website access | KVK website access requires automated session handling. Search and establishment number retrieval are performed against the KVK website. |
| Legal form: two tiers | Onboarding mode returns 23 base legal forms from the KVK search API. Verification mode extracts the detailed form (48 values) from the trade register document. A BV that is a structuurvennootschap will show as “Besloten Vennootschap” in onboarding and “Besloten Vennootschap (blijkens statuten structuurvennootschap)” in verification. |
| No UBO data | Ultimate beneficial owner information is not available from the KVK API or trade register extract. The UBO register in the Netherlands is not publicly accessible. |
| Null ownership percentages | Ownership percentages are only extracted when explicitly stated in the trade register extract. null means “not stated”, not “0%”. The system never infers or calculates percentages. |
| Null nationality | Nationality is always null unless explicitly stated in the document. The system does not assume Dutch nationality for shareholders of Dutch companies. |
| SBI codes via AI | SBI 2008 codes are AI-extracted from the trade register extract HTML. NACE and ISIC are then derived deterministically (no AI). SBI 2025 codes are derived via CBS crosswalk, with LLM disambiguation for ambiguous mappings. In onboarding (no TRE), all codes are AI-inferred from the activity description. |
| Establishment number required | Document listing and fetching requires the vestigingsnummer (establishment number), which is obtained automatically before documents can be listed. |
| Partial document failures | The three document listing calls (extract, financials, statutes) run in parallel. If one fails, partial results are returned. Only if all three fail is an error thrown. |
| KVK identifier casing | The system uses consistent KVK casing (uppercase) for identifiers, not kvk or KvK. |
| Statutes listing | All deposited statutes from KVK are included in the document list, regardless of tapedForAvg status. Documents not yet checked for privacy (tapedForAvg: false) may have longer delivery times. |
| Document delivery via email | Financial statements and statutes are ordered from KVK, delivered via email, then downloaded. This adds latency (~30 sec). Trade register extracts use a direct online flow. |
| AI model for legal reps | Legal representative parsing uses GPT-5.1 exclusively (no model racing). The AI extracts birth dates, start dates, roles, and authorization scope. |
| Company self-filtering | AI parsing sometimes includes the main company itself as a legal representative or shareholder. The system automatically filters these out by matching on KVK number. |
Company Status
Company status is determined deterministically from the KVKactief boolean field. No AI inference is involved in status determination.
| Local Status | English | Standardized Status | Notes |
|---|---|---|---|
| Ingeschreven | Registered | Active | actief = true |
| Uitgeschreven | Deregistered | Closed | actief = false |
The KVK provides only a binary active/inactive status. There are no detailed
closure reasons (bankruptcy, liquidation, etc.) or insolvency statuses
available from the structured API. More detailed status information may
occasionally be available in the trade register extract via AI parsing, but it
is not systematically extracted.
Legal Forms
The Netherlands has a two-tier legal form model. The level of detail you receive depends on the mode you request.- Onboarding mode returns 23 base legal forms from the KVK search API. These are the values in the
rechtsvormfield (e.g. “Besloten Vennootschap”, “Naamloze Vennootschap”, “Publiekrechtelijke Rechtspersoon”). This is a deterministic mapping with no AI involved. - Verification mode returns 48 detailed legal forms extracted from the trade register document. These are the
uitgebreideRechtsvormvalues (e.g. “Besloten Vennootschap (blijkens statuten structuurvennootschap)”, “Naamloze Vennootschap (beleggingsmaatschappij met veranderlijk kapitaal)”, “Publiekrechtelijke Rechtspersoon: Gemeente”). A dedicated AI parser constrained to the 48-value enum extracts the detailed form from the document.
Onboarding mode (23 base forms)
| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Eenmanszaak | Sole Proprietorship | SoleProprietorship | 4QXM |
| Eenmanszaak met Meerdere Eigenaren | Sole Proprietorship with Multiple Owners | Other | 4QXM |
| Rederij | Shipping Company | Corporation | UNJ2 |
| Maatschap | Partnership | Partnership | 9AAK |
| Vennootschap Onder Firma | General Partnership | Partnership | 62Y3 |
| Commanditaire Vennootschap | Limited Partnership | Partnership | CODH |
| Rechtspersoon in oprichting | Legal Entity in Formation | Other | EZQW |
| Besloten Vennootschap | Private Limited Company | LimitedLiabilityCompany | 54M6 |
| Naamloze Vennootschap | Public Limited Company | Corporation | B5PM |
| Coöperatie | Cooperative | Cooperative | NFFH |
| Onderlinge Waarborg Maatschappij | Mutual Guarantee Company | Cooperative | DEO1 |
| Vereniging | Association | NonprofitOrganization | 33MN |
| Vereniging van Eigenaars | Owners’ Association | Other | GNXT |
| Kerkgenootschap | Religious Society or Church | NonprofitOrganization | L7HX |
| Stichting | Foundation | NonprofitOrganization | V44D |
| Overige Privaatrechtelijke Rechtspersoon | Other Private Law Legal Entity | Other | M1IZ |
| Europese naamloze vennootschap (SE) | European Public Limited-Liability Company (SE) | Corporation | BBEB |
| Europees economisch samenwerkingsverband | European Economic Interest Grouping | Other | 5WU6 |
| Europese coöperatieve vennootschap (SCE) | European Cooperative Society (SCE) | Cooperative | BBEB |
| Kapitaalvennootschap binnen EER | Capital Company within the EEA | Corporation | BBEB |
| Kapitaalvennootschap buiten EER | Capital Company outside the EEA | Corporation | BBEB |
| Overige buitenlandse rechtspersoon of vennootschap | Other Foreign Legal Entity or Company | Other | M1IZ |
| Publiekrechtelijke Rechtspersoon | Public Law Legal Entity | GovernmentOwnedEntity | A0W7 |
Verification mode (48 detailed forms)
In verification mode, the legal form is extracted from the trade register document and resolved to one of 48 specific values. The 23 base forms above still appear when the base and detailed form are the same (e.g. “Eenmanszaak” stays “Eenmanszaak”). The additional 25 detailed variants only appear in verification mode.BV and NV variants (rows 8-13)
BV and NV variants (rows 8-13)
| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Besloten Vennootschap | Private Limited Company | LimitedLiabilityCompany | 54M6 |
| Besloten Vennootschap (blijkens statuten structuurvennootschap) | Private Limited Company (Structure Regime) | LimitedLiabilityCompany | 54M6 |
| Naamloze Vennootschap | Public Limited Company | Corporation | B5PM |
| Naamloze Vennootschap (blijkens statuten structuurvennootschap) | Public Limited Company (Structure Regime) | Corporation | B5PM |
| Naamloze Vennootschap (beleggingsmaatschappij met veranderlijk kapitaal) | Public Limited Company (Variable Capital Investment Company) | Corporation | B5PM |
| Naamloze Vennootschap (beleggingsmaatschappij met veranderlijk kapitaal blijkens statuten structuurvennootschap) | Public Limited Company (Variable Capital Investment Company, Structure Regime) | Corporation | B5PM |
Cooperative and mutual guarantee variants (rows 14-17)
Cooperative and mutual guarantee variants (rows 14-17)
| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Coöperatie | Cooperative | Cooperative | NFFH |
| Coöperatie (blijkens statuten structuurcoöperatie) | Cooperative (Structure Regime) | Cooperative | NFFH |
| Onderlinge Waarborg Maatschappij | Mutual Guarantee Company | Cooperative | DEO1 |
| Onderlinge Waarborg Maatschappij (blijkens statuten onderlinge) | Mutual Guarantee Company (Mutual Statutes) | Cooperative | DEO1 |
Association variants (rows 18-19)
Association variants (rows 18-19)
| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Vereniging (met volledige rechtsbevoegdheid) | Association (with Full Legal Capacity) | NonprofitOrganization | 33MN |
| Vereniging (met beperkte rechtsbevoegdheid) | Association (with Limited Legal Capacity) | NonprofitOrganization | 33MN |
Other private law subtypes (rows 23-27)
Other private law subtypes (rows 23-27)
| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Overige Privaatrechtelijke Rechtspersoon: Hofje | Other Private Law: Almshouse | Other | M1IZ |
| Overige Privaatrechtelijke Rechtspersoon: Boermarke | Other Private Law: Agricultural Commons | Other | M1IZ |
| Overige Privaatrechtelijke Rechtspersoon: Fundatie | Other Private Law: Endowment | Other | M1IZ |
| Overige Privaatrechtelijke Rechtspersoon: Gilde | Other Private Law: Guild | Other | M1IZ |
| Overige Privaatrechtelijke Rechtspersoon: Buurtschap | Other Private Law: Hamlet Community | Other | M1IZ |
Foreign forms (rows 31-34)
Foreign forms (rows 31-34)
Foreign entities registered in the Netherlands. The KVK profile API returns a dynamic
uitgebreideRechtsvorm with the foreign legal form name and country of establishment (e.g. “Société à responsabilité limitée (Frankrijk)”). The API response normalizes these to one of the 4 base forms below.| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Kapitaalvennootschap binnen EER | Capital Company within the EEA | Corporation | BBEB |
| Kapitaalvennootschap buiten EER | Capital Company outside the EEA | Corporation | BBEB |
| Kapitaalvennootschap buiten EER (formeel buitenlandse vennootschap) | Capital Company outside the EEA (formally foreign company) | Corporation | BBEB |
| Overige buitenlandse rechtspersoon of vennootschap | Other Foreign Legal Entity or Company | Other | M1IZ |
Public law entity subtypes (rows 35-48)
Public law entity subtypes (rows 35-48)
| Dutch Name | English | Standardized | ISO 20275 |
|---|---|---|---|
| Publiekrechtelijke Rechtspersoon: Adviescollege | Public Law: Advisory Council | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Bedrijfsvoeringsorganisatie (BVO) | Public Law: Shared Services Organization (BVO) | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: De Staat (Baten- en lastendienst) | Public Law: The State (Executive Agency) | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: De Staat (Ministerie) | Public Law: The State (Ministry) | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: De Staat (Zelfstandig onderdeel) | Public Law: The State (Autonomous Unit) | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Europese Groepering voor Territoriale Samenwerking (EGTS) | Public Law: European Grouping of Territorial Cooperation (EGTC) | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Gemeente | Public Law: Municipality | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Lichaam met bevoegdheid krachtens de Grondwet | Public Law: Body with Constitutional Authority | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Openbaar Lichaam op basis van gemeenschappelijke regeling | Public Law: Public Body under Joint Arrangement | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Provincie | Public Law: Province | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Rechtspersoon met Wettelijk Taak (RWT) | Public Law: Entity with Statutory Task (RWT) | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Universiteit of Academisch Ziekenhuis | Public Law: University or Academic Hospital | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Waterschap | Public Law: Water Board | GovernmentOwnedEntity | A0W7 |
| Publiekrechtelijke Rechtspersoon: Zelfstandig Bestuursorgaan (ZBO) | Public Law: Independent Administrative Body (ZBO) | GovernmentOwnedEntity | A0W7 |
Legal Representatives
Legal representatives come from the KVK trade register extract. You get a person’s name, birth date, start date, and a role that always comes from a fixed list.A closed role list
We use a closed list of canonical roles for the Netherlands. Everyrole.localName you receive in the API response is guaranteed to be one of these values.
The list is built on top of ISO 5009, the international standard for official organizational roles published by ISO and maintained by GLEIF. ISO 5009 covers the statutory roles defined in the Dutch Civil Code (directors, supervisory board members, liquidators, and so on). We took the Dutch entries from the ISO 5009 code list and deduplicated them into canonical roles.
On top of that, we added four roles that appear on Dutch trade register extracts but are out of scope for ISO 5009 because they are based on power of attorney (volmacht) rather than corporate governance:
- Gevolmachtigde and Gevolmachtigd handelsagent, registered via KVK Form 13
- Procuratiehouder, a historical commercial volmacht role
- Bewindvoerder, a trustee appointed during suspension of payments
shareholders field of the API response.
Full role enum
The 20 canonical role values you may receive in therole.localName field. Each ISO 5009 role can map to multiple OOR codes because the code depends on the legal form of the company. For example, “Bestuurder” is KHNVNO for a BV, TK4BXG for an NV, and PPIUMW for a Stichting.
| Dutch name | English | Standardized | ISO 5009 OOR codes |
|---|---|---|---|
| Bestuurder | Director | Director | KHNVNO (BV), TK4BXG (NV), PPIUMW (Stichting) |
| Bestuurder / bestuurslid | Director / Board Member | Director | W9JQJP (Vereniging) |
| Uitvoerend bestuurder | Executive Director | ExecutiveDirector | TFPVDK (BV), 7BGHMI (NV) |
| Niet uitvoerend bestuurder | Non-Executive Director | NonExecutiveDirector | VA30FP (BV), HHZHF9 (NV) |
| Voorzitter bestuur | Chairman of the Management Board | Chairman | 080BGK (BV), 934G9A (NV) |
| Voorzitter | Chairman | Chairman | 9W99BU (Vereniging) |
| Commissaris | Supervisory Board Member | SupervisoryBoardMember | GRP0OJ (BV), TP7XTW (NV), RERTFR (Stichting), LMY8OH (Vereniging) |
| Voorzitter raad van commissaren | Chairman of the Supervisory Board | ChairmanOfSupervisoryBoard | WPGA3Y (NV) |
| Secretaris | Secretary | Secretary | PV9S1F (Vereniging) |
| Penningmeester | Treasurer | Treasurer | GQ8JOW (Vereniging) |
| Vertegenwoordigingsbevoegde | Authorized Signatory (statutory) | AuthorizedSignatory | CHOFER (BV), RPL5H6 (NV), SXRUU6 (Vereniging), WNHFP9 (Stichting) |
| Vereffenaar | Liquidator | Liquidator | 7PTVPF (BV), WBJNBK (NV) |
| Curator | Court-Appointed Administrator | CourtAppointedAdministrator | ALIVPM (NV), SYLJPO (BV) |
| Beheerder | Administrator | Administrator | OIEAWD (Maatschap) |
| Beheerder / Beherend Vennoot | Managing Partner | ManagingPartner | BF4XP2 (VOF) |
| Beherend Vennoot | General Partner | GeneralPartner | BKH1IX (CV) |
| Gevolmachtigde | Authorized Representative | AuthorizedRepresentative | Topograph extension (Boek 3 volmacht) |
| Gevolmachtigd handelsagent | Authorized Commercial Agent | AuthorizedCommercialAgent | Topograph extension (Boek 3 volmacht) |
| Procuratiehouder | Procurator | Procurator | Topograph extension (historical volmacht) |
| Bewindvoerder | Trustee (suspension of payments) | Trustee | Topograph extension (Boek 3 bewind) |
Role normalization
Dutch trade register extracts sometimes use informal variants or add authority scope to a role name. We normalize these to the canonical value so you always get a predictable result.| What the extract says | What you receive |
|---|---|
| Directeur, Statutair bestuurder, Algemeen directeur | Bestuurder |
| Bestuurder - Alleen/zelfstandig bevoegd | Bestuurder |
| Bestuurder - Gezamenlijk bevoegd | Bestuurder |
| CEO, CFO, COO | Bestuurder |
| Gevolmachtigde - Beperkte volmacht | Gevolmachtigde |
| Gevolmachtigde - Onbeperkte volmacht | Gevolmachtigde |
representationMode field on the response, not mixed into the role.
Fields extracted per legal representative
| Field | Dutch source term | Description |
|---|---|---|
| Birth date | Geboortedatum | Date of birth |
| Start date | Datum in functie | Date the person started in the role |
| Role | (from the extract) | One of the canonical values above |
| Name title | Mr., Mrs., Dr., etc. | Honorific prefix only |
Other Key Persons
Two roles appear on Dutch trade register extracts but are not legal representatives. They are returned separately:| Dutch name | English | Standardized | ISO 5009 OOR codes |
|---|---|---|---|
| Oprichter | Founder | Founder | AJ86T4 (BV), 6ITGMW (NV), KLUFYX (Stichting) |
| Lid | Member | Member | 1AHQJK (Vereniging) |
Shareholders
Shareholders are extracted from the KVK trade register extract HTML via AI parsing, using the same HTML document as legal representatives (fetched once via document factorization).Dutch Terms for Shareholders
| Dutch Term | English | Entity Type | Found In |
|---|---|---|---|
| Aandeelhouders | Shareholders | BV, NV companies | Capital companies |
| Vennoten | Partners | VOF, CV partnerships | Partnerships |
| Eigenaar | Owner | Eenmanszaak (sole proprietorship) | Sole proprietorships |
Extraction Logic
| Source | When Used | Data Extracted |
|---|---|---|
| Trade Register Extract HTML | Always (AI-parsed) | Partners, Shareholders, Owners with names and optional share percentages |
Ownership Fields
| Field | Description | Source |
|---|---|---|
sharePercentage | Ownership percentage | Only if explicitly stated in document (null if not stated) |
type | Individual or Company | Determined from AI parsing context |
nationality | Nationality | Only if explicitly stated (null by default — never assumes Dutch) |
Shareholder data is available for BV/NV companies, VOF/CV partnerships (as
partners), and Eenmanszaak (as owner). Stichtingen (foundations) and
Verenigingen (associations) do not have shareholders.
Activity Code Mapping
The Netherlands uses the SBI (Standaard Bedrijfsindeling) classification. SBI 2008 codes (5-digit) are extracted from the trade register extract via AI parsing. From these, NACE Rev 2 and ISIC Rev 4 codes are derived deterministically (no AI), and SBI 2025 codes are derived via the official CBS crosswalk (with LLM disambiguation for ambiguous mappings).Company Profile (with Trade Register Extract)
| Classification | Source | Example | AI Inferred? |
|---|---|---|---|
| SBI 2025 | Derived from SBI 2008 via CBS crosswalk | 47120 | Yes (AI-extracted from HTML + crosswalk disambiguation) |
| NACE Rev 2 | Derived from SBI 2008 (truncate + dot) | 47.19 | No (deterministic) |
| ISIC Rev 4 | Formal mapping from NACE | 4719 | No (deterministic) |
Onboarding Profile (Search API only, no TRE)
| Classification | Source | Example | AI Inferred? |
|---|---|---|---|
| SBI 2025 | Derived from NACE via CBS crosswalk | 64110 | Yes |
| NACE Rev 2 | Derived from ISIC (formal mapping) | 64.11 | Yes (source ISIC is AI-inferred) |
| ISIC Rev 4 | LLM-inferred from activity description | 6411 | Yes |
Deterministic vs. AI-inferred: When the trade register extract is
available (company profile), NACE and ISIC are derived deterministically from
SBI 2008 codes (
isAIInferred: false). SBI 2025 codes use the CBS crosswalk
— 1:1 mappings are resolved automatically, ambiguous mappings (multiple SBI
2025 candidates for one NACE code) are disambiguated by an LLM using the
company’s activity description. When only the search API is available
(onboarding profile), all codes are AI-inferred from the activity description
text.Data Availability Matrix
| Data Type | BV/NV | VOF/CV | Eenmanszaak | Stichting/Vereniging | Notes |
|---|---|---|---|---|---|
| Company Profile | ✅ Async | ✅ Async | ✅ Async | ✅ Async | Basic data from Search API + AI enrichment from trade register |
| Legal Representatives | ✅ | ✅ | ✅ | ✅ | AI-parsed from trade register extract HTML |
| Shareholders | ✅ | ✅ (as partners) | ✅ (as owner) | ❌ | AI-parsed; VOF/CV show partners, EMZ shows owner |
| Ultimate Beneficial Owners | ❌ | ❌ | ❌ | ❌ | Not available from KVK (UBO register not publicly accessible) |
| Establishments | ❌ | ❌ | ❌ | ❌ | Not yet implemented |
| Activity Codes | ✅ | ✅ | ✅ | ✅ | SBI 2025, NACE, ISIC. Company profile: SBI 2008 from TRE → deterministic NACE/ISIC. Onboarding: AI-inferred from description. |
Documents by Company Type
All Companies
| Document Type | API Category | Format | SKU | Availability | Notes |
|---|---|---|---|---|---|
| Uittreksel Handelsregister (Trade Register Extract) | tradeRegisterExtract | NLD_REGISTER_EXTRACT | ✅ When available | Online extract from KVK (~30 sec, 24h cache) | |
| Jaarrekening (Financial Statements) | financialStatements[] | NLD_FINANCIAL_STATEMENTS | ✅ When filed | Annual accounts from KVK (delivered via email, 99-year cache) | |
| Statuten (Articles of Association) | articlesOfAssociation[] | NLD_STATUS | ✅ When filed | Corporate statutes from KVK (delivered via email, 99-year cache) |
Trade Register Extract: The Uittreksel is an HTML document fetched from
the KVK website and converted to PDF for delivery. The HTML content is
AI-parsed to extract structured data.
Document Delivery Methods: The trade register extract uses a direct
online flow (fast, ~30 sec). Financial statements and statutes use a
mail flow: the document is ordered from KVK, delivered via email, then
downloaded and saved. This adds latency but is the only retrieval method
available for these document types.
Document Listing: Documents are listed via three parallel KVK API calls:
(1) trade register extract availability, (2) financial statements, (3)
statutes. If one source fails, partial results are still returned. Only if all
three fail is an error thrown.
Example API Responses
All examples use placeholder data. Query:POST /v2/company with { "id": "<id>", "countryCode": "NL", "dataPoints": ["company", "legalRepresentatives"] }
Active BV (Source: KVK)
Active BV (Source: KVK)
Closed NV (Source: KVK)
Closed NV (Source: KVK)
active: false and status Uitgeschreven (Deregistered). No detailed closure reason is available from the KVK.VOF Partnership (Source: KVK)
VOF Partnership (Source: KVK)
Vennoten) appear as both legal representatives and shareholders. Ownership percentages are typically not stated for partnerships, so sharePercentage is null.Eenmanszaak -- Sole Proprietorship (Source: KVK)
Eenmanszaak -- Sole Proprietorship (Source: KVK)
Eigenaar) appears as a shareholder. The entrepreneur is the company itself.Stichting -- Foundation (Source: KVK)
Stichting -- Foundation (Source: KVK)
Bestuurders). No UBOs are available from the KVK.Available Documents (company example)
Available Documents (company example)
Documents are returned when
"dataPoints": ["availableDocuments"] is requested.| API Category | Document | Notes |
|---|---|---|
tradeRegisterExtract | Uittreksel Handelsregister PDF | When available (~30 sec, online flow) |
financialStatements[] | Jaarrekening (annual accounts) | When filed, PDF format (mail flow) |
articlesOfAssociation[] | Statuten (corporate statutes) | When filed, PDF format (mail flow) |