{
  "openapi": "3.0.1",
  "info": {
    "title": "SyndicData API",
    "description": "Professional API for Belgian VME discovery, syndic intelligence, stats, exports, and integration workflows.",
    "version": "v1"
  },
  "servers": [
    {
      "url": "/"
    }
  ],
  "paths": {
    "/api/map/vme-points": {
      "get": {
        "tags": [
          "Map"
        ],
        "summary": "Get map points",
        "description": "Returns map-ready VME and syndic points, optionally filtered by syndic, focus VME, or category.",
        "operationId": "GetMapPoints",
        "parameters": [
          {
            "name": "syndicNumber",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "focusVme",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "categories",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "south",
            "in": "query",
            "schema": {
              "type": "number",
              "format": "double"
            }
          },
          {
            "name": "west",
            "in": "query",
            "schema": {
              "type": "number",
              "format": "double"
            }
          },
          {
            "name": "north",
            "in": "query",
            "schema": {
              "type": "number",
              "format": "double"
            }
          },
          {
            "name": "east",
            "in": "query",
            "schema": {
              "type": "number",
              "format": "double"
            }
          },
          {
            "name": "zoom",
            "in": "query",
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          },
          {
            "name": "includeVmes",
            "in": "query",
            "schema": {
              "type": "boolean"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/streetview/{enterpriseNumber}": {
      "get": {
        "tags": [
          "Media"
        ],
        "summary": "Get cached Street View image",
        "description": "Returns a cached or freshly fetched Street View image for a VME address.",
        "operationId": "GetStreetView",
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          },
          "404": {
            "description": "Not Found"
          }
        }
      }
    },
    "/set-culture": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "culture",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "returnUrl",
            "in": "query",
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/vme/{enterpriseNumber}": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/acp/{enterpriseNumber}": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/hoa/{enterpriseNumber}": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/syndic/{enterpriseNumber}": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/syndicus/{enterpriseNumber}": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/property-manager/{enterpriseNumber}": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/robots.txt": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemap.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/public-nl.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/public-fr.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/public-en.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/public-{culture}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "culture",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/public/{culture}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "culture",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/public-{culture}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "culture",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/vmes-{culture}-{page}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "culture",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "page",
            "in": "path",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/vmes-{page}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "page",
            "in": "path",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/syndics-{culture}-{page}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "culture",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "page",
            "in": "path",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/sitemaps/syndics-{page}.xml": {
      "get": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "page",
            "in": "path",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/vme": {
      "get": {
        "tags": [
          "VME"
        ],
        "summary": "Search VMEs",
        "description": "Searches Belgian VMEs by query, region, and postal code with pagination.",
        "operationId": "SearchVmes",
        "parameters": [
          {
            "name": "q",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "region",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "zipcode",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "page",
            "in": "query",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          },
          {
            "name": "pageSize",
            "in": "query",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/vme/{enterpriseNumber}": {
      "get": {
        "tags": [
          "VME"
        ],
        "summary": "Get VME details",
        "description": "Returns a single VME profile by enterprise number.",
        "operationId": "GetVmeByEnterpriseNumber",
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/VmeSummary"
                }
              }
            }
          },
          "404": {
            "description": "Not Found"
          }
        }
      }
    },
    "/api/vme/{enterpriseNumber}/coordinates": {
      "post": {
        "tags": [
          "VME"
        ],
        "summary": "Update VME coordinates",
        "description": "Updates the registered-office latitude and longitude for a VME.",
        "operationId": "UpdateVmeCoordinates",
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "requestBody": {
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/CoordinateUpdate"
              }
            }
          },
          "required": true
        },
        "responses": {
          "200": {
            "description": "OK"
          },
          "404": {
            "description": "Not Found"
          }
        }
      }
    },
    "/api/syndics": {
      "get": {
        "tags": [
          "Syndic"
        ],
        "summary": "Search syndics",
        "description": "Searches professional or personal syndics by name, region, and portfolio size.",
        "operationId": "SearchSyndics",
        "parameters": [
          {
            "name": "q",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "region",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "minVme",
            "in": "query",
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          },
          {
            "name": "maxVme",
            "in": "query",
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          },
          {
            "name": "page",
            "in": "query",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          },
          {
            "name": "pageSize",
            "in": "query",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/syndics/{enterpriseNumber}": {
      "get": {
        "tags": [
          "Syndic"
        ],
        "summary": "Get syndic details",
        "description": "Returns a syndic profile by enterprise number, including consolidation data.",
        "operationId": "GetSyndicByEnterpriseNumber",
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/SyndicSummary"
                }
              }
            }
          },
          "404": {
            "description": "Not Found"
          }
        }
      }
    },
    "/api/syndics/{enterpriseNumber}/portfolio": {
      "get": {
        "tags": [
          "Syndic"
        ],
        "summary": "Get syndic portfolio",
        "description": "Returns the VMEs currently managed by a syndic, including inherited portfolio items.",
        "operationId": "GetSyndicPortfolio",
        "parameters": [
          {
            "name": "enterpriseNumber",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "type": "array",
                  "items": {
                    "$ref": "#/components/schemas/VmeSummary"
                  }
                }
              }
            }
          }
        }
      }
    },
    "/api/syndics/top/{count}": {
      "get": {
        "tags": [
          "Syndic"
        ],
        "summary": "Get top syndics",
        "description": "Returns the top syndic rankings by managed VME count.",
        "operationId": "GetTopSyndics",
        "parameters": [
          {
            "name": "count",
            "in": "path",
            "required": true,
            "schema": {
              "type": "integer",
              "format": "int32"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "type": "array",
                  "items": {
                    "$ref": "#/components/schemas/SyndicSummary"
                  }
                }
              }
            }
          }
        }
      }
    },
    "/api/stats/overview/live": {
      "get": {
        "tags": [
          "Stats"
        ],
        "summary": "Get live overview stats",
        "description": "Returns the live counts of VMEs, professional syndics, personal syndics, and known links.",
        "operationId": "GetLiveOverviewStats",
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/stats/overview": {
      "get": {
        "tags": [
          "Stats"
        ],
        "summary": "Get computed overview stats",
        "description": "Returns the latest computed market statistics, or falls back to live counts when unavailable.",
        "operationId": "GetOverviewStats",
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/export/vme": {
      "get": {
        "tags": [
          "Export"
        ],
        "summary": "Export VMEs as CSV",
        "description": "Exports a filtered VME dataset as CSV.",
        "operationId": "ExportVmes",
        "parameters": [
          {
            "name": "region",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "zipcode",
            "in": "query",
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/export/syndics": {
      "get": {
        "tags": [
          "Export"
        ],
        "summary": "Export syndics as CSV",
        "description": "Exports syndic portfolio summaries as CSV.",
        "operationId": "ExportSyndics",
        "parameters": [
          {
            "name": "region",
            "in": "query",
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/api/export/leads": {
      "get": {
        "tags": [
          "Export"
        ],
        "summary": "Export saved leads as CSV",
        "description": "Exports the authenticated user's saved leads as CSV.",
        "operationId": "ExportLeads",
        "responses": {
          "200": {
            "description": "OK"
          },
          "401": {
            "description": "Unauthorized"
          }
        }
      }
    },
    "/Account/PerformExternalLogin": {
      "post": {
        "tags": [
          "SyndicData"
        ],
        "requestBody": {
          "content": {
            "multipart/form-data": {
              "schema": {
                "required": [
                  "provider",
                  "returnUrl"
                ],
                "type": "object",
                "allOf": [
                  {
                    "type": "object",
                    "properties": {
                      "provider": {
                        "type": "string"
                      }
                    }
                  },
                  {
                    "type": "object",
                    "properties": {
                      "returnUrl": {
                        "type": "string"
                      }
                    }
                  }
                ]
              }
            },
            "application/x-www-form-urlencoded": {
              "schema": {
                "required": [
                  "provider",
                  "returnUrl"
                ],
                "type": "object",
                "allOf": [
                  {
                    "type": "object",
                    "properties": {
                      "provider": {
                        "type": "string"
                      }
                    }
                  },
                  {
                    "type": "object",
                    "properties": {
                      "returnUrl": {
                        "type": "string"
                      }
                    }
                  }
                ]
              }
            }
          },
          "required": true
        },
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/Account/Logout": {
      "post": {
        "tags": [
          "SyndicData"
        ],
        "requestBody": {
          "content": {
            "multipart/form-data": {
              "schema": {
                "required": [
                  "returnUrl"
                ],
                "type": "object",
                "properties": {
                  "returnUrl": {
                    "type": "string"
                  }
                }
              }
            },
            "application/x-www-form-urlencoded": {
              "schema": {
                "required": [
                  "returnUrl"
                ],
                "type": "object",
                "properties": {
                  "returnUrl": {
                    "type": "string"
                  }
                }
              }
            }
          },
          "required": true
        },
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/Account/PasskeyCreationOptions": {
      "post": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/Account/PasskeyRequestOptions": {
      "post": {
        "tags": [
          "SyndicData"
        ],
        "parameters": [
          {
            "name": "username",
            "in": "query",
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/Account/Manage/LinkExternalLogin": {
      "post": {
        "tags": [
          "SyndicData"
        ],
        "requestBody": {
          "content": {
            "multipart/form-data": {
              "schema": {
                "required": [
                  "provider"
                ],
                "type": "object",
                "properties": {
                  "provider": {
                    "type": "string"
                  }
                }
              }
            },
            "application/x-www-form-urlencoded": {
              "schema": {
                "required": [
                  "provider"
                ],
                "type": "object",
                "properties": {
                  "provider": {
                    "type": "string"
                  }
                }
              }
            }
          },
          "required": true
        },
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/Account/Manage/DownloadPersonalData": {
      "post": {
        "tags": [
          "SyndicData"
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    }
  },
  "components": {
    "schemas": {
      "CoordinateUpdate": {
        "required": [
          "latitude",
          "longitude"
        ],
        "type": "object",
        "properties": {
          "latitude": {
            "type": "number",
            "format": "double"
          },
          "longitude": {
            "type": "number",
            "format": "double"
          }
        }
      },
      "EnterpriseLink": {
        "type": "object",
        "properties": {
          "id": {
            "type": "integer",
            "format": "int32"
          },
          "sourceEnterpriseNumber": {
            "type": "string"
          },
          "targetEnterpriseNumber": {
            "type": "string"
          },
          "linkType": {
            "type": "string"
          },
          "effectiveSince": {
            "type": "string",
            "format": "date",
            "nullable": true
          },
          "sourceName": {
            "type": "string",
            "nullable": true
          },
          "targetName": {
            "type": "string",
            "nullable": true
          },
          "rawText": {
            "type": "string",
            "nullable": true
          },
          "observedAtUtc": {
            "type": "string",
            "format": "date-time"
          }
        }
      },
      "SyndicSummary": {
        "type": "object",
        "properties": {
          "enterpriseNumber": {
            "type": "string"
          },
          "name": {
            "type": "string"
          },
          "isPersonalSyndic": {
            "type": "boolean"
          },
          "street": {
            "type": "string",
            "nullable": true
          },
          "zipCode": {
            "type": "string",
            "nullable": true
          },
          "city": {
            "type": "string",
            "nullable": true
          },
          "region": {
            "type": "string"
          },
          "activeRegions": {
            "type": "array",
            "items": {
              "type": "string"
            }
          },
          "vmeCount": {
            "type": "integer",
            "format": "int32"
          },
          "aggregatedVmeCount": {
            "type": "integer",
            "format": "int32"
          },
          "directVmeCount": {
            "type": "integer",
            "format": "int32"
          },
          "inheritedVmeCount": {
            "type": "integer",
            "format": "int32"
          },
          "rank": {
            "type": "integer",
            "format": "int32"
          },
          "phone": {
            "type": "string",
            "nullable": true
          },
          "email": {
            "type": "string",
            "nullable": true
          },
          "website": {
            "type": "string",
            "nullable": true
          },
          "consolidationParentNumber": {
            "type": "string",
            "nullable": true
          },
          "consolidationParentName": {
            "type": "string",
            "nullable": true
          },
          "absorbedNumbers": {
            "type": "array",
            "items": {
              "type": "string"
            }
          },
          "absorbedLinks": {
            "type": "array",
            "items": {
              "$ref": "#/components/schemas/EnterpriseLink"
            }
          },
          "portfolio": {
            "type": "array",
            "items": {
              "$ref": "#/components/schemas/VmeSummary"
            }
          }
        }
      },
      "VmeSummary": {
        "type": "object",
        "properties": {
          "enterpriseNumber": {
            "type": "string"
          },
          "name": {
            "type": "string",
            "nullable": true
          },
          "street": {
            "type": "string",
            "nullable": true
          },
          "zipCode": {
            "type": "string",
            "nullable": true
          },
          "city": {
            "type": "string",
            "nullable": true
          },
          "region": {
            "type": "string"
          },
          "syndicEnterpriseNumber": {
            "type": "string",
            "nullable": true
          },
          "syndicName": {
            "type": "string",
            "nullable": true
          },
          "isPersonalSyndic": {
            "type": "boolean"
          },
          "syndicAppointedSince": {
            "type": "string",
            "format": "date",
            "nullable": true
          },
          "originalSyndicNumber": {
            "type": "string",
            "nullable": true
          },
          "originalSyndicName": {
            "type": "string",
            "nullable": true
          },
          "isInherited": {
            "type": "boolean"
          },
          "phone": {
            "type": "string",
            "nullable": true
          },
          "email": {
            "type": "string",
            "nullable": true
          },
          "website": {
            "type": "string",
            "nullable": true
          },
          "latitude": {
            "type": "number",
            "format": "double",
            "nullable": true
          },
          "longitude": {
            "type": "number",
            "format": "double",
            "nullable": true
          }
        }
      }
    }
  },
  "tags": [
    {
      "name": "Map"
    },
    {
      "name": "Media"
    },
    {
      "name": "SyndicData"
    },
    {
      "name": "VME"
    },
    {
      "name": "Syndic"
    },
    {
      "name": "Stats"
    },
    {
      "name": "Export"
    }
  ]
}