
Die UI API (User-Interface-API, Bibliothek SAPbouiCOM.dll) ist die COM-basierte Programmierschnittstelle des SAP-Business-One-Clients. Sie erlaubt Add-ons, die laufende SAP-Oberfläche zu erweitern: Formulare hinzufügen, Felder und Buttons einfügen, Menüs erweitern, Benutzerinteraktionen abfangen und auf Events wie ItemEvent, FormDataEvent oder MenuEvent reagieren.
Kontext
Ein UI-API-Add-on läuft als eigener Prozess neben dem SAP-Client und verbindet sich über die SboGuiApi-Bridge mit der laufenden Instanz. Über das Objektmodell Forms, Items, DataSources lassen sich sowohl Standard-Formulare modifizieren (z.B. neue Reiter auf der Verkaufsrechnung) als auch komplette Eigen-Formulare als fixed, document type oder user defined object registrieren. Kombiniert wird die UI API fast immer mit der DI API, weil die UI API zwar Eingaben einsammelt, aber keine Geschäftslogik besitzt: Buchungen, Validierungen gegen Stammdaten und das Speichern von Belegen laufen über DI-API-Objekte. Frameworks wie das VerXs Framework der Versino Financial Suite oder Coresuite Customize kapseln die UI API, um Connection Pooling, Event-Filter per Lambda-Prädikat und Thread-Safety zu vereinfachen.
Abgrenzung
Die UI API ist ausschließlich für den Windows-Client relevant; die SAP Business One Web Client-Oberfläche wird über eine eigene Extensibility-Architektur erweitert und nicht über SAPbouiCOM. Anders als DI API oder Service Layer ist die UI API keine Daten-, sondern eine Oberflächenschnittstelle — sie liest und schreibt nicht direkt in die Datenbank, sondern nimmt Eingaben entgegen und löst SAP-interne Aktionen aus. Server-seitige Jobs, Webhooks oder Integrationen ohne sichtbare Oberfläche nutzen deshalb DI API, Service Layer oder B1if statt der UI API.
Warum Unternehmen bei KI im ERP zögern
Predictive Maintenance: Wie den Mittelstand zur intelligenten Fabrik macht
RPA im ERP-Umfeld: Effizienzsteigerung durch digitale Prozesshelfer
Generative KI im ERP: Wie LLMs die Rolle von ERP-Systemen verändern
Mit APIs und Microservices die ERP-Zukunft vorbereiten