KI BMS

Client-Bibliotheken

Direkt einsetzbare API-Wrapper für KI BMS in Python, TypeScript, JavaScript, Go, Java, Rust, C#, C++, PHP, Ruby, Kotlin, Swift, Dart, Elixir und Clojure.

Jede Bibliothek ist eine einzelne Quelldatei, die du auf dieser Seite herunterlädst und in dein Projekt legst. Die meisten Sprachen kommen ohne weitere Abhängigkeiten aus - die Datei nutzt nur die Standardbibliothek. Rust ist die einzige Ausnahme: Füge die beiden im Datei-Header genannten Crates (reqwest + serde_json) deiner Cargo.toml hinzu, fertig. Jeder von der HTTP-API von KI BMS bereitgestellte Endpunkt ist als typisierte Funktion gekapselt, benannt nach dem Datenmodell und der Operation - die Oberfläche spiegelt damit eins zu eins die REST-API. Die Authentifizierung läuft über dieselben persönlichen Zugriffstoken wie der Rest der API. Die Bibliotheken lassen sich direkt im eigenen Code-Repo übernehmen, prüfen und erweitern.

Download

Wähle deine Sprache und lade die einzelne Quelldatei herunter. Modulname für KI BMS: ats_client. Klassenname für sprachen mit explizitem Wrapper-Typ: AtsClient.

Version: 0.3.13·Modul: ats_client·Modelle: 11
Tipps zum Einbinden je Sprache
  • PythonLege ats_client.py ins Paket; from ats_client import .... Reine Standardbibliothek (urllib.request / json / threading); setzt Python 3.8+ voraus.
  • TypeScriptLege ats_client.ts zu deinen TS-Dateien. Type-Check funktioniert mit jeder Kombination aus @types/node und DOM-Lib dank kleiner eingebauter Shims; zur Laufzeit wird fetch benutzt (Node 18+ / Browser).
  • GoLege ats_client.go in einen Ordner namens ats_client/, damit das package ats_client zum Import-Pfad passt.
  • JavaLege AtsClient.java in einen Ordner namens ats_client/, passend zur package ats_client;-Zeile in der Datei. Setzt JDK 11+ voraus; nutzt nur java.net.http.
  • RustDatei als Modul einbinden (mod ats_client; in lib.rs bzw. main.rs) und die beiden im Datei-Header genannten Crates in die Cargo.toml aufnehmen: reqwest (mit den Features blocking,json) sowie serde_json.
  • C# / .NETLege AtsClient.cs in einen beliebigen Ordner; die Datei deklariert namespace ats_client;. Setzt .NET 6+ voraus; nutzt nur HttpClient + System.Text.Json - keine NuGet-Pakete.
  • PHPrequire_once __DIR__ . '/ats_client.php' aus dem Bootstrap heraus, oder den Namespace ats_client\\ per Composer-PSR-4 autoloaden. Setzt PHP 8.0+ mit den Erweiterungen curl und json voraus (beide Standard).
  • Rubyrequire_relative 'ats_client' von beliebiger Stelle im Projekt. Die Wrapper-Klasse heisst AtsClient::Client. Setzt Ruby 3.0+ voraus; reine Standardbibliothek (net/http, json, securerandom).
  • KotlinLege AtsClient.kt in einen Ordner namens ats_client/, passend zur package ats_client-Zeile. Setzt Kotlin 1.9+ und JVM 11+ voraus; nur JDK.
  • SwiftLege AtsClient.swift zu deinen anderen Swift-Dateien. Setzt Swift 5.7+ voraus (macOS 12 / iOS 15 / Linux mit FoundationNetworking).

Authentifizieren

Erstelle ein persönliches Zugriffstoken (PAT) im Integrationen-Menü und übergib es der Bibliothek zur Laufzeit. Jede Sprache bietet dieselben zwei Wege: ein explizites setToken(...), oder die Umgebungsvariable XCLIENT_TOKEN für CI / Skripte. Tokens werden als Authorization: Bearer ... mit jeder Anfrage gesendet und niemals geloggt.

from ats_client import set_token
set_token("pat_…")
# or, equivalently:
# export XCLIENT_TOKEN=pat_…

Bibliothek einsetzen

Lege die heruntergeladene Datei in deinem Projekt als ats_client.py (bzw. die Entsprechung deiner Sprache) ab und importiere die benötigten Funktionen. Jede Funktion heisst <model>_<op> (account_create, deal_list, lead_get, ...) und ruft den passenden HTTP-Endpunkt auf, inklusive Retry bei 429, exponentiellem Backoff und automatischem Beachten des Retry-After-Headers. Listen-Funktionen akzeptieren die üblichen Query-Parameter (limit, offset, sort, q sowie die für den Typ erlaubten Filter); get/update/delete-Funktionen erwarten die Datensatz-ID als erstes Argument.

from ats_client import application_list, application_get, application_create, application_update, application_delete
# Erste 20 Datensätze
page = application_list(limit=20, sort="-created_at")
print(page["data"], page["meta"]["has_more"])
# Anlegen + Lesen + Ändern + Löschen
created = application_create({"name": "Example"})
fresh = application_get(created["id"])
application_update(created["id"], {"name": "Updated"})
application_delete(created["id"])

Verfügbare Modelle

Jede Bibliothek liefert eine Funktion pro Operation und Modell. Die Liste unten ist die Eins-zu-eins-Spiegelung der HTTP-Endpunkte für diese App.

ModellFunktionen
application
application_listapplication_getapplication_createapplication_updateapplication_delete
application_note
application_note_listapplication_note_getapplication_note_createapplication_note_updateapplication_note_delete
candidate
candidate_listcandidate_getcandidate_createcandidate_updatecandidate_delete
email_template
email_template_listemail_template_getemail_template_createemail_template_updateemail_template_delete
evaluation
evaluation_listevaluation_getevaluation_createevaluation_updateevaluation_delete
interview
interview_listinterview_getinterview_createinterview_updateinterview_delete
job
job_listjob_getjob_createjob_updatejob_delete
message
message_listmessage_getmessage_createmessage_updatemessage_delete
offer
offer_listoffer_getoffer_createoffer_updateoffer_delete
source
source_listsource_getsource_createsource_updatesource_delete
task
task_listtask_gettask_createtask_updatetask_delete

Umgebungsvariablen

VariableZweck
XCLIENT_TOKENPersönliches Zugriffstoken für alle API-Aufrufe.
XCLIENT_BASE_URLEingebettete Server-URL überschreiben (nur für Tests).

Analyse + Updates

Jeder Aufruf sendet ein Analyse-Event ans gleiche Dashboard wie die Web-UI (Operations-Name, Bibliotheksversion, OS - keine Feldwerte, keine Request-Bodies), damit das Team, das diese App betreibt, die Nutzung der Integration sieht. Die Daten werden sicher verarbeitet; ein Audit-Log aller dich betreffenden Events kann jederzeit beim Anbieter dieser App angefragt werden. Zusätzlich prüft die Bibliothek höchstens alle 24 Stunden auf eine neuere Version. In interpretierten Sprachen (Python, TypeScript unter Node, JavaScript unter Node, PHP, Ruby, Elixir) wird die Datei auf der Platte atomar ersetzt; der nächste Import lädt die neuen Bytes. In kompilierten Sprachen (Go, Java, Rust, C#, C++, Kotlin, Swift, Dart, Clojure) bleibt die Quelldatei unverändert - dort werden vorkompilierte Artefakte ausgeliefert, also stempelt der Versions-Probe nur einen Zeitstempel, den du beim Build sichtbar machen kannst. Mit XCLIENT_NO_AUTOUPDATE=1 lässt sich die Prüfung komplett abschalten.