Jump to content


anyweb

How can I make multiple hidden task sequences available on-demand in Configuration Manager 2012 R2

Recommended Posts

Introduction

 

In a previous post I explained how to deploy hidden task sequences in Configuration Manager by using the SMSTSPreferredAdvertID variable. You can use that method (or variations of it) to Deploy Task Sequences that are hidden and only available via PXE or Media. In this post I will show you how you can have multiple hidden task sequences available on-demand via a simple script and using a prestart command, the idea for this developed between myself and my esteemed work colleagues (thanks Magnus/Jimmy :-)) and that inspired me to put something together.

 

How does the on-demand bit work ?

 

The prestart command will only popup a prompt (on-demand) if the following file (X:\hidden.txt) is present on a client that is PXE booting. We place the file there by using a script (devel.vbs) and that script is invoked when a user presses F8 and types Devel prior to entering the PXE password. Once the file is present, the prestart script will check for another file (DeploymentIDs.txt on a UNC share) and if found, display the contents of that in a prompt to the end user. The end user will enter their choice and our variable is set. Done.

 

Step 1. Download the files

 

Download the following files

 

Extrafiles.zip

 

and unzip to somewhere useful like D:\sources\os\extrafiles

 

extrafiles unzipped.png

 

Step 2. Create some temporary directories

 

To enable the on-demand ability, we need to add a script to our boot image, and to do that we'll inject a file called devel.vbs into our boot wim image. This file needs to be accessible even before the prestart command kicks off so we will mount our boot wim file to inject it. To mount the boot wim we need some temporary storage so create some folders on C:\ like so

 

C:\WinPEMount

|__X86

|__X64

 

as shown in the screenshot below

 

WinPEMount directories.png

 

Step 3. Add a script to the boot image

Locate the boot wim that you use most often in your task sequences in the console and identify it's path. In the example below we will edit the i386 (X86) boot wim, but you can just as easily replace the path with X64.

 

boot wim source.png

 

browse to the data source listed in the properties and you'll probably see a few wim files, the file we are interested in is called boot.wim as every time your boot wim file is updated (for example adding drivers), this file is used as the source for all changes.

 

boot wim path.png

 

This file will be present locally on our Configuration Manager primary server in the following path D:\Program Files\Microsoft Configuration Manager\OSD\boot\i386\boot.wim assuming Configuration Manager is installed on D:\.

 

local path.png

 

Tip: Before making any changes to your boot wim files, make a copy of them and store them safe.

 

We will modify the boot wim file in the local path. To inject files we first need to mount the file with DISM. Use the version of DISM that comes with System Center 2012 R2 Configuration Manager, the correct version is included in ADK 8.1 and the correct version of DISM is 6.3.9600.16384. To start the correct version of DISM locate it in your start menu and right click on the Deployment Imaging Tools and Environment cmd prompt, choose Run as Administrator

 

Run As Administrator.png

 

and change directory to the directory that has your boot wim file. You can check the contents of the directory to verify that the boot wim file is present.

 

boot wim highlighted.png

 

using Dism mount the image using the following command

dism.exe /mount-wim /wimfile:"D:\Program Files\Microsoft Configuration Manager\OSD\boot\i386\boot.wim" /index:1 /mountdir:c:\WinPEMount\X86

press Enter when done

 

boot wim is mounted.png

 

Using Explorer, or a command prompt, copy the file called devel.vbs from our downloaded files from Step 1 to C:\WinPEMount\X86\Windows\System32 for example like in the screenshot below

 

1 files copied.png

 

Now the file is in place, commit our changes (save the changes) to the boot wim file.

dism.exe /unmount-wim /mountdir:c:\WinPEMount\x86 /commit

as shown in the screenshot below

 

dism unmount.png

 

Step 4. Add a prestart script to the boot image

 

Now that we've injected our needed script, we need to add our prestart command. To do that bring up the boot wim properties and browse to the Customization tab, fill in the details

 

Command Line:

cscript.exe //nologo check_hidden.vbs

Include files for the Prestart command:

\\sccm\sources\os\extrafiles

like in the screenshot below

 

include extrafiles.png

 

Click Apply, and OK and answer Yes to the Distribute Content question.

 

you have made changes that require you to update the distribution points.png

 

continue through the wizard until completion.

 

boot wim distributed.png

 

Step 5. Create a local user and a hidden share

 

On a suitable server (I used the Configuration Manager primary server in my lab, in production you may want to separate it), create a local user called HiddenList with a password matching the one in the check_hidden.vbs file downloaded in Step 1 above.

 

HiddenList Local user.png

 

Next create a folder called Hidden$ and share it, grant the local user HiddenList read access to the share.

 

HiddenList permissions on the share.png

 

Note: Don't forget to edit the Check_Hidden.vbs file downloaded in Step 1 and change the ip address and share name to match the one created above.

 

Step 6. Copy DeploymentIDs.txt to the hidden share

 

Copy the DeploymentIDs.txt file downloaded in Step 1 to the hidden$ share, edit the file in notepad making sure that it includes the DeploymentIDs and friendly name of the Hidden Task Sequences you have deployed in your environment. The Deployment ID value of a task sequence can be found by looking at Step 8 of this post. This text file will be the 'template' that is shown to the end user so make sure to enter the correct values.

 

DeploymentIDs txt file contents.png

 

 

Step 7. Verify and Test

 

Now everything is in place to test out the theory above. So PXE boot a computer and when you get to the PXE password screen, before entering the password press F8 and type devel. If you followed the guide above you should see a popup telling you that Devel mode Enabled.

 

DEVEL mode has been selected.png

 

Click Ok and close the command prompt window. Enter the PXE password and press Enter. The prestart command in the boot wim should display the following prompt.

 

Note: if you didn't enable Devel mode above then it won't popup the prestart prompt at all. That is on-demand in action!

 

prompt for deploymentID.png

 

after typing in your deploymentID and pressing enter you should see the following

 

hidden task sequence shown.png

 

Success !

 

Summary

The SMSTSPreferredAdvertID is a great variable and allows us to deploy hidden task sequences, however selecting that Task Sequence deploymentID is usually hard coded via a script to one DeploymentID or relies on the user knowing the values. This method allows you to conveniently use SMSTSPreferredAdvertID on-demand (by pressing F8 and typing Devel), and having a list of available hidden task sequences and their respective Deployment ID's on screen.

 

 

cheers

niall

Share this post


Link to post
Share on other sites

below is the updated script which now includes a function to drop the network share drive letter if not needed/used

' windows-noob.com (c) niall@windows-noob.com 2014/4/14.
' This script allows you to selectively run a hidden prestart command based on previous actions.
' In addition, it will list all DeploymentId's found in a file called DeploymentIDs.txt located on a UNC share
' see http://www.windows-noob.com/forums/index.php?/topic/4045-system-center-2012-configuration-manager-guides/ for details
' updated 2015-1-8 to add network share disconnect functionality
'
Option Explicit
DIM fso, WshNetwork, strUser, strPassword, clDrives, i, objFileToRead, strFileText
Set fso = CreateObject("Scripting.FileSystemObject")
Set WshNetwork = WScript.CreateObject("WScript.Network")
strUser = "HiddenList"
strPassword = "Password123"

'Map network drive
WshNetwork.MapNetworkDrive "Z:", "\\192.168.1.2\hidden$", , strUser, strPassword

'Check if Devel Mode was selected
If (fso.FileExists("x:\hidden.txt")) Then
  	'WScript.Echo("hidden.txt file exists, devel mode selected!")
	' Now check to see if DeploymentIDs.txt file exists, this file is used so that we can display what deployment ID's are available in the prestart prompt
		If (fso.FileExists("z:\DeploymentIDs.txt")) Then  
			'Found the DeploymentIDs.txt file, read it's contents into a variable
			Set objFileToRead = CreateObject("Scripting.FileSystemObject").OpenTextFile("z:\DeploymentIDs.txt",1)
			strFileText = objFileToRead.ReadAll()
			'InputBox ("The following hidden DeploymentID's are available. Please enter the Task Sequence Deployment ID:-" & vbCrLf & vbCrLf & strFileText)
			objFileToRead.Close
			Set objFileToRead = Nothing
			'WScript.Quit()
		else
			'msgbox "could not find DeploymentIDs.txt, please select manually"
				
		End If

	' Devel mode was selected so display the Prestart prompt
	Dim env
	set env = CreateObject("Microsoft.SMS.TSEnvironment")
	env("SMSTSPreferredAdvertID") = InputBox ("The following hidden DeploymentID's are available." & vbCrLf & vbCrLf & strFileText & vbCrLf & vbCrLf & "Please enter the Task Sequence Deployment ID eg: P0120038 and click [OK] or click [Cancel] to continue.")
		'MsgBox "The following Task Sequence Advertisement ID will be selected: " & env("SMSTSPreferredAdvertID")
	Disconnect()
Else
  	'WScript.Echo("The hidden.txt File does not exist so will not change SMSTSPreferredAdvertID!")
	Disconnect()

End If

Function Disconnect()
    'Disconnect ALL mapped drives
				Set clDrives = WshNetwork.EnumNetworkDrives
				For i = 0 to clDrives.Count -1 Step 2
					WSHNetwork.RemoveNetworkDrive clDrives.Item(i), True, True
				Next
End Function
WScript.Quit()

Share this post


Link to post
Share on other sites

if they click cancel then the required task sequence will not run and it will want to reboot the computer

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...


×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.