WPSecure

Table of Contents

Summary

Keeping our commitment to simplicity, this guide offers clear, easy-to-follow instructions for installing and using the Windows Personalization Packager. The most effective way to familiarize yourself with the product is through hands-on experience. We invite you to try it out by clicking the button in the top right corner of your screen.

Did you know the WPSecure Personalization Packager only has 7 action buttons? Create powerful deployment packages with ease—it's as simple as 1, 2, and 3.

You do not pay for or require a license to create deployment packages using the WPSecure Personalization Packager. However, you need a license for the devices on which the personalization packages are installed. A device license entitles you to install up to 5 Personalization packages on the licensed device.

The following article provides a functional, hands-on approach to creating and deploying WPSecure Personalization Packages using Microsoft Intune or SCCM.

But, If you prefer to read our classic documentation, stay on this page.

Glossary

Packaging tool

Creates deployment packages that contain desktop backgrounds, lock screen images, Outlook signatures and Screensavers that can be easily deployed to on-premises and Cloud-connected Windows devices.

Package

This is created using the Packager and is then deployed using software deployment utilities such as SCCM, Intune or similar tools. See deployment instructions below.

Campaign manager

This tool generates the campaign file that dictates the start and end dates and the priority of packages. The Campaign file is optional and is deployed by using software deployment tools like SCCM, Microsoft Intune or similar tools.

Campaign file

This file is created using the Campaign Manager. It can be deployed using SCCM, Microsoft Intune, or other deployment tools. The Package with the highest version is picked in the absence of the Campaign file. See deployment instructions below.

Prerequisites

The Personalization packages created by the Packager and the Packager have the following prerequisites.

WPSecure Windows Personalization packages are only certified for use with physical devices such as Desktops, Laptops, and Tablets, where users are not logged in concurrently (simultaneously).

Operating System: Windows 10 20H2 or later, or a Microsoft-supported version of Windows 11.
.NET Framework: Version 4.8 or later.
Processor: 1 gigahertz (GHz)  or  faster with 2 or more cores on a compatible 64-bit processor core (The packages work on x86 devices but are not supported).

Memory: 4 GB RAM or greater. 8 GB or more is preferred.

Storage: 64 GB or larger storage device.

Functional WMI and .NET Framework.

No local or global policies prevent changing Desktop backgrounds, Lockscreen images, Outlook signatures, or Screensavers in the user context.

All necessary exceptions for AppLocker and other security products that may impede the seamless operation of WPSecure must be configured appropriately.

Outlook signature deployment requires Microsoft Office 2016, Office 365 Client or later desktop clients.

The system must not have any faulty drivers, mainly those related to display, storage, or the processor.

Log location

The Personalization Packager records its progress, failures, and exceptions in the below log file.

				
					%temp%\wpsecure-packager.log
				
			

The Personalization package installer which runs as the SYSTEM user or as an elevated Administrator records its progress, failures, and exceptions in the below log file.

				
					%SystemDrive%\Windows\Temp\wpsecure-install.log
				
			

The Personalization package uninstaller which runs as the SYSTEM user or as an elevated Administrator records its progress, failures, and exceptions in the below log file.

				
					%SystemDrive%\Windows\Temp\wpsecure-uninstall.log
				
			

Following are the log files pertaining to loading, brokering, events, and selection of the Personalization packages.

				
					%temp%\wpsecure-xx.xx.xxxx.xxxx.log
%temp%\wpsecureloader.log
%temp%\wpsecurebr.log
				
			

Set up your environment

The WPSecure Personalization Engine runs on the least-privilege principle: The goal is to keep the system safe. So, changes to desktop backgrounds, lock screen images, Outlook signatures, and Windows screensavers are done in the standard user context as non-admin. 

If changes occur, the WPSecure engine will identify them and reinforce standards at multiple events. In short, let the WPSecure engine enforce Desktop backgrounds, Lockscreen images, Outlook signatures, and Screensavers.

This section will guide you through the following steps. 

  • Hide the Settings pages corresponding to Desktop backgrounds, Themes, and the Lockscreen.
  • Remove Group Policies or similar Microsoft Intune CSP policies that prevent changing Desktop backgrounds, Themes, Lockscreen images, Outlook signatures, and Screensavers.
Hide Desktop background, Lockscreen & Themes settings panels

After removing policies that restrict users from changing the desktop background, you can hide these options from the Control Panel using the Group Policy Editor. Here’s how:

  1. Open AD Group Policy editor.
  2. In the left pane, navigate to User Configuration\Administrative Templates\Control Panel.
  3. In the right pane, double-click on “Settings Page Visibility“.
    Select Enabled and then click on the Show button next to the List of Disallowed Control Panel items.
    In the Value column, type “Hide:personalization-background;lockscreen;themes“.
Remove AD Group Policies relating to Desktop backgrounds

Local and global policies that prevent end-users from changing desktop backgrounds and themes will conflict with the WPSecure desktop background processing engine. We recommend removing these policies and hiding the corresponding Windows Control Panel items or panels. 

Below are two policies that will prevent the WPSecure engine from changing the desktop background. So it is recommended to either remove or not configure them.

  1. Prevent Changing Desktop Background: This Group Policy can be found under User Configuration\Administrative Templates\Control Panel\Personalization. If this policy is enabled, it will prevent users from changing the desktop background.

  2. Desktop Wallpaper: This Group Policy can be found under User Configuration\Administrative Templates\Desktop\Desktop. If enabled, this policy will specify the desktop wallpaper and prevent the proper functioning of the WPSecure desktop background engine. We recommend setting all settings in the below page to “Not Configured”

Desktop Background Group Policy Not Configured

The below table is a Window Registry representation of the above Group policies. Make sure none of the values displayed in the table below are set.

Registry PathValue NameIncorrect Setting
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\ActiveDesktopNoChangingWallPaper1
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\SystemWallpaperExist
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\SystemWallpaperExist
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\SystemWallpaperStyle1 or 2
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\SystemWallpaperStyle1 or 2

HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\ActiveDesktop

NoChangingWallPaper1

The best test is to change the desktop wallpaper image manually. If you can do this, your system will be ready to handle customization deployment using WPSecure packages.

After resolving all policy conflicts, including but not limited to those mentioned above, you may hide the Windows panels and menus associated with changing desktop backgrounds and themes. To clarify, the objective is to hide the controls for changing desktop backgrounds and themes rather than limiting access to these features.

Hide Desktop background, Lockscreen & Themes settings panels

After removing policies that restrict users from changing the desktop background, you can hide these options from the Control Panel using the Group Policy Editor. Here’s how:

  1. Open AD Group Policy editor.
  2. In the left pane, navigate to User Configuration\Administrative Templates\Control Panel.
  3. In the right pane, double-click on “Settings Page Visibility“.
    Select Enabled and then click on the Show button next to the List of Disallowed Control Panel items.
    In the Value column, type “Hide:personalization-background;lockscreen;themes“.
Remove AD Group Policies relating to Lockscreen images

The WPSecure Personalization Engine will manage the Lock Screen image. Remove other policies that govern these settings and set them to ‘Not Configured‘.

  • Open AD Group Policy editor.
  • Navigate to Computer Configuration\Administrative Templates\Control Panel\Personalization.
Remove AD Group Policies relating to Screensavers

The WPSecure Personalization Engine will manage Screensavers. Remove other policies that govern these settings and set them to ‘Not Configured‘.

  • Open AD Group Policy editor
  • Navigate to User Configuration / Policies / Administrative Templates / Control Panel / Personalization
  • Double-click the policy named “Force specific screen saver“.
  • Set the policy to “Not Configured“.
Remove AD Group Policies relating to Outlook Signatures

The WPSecure Personalization Engine will manage Outlook Signatures. Remove other policies that govern these settings and set them to ‘Not Configured‘.

  • Open AD Group Policy editor.
  • Navigate to User Configuration / Administrative Templates / Microsoft Outlook / Outlook Options / Mail Format.
  • Double-click on the “Do not allow signatures for e-mail messages” setting.
  • Choose “Not Configured”

Personalization Packager installation

The Personalization Packager is available for download by clicking on the button located in the top right corner of this page. The download consists of a compressed ZIP file that contains a Microsoft Installer (MSI) file, accompanied by a Digital Signature issued by Sectigo, a reputable computer security service based in Roseland, New Jersey. To ensure the authenticity and safety of the installer, it is important to only download it from this website and not from any other source.

To install an MSI file on a Windows computer, you must first ensure that you are signed in as an administrator. Once you have located the MSI file, simply double-click it to run the installer and start the installation wizard. Follow the prompts to complete the installation process. Alternatively, you can use the Command Prompt or PowerShell to install an MSI file by using the command

				
					msiexec /i [location of MSI file]
				
			

The MSI installs the following applications.

  1. The Packager
  2. The Campaign Manager.

 

Desktop backgrounds, Outlook signatures and screensavers

Uninstall Personalization Packager

To uninstall the Packager, open ‘Windows Programs and Features,’ select ‘WPSecure Personalization Packager,’ and click ‘Uninstall.’

Personalization items

The Personalization Packager allows you to bundle your personalization elements, such as Desktop backgrounds, lock screen images, Outlook signatures, and screensavers, into a deployment package that can be easily deployed to locally networked and Cloud-connected devices.

The Personalization Packager creates self-contained personalization deployment packages that are deployed to Windows 10 and 11 devices.

Note: The Personalization deployment packages are x86-based assemblies that can run on both 64-bit and 32-bit (not supported) architectures. However, the Personalization Packager itself can only install and run on 64-bit machines.

The Personalization Packager accepts 5 types of personalization items.

  1. Desktop backgrounds.
  2. Lock screen images.
  3. Microsoft Outlook signature for ‘New’ messages.
  4. Microsoft Outlook signature for ‘Reply’ messages.
  5. A Windows screensaver.
Desktop backgrounds

This module assigns unique desktop background images to each screen, ensuring that the image’s structure and message are preserved. For instance, a landscape-oriented computer monitor will be assigned a landscape background image, while a portrait-oriented monitor will be assigned a portrait background image. This ensures that the message remains clear.

If an image with the exact width and height of the screen is available, it will be assigned to that screen. If not, the desktop background engine will select an image with the same aspect ratio from a list of available images. If no such image is available, the engine will choose an image with the same orientation. If no such image is available, the engine will select the closest fitting image to the screen’s dimensions.

The module can also recalibrate and assign appropriately sized images in response to changes in screen resolution, orientation, or the addition of another screen, thereby preventing distortion or cropping. This feature enables laptop users to seamlessly transition between desks without manually resetting their wallpaper when connecting to different external monitors, thereby saving time and effort.

Each image’s file size must not exceed 10 MB, and we recommend keeping the total size of the personalization package under 500 MB. Ensure the image PPI (Pixels Per Inch) is set to 72 PPI. 

You can set a personalization package as a 'Pending Reboot' reminder package, displaying a 'Pending Reboot' message on Desktop backgrounds. For additional details, refer to the extra settings section below.

Lock screen images

You can include a maximum of 2 lock screen images in the package: one in landscape orientation and another in portrait orientation. Keep the file size as small as possible without compromising the quality of the image. The maximum file size cannot exceed 25 MB.

The lock screen is applied to the primary display of the device. Depending on image availability, a portrait image will be assigned to a screen oriented as portrait, and a landscape image will be assigned to a screen set as landscape. 

You can set a personalization package as a 'Pending Reboot' reminder package, displaying a 'Pending Reboot' message on Lockscreen images. For additional details, refer to the extra settings section below.

Microsoft Outlook signatures

There are two types of Microsoft Outlook signatures: a ‘New message’ signature and a ‘Reply message’ signature. The total file size of each Outlook signature and its assets cannot exceed 10 MB, and we recommend keeping the number of characters for each HTM file below 25,000.

New message signature: A new message signature is used when composing a new Microsoft Outlook message. It should include a ‘wpsecure_new.htm’ HTML file and optionally include a ‘wpsecure_new.txt’ file, a ‘wpsecure_new.rtf’ file, and an optional ‘wpsecure_new_files’ directory that contains resource files like images, CSS, etc.

Reply message signature: A reply message signature is used when replying to an email message. It should include a ‘wpsecure_reply.htm’ HTML file and optionally include a ‘wpsecure_reply.txt’ file, a ‘wpsecure_reply.rtf’ file, and an optional ‘wpsecure_reply_files’ directory that contains resource files like images, CSS, etc.

Use placeholders like {{az_displayname}}, {{az_mobilephone}}, or {{az_jobtitle}} in the ‘wpsecure_new.htm’,‘wpsecure_new.rtf’, ‘wpsecure_new.txt’, ‘wpsecure_reply.htm’, ‘wpsecure_reply.rtf’, and ‘wpsecure_reply.txt’ files to automatically load user-specific data at runtime. The WPSecure Outlook signature engine replaces the placeholders with the information in the registry corresponding to each placeholder. If the Keypath does not exist, create it. For example, the following registry entry will replace the placeholder {{az_surname}}.

Key path

HKEY_CURRENT_USER\Software\Microsoft\Office\Outlook\wpsecure\signature

Sub key

Billy.George@mycompany.email

Name

az_surname

Value

George

Type

REG_SZ

If your organization uses Azure AD (Entra ID), there are two ways to set the values for the Microsoft Outlook signature placeholders programmatically. Both options require setting up AzureAD (EntraID) App registration.

Click here to learn how to create an app registration in Entra ID/Azure and deploy the placeholder’s values.

Important note: If your Outlook signature templates have placeholders and multiple user-attribute values corresponding to the placeholders are not available, the signature will not be displayed.

User self-service sync

Allow Users to download placeholder data for their Outlook signatures (Preferred method).

Organization wide silent sync

Allow Administrators to download placeholder data for Outlook signatures on behalf of the Users.

If legacy Active Directory Services are used, User attributes will automatically synchronize (If your environment is setup correctly).

Attributes synchronized from Azure have a prefix of ‘az_‘.  Example: ‘az_attributename‘,
and the attributes synchronized from Active Directory Services have an ‘ad_‘ prefix. Example: ‘ad_attributename‘.

Using custom automation, You can manually create your placeholders or sync them from other sources. Example: ‘my_custom_attribute‘.

The following table outlines the supported attributes for Azure and Active Directory Services.

Active DirectoryAzure (Entra)Description
ad_telephonenumberaz_businessphones1Phone number associated with the user.
ad_laz_cityCity where the user is located.
ad_companyaz_companynameName of the user’s company or organization.
ad_caz_countryCountry code or name where the user resides.
ad_departmentaz_departmentDepartment or team within the organization.
ad_displaynameaz_displaynameUser’s display name (usually first and last name).
ad_employeeidaz_employeeidUnique identifier for the employee.
ad_facsimiletelephonenumberaz_faxnumberFax number associated with the user.
ad_givennameaz_givennameUser’s first name.
ad_titleaz_jobtitleJob title or position within the organization.
ad_mailaz_mailEmail address of the user.
ad_mailnicknameaz_mailnicknameUnique nickname for the user’s email address.
ad_mobileaz_mobilephoneMobile phone number of the user.
ad_officeaz_officelocationPhysical office location or workspace.
ad_postalcodeaz_postalcodePostal code or ZIP code of the user’s address.
ad_staz_stateState or region where the user resides.
ad_streetaddressaz_streetaddressStreet address of the user.
ad_snaz_surnameUser’s last name or surname.
ad_userprincipalnameaz_userprincipalnamePrincipal name used for authentication (usually the email address).
Windows screensaver

 The file size of the screensaver video file must be at most 50 MB. Import a video with the .MP4 file extension. WPSecure utilizes MP4 files, also known as MPEG-4 video files, for Screensaver.

Ensure that the videos used are of high resolution and quality. This will help to create a visually appealing and professional-looking screensaver.

You can set a personalization package as a 'Pending Reboot' reminder package, displaying a 'Pending Reboot' message on the video Screensaver. For additional details, refer to the extra settings section below.

The Personalization Packager does not control Screensaver settings like ‘Wait‘ or ‘On resume, display logon screen.‘ Set these values using Global or Local Policies. Ensure there are no Policies preventing users from changing the Screensaver is being applied.

Using the Personalization packager

You can launch the Personalization Packager from the start menu. Upon opening the application, you will be presented with the ‘Terms of Use and Service’ page. Please take a moment to review it.

Listed below are the actions triggered by each button on this page.

Import desktop background images: To import multiple images in JPG format, click on this button. A file explorer window will open, allowing you to select a folder containing the images you want to import. Please note that the packager only allows up to 90 desktop background images of varying dimensions and orientations. Each image should not exceed 10 MB, and the Image Width and Height cannot be a decimal/fraction. If any of these conditions are not met, the import process may fail.

Import lock screen image: You can import two lock screen images: one in landscape orientation and another in portrait orientation. The file size of each image should not exceed 25 MB.

Import Outlook signature: Import a Microsoft Outlook signature HTM file.

Import screensaver: Import a video file in MP4 file format.

Remove selected items: Select an item from the list to remove it.

Remove all items: Click this button to remove all items in the list. This can be useful when you want to clear out all existing items before uploading new ones, or if you want to start fresh with a new personalization package.

Create personalization package: Use this button to export the personalization package to a folder. A personalization package is a collection of all the settings and files you have imported or created for your desktop backgrounds, Outlook signatures, and screensavers.  The selected destination folder has to be empty. The personalization package creation process creates two folders: general_install and intune_install.

The general_install folder contains installation files for deployment via enterprise software management tools like Microsoft Endpoint Configuration Manager (SCCM). Run the ‘wpsecure-install.exe’ to install the personalization package. More details regarding the enterprise installation and uninstallation process are in the ‘documentation.html’ file.

The intune_install folder contains the ‘wpsecure-install.intunewin’ file to be uploaded to the Microsoft Endpoint Device Management portal (Intune). The command-line for this is identical to the general install.

The process also creates a documentation.html file that provides all the information required to deploy the personalization package, like package version, install command line, uninstall command line, and detection methods.

Desktop Personalization deployment

The image below displays the Packager interface when one or more personalization items have been loaded. To preview the content, click on each item.

Note: Please refrain from altering the items while in preview mode. Doing so will result in a fatal error and cause the process to fail.

If one or more items should fail import, the following screen will report the failed item. You can understand the problem better by looking at the log file in the following location.

				
					%temp%\wpsecure-packager.log
				
			

Personalization package installation

A personalization package is a collection of all the settings and files you have imported, such as desktop backgrounds, lock screen images, Outlook signatures, and screensavers.  The personalization package creation process creates two folders: general_install and intune_install.

The general_install folder contains installation files for deployment via enterprise software management tools like Microsoft Endpoint Configuration Manager (SCCM). Run the ‘wpsecure-install.exe’ to install the personalization package. More details regarding the enterprise installation and uninstallation process are in the ‘documentation.html’ file.

The intune_install folder contains the ‘wpsecure-install.intunewin’ file to be uploaded to the Microsoft Endpoint Device Management portal (Intune). The command line for this is identical to the general install.

The process also creates a documentation.html file that provides all the information required to deploy the personalization package, such as the package version, the install and uninstall command lines, and detection methods.

Install command line

The install command line is the same for deployment via Microsoft Endpoint Configuration Manager, Intune, or other deployment tools.

The general install package is in the ‘general_install‘ folder of the Personalization package output directory.

The install package for Microsoft Intune is in the ‘intune_install‘ folder of the Personalization package output directory.

Use the switch ‘-silent‘ to install the package silently.

				
					wpsecure-install.exe
				
			
				
					wpsecure-install.exe -silent
				
			
Install detection

Use the following file paths to detect if the Personalization package is installed on the target device.

For x86 Systems

				
					'C:\Program Files\wpsecure\packages\20.24.0421.1758\wpsecure.exe'
				
			

For x64 Systems

				
					'C:\Program Files (x86)\wpsecure\packages\20.24.0421.1758\wpsecure.exe'
				
			

In this example, ‘C:\‘ is the drive containing the ‘Program Files’ directory and ‘20.24.0421.1758‘ is the Personalization package version. Also, note that every single file in the above folder is crucial to the proper functioning of the Personalization package. Avoid moving, adding, or changing files outside the Personalization Packager before or after deployment.

Uninstall command line

The uninstall command line is the same for deployment via Microsoft Endpoint Configuration Manager, Intune, or other deployment tools.

The general uninstall package is in the ‘general_install’ folder of the Personalization package output directory.

The uninstall package for Microsoft Intune is in the ‘intune_install’ folder of the Personalization package output directory.

The Personalization package can also be uninstalled from the Control Panel’s Programs and Features section.

				
					wpsecure-uninstall.exe
				
			

The above command line will uninstall the version corresponding to this package.

				
					wpsecure-uninstall.exe -silent
				
			

The above command line will silently uninstall the version corresponding to this package.

				
					 wpsecure-uninstall.exe -all
				
			

The above command line will uninstall all Personalization packages.

				
					wpsecure-uninstall.exe -all -silent
				
			

The above command line will silently uninstall all Personalization packages

				
					wpsecure-uninstall.exe 20.24.0421.1758
				
			

The above command line will uninstall the Personalization package version “20.24.0421.1758”.

				
					wpsecure-uninstall.exe 20.24.0421.1758 -silent
				
			

The above command line will silently uninstall the Personalization package version “20.24.0421.1758”.

The Campaign Manager

This tool creates a campaign file. The campaign file gets mass deployed to devices. The file name of the campaign file is ‘wpsecure.campaigns’. The file contains information regarding each personalization package’s start dateend date, and priority. Click the add new campaign button below to add a new campaign and the remove selected items button to remove one or more campaigns. You can open the Campaign Manager from the Windows start menu. A successful sign-in will land you on the following Screen.

Click on the add new campaign button to create a new campaign. Alternatively, click on Import an existing campaign file to open campaigns saved into a previously saved campaigns file.

Campaign number: Assign a positive numeric value. While this does not have technical value, this value is used to maintain uniqueness.

Package version: This is the version corresponding to the Personalization package. You’ll find the value in the ‘documentation.html‘ file of the Package installer.

Start and End dates: When the campaign will start and end.

Campaign Priority: This numeric value plays a crucial role in conflict resolution. In scenarios where two Personalization packages share the same schedule, and the WPSecure personalization engine encounters a conflict, the Priority value determines which Personalization package takes precedence.

Group number: Assign a collection of Users the same ‘Group number’ and target specific Personalization Packages to them based on a schedule. The group number can be assigned to a User using the command below. This command has to be run in the User context.

				
					wpsecure-set.exe -groupid 1475
				
			

Click the buttons below to either import an existing campaign file or generate a new campaign file. The file name of the campaign file is ‘wpsecure.campaigns’.

The window after adding a campaign or importing an existing campaign file will look similar to the below window.

The campaign generation process creates two folders: general_install and intune_install. The general_install folder contains installation files for deployment via enterprise software management tools like Microsoft Endpoint Configuration Manager (SCCM). Run the ‘wpsecurecc.exe’ file to copy the campaign file to the correct location.

The intune_install folder contains the ‘wpsecurecc.intunewin’ file that can be uploaded to the Microsoft Endpoint Device Management portal (Intune). The command line for this is identical to the general install.

The process also creates a documentation.html file that provides all the information required to deploy the campaign file, like install command line, uninstall command line, and detection methods. Save this file for future reference regarding the personalization Package versions, start dates, end dates, and priority.

Once the campaign file has been deployed to Windows 10 and 11 devices, the Personalization Packages corresponding to the best-fitting campaign listed in the campaign file will be triggered.

Campaign file installation

The install command line is the same for deployment via Microsoft Endpoint Configuration Manager, Intune, or other deployment tools.

The general campaign install package is in the ‘general_install‘ folder of the Campaign package output directory.

The campaign install package for Microsoft Intune is in the ‘intune_install‘ folder of the Campaign package output directory.

Install command line

Campaign file installation always runs in silent mode. Use the below command line to install the campaign file.

				
					  wpsecurecc.exe

				
			
Install detection

Use the following Windows Registry key/value pair to detect if the campaign is installed on the target device.

Key path

HKEY_LOCAL_MACHINE\SOFTWARE\wpsecure

Name

wpsecurecampaignversion

Value

20.23.0918.1728

The campaign version number will be referenced in the ‘documentation.html‘ file generated during the “campaign file deployment package” creation process.

Uninstall command line

The uninstall command line is the same for deployment via Microsoft Endpoint Configuration Manager, Intune, or other deployment tools.

The general campaign uninstall package is in the ‘general_install‘ folder of the Campaign package output directory.

The campaign uninstall package for Microsoft Intune is in the ‘intune_install‘ folder of the Campaign package output directory.

				
					wpsecurecc.exe -remove
				
			

Package selection criteria

You can install up to 5 WPSecure Personalization Packages on each device.

The list below gives you an idea of how the WPSecure engine will pick the right package.

Identify all locally installed packages.

Is there a Campaigns file? Yes or No.

List campaigns that have an active schedule. (If Campaigns files exist).

Limit lists to only campaigns that target the Users GroupID. (If Campaigns files exist).

Generate a list of packages sorted by campaign priority. (If Campaigns files exist).

Do a secondary sort based on the package version hierarchy. (If Campaigns files exist).

Add the Default package version to the bottom of the list if not already in the above list. (If default package version is set).

Add the remaining locally installed packages to the bottom of the list without the packages excluded by the Campaign file.

The WPSecure engine will select the first personalization package shortlisted based on the above criteria for each personalization element. 

Desktop backgrounds.

Lock screen images.

Outlook signature for 'New' messages.

Outlook signature for 'Reply' messages.

Windows screensavers.

You can create priorities, defaults, and catch-alls in multiple ways. This can be done using the combination of the Campaign file, setting default packages, and package version hierarchies, allowing for a tailored configuration.

We recommend first creating a default package and rolling out this package to all your Windows 10 and 11 devices. Include Desktop backgrounds, Outlook signature, and Windows screensaver in this package.

Commands to apply extra settings

The executable is in the WPSecure application directory within the ProgramFiles (x86) directory.

Default Personalization Package

You can set a specific package version as the default version. The default package will be picked from the list of locally installed packages, even if it’s not the greatest version.

Note: The package set as default will be overridden by packages referenced in the campaign file. Run this command as an administrator.

				
					wpsecure-set.exe -dpv 20.24.0225.1230
				
			

Pending reboot messaging

Windows Operating System health is directly related to consistent device restart cycles. Use Desktop backgrounds, lock screen images, and Video screensavers to remind Users when a restart cycle is pending. Designate a personalization package as a ‘Pending Restart’ reminder package. Only the following modules can use this feature.

  • Desktop backgrounds
  • Lock Screen images
  • Screensavers

Run the following command as an administrator or as a SYSTEM.

				
					wpsecure-set.exe -prpv 20.24.0623.1319
				
			

You can detect this setting using the following registry location.

Key path

HKEY_LOCAL_MACHINE\SOFTWARE\wpsecure

Name

wpsecurependingrebootdisplaypackageversion

Type

REG_SZ

Value

20.24.0623.1319

Compliance and remediation scripts in Microsoft Intune or SCCM can help you set the above ‘pendingreboot‘ flag.

Your ‘detection’ script can look similar to the below Powershell script.

				
					if (!(Get-Module -ListAvailable -Name PendingReboot)) { 
    #Install Nuget Provider.
    Install-PackageProvider -Name Nuget -Force
    #Install Nuget Pending Reboot Module.    
    Install-Module -Name PendingReboot -Force    
} 
if (Get-Module -ListAvailable -Name PendingReboot -ErrorAction SilentlyContinue) {    
    #Check pending reboot
    if((Test-PendingReboot -ErrorAction SilentlyContinue).IsRebootPending) {        
        #Reboot is pending
        exit 1
    } else {
        #Reboot is not pending
        Remove-ItemProperty -Path HKLM:\SOFTWARE\WPSecure -Name pendingreboot -Force -ErrorAction SilentlyContinue
        exit 0
    }
} else {
    #Module was not installed or is not available. How would you like to handle this.
    #if exit value is 1 Pending Reboot flag will be set. If exit value is 0 Pending Reboot value will not be set.    
    exit 0
}
				
			

Your ‘remediation’ script can look similar to the below Powershell script.

				
					Set-ItemProperty -Path HKLM:\SOFTWARE\WPSecure -Name pendingreboot -Type DWord -Value 1 -Force -ErrorAction SilentlyContinue
				
			

Disable or enable the WPSecure management engine.

There may be instances where it is desirable to disable WPSecure without uninstalling the WPSecure Windows Personalization Packages. Run as administrator.

				
					wpsecure-set.exe -disable
				
			
				
					wpsecure-set.exe -enable
				
			

Run the following command as administrator to turn off only the background processing engine. Do this on devices where you want to permanently turn off the desktop background deployments using WPSecure. Default is enabled

				
					wpsecure-set.exe -disablebg
				
			
				
					wpsecure-set.exe -enablebg
				
			

Run the following command as administrator to turn off only the Outlook signature processing engine. Do this on devices where you want to permanently turn off the Outlook signature deployments using WPSecure. Default is enabled

				
					wpsecure-set.exe -disablesig
				
			
				
					wpsecure-set.exe -enablessig
				
			

Run the following command as administrator to turn off only the lock screen processing engine. Do this on devices where you want to permanently turn off the lock screen image deployments using WPSecure. Default is enabled

				
					wpsecure-set.exe -disablels
				
			
				
					wpsecure-set.exe -enablesls
				
			

Run the following command as administrator to turn off only the Windows screensaver processing engine. Do this on devices where you want to permanently turn off the screensaver deployments using WPSecure. Default is enabled

				
					wpsecure-set.exe -disabless
				
			
				
					wpsecure-set.exe -enablesss
				
			

Campaign Group number

Assign a collection of Users with the same ‘Group number’ and target specific Personalization Packages to them based on a schedule. The group number can be assigned to a User using the command below.

This command has to be run in the User context.

				
					wpsecure-set.exe -groupid 1475
				
			

Logging

When something goes wrong within a complex system like WPSecure, log files provide a detailed list of events that occurred before the malfunction. This information helps troubleshoot issues effectively. You can turn ON and OFF logging by using the following command. Run as administrator. Default is ON. ‘el‘ = Enable and ‘dl‘ = Disable.

				
					wpsecure-set.exe -el
				
			
				
					wpsecure-set.exe -dl
				
			

Real-time Loading

This value determines if WPSecure packages load immediately after installation or wait until the user locks/unlocks the screen. Run as administrator. Default is enabled. ‘eroi‘ = Enable and ‘droi‘ = Disable.

				
					wpsecure-set.exe -eroi
				
			
				
					wpsecure-set.exe -droi
				
			

Screensaver

It is not ideal for the Screensaver to run endlessly. So, by default, it will return to the lockscreen after a 60-minute run. This setting can be changed using the below command. In this example, the Screensaver will return to the lockscreen after a 120-minute run. Input is in minutes.

This has to be run as an administrator.

				
					wpsecure-set.exe -ssrtls 120
				
			

AD Group Policy or Intune Configuration Service Provider usually sets the below value. But sometimes, the values have to be reinforced. This value pertains to the initiation of the Screensaver. How long after the device is idle should the Screensaver start? Make this value the same as other Providers who enforce the same setting. In the below example, the Screensaver timeout is set to 360 seconds or 6 minutes. Input is in minutes.

This command has to run in the User context.

				
					wpsecure-set.exe -ssto 360
				
			

AD Group Policy or Intune Configuration Service Provider usually sets the below value. But sometimes, the values have to be reinforced. Show the login screen after Screensaver exits. ‘0‘ does not return to the login screen, and ‘1‘ returns to the login screen.

This command has to run in the User context.

				
					wpsecure-set.exe -ssis 1
				
			

Outlook Signature

Azure AD users can automatically synchronize their account attributes (supported attributes are listed below) with the registry location mentioned above. Users can initiate the synchronization process by clicking on the StartMenu shortcut, created by running the below-specified executable and providing the necessary parameters. Click here to read more.

TenantID and ClientID values will be generated during the Azure app registration (Discussed above). The version is just your internal deployment identifier to be used if you were to deploy this using Software deployment tools like SCCM or Microsoft Intune.

Users can click on the shortcut to trigger the synchronization. The command below has to be run as administrator.

				
					wpsecure-set.exe -source azure -tenantid 9fb4d4d6-7541-490f-a49a-111d3393731f -clientid 55eba948-6cdd-4b98-ad9b-7ff7b36138c6 -createsc -version 1.23.56.9
				
			

The above shortcut can be removed using the following command. The last personalization package that gets uninstalled from a device will also remove the shortcut. The command has to be issued as an administrator.

				
					wpsecure-set.exe -smsssc
				
			

Running the below command in the logged-in user context can initiate an organization-wide Outlook signature placeholder sync. Click here to read more.

				
					wpsecure-set.exe -source azure -tenantid 9fa4d436-7741-492f-a49a-001d3392731f -clientid 45eab948-6cdd-4b98-ad9b-7ff6b36038c4 -secret AzR8T2DKUe4.mKsugDLS8~ijvOr2XB9Tq45MxcT- -version 1.2.3.4
				
			

If your organization uses legacy Active Directory Services, run the command below in the User context. But, the WPSecure Outlook signature processing engine does this automatically. 

				
					wpsecure-set.exe -source ad
				
			

Run the command below as a standard user to remove the user’s Outlook signature data synced from Azure AD (Entra ID) or Active Directory. If you want to permanently uninstall WPSecure, run this command before uninstalling the last WPSecure Personalization package.

				
					wpsecure-set.exe -sigdatadel
				
			

The WPSecure Outlook signature processing engine sets the default ‘New’ and ‘Reply’ message signatures. If the user changes the default signatures, the engine will replace the defaults at the next event trigger. Such a setup allows users to add or use another signature during the current session.

Run the following command as administrator to prevent users from changing the defaults. The default setting is “enabled“.

Note: When disabled, only the primary Outlook account (Windows user account or the Office license holder) will have the default Outlook signature set. Other Outlook profiles will not have the default set. Neither the primary nor the secondary profiles can add, remove signatures or default assignments; they can use signatures set by the WPSecure engine.

				
					wpsecure-set.exe -dsigchange
				
			

Run the following command as administrator to allow users to change the defaults.

				
					wpsecure-set.exe -esigchange
				
			

Outlook roaming signature files (HTM, TXT, and RTF) usually have the User’s Outlook account email address suffixed to the file’s name, such as ‘wpsecure_new (my.email@myorg.com).htm‘. However, in some hybrid environments, the suffix might be the User UPN (User Principal Name) instead of the User email address.

WPSecure Outlook signature processing engine makes every effort to identify the relevant suffix regardless of the Exchange server configuration. However, the setting below helps the process by directing the engine to use UPN or Email. 

Industry experts recommend that User accounts in O365 environments use the same email and UPN. However, your organization might prefer different values. These settings might not be required, but if the Outlook default signatures are not correctly set because the User email is not the same as the User’s UPN, use the command below to force the use of either the UPN or the email. Run the command as an Administrator.

				
					wpsecure-set.exe -osaeu 1
				
			

Run the above command as administrator to direct the engine to use the Users email address.

				
					wpsecure-set.exe -osaeu 2
				
			

Run the above command as administrator to direct the engine to use the User’s UPN (User Principal Name).

				
					wpsecure-set.exe -osaeu 0
				
			

Run the above command as administrator to delete the above setting.

The “Store my Outlook settings in the cloud” feature was introduced in Outlook Desktop for Microsoft 365 accounts with cloud mailboxes using the Monthly Enterprise Channel, Current Channel, or Semi-Annual Enterprise Channel (version 2108).

We recommend using this feature. The feature SYNC’s the Outlook signatures created by the WPSecure signature processing engine to the Cloud.

But if you want to turn off Outlook signature roaming, run the below command as a standard user.

				
					wpsecure-set.exe -drstt
				
			

The above command disables Outlook signature roaming.

				
					wpsecure-set.exe -erstt
				
			

The above command enables Outlook signature roaming. If you disabled it in the past, use the command to reenable it.

If Outlook signature roaming is enabled, the WPSecure Outlook signature processing engine will request an immediate SYNC of the signature. The command below will direct the engine not to request Outlook to SYNC immediately. If roaming is enabled, the Outlook client will still SYNC the signature on a schedule, just not immediately. The command will also disable the Outlook Web Plugin functionality currently under development.

To disable this option, run the following command as the administrator.

				
					wpsecure-set.exe -dsigstc
				
			

Run the following command as administrator to enable the setting mentioned above.

				
					wpsecure-set.exe -esigstc
				
			

Articles

The following articles provide a functional, hands-on approach to creating and deploying WPSecure Personalization Packages using Microsoft Intune or SCCM.

However, we recommend reading through the current documentation page to learn the details of the WPSecure Personalization Packager. 

Deploy Windows Personalization packages using Microsoft Intune – Click here.

How Would NASA Manage Outlook Signatures, Desktop Backgrounds, Lock Screen Images, And Screensavers? – Click here.

Deploy Video Screensavers, Desktop Wallpapers, Outlook Email Signatures, And Lock Screen Images Using Microsoft Intune – A Global Coffee Shop Brand – Click here.

Create and deploy Outlook email signature from Microsoft Online Template Repo using Intune (linkedIn) – Click here.

Deploy Outlook email signature only using Microsoft Intune – Click here.

Deploy Windows Personalization packages using Microsoft SCCM – Click here.

Deploy Outlook email signature only using SCCM – Click here.

Set Windows Lock Screen images using Microsoft Intune – Click here.

Show ‘Pending Reboot’ messages with Personalization packages – Click here.