profacto bietet einen token-gesicherten Zugriff auf ausgewählte Tabellen, Felder und Felder Funktionen mit sehr flexibler Architektur. Bei Wünschen für zusätzliche Tabellen, API-Sets, bestimmte Funktionen oder als externer Entwickler sprich mit einem größeren Projekt, um größere Zusammenhänge und Prozesse mit profacto digital zu integrieren: sprich uns gerne an.
Inhalt |
---|
Untergeordnete Seiten (Anzeige untergeordneter Seiten) |
---|
...
Folgende APIs sind bereits für alle kostenpflichtigen profacto-Versionen zugänglich:
- Integration
- Zeiterfassung
- Produktion
- Kontakte
- Kunden
- Aktivitäten
- Lieferanten
- Projekte
- Artikel
- Personal
- Lager
- Bestellung
- Dateien
- Administration
- API Pinger (rein technischer Zugriff zu Testzwecken von Entwicklern)
Diese APIs befinden sich Nur für die Standard-Version von profacto sind diese APIs verfügbar:
- Produktion sowie ProduktionSchreiben
- Kontakte sowie KontakteSchreiben
- Kunden sowie KundenSchreiben
- Aktivitäten sowie AktivitätenSchreiben
- Lieferanten sowie LieferantenSchreiben
- Projekte sowie ProjekteSchreiben
- Artikel sowie ArtikelSchreiben
- Personal sowie PersonalSchreiben
- Lager
- Bestellung sowie BestellungSchreiben
- Dateien
- Buchhaltung
- Kalkulation
- Konstanten
Diese APIs befinden sich weiterhin im Aufbau, der sich nach aktuellen Anforderungen richtet.
Dazu gehört, daß man bestimmten Mitarbeitern (ein Personal-Datensatz ist Voraussetzung) ein Token gibt, mit dem der Zugriff gewährt, aber eben auch zeitlich limitiert oder entzogen werden kann.
Zugriff
In den Voreinstellungen, profacto Administration werden die Tokens vergeben.
Der Schlüssel öffnet die Token-Vergabe.
Die WAN-Server-Adresse muß hinterlegt werden, um für die OTA-Integration eine spezielle Konfigurationsdatei zu erzeugen oder andere externe API-Zugriffe auf profacto zu ermöglichen.
. Seit profacto 2024.1 differenzieren wir dort, wo eine entsprechende Funktion zur Verfügfung steht, zwischen Lesetoken und Schreibtoken. Dies erlaubt es, Mitarbeitern Leserechte auf bestimmte Tabellen zu gewähren, nicht aber das Recht, diese Daten auch zu modifizieren. Da die APIs inzwischen sehr leistungsfähig sind und durchaus auch außerhalb des lokalen Netzwerks eingesetzt werden können, erhöht diese Maßnahme die Zugriffssicherheit auf Ihre Daten.
Dazu gehört, daß man bestimmten Mitarbeitern (ein Personal-Datensatz ist Voraussetzung) ein Token gibt, mit dem der Zugriff gewährt, aber eben auch zeitlich limitiert oder entzogen werden kann.
Zugriff
In den Voreinstellungen, profacto API und OTA werden die Tokens vergeben.
Das eindeutige Token wird einer Personalnummer wie ein Fingerabdruck zugeordnet und danach der gewünschten API. Für diverse APIs muß man auch verschiedene Tokens erstellen. Standard ist eine Laufzeit von 5 Jahren, die email dient dazu es auch direkt übermitteln zu können.
Mittels Token wird zugleich identifiziert, welche API von wem aufgerufen wird.Das Token kopieren Sie im Zweifelsfall einfach heraus
Hinweis |
---|
“token is invalid” hier handelt sich um einen Hinweis, der darauf aufmerksam machen möchte, dass die Voreintellungen noch göffnet sind. Bitte Diese Schließen und den Link (Token) nochmal laden. |
Entwickler-Paket
Info | ||
---|---|---|
| ||
Du hast eine Idee die profacto API für Deine Firma zu nutzen und möchtest jemanden beauftragen es zu entwicklen? Du bist selbständiger Entwickler und möchtest die profacto API in deine App integrieren? Dann sind die folgenden Infos der Startpunkt. |
...
Wir stellen gerne den Kontakt zu Entwicklern her. |
Für Entwickler stellen wir gerne eine profacto Lizenz und Entwicklungsumgebung bereit.
macOS: profacto Installer
Windows: profacto Installer
Die zugehörige Lizenz und Zugang zum API-Netzwerk mit Kunden und anderen Entwicklern stellen wir dir gerne auf Anfrage bereit: am besten gleich das hier verlinkte FairUseAgreement profactoDeveloper vorausgefüllt mitsenden bereit.
Auf GitHub stellen wir einerseits HTML-Templates und auch Scripts zum Zugriff auf die API bereit.
Wenn du dort eigene Scripte der Öffentlichkeit zur Verfügung stellen möchtest, ist das herzlich willkommen und wir unterstützen den Austausch dazu sehr gerne. Das ganze wird Die Scripts und Templates werden unter der MIT-Lizenz verfügbar gemacht.
...
Symbole zum Vergleichen von Attribut und Value. Es gibt folgende Symbole:
Vergleich Symbol(e) Kommentar Ist gleich =, == Erhält passende Daten, unterstützt den Joker @, berücksichtigt weder Groß- und Kleinschreibung noch diakritische Zeichen. ===, IS Erhält passende Daten, bewertet @ als Standardzeichen und nicht als Joker, berücksichtigt weder Groß- und Kleinschreibung noch diakritische Zeichen. Ungleich zu #, != unterstützt den Joker (@) !==, IS NOT bewertet @ als Standardzeichen und nicht als Joker Kleiner als < Größer als > Kleiner als oder gleich <= Größer als oder gleich >= Enthalten in IN Erhält Daten, die mit mindestens einem Wert in einer Collection bzw. einem Satz Werte übereinstimmt Nicht enthalten in einer Anweisung NOT Klammern sind zwingend, wenn NOT vor einer Anweisung mit mehreren Operatoren verwendet wird Enthält Schlüsselwort % Schlüsselwörter lassen sich in Attributen vom Typ String oder Bild verwenden - Value: Wert zum Vergleichen mit dem aktuellen Wert der Eigenschaft.
Für eine Suche nach einem String innerhalb eines anderen String (eine Suche "Enthalten in") verwenden Sie den Joker (@) in value, um den zu suchenden String zu isolieren, zum Beispiel: "@Schmi@", um alle Schmid, Schmied, Schmitt und so weiter zu finden. - Für numerische Werte dient Punkt als Dezimaltrenner.
- Datumsangeben müssen im Format "YYYY-MM-DD" sein.
Bei einer Suche mit einem IN Vergleichsoperator muss value eine Collection sein bzw. Werte, die zum Typ des Attributspfads zwischen eckigen Klammern [] passen, getrennt durch Kommas (bei Strings müssen Anführungszeichen " mit "\" abschließen). LogicalOperator: verbindet mehrere Bedingungen in der Suche (optional). Es gibt folgende logische Operatoren (Sie können Name oder Symbol übergeben):
Konjunktion Symbol(e) AND &, &&, and OR |, ||, or - order by Attribut: Sie können eine Anweisung order by Attribute in der Suche hinzufügen, so dass die Ergebniswerte sortiert werden. Sie können mehrere Sortieranweisungen, durch Komma getrennt, verwenden, (z.B. order by Attribut1 desc, Attribut2 asc). Die Sortierung ist standardmäßig aufsteigend. Übergeben Sie 'desc' für absteigende Reihenfolge und 'asc' für aufsteigende Reihenfolge
Die Tabellen- und Feldnamen für table und fields müssen nicht exakt der Groß-Kleinschreibung der Struktur folgen, für query ist dies jedoch zwingend.
Ausgabe der Daten
Info | ||
---|---|---|
| ||
Suchen Sie Strings, die Leerzeichen enthalten, müssen Sie diese mit hochgestellten einzelnen Anführungszeichen kapseln, um zu verhindern, dass intern der Suchstring falsch interpretiert wird. |
Ausgabe der Daten
Die Daten werden als JSON-String zurückgegeben.
...
Man sieht, daß trotzdem alle zulässigen Felder unterstützt werden, die Abfrage deswegen nicht komplett scheitert.
Beispiel api_get mit Bestellungen
Um sich alle Bestellungen abzuholen benötigt man einen Token für Bestellungen, die Tabelle Bestellungen und die auszugebenden Felder.
http://meinserver:8080/4DAction/api_get?token=C900BFE22DFF4B75917837006E247932&table=Bestellung&fields=BestellNr,Kurzbez,Bestelldatum,Bemerkung
Als Resultat erhält man alle Bestellungen die mit dem Token zugänglich sind:
"{"Error":[],"Bestellung":[{"BestellNr":130001,"Kurzbez":"WHG-Ahmerkamp GmbH - Warendorf","Bestelldatum":"0000-00-00","Bemerkung":""},{"BestellNr":130002,"Kurzbez":"Holzma - Calw-Holzbronn","Bestelldatum":"2015-07-08","Bemerkung":"\\rNeues Bauabnahmedatum: 07.07.15"}],"error":"finished"}"
Standard-Felder für die Tabelle "Bestellung" (Werden keine Felder angegeben, werden die Folgenden automatisch als Abruf-Felder bestimmt)
BestellNr, Bestelldatum, AuftragsNr
Verbotene Felder für das Abrufen der Tabelle "Bestellung"
PKUUID_104
Beispiel api_get mit Bestellpositionen
Das vorher gegangene Beispiel mit den Bestellungen nutzen wir um die Bestellpositionen für eine Bestellung abzurufen.
Dafür müssen wir den Parameter query dem API-Aufruf mitgeben. An dieser Stelle möchten wir alle Bestellpositionen für die Bestellung mit der BestellNr. 130076 abrufen.
Wir ändern die Tabelle auf BestellPos und suchen uns die entsprechenden Felder die wir in unserer Response ausgegeben bekommen möchten (e.g. BestellNr, ArtikelNr,Bestellmenge).
http://meinserver:8080/4DAction/api_get?token=C900BFE22DFF4B75917837006E247932&query=BestellNr=130076&table=BestellPos&fields=BestellNr,ArtikelNr,BestellMenge
Wir erhalten die dazugehörigen Positionen in einem JSON-Objekt:
{"Error":[],"BestellPos":[{"BestellNr":130076,"ArtikelNr":"KF-AH-19","BestellMenge":32},{"BestellNr":130076,"ArtikelNr":"KF-AH-19","BestellMenge":2}],"error":"finished"}
Standard-Felder für die Tabelle "BestellPos" (Werden keine Felder angegeben, werden die Folgenden automatisch als Abruf-Felder bestimmt)
BestellNr, ArtikelNr, LfdNr
BestellNr, ArtikelNr, LfdNr
Pagination
Mittels der Pagination kann man sich die Daten in einzelnen Blöcken darstellen lassen.
Dafür werden die Parameter zum api_get-Befehl übergeben:
Parameter | Format | Default |
---|---|---|
offset | Integer | 0 |
limit | Integer | 0 |
offset definiert ab welchem Datensatz weitergelesen werden soll
limit wiederum begrenzt die Anzahl der Datensätze die ausgegeben werden sollen
Da jeder neue Abschnitt auch die Daten neu liest kann es zu Verschiebungen kommen, wenn im Verlauf einer Abfrage Daten in einer bestimmten Ordnung hinzugefügt oder gelöscht werden.
In der Rückmeldung wird immer angeben, wieviele records vorhanden sind:
{"total_in_query":25,"offset":0} - wenn es weder limit noch offset gab
{"total_in_query":25,"offset":25,"total_in_page":0} - wenn limit und offset angegeben waren.
Werte, die nicht erfüllt werden können, werden dabei ohne Fehlermeldung auf das mögliche reduziert, was ggf. auch in einer leeren Rückgabe münden kann.
Fehlermeldungen
"error":"" - immer am Anfang der JSON-Response
"errorMsg":"" - immer am Ende der JSON-Response
"structure_access_info":[] - vor den Nutzdaten
Neue Daten schreiben mit api_put_*
...
update - Werte: True oder False. Regelt, ob ein vorhandener Datensatz aktualisiert werden soll oder nicht. Bei Neuanlage kann dieses Flag weggelassen werden.
response - Werte: HTML oder JSON. Regelt, ob die Rückmeldung als HTML-Seite oder als JSON-Objekt erfolgen soll. Lassen Sie dieses Flag weg, wird JSON rückgeliefert.response
Exklusiv für api_put_bestellpos und api_put_projectpos:
append - Werte: HTML True oder JSONFalse. Regelt, ob die Rückmeldung als HTML-Seite oder als JSON-Objekt erfolgen soll. Lassen Sie dieses Flag weg, wird JSON rückgeliefertBestimmt ob die gegenwärtige Positionsnummer hochgezählt werden soll, ist das der Fall gibt man bei Positionsnummer (api_put_projectpos) bzw. LfdNr (api_put_bestellpos) 0 an.
Ausgeschlossene Parameter:
...