> ## Documentation Index
> Fetch the complete documentation index at: https://docs.business-os.de/llms.txt
> Use this file to discover all available pages before exploring further.

# Mandanten und aktive Services

> Listet alle Mandanten (Companies), die unter der angegebenen DATEV-Verbindung verfügbar sind, samt der je Mandant aktiven Service-Subscriptions (z. B. *Belegbilderservice*, *Rechnungsdatenservice 1.0*, *DATEV Rechnungswesen-Exportservice*).

**Kosten:** 1 Credit pro Aufruf



## OpenAPI

````yaml GET /v2/datev/companies
openapi: 3.1.0
info:
  title: Business OS API
  description: >-
    API für Business OS – Zugang zu DATEV und Banking Enterprise-Schnittstellen.
    Alle Endpoints erfordern einen API Key im `x-api-key` Header. Credits werden
    pro API-Call abgezogen.
  version: 2.0.0
  contact:
    name: Business OS Support
    email: impressum@business-os.de
    url: https://business-os.de/kontakt
servers:
  - url: https://api.business-os.de
    description: Production
security:
  - ApiKeyAuth: []
tags:
  - name: DATEV Allgemein
    description: >-
      Modulübergreifende DATEV-Endpunkte (z. B. Abo-/Service-Diagnose für
      Mandanten)
  - name: DATEV DUO
    description: DATEV Unternehmen Online — Kassenbuch, Belegbilder und Buchungsvorschläge
  - name: DATEV ReWe - Write
    description: 'DATEV Rechnungswesen — Write: Buchungen, Kontakte, Belegtypen, Steuersätze'
  - name: DATEV ReWe - Read
    description: >-
      DATEV Rechnungswesen — Read (Export): Geschäftsjahre und weitere
      Lesemodule
  - name: Banking AIS
    description: >-
      Account Information Services — Verbindungen, Kontostände und Transaktionen
      verwalten
  - name: Banking PIS
    description: Payment Initiation Services — Zahlungen ausführen und Status abrufen
  - name: Banking Webhooks
    description: Webhook-Konfiguration für Echtzeit-Benachrichtigungen
paths:
  /v2/datev/companies:
    get:
      tags:
        - DATEV Allgemein
      summary: Mandanten und aktive DATEV-Services
      description: >-
        Listet alle Mandanten (Companies), die unter der angegebenen
        DATEV-Verbindung verfügbar sind, samt der je Mandant aktiven
        Service-Subscriptions (z. B. *Belegbilderservice*,
        *Rechnungsdatenservice 1.0*, *DATEV Rechnungswesen-Exportservice*).


        **Kosten:** 1 Credit pro Aufruf
      parameters:
        - $ref: '#/components/parameters/ConnectionIdParam'
        - $ref: '#/components/parameters/CreditQuelleParam'
      responses:
        '200':
          description: Liste der Mandanten und deren Service-Subscriptions
          content:
            application/json:
              schema:
                type: object
                properties:
                  data:
                    type: array
                    items:
                      type: object
                      properties:
                        id:
                          type: string
                          description: Mandant-ID in der Form `<Berater-Nr>-<Mandanten-Nr>`
                          example: 122130-13170
                        name:
                          type: string
                          description: Name des Mandanten
                          example: Mustermann GmbH
                        client_number:
                          type: integer
                          description: DATEV-Mandanten-Nummer
                          example: 13170
                        consultant_number:
                          type: integer
                          description: DATEV-Berater-Nummer
                          example: 122130
                        environmentId:
                          type: string
                          nullable: true
                          description: Umgebungs-ID (sofern von DATEV gesetzt)
                        subscription:
                          type: array
                          description: Pro Mandant gebuchte DATEV-Services.
                          items:
                            type: object
                            properties:
                              id:
                                type: string
                                nullable: true
                                description: Subscription-ID, falls von DATEV gesetzt
                              name:
                                type: string
                                description: >-
                                  Originalname des Services (von DATEV
                                  unverändert übernommen)
                                example: Belegbilderservice
                              status:
                                type: string
                                nullable: true
                                description: Status-Code des Services, falls gesetzt
                              active:
                                type: boolean
                                description: True, wenn der Service aktiv abonniert ist
              example:
                data:
                  - subscription:
                      - id: null
                        name: Belegbilderservice
                        status: null
                        active: true
                      - id: null
                        name: Rechnungsdatenservice 1.0
                        status: null
                        active: true
                    id: 122130-13170
                    client_number: 13170
                    consultant_number: 122130
                    environmentId: null
                    name: Mustermann GmbH
        '400':
          description: Fehlender oder ungültiger Query-Parameter (z. B. `connectionId`).
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/DatevError'
              example:
                error: connectionId query parameter ist erforderlich.
        '401':
          $ref: '#/components/responses/DatevUnauthorized'
        '402':
          $ref: '#/components/responses/DatevPaymentRequired'
        '404':
          $ref: '#/components/responses/DatevNoConnection404'
        '500':
          $ref: '#/components/responses/DatevInternal500'
        default:
          $ref: '#/components/responses/DatevServiceError'
components:
  parameters:
    ConnectionIdParam:
      name: connectionId
      in: query
      required: true
      schema:
        type: string
        format: uuid
        example: abbc18fd-ba5e-4dfd-afc4-9dec0c0ad145
      description: >-
        UUID der DATEV-Verbindung. Abrufbar über den `/connections`-Endpunkt des
        jeweiligen Moduls (z. B. `GET /v2/datev-duo/connections`).
    CreditQuelleParam:
      name: quelle
      in: query
      required: false
      schema:
        type: string
        default: API
        example: Make
      description: >-
        Kennzeichnung der Aufrufquelle für die Nutzungsanalyse. Standard bei
        Weglassen: `API` (direkter API-Aufruf). Für Automationen aus Make z. B.
        `Make` angeben.
  schemas:
    DatevError:
      type: object
      description: >-
        JSON-Fehlerantwort. Bei Fehlern der DATEV-Schnittstelle kann zusätzlich
        `details` gesetzt sein. Bei bekannten Fehlerkategorien ist ein stabiler
        `code` gesetzt, anhand dessen Automatisierungen reagieren können.
      required:
        - error
      properties:
        error:
          type: string
          description: Fehlermeldung
        message:
          type: string
          description: >-
            Zusätzliche Erläuterung; wenn der Header `x-api-key` fehlt: Hinweis
            zur erforderlichen Header-Zeile.
        code:
          type: string
          description: >-
            Stabiler, maschinenlesbarer Fehlercode für bekannte
            Fehlerkategorien. Wird nur gesetzt, wenn die Ursache eindeutig
            erkannt wurde.


            - `datev_connection_invalid`: Account-Key ist abgelaufen oder
            widerrufen — Reconnect über das Dashboard nötig. Begleitet von
            `reconnectUrl`.

            - `datev_export_service_missing`: Mandant hat keine relevante
            DATEV-Subscription gebucht (z. B. Belegbilderservice,
            Rechnungsdatenservice, Datenservice Export Rechnungswesen-Familie).
            Begleitet von `activeSubscriptions` mit der Liste der tatsächlich
            aktiven Services.

            - `datev_endpoint_not_authorized`: Subscription am Mandanten ist
            vorhanden und der Token gilt, aber das DATEV-RVO-Schreib-/Leserecht
            für den konkreten Endpoint fehlt für den authentifizierten Nutzer.
            Reconnect hilft hier nicht — der Steuerberater/Mandant-Inhaber muss
            in DATEV RVO das entsprechende Teilrecht freischalten.
          enum:
            - datev_connection_invalid
            - datev_export_service_missing
            - datev_endpoint_not_authorized
        reconnectUrl:
          type: string
          format: uri
          description: >-
            URL zum Business OS Dashboard, über die der Nutzer die
            DATEV-Verbindung erneuern kann. Gesetzt bei `code =
            datev_connection_invalid`.
        activeSubscriptions:
          type: array
          items:
            type: string
          description: >-
            Liste der aktuell aktiven DATEV-Service-Subscriptions des Mandanten
            (z. B. Belegbilderservice, Rechnungsdatenservice 1.0). Gesetzt bei
            `code = datev_export_service_missing`, damit Automationen erkennen,
            welche Services bereits gebucht sind.
        details:
          type: object
          description: >-
            Strukturierte Zusatzinformationen bei Antworten der
            DATEV-Schnittstelle.
          additionalProperties: true
  responses:
    DatevUnauthorized:
      description: >-
        API-Key fehlt, ist ungültig, widerrufen oder abgelaufen. Fehlt der
        Header `x-api-key`, enthält die Antwort zusätzlich `message`.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/DatevError'
          examples:
            ungueltigerKey:
              summary: Ungültiger oder unbekannter Key
              value:
                error: Ungültiger API-Key
            fehlenderHeader:
              summary: Fehlender x-api-key Header
              value:
                error: Fehlende Header
                message: x-api-key Header ist erforderlich.
    DatevPaymentRequired:
      description: Nicht genügend Credits für diesen Aufruf.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/DatevError'
          example:
            error: Nicht genügend Credits
    DatevNoConnection404:
      description: >-
        Es ist keine gespeicherte DATEV-Verbindung für die Organisation
        vorhanden. Der Text in `error` nennt das gewählte DATEV-Produkt (z. B.
        DATEV Unternehmen Online).
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/DatevError'
          example:
            error: Keine Verbindung gefunden für DATEV Unternehmen Online
    DatevInternal500:
      description: >-
        Unerwarteter Serverfehler oder fehlende Serverkonfiguration für den
        DATEV-Dienst.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/DatevError'
          example:
            error: API-Dienst nicht konfiguriert.
    DatevServiceError:
      description: >-
        Fehlerantwort der DATEV-Schnittstelle (HTTP-Status entspricht der
        DATEV-Antwort). Der Body enthält `error` und optional `details` mit
        Zusatzinformationen. Bei 403 wegen fehlendem DATEV
        Rechnungswesen-Exportservice ist zusätzlich `code =
        datev_export_service_missing` und `activeSubscriptions` gesetzt.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/DatevError'
          examples:
            mitDetails:
              summary: Beispiel mit details
              value:
                error: Validierung fehlgeschlagen
                details:
                  message: …
            exportserviceFehlt:
              summary: 403 – DATEV Rechnungswesen-Exportservice nicht abonniert
              value:
                error: >-
                  DATEV Rechnungswesen-Exportservice ist für diesen Mandanten
                  nicht abonniert. Aktive Services: Belegbilderservice,
                  Rechnungsdatenservice 1.0. Bitte den Service über DATEV beim
                  Mandant aktivieren.
                code: datev_export_service_missing
                activeSubscriptions:
                  - Belegbilderservice
                  - Rechnungsdatenservice 1.0
                details:
                  errors:
                    - message: 'RVO-Recht fehlt: Stammdaten'
            verbindungUngueltig:
              summary: 401 – DATEV-Verbindung ungültig (zur Referenz)
              value:
                error: >-
                  Die DATEV-Verbindung ist ungültig oder abgelaufen. Bitte im
                  Business OS Dashboard die Verbindung erneuern.
                code: datev_connection_invalid
                reconnectUrl: https://app.business-os.de/
  securitySchemes:
    ApiKeyAuth:
      type: apiKey
      in: header
      name: x-api-key
      description: >-
        Dein Business OS API Key. Erstelle einen unter
        [app.business-os.de](https://app.business-os.de/) → API Keys.

````