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

image-20240404-122849.pngImage Added

Die Aktivität führt ein beliebiges von Ihnen entwickelte PowershellPowerShell-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.

image-20240306-135941.pngImage Removed

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

RessourcedateiResourcedatei, 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 jetzt auch Sie PowerShell-Befehle direkt in ein Textfeld eingegeben werden.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 DialogFenster, 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>


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<PowerShellMessageItem>List<WmsPowerShellMessageItem>

Parameter

Ab

Status
colourYellow
titleWMS 2.1.0
können Sie in der Aktivität auch Parameter definieren. Mit Klick auf die Schaltfläche “Parameter definieren…“ öffnet sich ein DialogFenster, 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-20240306-141908.pngImage Removedimage-20240306-141908.pngImage Added

Image Modified



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.

Hinweise und Hilfe

Info

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

Info

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

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

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