Scenario
This TID details a scenario where a company has sites in 3 different countries and wants to use a single Imaging Toolkit project to maintain consistency.
ENGL TID-2015001 looks at using the IP address of the ZENworks server (PROXYADDR) to identify the site-specific information; in this TID the subnet is used.
In this example each site is on a different subnet and the location is determined by the first three octets of a class C subnet. The company wishes to set the following settings dynamically based on the location of the machine being deployed:
- Timezone
- Locale (language settings)
- Department (used for AD and ZCM registration)
In addition, they also want to be able to alter the default site selection in order to build machines for different locations.
By using this TID as a guideline it should be straightforward to modify the scenario to meet your own specific requirements.
Procedure
- Update the Zim script (
zim.cfg
) to identify the current location of the machine using thesubnet
variable - Read the site-specific information from a lookup file
- Stored the information to ZENworks Image safe Data (
ZISD
) - Modify the project settings to use environment variables for the settings that are to be set dynamically and recreate the build proces (
Ztoolkit
) image. - Deploy and test
|
-
Create site lookup file
Create a site lookup file called
sites.ini
in thetftp/zimfiles
folder on the ZENworks server.NOTE: On Windows servers this will be:
%ZENWORKS_HOME%\share\tftp\zimfiles\sites.ini
and on Linux:
/srv/tftp/zimfiles/sites.ini
This file contains multiple sections. The first section is a list ofsubnets
and the sites where they are located. The remaining sections contain the information for the site name found in the first section.For example:
; ENGL Sites Lookup File (sites.ini) ; ; Format: ; ; [SUBNET] section ; <First three octets of the IP address> = <Site Name> ; ; [<Site Name>] sections ; Country = Short country code ; SITE = Active Directory OU and ZCM registration Key ; TZ = Time zone ; SL = System / User locale ; IL = Input locale ; DEPT = Departments (comma separated list) [SUBNET] 10.40.1 = New York 10.30.1 = Paris 10.20.0 = London [New York] Country = US SITE = New York TZ = Eastern Standard Time SL = en-US IL = 0409:00000409 DEPT = HR, Training, Administration [Paris] Country = FR SITE = Paris TZ = Romance Standard Time SL = fr-FR IL = 040C:0000040C DEPT = Administration, Staff [London] Country = UK SITE = London TZ = GMT Standard Time SL = en-UK IL = 0809:00000809 DEPT = HR, Training, Administration, Development
-
Update zimget.s/zimpeget.cmd to retrieve site lookup file
If you are using ZENworks (img) imaging, then the
zimget.s
file is found in thetftp/zimfiles
folder on theZENworks
imaging server and is used to download the files from the server into the imaging environment.
Update the file to include the line highlighted in green below:
echo Downloading ENGL Zim files... tftp $PROXYADDR /dev/null verbose on bin get zimfiles/ldapsdk.tar $ZIMDIR/ldapsdk.tar get zimfiles/zim.tgz /zimbin/zim.tgz get zimfiles/engl.lic $ZIMDIR/engl.lic get zimfiles/zim.cfg $ZIMDIR/zim.cfg get zimfiles/images.ini $ZIMDIR/images.ini get zimfiles/projects.ini $ZIMDIR/projects.ini get zimfiles/zimrun.s $ZIMDIR/zimrun.s get zimfiles/sites.ini $ZIMDIR/sites.ini quit _END_
Save the changes to thezimget.s
file.
If you are using WinPE imaging, then the
zimpeget.cmd
file is found in thetftp/zimfiles
folder on theZENworks
imaging server and is used to download the files from the server into the imaging environment.
Update the file to include the sites.ini entry highlighted in green in the last line of code below:
REM TFTP files if %PLATFORM%==x64 ( for %%i in (Microsoft.VC80.CRT.manifest msvcm80.dll msvcp80.dll msvcr80.dll) do Ztftpclient.exe /get /host:%PROXYADDR% /remote:"zimfiles/%PLATFORM%/%%i" /local:%%i >NUL ) for %%i in (zim.exe ztrace.exe) do Ztftpclient.exe /get /host:%PROXYADDR% /remote:"zimfiles/%PLATFORM%/%%i" /local:%%i >NUL for %%i in (engl.lic zim.cfg zim.jpg images.ini projects.ini clones.ini sites.ini) do Ztftpclient.exe /get /host:%PROXYADDR% /remote:"zimfiles/%%i" /local:%%i >NUL
Save the changes to thezimpeget.cmd
file.
-
Modify Zim script (zim.cfg) to read site lookup file and store information to ZISD
Update the
tftp/zimfiles/zim.cfg
file with the following changes:-
Identify the site using a SUBNET variable
Add an entry in the zim.cfg file after the network information has been identified as shown in green below:
; Get network info Network:Get,eth0,IPADDR,Network_IP Network:Get,eth0,NETMASK,Network_Mask Network:Get,eth0,HWADDR,Network_Mac ; Identify each octet of IP address Set:Network_IP_oct1,Token("%Network_IP%", ".", 1) Set:Network_IP_oct2,Token("%Network_IP%", ".", 2) Set:Network_IP_oct3,Token("%Network_IP%", ".", 3) ; Identify subnet Set:Network_Subnet,%Network_IP_oct1%.%Network_IP_oct2%.%Network_IP_oct3% ; Read in current location from sites.ini File:Ini,Get,"/zimbin/sites.ini","SUBNET","%Network_Subnet%",lookup_site
-
Update "Hardware Detected" form to include a site drop down list
The changes (shown in green) below will add a list of the sites to the form. The list will default to the current site based on the
PROXYADDR
information above.; Launch a Form to display detected hardware and select machine type Form:Start,"Info","Hardware Detected","_OkCancel^_Ok",Blue Form:Item,"Item1",Label,"Manufacturer" Form:Item,"Item2",EditBox,"%Lookup_Section%",ReadOnly Form:Item,"Item3",Label,"Model" Form:Item,"Item4",EditBox,"%Lookup_Value%",ReadOnly Form:Item,"Item5",Label,"Hardware Image" Form:Item,"Item6",EditBox,"%Drivers_Image%",ReadOnly Form:Item,"Item7",Label,"Hardware Type" Form:Item,"Item8",EditBox,"%Machine_Type%",ReadOnly Form:Item,"Item9",Label,"OS" Form:Item,"Item10",EditBox,"%Project_OS%",ReadOnly Form:Item,"Item11",Label,"Computer Name" Form:Item,"Item12",EditBox,"%Ask_COMPUTERNAME%" Form:Item,"Site1",Label,"Site:" Form:Item,"Site2",ListBox_File,"%lookup_site%","/zimbin/sites.ini","SUBNET","=",2 Form:Item,"Item13",Label,"Auto Restart after imaging" Form:Item,"Item14",RadioButtons,"Yes","Yes,No" Form:Display,"Info"
-
Save selected site
When a form is submitted, variables are created and set to the values of each form item. See the Imaging Toolkit documentation for more information.
Create a new variable to hold the value of the selected site as shown below in green:If:Var,_Form,EQ,"_Cancel" Menu:Return End: Set:Ask_COMPUTERNAME,"%_Info_item12%" Set:ask_site,%_Info_Site2% Set:AutoRestart,"%_Info_item14%"
-
Read in site-specific information
Now that the site has been identified Zim must gather the site-specific information by adding the following lines:
;Read site lookup file (sites.ini) Set:SiteIniPath,"%_ZimDir%sites.ini" File:Ini,Get,"%SiteIniPath%","%ask_site%","Country",lookup_Country File:Ini,Get,"%SiteIniPath%","%ask_site%","SITE",lookup_SITE File:Ini,Get,"%SiteIniPath%","%ask_site%","TZ",lookup_TZ File:Ini,Get,"%SiteIniPath%","%ask_site%","SL",lookup_SL File:Ini,Get,"%SiteIniPath%","%ask_site%","IL",lookup_IL
-
Update ZISD
The information read in must now be stored to ZISD so that it can be used during the Windows build process:
; Update VendorDataENGL (sample) Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","Machine_Type","%Machine_Type%") Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","OS","%Project_OS%") Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","Project","%Lookup_Project%") ;Add site values to VendorDataENGL string Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","Country","%lookup_Country%") Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","SITE","%lookup_SITE%") Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","TZ","%lookup_TZ%") Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","SL","%lookup_SL%") Set:VendorDataENGLSTRING,PutKeyPairStringValue("%VendorDataENGLSTRING%","IL","%lookup_IL%")
Save the changes to thezim.cfg
file.
-
-
Modify project settings to use variables
Nearly every setting in a project can be configured to use a variable. In this example the company wishes to control the localisation and registration settings using variables.
By default thephase0-before.vbs
script in a project will export all values stored in VendorDataENGL as Windows environment variables with a prefix of "ENGL_" so it is a simple matter of modifying the project settings to use these values.-
Configure localisation settings
- Launch Build Console
- Open the project
- Select the Expert View
- Select the Windows - Localisation section
- Set the appropriate Build Variables
- Save the changes to the project
- Launch Build Console
-
Active Directory join to a specific OU
- Launch Build Console
- Open the project
- Select the Expert View
- Select the Windows - Active Directory / Workgroup section
- Update the OU entry to use the appropriate variable(s)
- Save the changes to the project
- Launch Build Console
-
ZCM registration to a specific folder
- Configure a ZENworks Registration key
Instructions on how to create ZENworks registration keys can be found in the ZENworks Documentation. These are used to control which folder a workstation object is registered into.
NOTE: To make management easier ensure folders and keys are created with names rather than using a GUID
- Update the project
- Launch Build Console
- Open the project
- Select the Expert View
- Select the Windows - Active Directory / Workgroup section
- Update the OU entry to use the appropriate variable(s)
- Launch Build Console
- Save the changes to the project
- Configure a ZENworks Registration key
-
Configure localisation settings
-
Create and deploy new Ztoolkit image
- Launch Build Console
- Open the project
- Run the Deployment Wizard
- Select the option to create Build Process images
- Select the option to create the Build Process (ztoolkit) image
- Once complete copy the new Ztoolkit image to the server
- Launch Build Console
-
Test
Both Zim and the project have now been configured to identify and use site-specific information.
To test everything is working do the following:- PXE boot a machine into Zim
- Select the Restore menu
- Select the project
- When prompted confirm the computer name and note that the current site has automatically been selected
- Continue to restore all images and allow the machine to build
- Once the machine has built successfully log in and confirm the site-specific settings have been applied successfully
- PXE boot a machine into Zim
- If there are issues with the process review both the zim.log and ztoolkit.log to see where / what has failed to happen.
For more information about the log files review ENGL TID-2013016
If you have any problems or questions about the steps in this TID please contact the ENGL support team