Änderungen von Dokument Eigene Autoconf-Rolle erstellen
Zuletzt geändert von Tom Altenbrunn am 2023/03/17 08:03
Von Version 50.2
bearbeitet von Tom Altenbrunn
am 2023/03/16 16:40
am 2023/03/16 16:40
Änderungskommentar:
Es gibt keinen Kommentar für diese Version
Auf Version 29.1
bearbeitet von Jonas Mayer
am 2023/03/16 07:58
am 2023/03/16 07:58
Änderungskommentar:
Es gibt keinen Kommentar für diese Version
Zusammenfassung
-
Seiteneigenschaften (2 geändert, 0 hinzugefügt, 0 gelöscht)
-
Anhänge (0 geändert, 0 hinzugefügt, 8 gelöscht)
Details
- Seiteneigenschaften
-
- Dokument-Autor
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. TomAltenbrunn@sbede1 +XWiki.jonasmayer@sbede - Inhalt
-
... ... @@ -2,6 +2,7 @@ 2 2 3 3 ---- 4 4 5 + 5 5 = (% style="font-size:22px" %)__**Allgemeines**__(%%) = 6 6 7 7 ... ... @@ -28,7 +28,7 @@ 28 28 29 29 Für die Funktionalität der Autoconf-Rolle ist es also nötig, PowerShell-Skripte am Server abzuspeichern, die die Instruktionen an den Arbeitsstationen ausführen. Für diese Skripte sind folgende Dateinamen zulässig: 30 30 31 -* **main.ps1** - Skript wird in allen Phasen ausgeführt, die innerhalb der Beschreibungsdatei (% data-xwiki-non-generated-content="java.util.List" %){{box}}meta/logodidact.yml{{/box}}(%%)festgelegt sind. Eine solche Datei folgt dem Prinzip „in jeder Phase soll genau das gleiche stattfinden“.32 +* **main.ps1** - Skript wird in allen Phasen ausgeführt, die innerhalb der Beschreibungsdatei {{box}}meta/logodidact.yml{{/box}} festgelegt sind 32 32 * (% style="color:#8e44ad" %)**setup.ps1**(%%) - Skript wird ausschließlich in der SETUP-Phase während des Deployments ausgeführt. In der Setup-Phase ist der Client noch veränderlich und besitzt noch keine Schutzfunktion, selbst wenn der Schutz aktiviert ist. 33 33 * (% style="color:#8e44ad" %)**custom.ps1**(%%) - Skript wird ausschließlich in der CUSTOM-Phase ausgeführt. Dies geschieht sowohl 1x während des Deployments als auch später nach jedem Hochfahren des PCs 1x im Hintergrund. 34 34 * (% style="color:#8e44ad" %)**user.ps1**(%%) - Skript wird ausschließlich in der USER-Phase ausgeführt. Diese Phase wird nicht direkt während des Deployments durchlaufen, sondern erst später während der Benutzeranmeldung an betriebsbereiten PCs. ... ... @@ -40,11 +40,6 @@ 40 40 (% style="font-size:12px" %)**Hinweis: **Skripte, die durch ihren Dateinamen auf einzelne Phasen eingeschränkt sind ((% style="color:#8e44ad; font-size:12px" %)lila eingefärbt(% style="font-size:12px" %)), dürfen sich inhaltlich zueinander unterscheiden. Dadurch kann eine Autoconf-Rolle sehr flexibel gestaltet werden und in den verschiedenen Phasen des Deployments unterschiedliche Aktionen ausführen. 41 41 ))) 42 42 43 - 44 - Nachfolgend sind grafisch die diversen Deploy-Phasen dargestellt, welche ein Client während des Imaging-Vorgangs durchläuft. Die Abarbeitung von AutoConf-Rollen beginnen ab der Phase "**Re-Setup**" 45 - 46 - [[image:image-20230316155817-1.png]] 47 - 48 48 ---- 49 49 50 50 ... ... @@ -100,7 +100,7 @@ 100 100 ---- 101 101 102 102 103 -= (% style="font-size:22px" %)__** Funktionsfertiges Beispiel: Rolle „WLAN Profil mit PSK anlegen“**__(%%) =99 += (% style="font-size:22px" %)__**Weiteres, funktionsfertiges Beispiel: Rolle „WLAN Profil mit PSK anlegen“**__(%%) = 104 104 105 105 106 106 Zum besseren Verständnis wird nachfolgend eine feste Autoconf-Rolle zur Konfiguration eines WLAN-Profils (SSID inkl. PSK) an Clients näher beleuchtet. ... ... @@ -123,7 +123,7 @@ 123 123 (% style="color:#8e44ad" %) uuid:(%%) 52318636-c4f5-11ea-baf9-0bff00c66ff4 124 124 visible: true 125 125 (% style="color:#19177c" %) priority:(%%) 0 126 - apply _always: false122 + applyAlways: false 127 127 (% style="color:#f1c40f" %) tags:(%%) 128 128 - CUSTOM 129 129 (% style="color:#e74c3c" %) vars:(%%) ... ... @@ -162,7 +162,7 @@ 162 162 163 163 == (% style="font-size:16px" %)**Inhalt des PowerShell-Skripts main.ps1, das die Variablen entgegennimmt**(%%) == 164 164 165 -Im Unterverzeichnis {{box}} win/ {{/box}} 161 +Im Unterverzeichnis {{box}} win/ {{/box}} oder {{box}} lin/ {{/box}} der Autoconf-Rolle können sich wie erläutert unterschiedliche PowerShell-Skripte zur Ausführung in den verschiedenen Phasen befinden. 166 166 In dieser Rolle liegt konkret das allgemeingültige Skript {{box}}main.ps1{{/box}} vor, welches die Variablen als Parameter ##$ssid## und ##$psk## intern verwendet. 167 167 168 168 ... ... @@ -293,91 +293,3 @@ 293 293 exit 1 294 294 } 295 295 {{/code}} 296 - 297 ----- 298 - 299 - 300 - 301 -= (% style="font-size:22px" %)__**Weiteres Beispiel: eigene AutoConf-Rolle zur „Deaktivierung der Suchhervorhebung in Windows“**__(%%) = 302 - 303 -Im nachfolgenden Beispiel wird eine einfache Rolle zur Deaktivierung der Suchvorhebung in Windows deklariert. 304 -\\[[image:image-20230316103442-2.png||height="530" width="1142" class="img-thumbnail"]] 305 - 306 ----- 307 - 308 -== (% style="font-size:16px" %)**Aufbau der logodidact.yml**(%%) == 309 - 310 -Neben den allgemeinen Informationen über die Autoren (authors), Unternehmen (company), einer Beschreibung (description), dem Anzeigenamen (display_name) im LD Control Center, usw, beginnt im Abschnitt {{code language="bash"}}vars{{/code}} die eigentliche Definition der Variable 311 -"**{{code}}disableSearchHighlight{{/code}}**". 312 - 313 - 314 -{{code language="yaml" width="45%"}} 315 -#logodidact.yml 316 - 317 -ld_info: 318 - authors: 319 - - Tom Altenbrunn 320 - - Olav Krapp 321 - - Marcel Petersen 322 - - Kerim Ekin 323 - company: SBE network solutions GmbH 324 - description: | #Beschreibung 325 - Die Suchhervorhebung in der Windows Suchleiste wird deaktiviert 326 - display_name: Windows Suchhervorhebung #Anzeigename im LD Control Center 327 - license: SBE 328 - uuid: fec4ff30-b2a6-407f-a6b3-0a621cd7eaf7 #einmalige UUID 329 - vars: #Deklaration der Variablen 330 - disableSearchHighlight: #Name der Variable 331 - display_name: Suchhervorhebung im Suchfeld deaktivieren #Anzeigename im LD Control Center 332 - optional: true #Auswahl optional 333 - type: BOOLEAN #Variablentyp Boolean = True/False 334 - value: false #Standardwert false 335 - visible: true #Sichtbarkeit der Variable im LD Control Center 336 - priority: 0 #Abarbeitungspriorität 337 - apply_always: false 338 - tags: 339 - - CUSTOM #Ausführungszeitpunkt während der/den Phase(n) 340 - systems: 341 - - WINDOWS #Betriebssystem 342 -{{/code}} 343 - 344 ----- 345 - 346 -== (% style="font-size:16px" %)**Aufbau der main.ps1**(%%) == 347 - 348 -Danach erfolgt die Erstellung des ausführbaren Codes per Powershell. Im ersten Abschnitt (% style="color:#008000" %)**Param** (%%)werden die in der im vorigen Abschnitt definierten Variablen {{code}}vars{{/code}} aus der logodidact.yml aufgeführt und definiert. Bei der Variable "**{{code}}disableSearchHighlight{{/code}}**" handelt es sich um ein Boolean (True/False). Die Bedingung "**[parameter(Mandatory=$false)]**" setzt das Vorhandensein der Variable während dem Ablauf des Skriptes nicht als zwingend notwendig voraus, sodass bei einem darauffolgenden Verarbeitungsfehler o.ä. die Abarbeitung weiter erfolgt. 349 - 350 -{{code language="powershell"}} 351 -#main.ps1 352 - 353 -Param 354 -( 355 - [parameter(Mandatory=$false)] #Variable zwingend erforderlich? 356 - [bool] #Variablentyp 357 - $disableSearchHighlight #Name der def. Variable aus logodidact.yml 358 -) 359 - 360 -$SystemVersion=[System.Environment]::OSVersion.Version #Hole Windows Systemversion 361 - 362 -#Beginn des eigentlichen Codes 363 -if ($SystemVersion.Major -eq 10 -and $SystemVersion.Build -ge 19044) { 364 - $val = [int]!$disableSearchHighlight 365 - Write-Verbose "Setting EnableDynamicContentInWSB to '$val'" 366 - [Microsoft.Win32.Registry]::SetValue("HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows\Windows Search","EnableDynamicContentInWSB",$val,[Microsoft.Win32.RegistryValueKind]::DWord) 367 -} else { 368 - Write-Host "Feature ist erst ab dem Release 21H2 verfügbar." 369 -} 370 -{{/code}} 371 - 372 ----- 373 - 374 -== (% style="font-size:16px" %)**Einlesen der AutoConf-Rollen am Server**(%%) == 375 - 376 -[[image:image-20230316110425-1.png||height="124" width="1186" class="img-thumbnail"]] 377 - 378 - 379 -== (% style="font-size:16px" %)**Ansicht im LD Control Center**(%%) == 380 - 381 -[[image:image-20230316110525-2.png||class="img-thumbnail"]] 382 - 383 -
- image-20230316094933-1.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -43.3 KB - Inhalt
- image-20230316095106-2.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -47.8 KB - Inhalt
- image-20230316102252-3.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -166.3 KB - Inhalt
- image-20230316102302-4.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -166.3 KB - Inhalt
- image-20230316103224-1.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -166.3 KB - Inhalt
- image-20230316103442-2.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -201.2 KB - Inhalt
- image-20230316110425-1.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -166.3 KB - Inhalt
- image-20230316110525-2.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.TomAltenbrunn@sbede - Größe
-
... ... @@ -1,1 +1,0 @@ 1 -48.3 KB - Inhalt