Versionen im Vergleich

Schlüssel

  • Diese Zeile wurde hinzugefügt.
  • Diese Zeile wurde entfernt.
  • Formatierung wurde geändert.

Status
colourYellow
titleWMS

2020 (

1.0.1 (2020)
 

Image RemovedImage Added

Panel
titleInhalt

Inhalt

image-20240404-122849.pngImage Added

Die Aktivität führt ein

Powershell

beliebiges von Ihnen entwickelte PowerShell-Skript aus einer Datei aus. 

Status
colourYellow
titleWMS 2.1.0

Mit einer überarbeiteten Version kann das PowerShell-Skript jetzt direkt angegeben werden. Ebenso können Parameter definiert und dem Skript übergeben werden.

Inhalt

Inhalt
minLevel1
maxLevel3

Hinweise und Hilfe

Panel
panelIconId2757
panelIcon:exclamation:
panelIconText
bgColor#FFEBE6

Beachten Sie, dass das WMS das Skript weder verarbeitet noch auswertet oder prüft. Somit erfolgt auch keine Prüfung der Mandantenverzeichnisse.

Panel
panelIconId2757
panelIcon:exclamation:
panelIconText
bgColor#FFBDAD

Die Accantum GmbH übernimmt keine Verantwortung für Schäden, welche durch die Ausführung von Skripten verursacht werden. Das WMS hat keinen Einfluss auf die Skripten und kann deren Inhalt nicht prüfen. Mit einem PowerShell-Skript können sicherheitsrelevante Einschränkungen umgangen und somit nicht gewollte, schädliche Aktionen auf dem Server ausgeführt werden.

Informationen zur sicheren Verwendung von PowerShell-Skripts finden Sie auf den Seiten von Microsoft:
https://learn.microsoft.com/de-de/mem/configmgr/apps/deploy-use/learn-script-security

Viele weitere Beispiele und Anleitungen zur Anwendung von PowerShell-Skripten finden Sie ebenfalls auf den Seiten von Microsoft:
https://learn.microsoft.com/de-de/powershell/

Eigenschaften

Eingabe

Name

Beschreibung

Datentyp

Erforderlich

Dateiname

Name der Datei, die das Skript enthält.

string

(Warnung)

Verzeichnis

Verzeichnis, in dem die Datei liegt

string

(Warnung)

Ressource

Ressourcedatei

Resourcedatei, die das Skript enthält, siehe dazu Ressourcen Einstellungen und Zuordnungen

WmsSettingMapping


Ressource verwenden

Kennzeichen, ob eine Ressourcen verwendet werden soll, statt eines Dateinamens

bool


Auswahl “von Datei / per Text”

Mit der Auswahl kann festgelegt werden, ob das Skript von einer Datei geladen oder ob das Skript direkt als Text angegeben werden soll.

Text

Status
colourYellow
titleWMS 2.1.0

Alternativ zur Angabe einer PowerShell-Skript-Datei können Sie PowerShell-Befehle direkt in das Textfeld eingegeben. Bei Klick auf die Schaltfläche mit dem Stift-Symbol, öffnet sich ein Fenster, in dem das Skript in einem größeren Fenster und mit Syntax-Highlighting editiert werden kann.

image-20240306-150305.pngImage Added

string

Parameter definieren…

Status
colourYellow
titleWMS 2.1.0

Beim Klick auf die Schaltfläche öffnet sich ein Fenster, in dem Parameter definiert werden können, auf die bei der Ausführung des PowerShell-Skripts zugegriffen werden kann.

Die Namen der Parameter enthalten kein “$”-Zeichen und müssen mit denen im Skript übereinstimmen.

Auflistung

Script bei Fehler abbrechen

Status
colourYellow
titleWMS 2.1.0

Wenn Kennzeichen gesetzt ist, dann wird die Ausführung des Skripts unterbrochen, sobald ein Fehler mit “write-error” protokolliert wird.

Ausgabe

Name

Beschreibung

Datentyp

Erforderlich

Ergebnis

Das Ergebnis der Ausführung des Skripts. Leer, wenn das Skript kein Ergebnis liefert.

List<PSObject>

Fehlermeldungen
BeschreibungCodeDatentypDie Datei "<Dateiname>" existiert nicht.11101: EActivityMsgCode.File_NotExistsActivityExceptionDer Zugriff auf das Verzeichnis ist Ihrem Mandanten nicht erlaubt ("<Dateiname>"). (siehe Mandanten)11000: EActivityMsgCode.Dir_UnauthorizedAccessActivityExceptionBeispiel zur Auswertung des Ergebnisses


Informationen

Status
colourYellow
titleWMS 2.1.0

Meldungen, welche während der Ausführung des PowerShell-Skripts ausgegeben wurden.

Im Skript können die Meldungen mit den Aufrufen von write-error, write-warning, write-information, etc. protokolliert werden.

List<WmsPowerShellMessageItem>

Parameter

Ab

Status
colourYellow
titleWMS 2.1.0
können Sie in der Aktivität Parameter definieren. Mit Klick auf die Schaltfläche “Parameter definieren…“ öffnet sich ein Fenster, in dem eine Liste von Parametern angelegt werden kann. Als Werte können beliebige Objekte verwendet werden.

Um im PowerShell-Skript auf die Parameter zugreifen zu können, müssen diese im Skript wie folgt definiert werden:

param( [string]$ParamString,
         [Int]$ParamInt,
         [double]$ParamDouble,
         [datetime]$ParamDateTime)

Innerhalb von param(…) müssen die Parameter in einer Komma separierten Liste angegeben werden. Dabei ist vor dem Namen des Parameters das Zeichen “$” zu setzen (z.B. lautet für Parametername “ParamString” die Variable “$ParamString”).

Optional kann vor dem Variablennamen in eckigen Klammern der Datentyp angegeben werden (z.B. [string]$ParamString). Wir empfehlen dies, weil dadurch eine Differenz des Datentyps bei einem übergebenen Wert sofort zu einem Fehler führt und somit ein ungewolltes Verhalten bei der Ausführung des Skripts vermieden werden kann.

Ergebnis (PSObject)

Beispiel 1: String-Werte 

Das Ergebnis der Aktivität ist eine Liste der Ausgaben aus dem Powershell-Script. Mittels ToString können sie den Wert aus dem PSObject ermitteln.

In folgenden Beispiel enthält die Liste zwei Werte:

Image Modified
Image RemovedImage Removed
Image Added

image-20240306-141908.pngImage Added

Image Added



Beispiel 2: Komplexe Ergebnistypen (z.B. von einem Web-Request)

Handelt es sich bei einer Rückgabe um einen komplexeren Typ, können dessen Eigenschaften über die Namen abgerufen werden.

Powershell-Skript:
Codeblock
languagepowershell
$obj =  [PSCustomObject]@{
    Name     = 'MyName'
    Description = 'MyDescription'
    State    = 'ok'
}
Im Workflow:
Codeblock
languagevb
 psObject.Properties.Item("Description").Value.ToString()

Der Value der Eigenschaft ist dabei vom Typ "object". d.h. um damit weiter arbeiten zu können müssen Sie den Typ kennen und konvertieren.

Informationen

Die Aktivität gibt eine Liste von Informationen aus, welche im PowerShell-Skript protokolliert werden. Je nach Befehl im PowerShell-Skript können diese Informationen als Fehler, Warnung oder Information spezifiziert werden:

  • write-error

  • write-warning

  • write-information bzw. write-host