Benutzer-Werkzeuge

Webseiten-Werkzeuge


engine:procedures:mi_modifyapplicpartstree_ad

mi_ModifyApplicPartsTree_Ad

Erstellt, verschiebt oder löscht ein Element im „Anwendungs-Baum“. Damit ist die hierarchische Struktur von Teilen einer registrierten „dStore-Anwendung“ (s. mi_GetApplications_Ad bzw. mi_GetApplicationParts_Ad) gemeint.

Anmerkungen :
1.) Soll eine Element verschoben werden, d.h. soll „ApplicationPartTreeID“ als neuen Vorgänger das Element „PredecessorApplicPartTreeID“ bekommen, darf es sich bei dem neuen Vorgänger nicht etwa um ein Nachfolge-Element von „ApplicationPartTreeID“ handeln oder gar um das Element „ApplicationPartTreeID“ selbst (sonst gibt es den Fehler „-500“) !
2.) Außerdem ist es verboten, ein „root“-Element zu verschieben !

HTTP-MethodPOST
HTTP-AuthOptional
Aliasmi_ModifyApplicationPartsTree_Ad
Tags
Engine-Kategoriebasics
Engine-TypDaten-Änderung
Letzte Aktualisierung7.0.7 (2015-01-29)

Parameter

UserIDNULL ID eines in „UserInfo“ registrierten „dStore“-Benutzers. Bei „NULL“ wird der Benutzer, der die Prozedur aufruft, gewählt. Zu diesem Benutzer wird das neue Element angelegt, bzw. es wird überprüft, ob „PredecessorApplicPartTreeID“ diesem Benutzer gehört.
smallint4.0.8
ApplicationPartIDNULL Wird nur im Fall „ApplicationPartTreeID = NULL“ benötigt - dann muß der Parameter aber auch angegeben sein ! ID eines Teils einer „dStore“-Anwendung, zu dem das neue Element im Anwendungs-Baum gehört.
integer4.0.8
PredecessorApplicPartTreeIDNULL ID eines Elementes im „Anwendungs-Baum“. Beim Anlegen eines neuen Elementes ist dies der Vorgänger („NULL“ bedeutet, daß ein „Wurzel“-Element angelegt wird), beim Verschieben wird hierdurch der neue Vorgänger angegeben. (s. a. Beschreibung)
integer4.0.8
Delete0 „ApplicationPartTreeID“ soll…
„0“ : unter „PredecessorApplicPartTreeID“ verschoben werden
„1“ : inkl. evtl. vorhandener untergeordneter Elemente gelöscht werden
„2“ : gelöscht werden, sofern KEINE untergeordnete Elemente existieren
tinyint4.0.8

Rückgabe

Die Prozedur hat keine Rückgaben.

Output-Parameter

ApplicationPartTreeIDID eines Elementes im „Anwendungs-Baum“. Falls „NULL“, wird ein neues Element angelegt, ansonsten entscheidet „Delete“ darüber, ob das vorhandene Element gelöscht oder verschoben wird.

Mögliche Return-Codes

Code Beschreibung Quelle 1)
-583Ein Element kann nicht unter sich selbst oder ein untergeordnetes Element verschoben werdennur direkt
-582Unterhalb eines Elements kann zum gleichen Benutzer ein Anwendungs-Teil höchstens einmal vorkommennur direkt
-581Das Element kann nicht gelöscht werden, da noch untergeordnete Elemente existierennur direkt
-569Der Benutzer hat kein Ausführungsrecht für die Prozedurnur indirekt
-567Die Prozedur darf z. Zt. nicht ausgeführt werdennur indirekt
-566Die Prozedur darf mit den übergebenen Parametern nicht ausgeführt werdennur indirekt
-535Das Datum liegt nicht in der Vergangenheitnur indirekt
-530Der Wert ist nicht konvertierbarnur indirekt
-510Der Benutzer ist nicht registriertnur indirekt
-504Es ist ein Problem aufgetreten, das nicht gelöst werden kann, Prozedur wird daher abgebrochennur indirekt
-500Falsche Parameterdirekt und indirekt

XML-Schema

Die Rückgabe erfolgt als XML-Dokument welches gegen das Schema Response/EngineProcedure_v1_0.xsd validiert.

Historie

7.0.7 2015-01-29Interne Änderung : Datentyp-Erweiterung des „ReferenceKey“ [für „_mi_StartProcedure“-Aufruf]
5.5.1 2008-07-29Fehler : Es konnte vorkommen, daß ein Nachfolge-Element mit NEGATIVER ID angelegt wurde [wodurch ja aber „root“-Elemente gekennzeichnet sind] !
5.5.0 2008-01-071. Ab jetzt wird explizit überprüft, ob unterhalb eines Elementes zum gleichen Benutzer ein Anwendungs-Teil höchstens einmal vorkommt
2. Ausgabe via „print“ im Fehler-Fall „-500“
3. Neuer Fehler-Code für einen Fall („-583“)
5.0.3 2005-06-07Ab jetzt ist es verboten, ein „root“-Element zu verschieben !
4.0.13 2004-05-18Ab jetzt wird beim Löschen auch dafür gesorgt, daß untergeordnete Elemente mitgelöscht werden, bzw., dies wird über „Delete“ gesteuert - dieser Parameter ist daher ab jetzt ein „tinyint“ !
4.0.11 2004-03-31Ab jetzt wird geprüft bzw. sichergestellt, daß beim Verschieben eines Elementes der neue Vorgänger nicht etwa ein Nachfolge-Element des Elementes oder gar das Element selbst ist !
4.0.9 2004-03-031. Fehler beim Anlegen von „root“-Elementen
2. Ausführen von „set transaction isolation level 1“ und „set rowcount 0“ zu Beginn der Prozedur
4.0.8 2004-02-20Erstmalig in dieser Version erstellt

Code-Snippets

Engine Playground

Der folgende Link öffnet in einem separaten Fenster den Engine Playground der fest mit dem dbap-demo System verbunden ist:

cURL

Unformatierte Ausgabe:

curl -X POST  'http://<partner>-<project>.dstore.de/default/engine/mi_ModifyApplicPartsTree_Ad'

Mit xmllint 2) formatierte Ausgabe:

curl -X POST  'http://<partner>-<project>.dstore.de/default/engine/mi_ModifyApplicPartsTree_Ad' | xmllint --format -
dStore_php
use dStore_php\WebService;
 
$service = new WebService\Service( WebService\Scheme::HTTP,'<partner>-<project>.dstore.de', 80);
 
$request = new WebService\Requests\Engine\Procedure\Request(
			new WebService\Requests\AccessData('default'),
	'mi_ModifyApplicPartsTree_Ad',
		array(
			// 'UserID' => NULL,
			// 'ApplicationPartID' => NULL,
			// 'PredecessorApplicPartTreeID' => NULL,
			// 'Delete' => 0
		)
);
 
$service->execute($request);
 
			$xml_result = $request->getResponse()->getBody()->toSimpleXmlDocument();
			$ResultSet = $xml_result->getRowsAsArray();
 
$OutputParams = $xml_result->getOutputParametersAsArray();
engine/execute

XML zur Ausführung mit der Methode engine/execute, z.B. per

curl --header 'Content-Type: application/xml' -X POST 'http://<partner>-<kunde>.dstore.de/default/engine/execute' -d '<xml-daten>'
<?xml version="1.0" encoding="UTF-8"?>
<ListOfBatches>
	<Batch No="0">
		<Procedure Name="mi_ModifyApplicPartsTree_Ad">
			<Parameters>
				<!-- <Parameter Name="UserID">NULL</Parameter> -->
				<!-- <Parameter Name="ApplicationPartID">NULL</Parameter> -->
				<!-- <Parameter Name="PredecessorApplicPartTreeID">NULL</Parameter> -->
				<!-- <Parameter Name="Delete">0</Parameter> -->
			</Parameters>
		</Procedure>
	</Batch>
</ListOfBatches>
1)
direkt meint „von der Prozedur selber“ und indirekt meint „von intern aufgerufenen Unterprozeduren“
2)
I.d.R. auf Unix-artigen Systemen bereits installiert, Bestandteil der libxml2, siehe http://www.xmlsoft.org
engine/procedures/mi_modifyapplicpartstree_ad.txt · Zuletzt geändert: 11.01.2016 (Externe Bearbeitung)