Serviceauftrags-Open-API-Entwicklerhandbuch
Verwenden Sie die Service Order Open API, um Serviceauftragsinformationen zu erstellen, zu aktualisieren und abzurufen.
Dieser Entwicklerleitfaden enthält Informationen zum Erweitern von Serviceauftrags-OpenAPI, um verschiedene Anpassungen vorzunehmen.
Erweiterung der Service Order Open API
Die Service Order Open API kann durch Bearbeiten von Skripteinbindungen erweitert werden.
- TMFServiceOrderAPIUtil: Enthält Funktionen zur Verarbeitung von POST-Anforderungen.
- TMFServiceOrderGetAPIUtil: Enthält Funktionen zur Verarbeitung von GET-Anforderungen.
- ServiceOrderExtensionOOB: Enthält Hilfsfunktionen, die Funktionen in TMFServiceOrderAPIUtil und TMFServiceOrderGetAPIUtilunterstützen.
- ServiceOrderProcessor: Eine leere Skripteinbindungsdatei. Verwenden Sie diese Datei, um alle Funktionen zu definieren, die Sie in ServiceOrderExtensionOOBüberschreiben möchten.
Erweitern Sie die Service Order Open API, um die folgenden Anpassungen vorzunehmen.
Erforderliche Parameter
Um zu ändern, welche Anforderungstextparameter zum Erstellen eines Serviceauftrags erforderlich oder nicht erforderlich sind, überschreiben Sie die Funktion getServiceOrderSchema(), die in der Skripteinbindung ServiceOrderExtensionOOB enthalten ist.
Die Funktion getServiceOrderSchema() liest das Schema aus der Skripteinbindung TMFOrderAPIConstants. „TMFOrderAPIConstants“ ist geschützt und kann nicht bearbeitet werden. Sie können also nicht einfach das Schema aktualisieren. Stattdessen muss ein neues Schema aus einer anderen Datei gelesen werden. Sie können getServiceOrderSchema() überschreiben, um ein neues Schema zu lesen. Um getServiceOrderSchema()zu überschreiben, schreiben Sie eine Funktion mit demselben Namen in der Skripteinbindung ServiceOrderProcessor. Die neue Funktion in ServiceOrderProcessor wird von TMFServiceOrderAPIUtil aufgerufen, um die Standardfunktion getServiceOrderSchema() in ServiceOrderExtensionOOBzu ersetzen.
getServiceOrderSchema() ein anwenderdefiniertes Schema zurück, das in einer neuen Konstantendatei definiert ist. // ServiceOrderProcessor
var ServiceOrderProcessor = Class.create();
ServiceOrderProcessor.prototype = Object.extendsObject(ServiceOrderExtensionOOB, {
// Define overriding functions here
// Function name and parameters must be identical to the function it overrides
getServiceOrderSchema: function() {
//Define your own custom schema in a new constant file
return JSON.parse(Constants.SCHEMA.CREATE_SERVICE_ORDER);
},
type: 'ServiceOrderProcessor'
});Validierung des Anforderungstexts
„true“ zurückgeben.validPostRequest(): Wird vonprocessPostOrder()in TMFServiceOrderAPIUtilaufgerufen.validServiceObj(): Wird vonprocessPostOrder()in TMFServiceOrderAPIUtilaufgerufen.validRelatedPartyObj(): Wird vonprocessPostOrder()in TMFServiceOrderAPIUtilaufgerufen.validGetRequest(): Wird vonprocessGetOrder()in TMFServiceOrderGetAPIUtilaufgerufen.
„false“zurückgibt, wird der API-Vorgang beendet. Um eine anwenderdefinierte Validierung anzuwenden, überschreiben Sie die ServiceOrderExtensionOOB- Hilfsfunktionen, indem Sie Funktionen mit identischen Namen und Parametern in ServiceOrderProcessorerstellen. Diese neuen ServiceOrderProcessor- Funktionen werden von „TMFServiceOrderAPIUtil“ und „TMFServiceOrderGetAPIUtil“ aufgerufen, um die standardmäßigen ServiceOrderExtensionOOB- Hilfsfunktionen zu ersetzen.// ServiceOrderProcessor
var ServiceOrderProcessor = Class.create();
ServiceOrderProcessor.prototype = Object.extendsObject(ServiceOrderExtensionOOB, {
// Define overriding functions here
// Function name and parameters must be identical to the function it overrides
validatePostRequest: function(orderObject, details) {
// Returning false terminates the POST request
// Make sure to push error message in details array in case of error
if (gs.nil(orderObject.serviceOrderItem)) {
details.push(new TMFCommonOrderAPIUtil().getErrorDetailsObj(TMFOrderAPIConstants.MESSAGES.MISSING_ORDER_ITEM, '/'));
return false;
}
return true;
},
type: 'ServiceOrderProcessor'
});Zusätzliche REST-Vorgänge
Um zusätzliche Vorgänge zu erstellen, die über die vorhandenen GET- und POST-Vorgänge hinausgehen, erstellen Sie zusätzliche geskriptete REST-Ressourcen für die Service Order Open API. Die Logik der neuen geskripteten REST-Ressourcen sollte mit den vorhandenen Vorgängen übereinstimmen. Definieren Sie Funktionen für die neuen Vorgänge in einer neuen Skripteinbindung.
Feldzuordnung
Beim Erstellen von Datensätzen ordnet die API Anforderungstextparameter Datensatzfeldern zu. Beim Abrufen von Datensätzen ordnet die API Datensatzfelder Antwortobjektattributen zu.
transformOrderGr ()transformOrdLineItemGr ()transformCustLineItmContact ()transformOrderItemChar ()
transformPostOrderResponse()transformGetOrderResponse ()transformServiceObj ()transformZugehörigeparteiKundenpositionElement ()transformOrderItemBeziehung ()transformGetOrdLineItmResponse()umwandelnServicemerkmale()transformServiceSpecification()
Passen Sie Feldzuordnungen an, um Daten für zusätzliche Felder hinzuzufügen und abzurufen oder um die Standardzuordnungen für Felder zu ändern. Um die Feldzuordnungen anzupassen, überschreiben Sie die Zuordnungsfunktionen für ServiceOrderExtensionOOB, indem Sie Funktionen mit identischen Namen und Parametern in ServiceOrderProcessorerstellen. Diese neuen ServiceOrderProcessor- Funktionen werden von „TMFServiceOrderAPIUtil“ und „TMFServiceOrderGetAPIUtil“ verwendet, um die standardmäßigen ServiceOrderExtensionOOB- Zuordnungsfunktionen zu ersetzen.
// ServiceOrderProcessor
var ServiceOrderProcessor = Class.create();
ServiceOrderProcessor.prototype = Object.extendsObject(ServiceOrderExtensionOOB, {
// Define overriding functions here
// Function name and parameters must be identical to the function it overrides
transformOrderGr: function(requestObject, orderGr) {
orderGr.external_id = requestObject.externalId;
return orderGr;
},
transformPostOrderResponse: function(orderObject, orderGr) {
orderObject.id = orderGr.getValue('sys_id');
return orderObject;
},
type: 'ServiceOrderProcessor'
});