3942 lines
200 KiB
Plaintext
3942 lines
200 KiB
Plaintext
'******************************************************************************
|
|
'*
|
|
'* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
'*
|
|
'* Module Name: PAGEFILECONFIG.vbs
|
|
'*
|
|
'* Abstract: Enables an administrator to display and configure
|
|
'* a systems Virtual Memory paging file settings.
|
|
'*
|
|
'*
|
|
'******************************************************************************
|
|
|
|
OPTION EXPLICIT
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
'******************************************************************************
|
|
' Start of Localization Content
|
|
'******************************************************************************
|
|
|
|
' Valid volume pattern [ a,b drives are invalid ]
|
|
CONST L_VolumePatternFormat_Text = "^([b-zB-Z]:|\*)$"
|
|
|
|
' constants for showresults
|
|
CONST L_Na_Text = "N/A"
|
|
CONST L_MachineName_Text = "System Name"
|
|
CONST L_User_Text = "User"
|
|
CONST L_Password_Text = "Password"
|
|
CONST L_Intsize_Text = "Initial Size"
|
|
CONST L_Maxsize_Text = "Maximum Size"
|
|
CONST L_Volume_Text = "Volume Name"
|
|
CONST L_Format_Text = "Format"
|
|
|
|
' the column headers used in the output display
|
|
CONST L_ColHeaderHostname_Text = "Host Name"
|
|
CONST L_ColHeaderDrive_Text = "Drive/Volume"
|
|
CONST L_ColHeaderVolumeLabel_Text = "Volume Label"
|
|
CONST L_ColHeaderFileName_Text = "Location\File Name"
|
|
CONST L_ColHeaderInitialSize_Text = "Initial Size"
|
|
CONST L_ColHeaderMaximumSize_Text = "Maximum Size"
|
|
CONST L_ColHeaderCurrentSize_Text = "Current Size"
|
|
CONST L_ColHeaderPageFileStatus_Text = "Page File Mode"
|
|
CONST L_ColHeaderFreeSpace_Text = "Total Free Space"
|
|
CONST L_ColHeaderTotalMinimumSize_Text = "Total (All Drives): Minimum Size"
|
|
CONST L_ColHeaderTotalRecommendedSize_Text = "Total (All Drives): Recommended Size"
|
|
CONST L_ColHeaderTotalSize_Text = "Total (All Drives): Currently Allocated"
|
|
|
|
|
|
' Maximum Column Header Lengths used to display various fields.
|
|
' Localization team can adjust these columns to fit the localized strings.
|
|
|
|
' constants for data lengths for ShowResults (15,13,13,19,20,20,20,22)
|
|
CONST L_CONST_HOSTNAME_Length_Text = 15
|
|
CONST L_CONST_DRIVENAME_Length_Text = 19
|
|
CONST L_CONST_VOLLABEL_Length_Text = 17
|
|
CONST L_CONST_PAGEFILENAME_Length_Text = 19
|
|
CONST L_CONST_INTSIZE_Length_Text = 20
|
|
CONST L_CONST_MAXSIZE_Length_Text = 20
|
|
CONST L_CONST_CURRENTSIZE_Length_Text = 20
|
|
CONST L_CONST_FREESPACE_Length_Text = 22
|
|
CONST L_ColHeaderPageFileStatusLength_Text = 20
|
|
|
|
|
|
' constants for data lengths for ShowResults (15,33,37,40)
|
|
CONST L_CONST_TOTALMINSIZE_Length_Text = 33
|
|
CONST L_CONST_TOTALRECSIZE_Length_Text = 37
|
|
CONST L_CONST_TOTALSIZE_Length_Text = 40
|
|
|
|
|
|
' user reply for the warning messages
|
|
CONST L_UserReplyYes_Text = "y"
|
|
CONST L_UserReplyNo_Text = "n"
|
|
|
|
'Constants for indication of page file status
|
|
CONST L_CONST_System_Managed_Text = "System Managed"
|
|
CONST L_Custom_Text = "Custom"
|
|
|
|
' constants for CScript usage
|
|
CONST L_UseCscript1_ErrorMessage = "This script should be executed from the command prompt using CSCRIPT.EXE."
|
|
CONST L_UseCscript2_ErrorMessage = "For example: CSCRIPT %windir%\System32\PAGEFILECONFIG.vbs <arguments>"
|
|
CONST L_UseCscript3_ErrorMessage = "To set CScript as the default application to run .vbs files, run the following:"
|
|
CONST L_UseCscript4_ErrorMessage = " CSCRIPT //H:CSCRIPT //S"
|
|
CONST L_UseCscript5_ErrorMessage = "You can then run ""%windir%\System32\PAGEFILECONFIG.vbs <arguments>"" without preceding the script with CSCRIPT."
|
|
|
|
' common constants for showing help for all the options
|
|
CONST L_UsageDescription_Text = "Description:"
|
|
CONST L_UsageParamList_Text = "Parameter List:"
|
|
CONST L_UsageExamples_Text = "Examples:"
|
|
CONST L_UsageMachineName_Text = " /S system Specifies the remote system to connect to."
|
|
CONST L_UsageUserNameLine1_Text = " /U [domain\]user Specifies the user context under which"
|
|
CONST L_UsageUserNameLine2_Text = " the command should execute."
|
|
CONST L_UsagePasswordLine1_Text = " /P password Specifies the password for the given"
|
|
CONST L_UsagePasswordLine2_Text = " user context."
|
|
|
|
' constants for showing help
|
|
CONST L_ShowUsageLine02_Text = "PAGEFILECONFIG.vbs /parameter [arguments]"
|
|
CONST L_ShowUsageLine05_Text = " Enables an administrator to display and configure a system's "
|
|
CONST L_ShowUsageLine06_Text = " paging file Virtual Memory settings."
|
|
CONST L_ShowUsageLine08_Text = "Parameter List:"
|
|
CONST L_ShowUsageLine09_Text = " /Change Changes a system's existing paging file"
|
|
CONST L_ShowUsageLine10_Text = " Virtual Memory settings."
|
|
CONST L_ShowUsageLine12_Text = " /Create Creates/Adds an additional ""Paging File"" to a system."
|
|
CONST L_ShowUsageLine14_Text = " /Delete Deletes a ""Paging File"" from a system."
|
|
CONST L_ShowUsageLine16_Text = " /Query Displays a system's paging file"
|
|
CONST L_ShowUsageLine17_Text = " Virtual Memory settings."
|
|
CONST L_ShowUsageLine19_Text = "Examples:"
|
|
CONST L_ShowUsageLine20_Text = " PAGEFILECONFIG.vbs"
|
|
CONST L_ShowUsageLine21_Text = " PAGEFILECONFIG.vbs /?"
|
|
CONST L_ShowUsageLine22_Text = " PAGEFILECONFIG.vbs /Change /?"
|
|
CONST L_ShowUsageLine23_Text = " PAGEFILECONFIG.vbs /Create /?"
|
|
CONST L_ShowUsageLine24_Text = " PAGEFILECONFIG.vbs /Delete /?"
|
|
CONST L_ShowUsageLine25_Text = " PAGEFILECONFIG.vbs /Query /?"
|
|
|
|
' constants for showing help for /Change option
|
|
CONST L_ShowChangeUsageLine02_Text = "PAGEFILECONFIG.vbs /Change [/S system [/U username [/P password]]]"
|
|
CONST L_ShowChangeUsageLine03_Text = " { { [/I initialsize] [/M maximumsize] } | { /SYS } }"
|
|
CONST L_ShowChangeUsageLine04_Text = " /VO volume1 [/VO volume2 [... [/VO volumeN]]]"
|
|
CONST L_ShowChangeUsageLine07_Text = " Changes an existing paging file's Virtual Memory Settings."
|
|
CONST L_ShowChangeUsageLine18_Text = " /I initialsize Specifies the new initial size (in MB)"
|
|
CONST L_ShowChangeUsageLine19_Text = " to use for the paging file specified."
|
|
CONST L_ShowChangeUsageLine21_Text = " /M maximumsize Specifies the new maximum size (in MB)"
|
|
CONST L_ShowChangeUsageLine22_Text = " to use for the paging file specified."
|
|
CONST L_ShowChangeUsageLine24_Text = " /SYS systemmanaged Specifies that the page file has to "
|
|
CONST L_ShowChangeUsageLine25_Text = " be managed by the system."
|
|
CONST L_ShowChangeUsageLine27_Text = " /VO volumeletter Specifies the local drive who's paging"
|
|
CONST L_ShowChangeUsageLine28_Text = " file settings need to be changed. Specify"
|
|
CONST L_ShowChangeUsageLine29_Text = " '*' to select all the local drives."
|
|
CONST L_ShowChangeUsageLine30_Text = " Example: ""C:"" or ""*"""
|
|
CONST L_ShowChangeUsageLine33_Text = " PAGEFILECONFIG.vbs /Change /?"
|
|
CONST L_ShowChangeUsageLine34_Text = " PAGEFILECONFIG.vbs /Change /M 400 /VO c:"
|
|
CONST L_ShowChangeUsageLine35_text = " PAGEFILECONFIG.vbs /Change /VO c: /SYS"
|
|
CONST L_ShowChangeUsageLine36_Text = " PAGEFILECONFIG.vbs /Change /S system /U user /M 400 /VO c:"
|
|
CONST L_ShowChangeUsageLine37_Text = " PAGEFILECONFIG.vbs /Change /S system /U user /I 20 /VO *"
|
|
CONST L_ShowChangeUsageLine38_Text = " PAGEFILECONFIG.vbs /Change /S system /U user /P password /I 200"
|
|
CONST L_ShowChangeUsageLine39_Text = " /M 500 /VO c: /VO d:"
|
|
|
|
' constants for showing help for /Create option
|
|
CONST L_ShowCreateUsageLine02_Text = "PAGEFILECONFIG.vbs /Create [/S system [/U username [/P password]]]"
|
|
CONST L_ShowCreateUsageLine03_Text = " { {/I initialsize /M maximumsize} | { /SYS } }"
|
|
CONST L_ShowCreateUsageLine04_Text = " /VO volume1 [/VO volume2 [... [/VO volumeN]]]"
|
|
CONST L_ShowCreateUsageLine07_Text = " Creates/Adds an additional ""Paging File"" to a system."
|
|
CONST L_ShowCreateUsageLine18_Text = " /I initialsize Specifies the initial size (in MB) to use"
|
|
CONST L_ShowCreateUsageLine19_Text = " for the paging file being created."
|
|
CONST L_ShowCreateUsageLine21_Text = " /M maximumsize Specifies the maximum size (in MB) to use"
|
|
CONST L_ShowCreateUsageLine22_Text = " for the paging file being created."
|
|
CONST L_ShowCreateUsageLine24_Text = " /SYS systemmanaged Specifies that the page file has to "
|
|
CONST L_ShowCreateUsageLine25_Text = " be managed by the system."
|
|
CONST L_ShowCreateUsageLine27_Text = " /VO volumeletter Specifies the local drive on which the"
|
|
CONST L_ShowCreateUsageLine28_Text = " paging file has to be created. Specify '*'"
|
|
CONST L_ShowCreateUsageLine29_Text = " to select all the local drives."
|
|
CONST L_ShowCreateUsageLine30_Text = " Example: ""C:"" or ""*"""
|
|
CONST L_ShowCreateUsageLine33_Text = " PAGEFILECONFIG.vbs /Create /?"
|
|
CONST L_ShowCreateUsageLine34_Text = " PAGEFILECONFIG.vbs /Create /I 140 /M 300 /VO d:"
|
|
CONST L_ShowCreateUsageLine35_Text = " PAGEFILECONFIG.VBS /Create /VO c: /SYS"
|
|
CONST L_ShowCreateUsageLine36_Text = " PAGEFILECONFIG.vbs /Create /S system /U user /I 150 /M 300 /VO d:"
|
|
CONST L_ShowCreateUsageLine37_Text = " PAGEFILECONFIG.vbs /Create /S system /U user /I 50 /M 200 /VO *"
|
|
CONST L_ShowCreateUsageLine38_Text = " PAGEFILECONFIG.vbs /Create /S system /U user /P password /I 100"
|
|
CONST L_ShowCreateUsageLine39_Text = " /M 600 /VO d: /VO e: /VO f:"
|
|
|
|
' constants for showing help for /Delete option
|
|
CONST L_ShowDeleteUsageLine02_Text = "PAGEFILECONFIG.vbs /Delete [/S system [/U username [/P password]]]"
|
|
CONST L_ShowDeleteUsageLine03_Text = " /VO volume1 [/VO volume2 [... [/VO volumeN]]]"
|
|
CONST L_ShowDeleteUsageLine06_Text = " Deletes paging file(s) from a system."
|
|
CONST L_ShowDeleteUsageLine17_Text = " /VO volumeletter Specifies the local drive who's paging"
|
|
CONST L_ShowDeleteUsageLine18_Text = " file has to be deleted."
|
|
CONST L_ShowDeleteUsageLine19_Text = " Example: ""C:"""
|
|
CONST L_ShowDeleteUsageLine22_Text = " PAGEFILECONFIG.vbs /Delete /?"
|
|
CONST L_ShowDeleteUsageLine23_Text = " PAGEFILECONFIG.vbs /Delete /VO d:"
|
|
CONST L_ShowDeleteUsageLine24_Text = " PAGEFILECONFIG.vbs /Delete /S system /U user /VO d: /VO e:"
|
|
CONST L_ShowDeleteUsageLine25_Text = " PAGEFILECONFIG.vbs /Delete /S system /U user /P password /VO d:"
|
|
|
|
' constants for showing help for /Query option
|
|
CONST L_ShowQueryUsageLine02_Text = "PAGEFILECONFIG.vbs /Query [/S system [/U username [/P password]]]"
|
|
CONST L_ShowQueryUsageLine03_Text = " [/FO format] [/NH]"
|
|
CONST L_ShowQueryUsageLine06_Text = " Displays a system's paging file Virtual Memory settings."
|
|
CONST L_ShowQueryUsageLine17_Text = " /FO format Specifies the format in which the output"
|
|
CONST L_ShowQueryUsageLine18_Text = " is to be displayed."
|
|
CONST L_ShowQueryUsageLine19_Text = " Valid values: ""TABLE"", ""LIST"", ""CSV""."
|
|
CONST L_ShowQueryUsageLine21_Text = " /NH Specifies that the ""Column Header"" should"
|
|
CONST L_ShowQueryUsageLine22_Text = " not be displayed in the output."
|
|
CONST L_ShowQueryUsageLine25_Text = " PAGEFILECONFIG.vbs"
|
|
CONST L_ShowQueryUsageLine26_Text = " PAGEFILECONFIG.vbs /Query"
|
|
CONST L_ShowQueryUsageLine27_Text = " PAGEFILECONFIG.vbs /Query /?"
|
|
CONST L_ShowQueryUsageLine28_Text = " PAGEFILECONFIG.vbs /Query /FO table"
|
|
CONST L_ShowQueryUsageLine29_Text = " PAGEFILECONFIG.vbs /Query /FO csv /NH"
|
|
CONST L_ShowQueryUsageLine30_Text = " PAGEFILECONFIG.vbs /Query /S system /U user"
|
|
CONST L_ShowQueryUsageLine31_Text = " PAGEFILECONFIG.vbs /Query /S system /U user /P password /FO LIST"
|
|
|
|
' constants for error messages
|
|
CONST L_UnableToInclude_ErrorMessage = "ERROR: Unable to include the common module ""CmdLib.Wsc""."
|
|
CONST L_InvalidHelpUsage_ErrorMessage = "ERROR: Invalid Help Usage. Use only /? for help."
|
|
CONST L_InvalidParameter_ErrorMessage = "ERROR: Invalid argument/Option - '%1'."
|
|
CONST L_InvalidInput_ErrorMessage = "ERROR: Invalid input. Please check the input values."
|
|
CONST L_InvalidCredentials_ErrorMessage = "ERROR: Invalid credentials. Verify the machine, user and password given."
|
|
CONST L_InvalidVolumeName_ErrorMessage = "ERROR: Invalid volume '%1' specified."
|
|
CONST L_InvalidUserReply_ErrorMessage = "ERROR: Invalid choice. Enter a valid choice."
|
|
CONST L_FailCreateObject_ErrorMessage = "ERROR: Unable to create object."
|
|
CONST L_UnableToRetrieveInfo_ErrorMessage = "ERROR: Unable to retrieve information."
|
|
CONST L_CannotCreate_ErrorMessage = "ERROR: Paging file for the specified volume '%1' cannot be created."
|
|
CONST L_InvalidPhysicalDrive_ErrorMessage = "ERROR: Volume '%1' is not a valid physical drive."
|
|
CONST L_UpdateFailed_ErrorMessage = "ERROR: Paging file update failed."
|
|
CONST L_InvalidInitSizeValue_ErrorMessage = "ERROR: Enter a numeric value for the initial paging file size."
|
|
CONST L_InvalidMaxSizeValue_ErrorMessage = "ERROR: Enter a numeric value for the maximum paging file size."
|
|
CONST L_CONST_Systemmanaged_Earlier_Text = "ERROR: The page file on drive %1 is system managed. Both initial and maximum size must be specified."
|
|
|
|
' constant for hint message to show remote connectivity failure
|
|
CONST L_HintCheckConnection_Message = "ERROR: Please check the system name, credentials and WMI (WBEM) service."
|
|
|
|
' constants for info. messages
|
|
CONST L_PageFileDoesNotExist_ErrorMessage = "ERROR: No paging file exists on volume '%1'"
|
|
CONST L_NoPageFiles_Message = "ERROR: No paging file(s) available."
|
|
|
|
' constants for Syntax Error Messages
|
|
CONST L_InvalidSyntax_ErrorMessage = "ERROR: Invalid Syntax."
|
|
CONST L_InvalidServerName_ErrorMessage = "ERROR: Invalid Syntax. System name cannot be empty."
|
|
CONST L_InvalidUserName_ErrorMessage = "ERROR: Invalid Syntax. User name cannot be empty."
|
|
CONST L_NoHeaderNotAllowed_ErrorMessage = "ERROR: /NH option is allowed only for ""TABLE"" and ""CSV"" formats."
|
|
CONST L_TypeUsage_Message = "Type ""%1 /?"" for usage."
|
|
CONST L_TypeCreateUsage_Message = "Type ""%1 /Create /?"" for usage."
|
|
CONST L_TypeChangeUsage_Message = "Type ""%1 /Change /?"" for usage."
|
|
CONST L_TypeDeleteUsage_Message = "Type ""%1 /Delete /?"" for usage."
|
|
CONST L_TypeQueryUsage_Message = "Type ""%1 /Query /?"" for usage."
|
|
|
|
' constants for missing mandatory option messages
|
|
CONST L_VolumeNameNotSpecified_ErrorMessage = "Mandatory option '/VO' is missing."
|
|
CONST L_InitialSizeNotSpecified_ErrorMessage = "Either '/SYS' or both '/I' and '/M' are mandatory with Create option."
|
|
CONST L_MaximumSizeNotSpecified_ErrorMessage = "Mandatory option '/M' is missing."
|
|
CONST L_NoneoftheSizeSpecified_ErrorMessage = "Either '/SYS' or one of '/I' and '/M' are mandatory with Change option."
|
|
CONST L_CONST_NoneoftheSizes_AllowedWithSysManaged_Text = "Either '/I' or '/M' can not be specified with '/SYS'."
|
|
CONST L_FormatNotSpecified_ErrorMessage = "Mandatory options '/FO' is missing."
|
|
|
|
' error messages for invalid usage of s,u,p switches
|
|
CONST L_InvalidServerCredentials_ErrorMessage = "ERROR: Invalid Syntax. /U can be specified only when /S is specified."
|
|
CONST L_InvalidUserCredentials_ErrorMessage = "ERROR: Invalid Syntax. /P can be specified only when /U is specified."
|
|
|
|
' constants for Mutliple line Error Messages
|
|
CONST L_InsufficientMaxSize1_ErrorMessage = "ERROR: The maximum paging file size on volume '%1' should be greater than or "
|
|
CONST L_InsufficientMaxSize2_ErrorMessage = " equal to the initial paging file size, and less than %2 MB or less "
|
|
CONST L_InsufficientMaxSize3_ErrorMessage = " than the disk size."
|
|
CONST L_InitialSizeRange1_ErrorMessage = "ERROR: The initial paging file size must be between 2 MB and %1 MB, and "
|
|
CONST L_InitialSizeRange2_ErrorMessage = " cannot exceed the amount of free space on the drive '%2' selected. "
|
|
CONST L_NotEnoughSpace1_ErrorMessage = "ERROR: There is not enough space on the drive '%1' for the paging file"
|
|
CONST L_NotEnoughSpace2_ErrorMessage = " Please enter a smaller number or free some disk space."
|
|
CONST L_AtLeastFiveMB1_ErrorMessage = "ERROR: There is not enough space on the drive '%1' to create the paging file"
|
|
CONST L_AtLeastFiveMB2_ErrorMessage = " size specified. At least 5 megabytes of free disk space must be left"
|
|
CONST L_AtLeastFiveMB3_ErrorMessage = " after the paging file is created. Specify a smaller paging file size"
|
|
CONST L_AtLeastFiveMB4_ErrorMessage = " or free some disk space."
|
|
CONST L_DiskTooSmall1_ErrorMessage = "ERROR: Drive '%1' is too small for the maximum paging file size specified."
|
|
CONST L_DiskTooSmall2_ErrorMessage = " Please enter a smaller number."
|
|
CONST L_CannotDelete1_ErrorMessage = "ERROR: The paging file from volume '%1' cannot be deleted."
|
|
CONST L_CannotDelete2_ErrorMessage = " At least one paging file must be present."
|
|
|
|
' constants for Mutliple line Warning Messages
|
|
CONST L_GrowsToFreeSpaceWarning1_Message = "WARNING: Drive '%1' does not have enough free space for the maximum paging "
|
|
CONST L_GrowsToFreeSpaceWarning2_Message = " file specified. If you continue with this setting, the paging file "
|
|
CONST L_GrowsToFreeSpaceWarning3_Message = " will only grow to the size of the available free space (%2 MB)."
|
|
CONST L_CrashDumpSettingWarning1_Message = "WARNING: If the paging file on volume '%1' has an initial size of less than"
|
|
CONST L_CrashDumpSettingWarning2_Message = " %2, then the system may not be able to create a crash dump debugging"
|
|
CONST L_CrashDumpSettingWarning3_Message = " information file if a STOP error (blue screen) occurs."
|
|
|
|
' constants for Multiple line SUCCESS / SKIPPING messages
|
|
CONST L_ChangeIntSuccess1_Message = "SUCCESS: The initial size for the paging file on '%1' was changed from "
|
|
CONST L_ChangeIntSuccess2_Message = " %2 MB to %3 MB."
|
|
CONST L_ChangeMaxSuccess1_Message = "SUCCESS: The maximum size for the paging file on '%1' was changed from "
|
|
CONST L_ChangeMaxSuccess2_Message = " %2 MB to %3 MB."
|
|
CONST L_ChangeIntSkipping1_Message = "SKIPPING: The initial size specified for the paging file on '%1' is same as "
|
|
CONST L_ChangeIntSkipping2_Message = " the present value."
|
|
CONST L_ChangeMaxSkipping1_Message = "SKIPPING: The maximum size specified for the paging file on '%1' is same as "
|
|
CONST L_ChangeMaxSkipping2_Message = " the present value."
|
|
CONST L_CreateSuccess1_Message = "SUCCESS: A paging file with initial size of %1 MB and a maximum size "
|
|
CONST L_CreateSuccess2_Message = " of %2 MB was created on the volume: '%3'"
|
|
CONST L_CreateSkipping_Message = "SKIPPING: A paging file already exists on the volume: '%1'"
|
|
CONST L_DeleteSuccess_Message = "SUCCESS: The paging file from volume '%1' has successfully been removed."
|
|
CONST L_CreateSystemSuccess_message = "SUCCESS: The paging file of system managed size has been created on the volume: '%1'."
|
|
CONST L_ChangeSystemSuccess_message = "SUCCESS: The paging file on the volume '%1' has been changed to system managed size."
|
|
CONST L_CONST_Already_SystemManaged_Text = "ERROR: The page File on drive %1 is already system managed."
|
|
|
|
' constant for other error messages
|
|
CONST L_InvalidFormat_ErrorMessage = "Invalid format '%1' specified."
|
|
CONST L_SystemManagedSize_ErrorMessage = "ERROR: Volume '%1' is system managed."
|
|
CONST L_PromptForContinueAnyWay_Message = "Continue Anyway [y/n]?"
|
|
CONST L_NotAllowedMoreThanOnce_ErrorMessage = "'%1' option is not allowed more than '1' time."
|
|
CONST L_RestartComputer_Message = "Restart the computer for these changes to take effect."
|
|
|
|
'******************************************************************************
|
|
' END of Localization Content
|
|
'******************************************************************************
|
|
|
|
' constants used for format selection
|
|
CONST PatternFormat_Text = "^(table|list|csv)$"
|
|
CONST DefaultFormat_Text = "list"
|
|
CONST ListFormat_Text = "list"
|
|
|
|
' the main options
|
|
CONST OPTION_HELP = "?"
|
|
CONST OPTION_CHANGE = "change"
|
|
CONST OPTION_CREATE = "create"
|
|
CONST OPTION_DELETE = "delete"
|
|
CONST OPTION_QUERY = "query"
|
|
|
|
' the suboptions
|
|
CONST SUB_OPTION_SERVER = "s"
|
|
CONST SUB_OPTION_USER = "u"
|
|
CONST SUB_OPTION_PASSWORD = "p"
|
|
CONST SUB_OPTION_INTSIZE = "i"
|
|
CONST SUB_OPTION_MAXSIZE = "m"
|
|
CONST SUB_OPTION_VOLUME = "vo"
|
|
CONST SUB_OPTION_FORMAT = "fo"
|
|
CONST SUB_OPTION_NOHEADER = "nh"
|
|
CONST SUB_OPTION_SYSTEM_MANAGED = "sys"
|
|
|
|
' constant for CScript
|
|
CONST CONST_CSCRIPT = 2
|
|
|
|
' constants for error codes
|
|
CONST CONST_ERROR = 0
|
|
|
|
' constants for options
|
|
CONST CONST_SHOW_USAGE = 3
|
|
CONST CONST_CHANGE_OPTION = 11
|
|
CONST CONST_CREATE_OPTION = 21
|
|
CONST CONST_DELETE_OPTION = 31
|
|
CONST CONST_QUERY_OPTION = 41
|
|
|
|
' constant for matched pattern
|
|
CONST CONST_NO_MATCHES_FOUND = 0
|
|
|
|
' utility specific constants
|
|
CONST INITIAL_SIZE_LB = 2
|
|
CONST DRIVE_TYPE = 3
|
|
CONST MEGA_BYTES = " MB"
|
|
CONST SIZE_FACTOR = 1.5
|
|
CONST CONVERSION_FACTOR = 1048576
|
|
CONST PAGEFILE_DOT_SYS = "\pagefile.sys"
|
|
CONST CONST_SYSTEM_INIT_SIZE = 0
|
|
CONST CONST_SYSTEM_MAX_SIZE = 0
|
|
|
|
' constant for the UNC format server name
|
|
CONST UNC_FORMAT_SERVERNAME_PREFIX = "\\"
|
|
|
|
' constants for exit values
|
|
CONST EXIT_SUCCESS = 0
|
|
CONST EXIT_UNEXPECTED = 255
|
|
CONST EXIT_INVALID_INPUT = 254
|
|
CONST EXIT_METHOD_FAIL = 250
|
|
CONST EXIT_QUERY_FAIL = 253
|
|
CONST EXIT_INVALID_PARAM = 999
|
|
CONST EXIT_PARTIAL_SUCCESS = 128
|
|
|
|
' Define namespace and class names of wmi
|
|
CONST CONST_WBEM_FLAG = 131072
|
|
CONST CONST_NAMESPACE_CIMV2 = "root\cimv2"
|
|
CONST CLASS_PAGE_FILE_SETTING = "Win32_PageFileSetting"
|
|
CONST CLASS_LOGICAL_DISK = "Win32_LogicalDisk"
|
|
CONST CLASS_COMPUTER_SYSTEM = "Win32_ComputerSystem"
|
|
CONST CLASS_PAGE_FILE_USAGE = "Win32_PageFileUsage"
|
|
CONST CLASS_OPERATING_SYSTEM = "Win32_OperatingSystem"
|
|
CONST CLASS_PERFDISK_PHYSICAL_DISK = "Win32_PerfRawData_PerfDisk_PhysicalDisk"
|
|
|
|
Dim UseCscriptErrorMessage ' string to store the CScript usage
|
|
Dim blnLocalConnection ' flag for local connection
|
|
Dim blnSuccessMsg ' flag for indicating if any success messages have been delivered
|
|
Dim blnFailureMsg ' flag to indicate if any failure messages have been delivered
|
|
Dim component ' object for the common module
|
|
|
|
' Error Messages
|
|
Dim InsufficientMaxSizeErrorMessage
|
|
Dim InitialSizeRangeErrorMessage
|
|
Dim NotEnoughSpaceErrorMessage
|
|
Dim AtLeastFiveMBErrorMessage
|
|
Dim DiskTooSmallErrorMessage
|
|
Dim CannotDeleteErrorMessage
|
|
|
|
' Warning Messages
|
|
Dim GrowsToFreeSpaceWarningMessage
|
|
Dim CrashDumpSettingWarningMessage
|
|
|
|
' Success / Skipping messages
|
|
Dim ChangeIntSuccessMessage
|
|
Dim ChangeMaxSuccessMessage
|
|
Dim ChangeIntSkippingMessage
|
|
Dim ChangeMaxSkippingMessage
|
|
Dim CreateSuccessMessage
|
|
|
|
InsufficientMaxSizeErrorMessage = L_InsufficientMaxSize1_ErrorMessage & vbCRLF & _
|
|
L_InsufficientMaxSize2_ErrorMessage & vbCRLF & _
|
|
L_InsufficientMaxSize3_ErrorMessage
|
|
InitialSizeRangeErrorMessage = L_InitialSizeRange1_ErrorMessage & vbCRLF & _
|
|
L_InitialSizeRange2_ErrorMessage
|
|
NotEnoughSpaceErrorMessage = L_NotEnoughSpace1_ErrorMessage & vbCRLF & _
|
|
L_NotEnoughSpace2_ErrorMessage
|
|
AtLeastFiveMBErrorMessage = L_AtLeastFiveMB1_ErrorMessage & vbCRLF & _
|
|
L_AtLeastFiveMB2_ErrorMessage & vbCRLF & _
|
|
L_AtLeastFiveMB3_ErrorMessage & vbCRLF & _
|
|
L_AtLeastFiveMB4_ErrorMessage
|
|
DiskTooSmallErrorMessage = L_DiskTooSmall1_ErrorMessage & vbCRLF & _
|
|
L_DiskTooSmall2_ErrorMessage
|
|
CannotDeleteErrorMessage = L_CannotDelete1_ErrorMessage & vbCRLF & _
|
|
L_CannotDelete2_ErrorMessage
|
|
|
|
GrowsToFreeSpaceWarningMessage = L_GrowsToFreeSpaceWarning1_Message & vbCRLF & _
|
|
L_GrowsToFreeSpaceWarning2_Message & vbCRLF & _
|
|
L_GrowsToFreeSpaceWarning3_Message
|
|
CrashDumpSettingWarningMessage = L_CrashDumpSettingWarning1_Message & vbCRLF & _
|
|
L_CrashDumpSettingWarning2_Message & vbCRLF & _
|
|
L_CrashDumpSettingWarning3_Message
|
|
|
|
ChangeIntSuccessMessage = L_ChangeIntSuccess1_Message & vbCRLF & _
|
|
L_ChangeIntSuccess2_Message
|
|
ChangeMaxSuccessMessage = L_ChangeMaxSuccess1_Message & vbCRLF & _
|
|
L_ChangeMaxSuccess2_Message
|
|
ChangeIntSkippingMessage = L_ChangeIntSkipping1_Message & vbCRLF & _
|
|
L_ChangeIntSkipping2_Message
|
|
ChangeMaxSkippingMessage = L_ChangeMaxSkipping1_Message & vbCRLF & _
|
|
L_ChangeMaxSkipping2_Message
|
|
CreateSuccessMessage = L_CreateSuccess1_Message & vbCRLF & _
|
|
L_CreateSuccess2_Message
|
|
|
|
blnLocalConnection = FALSE
|
|
blnSuccessMsg = FALSE
|
|
blnFailureMsg = FALSE
|
|
|
|
|
|
' create the object for commom module
|
|
Set component = CreateObject( "Microsoft.CmdLib" )
|
|
|
|
' check if the commom module(CmdLib.wsc) is not registered
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToInclude_ErrorMessage)
|
|
WScript.Quit(EXIT_METHOD_FAIL)
|
|
End If
|
|
|
|
' set the scripting host to WScript
|
|
Set component.ScriptingHost = WScript.Application
|
|
|
|
' Check whether the script is run using CScript
|
|
If CInt(component.checkScript) <> CONST_CSCRIPT Then
|
|
UseCscriptErrorMessage = L_UseCscript1_ErrorMessage & vbCRLF & _
|
|
ExpandEnvironmentString(L_UseCscript2_ErrorMessage) & vbCRLF & vbCRLF & _
|
|
L_UseCscript3_ErrorMessage & vbCRLF & _
|
|
L_UseCscript4_ErrorMessage & vbCRLF & vbCRLF & _
|
|
ExpandEnvironmentString(L_UseCscript5_ErrorMessage)
|
|
WScript.Echo (UseCscriptErrorMessage)
|
|
WScript.Quit(EXIT_UNEXPECTED)
|
|
End If
|
|
|
|
' call the main function
|
|
Call VBMain()
|
|
|
|
' quit with exit value = 0
|
|
WScript.Quit(EXIT_SUCCESS)
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: VBMain
|
|
'*
|
|
'* Purpose: This is the main function which starts execution
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: None
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Sub VBMain()
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
' Declaring main variables
|
|
Dim strMachine ' machine to configure page files on
|
|
Dim strUserName ' user name to connect to the machine
|
|
Dim strPassword ' password for the user
|
|
Dim intIntSize ' initial size for the page file
|
|
Dim intMaxSize ' maximum size for the page file
|
|
Dim strVolName ' volume name
|
|
Dim objVols ' object containing volume names
|
|
Dim strFormat ' query display format
|
|
Dim blnNoHeader ' stores if -nh is specified or not
|
|
Dim blnSystemManaged ' Specifies whether pagefile has to be system managed
|
|
Dim blnInitSize ' Specifies whether /I switch is specified or not
|
|
Dim blnmaxSize ' Specifies whether /M switch is specified or not
|
|
Dim intMainOption ' main option specified
|
|
Dim intTempResult ' temporary variable to hold the return value
|
|
Dim blnValidArguments ' stores the return value of ValidateArguments
|
|
|
|
' Initializing Variables
|
|
intTempResult = CONST_ERROR ' default is CONST_ERROR (=0)
|
|
strFormat = DefaultFormat_Text ' default format is LIST
|
|
blnInitSize = FALSE
|
|
blnMaxSize = FALSE
|
|
|
|
Set objVols = CreateObject("Scripting.Dictionary")
|
|
objVols.CompareMode = VBBinaryCompare
|
|
If Err.Number Then
|
|
' Unable to create the dictionary object.
|
|
Err.Clear
|
|
WScript.Echo(L_FailCreateObject_ErrorMessage)
|
|
WScript.Quit(EXIT_METHOD_FAIL)
|
|
End If
|
|
|
|
intTempResult = intParseCmdLine( strMachine, _
|
|
strUserName, _
|
|
strPassword, _
|
|
intIntSize, _
|
|
intMaxSize, _
|
|
strVolName, _
|
|
objVols, _
|
|
strFormat, _
|
|
blnNoHeader, _
|
|
blnSystemManaged, _
|
|
blnInitSize, _
|
|
blnMaxSize, _
|
|
intMainOption )
|
|
|
|
' Select the operation specified by the user
|
|
Select Case intTempResult
|
|
Case CONST_SHOW_USAGE
|
|
Select Case intMainOption
|
|
Case CONST_CHANGE_OPTION
|
|
Call ShowChangeUsage()
|
|
Case CONST_CREATE_OPTION
|
|
Call ShowCreateUsage()
|
|
Case CONST_DELETE_OPTION
|
|
Call ShowDeleteUsage()
|
|
Case CONST_QUERY_OPTION
|
|
Call ShowQueryUsage()
|
|
Case Else
|
|
Call ShowUsage()
|
|
End Select
|
|
|
|
Case CONST_CHANGE_OPTION
|
|
blnValidArguments = ValidateArguments (strMachine, strUserName, strPassword, _
|
|
intIntSize, intMaxSize, objVols, strFormat, _
|
|
blnNoHeader, blnSystemManaged, blnInitSize, _
|
|
blnMaxSize, intMainOption)
|
|
' If all arguments valid, proceed
|
|
If blnValidArguments Then
|
|
Call ProcessChange(strMachine, strUserName, strPassword, _
|
|
intIntSize, intMaxSize, blnSystemManaged, objVols)
|
|
End If
|
|
|
|
Case CONST_CREATE_OPTION
|
|
blnValidArguments = ValidateArguments (strMachine, strUserName, strPassword, _
|
|
intIntSize, intMaxSize, objVols, strFormat, _
|
|
blnNoHeader, blnSystemManaged, blnInitSize, _
|
|
blnMaxSize, intMainOption)
|
|
' If all arguments valid, proceed
|
|
If blnValidArguments Then
|
|
Call ProcessCreate(strMachine, strUserName, strPassword, _
|
|
intIntSize, intMaxSize, blnSystemManaged, objVols)
|
|
End If
|
|
|
|
Case CONST_DELETE_OPTION
|
|
blnValidArguments = ValidateArguments (strMachine, strUserName, strPassword, _
|
|
intIntSize, intMaxSize, objVols, strFormat, _
|
|
blnNoHeader, blnSystemManaged, blnInitSize, _
|
|
blnMaxSize, intMainOption)
|
|
' If all arguments valid, proceed
|
|
If blnValidArguments Then
|
|
Call ProcessDelete(strMachine, strUserName, strPassword, blnSystemManaged, objVols)
|
|
' Here wild cards cannot be specified
|
|
End If
|
|
|
|
Case CONST_QUERY_OPTION
|
|
blnValidArguments = ValidateArguments (strMachine, strUserName, strPassword, _
|
|
intIntSize, intMaxSize, objVols, strFormat, _
|
|
blnNoHeader, blnSystemManaged, blnInitSize, _
|
|
blnMaxSize, intMainOption)
|
|
' If all arguments valid, proceed
|
|
If blnValidArguments Then
|
|
Call ProcessQuery(strMachine, strUserName, strPassword, strFormat, blnSystemManaged, blnNoHeader)
|
|
End If
|
|
|
|
Case CONST_ERROR
|
|
WSCript.Quit(EXIT_INVALID_INPUT)
|
|
End Select
|
|
|
|
End Sub
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: intPaseCmdLine
|
|
'*
|
|
'* Purpose: Parses the command line arguments into the variables
|
|
'*
|
|
'* Input:
|
|
'* [out] strMachine machine to configure page files on
|
|
'* [out] strUserName user name to connect to the machine
|
|
'* [out] strPassword password for the user
|
|
'* [out] intIntSize initial size for the page file
|
|
'* [out] intMaxSize maximum size for the page file
|
|
'* [in] strVolName individual volume name(s)
|
|
'* [out] objVols object containing volume names
|
|
'* [out] strFormat query display format
|
|
'* [out] intMainOption main option specified
|
|
'*
|
|
'* Output: Returns CONST_SHOW_USAGE, CONST_CHANGE_OPTION ,
|
|
'* CONST_CREATE_OPTION, CONST_DELETE_OPTION ,
|
|
'* CONST_QUERY_OPTION or CONST_ERROR.
|
|
'* Displays error message and quits if invalid option is asked
|
|
'*
|
|
'******************************************************************************
|
|
Private Function intParseCmdLine( ByRef strMachine, _
|
|
ByRef strUserName, _
|
|
ByRef strPassword, _
|
|
ByRef intIntSize, _
|
|
ByRef intMaxSize, _
|
|
ByVal strVolName, _
|
|
ByRef objVols, _
|
|
ByRef strFormat, _
|
|
ByRef blnNoHeader, _
|
|
ByRef blnSystemManaged, _
|
|
ByRef blninitSize, _
|
|
ByRef blnMaxSize, _
|
|
ByRef intMainOption )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim strUserGivenArg ' to temporarily store the user given arguments
|
|
Dim intArgIter ' to count the number of arguments given
|
|
Dim intQCount ' to count the number of help options given
|
|
Dim intMainOptionNumber ' to count the number of main operations selected (Max allowed = 1)
|
|
Dim intVolumes ' to store the number of volumes specified
|
|
' Following variables are used to check if a switch if given more than once
|
|
Dim blnIntSizeSpecified
|
|
Dim blnMaxSizeSpecified
|
|
Dim blnFormatSpecified
|
|
Dim blnMachineSpecified
|
|
Dim blnUserSpecified
|
|
Dim blnPasswordSpecified
|
|
|
|
' Initialization
|
|
strUserGivenArg = ""
|
|
intMainOptionNumber = 0
|
|
intQCount = 0
|
|
intArgIter = 0
|
|
intParseCmdLine = 0
|
|
|
|
' initially none of the parameters are specified, so set all flags to FALSE
|
|
blnIntSizeSpecified = FALSE
|
|
blnMaxSizeSpecified = FALSE
|
|
blnFormatSpecified = FALSE
|
|
blnMachineSpecified = FALSE
|
|
blnUserSpecified = FALSE
|
|
blnPasswordSpecified = FALSE
|
|
blnNoHeader = FALSE
|
|
blnSystemManaged = FALSE
|
|
|
|
' if no arguments are specified, default option is query
|
|
If WScript.Arguments.Count = 0 Then
|
|
intParseCmdLine = CONST_QUERY_OPTION
|
|
intMainOption = CONST_QUERY_OPTION
|
|
End If
|
|
|
|
' Retrieve the command line parameters and their values
|
|
Do While intArgIter <= WScript.Arguments.Count - 1
|
|
strUserGivenArg = WScript.Arguments.Item(intArgIter)
|
|
' check if the first character is a '-' OR '/' symbol; NOTE that "/" is the standard
|
|
If Left(strUserGivenArg,1) = "/" OR Left(strUserGivenArg,1) = "-" Then
|
|
' ignore the symbol and take the rest as the switch specified
|
|
strUserGivenArg = Right(strUserGivenArg,Len(strUserGivenArg) - 1)
|
|
Select Case LCase(strUserGivenArg)
|
|
|
|
Case LCase(OPTION_HELP)
|
|
intQCount = intQCount + 1
|
|
If (CInt(intQCount) >= 2 OR CInt(WScript.Arguments.Count) > 2) Then
|
|
intParseCmdLine = CONST_ERROR
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
Exit Function
|
|
Else
|
|
intParseCmdLine = CONST_SHOW_USAGE
|
|
intArgIter = intArgIter + 1
|
|
End If
|
|
|
|
Case LCase(OPTION_CHANGE)
|
|
If intQCount = 1 Then ' intQCount = 1 means help specified
|
|
intParseCmdLine = CONST_SHOW_USAGE
|
|
Else
|
|
intParseCmdLine = CONST_CHANGE_OPTION
|
|
End If
|
|
intMainOption = CONST_CHANGE_OPTION
|
|
intMainOptionNumber = intMainOptionNumber + 1
|
|
intArgIter = intArgIter + 1
|
|
|
|
Case LCase(OPTION_CREATE)
|
|
If intQCount = 1 Then ' intQCount = 1 means help specified
|
|
intParseCmdLine = CONST_SHOW_USAGE
|
|
Else
|
|
intParseCmdLine = CONST_CREATE_OPTION
|
|
End If
|
|
intMainOption = CONST_CREATE_OPTION
|
|
intMainOptionNumber = intMainOptionNumber + 1
|
|
intArgIter = intArgIter + 1
|
|
|
|
Case LCase(OPTION_DELETE)
|
|
If intQCount = 1 Then ' intQCount = 1 means help specified
|
|
intParseCmdLine = CONST_SHOW_USAGE
|
|
Else
|
|
intParseCmdLine = CONST_DELETE_OPTION
|
|
End If
|
|
intMainOption = CONST_DELETE_OPTION
|
|
intMainOptionNumber = intMainOptionNumber + 1
|
|
intArgIter = intArgIter + 1
|
|
|
|
Case LCase(OPTION_QUERY)
|
|
If intQCount = 1 Then ' intQCount = 1 means help specified
|
|
intParseCmdLine = CONST_SHOW_USAGE
|
|
Else
|
|
intParseCmdLine = CONST_QUERY_OPTION
|
|
End If
|
|
intMainOption = CONST_QUERY_OPTION
|
|
intMainOptionNumber = intMainOptionNumber + 1
|
|
intArgIter = intArgIter + 1
|
|
|
|
Case LCase(SUB_OPTION_SERVER)
|
|
' Check if server name is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
' Check if Machine Name is already specified
|
|
If NOT blnMachineSpecified Then
|
|
blnMachineSpecified = TRUE ' Set Specified Flag to TRUE
|
|
If NOT component.getArguments(L_MachineName_Text,strMachine,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
End If
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case LCase(SUB_OPTION_USER)
|
|
' Check if user name is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
' Check if User Name is already specified
|
|
If NOT blnUserSpecified Then
|
|
blnUserSpecified = TRUE ' Set Specified Flag to TRUE
|
|
If NOT component.getArguments(L_User_Text,strUserName,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
End If
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case LCase(SUB_OPTION_PASSWORD)
|
|
' Check if password is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
' Check if Password is already specified
|
|
If NOT blnPasswordSpecified Then
|
|
blnPasswordSpecified = TRUE ' Set Specified Flag to TRUE
|
|
If NOT component.getArguments(L_Password_Text,strPassword,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
End If
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case LCase(SUB_OPTION_INTSIZE)
|
|
' Check if initsize is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
' Check if initsize is already specified
|
|
If NOT blnIntSizeSpecified Then
|
|
blnIntSizeSpecified = TRUE ' Set Specified Flag to TRUE
|
|
If NOT component.getArguments(L_Intsize_Text,intIntSize,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
End If
|
|
blnInitSize = TRUE
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case LCase(SUB_OPTION_MAXSIZE)
|
|
' Check if maxsize is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
' Check if Maxsize is already specified
|
|
If NOT blnMaxSizeSpecified Then
|
|
blnMaxSizeSpecified = TRUE ' Set Specified Flag to TRUE
|
|
If NOT component.getArguments(L_Maxsize_Text,intMaxSize,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
End If
|
|
blnMaxSize = TRUE
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case LCase(SUB_OPTION_FORMAT)
|
|
' Check if maxsize is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
' Check if format is already specified
|
|
If NOT blnFormatSpecified Then
|
|
blnFormatSpecified = TRUE ' Set Specified Flag to TRUE
|
|
If NOT component.getArguments(L_Format_Text,strFormat,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
End If
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case LCase(SUB_OPTION_NOHEADER)
|
|
' Check if -nh is already specified
|
|
If NOT blnNoHeader Then
|
|
blnNoHeader = TRUE
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage , _
|
|
Array(WScript.Arguments.Item(intArgIter))
|
|
' print the appropriate help usage message
|
|
Call typeMessage(intMainOption)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case Lcase(SUB_OPTION_SYSTEM_MANAGED)
|
|
' Check if -sm is specified
|
|
If Not blnSystemManaged Then
|
|
blnSystemManaged = TRUE
|
|
intArgIter = intArgIter + 1
|
|
Else
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NotAllowedMoreThanOnce_ErrorMessage, _
|
|
Array(Wscript.Arguments.Item(intArgIter))
|
|
' Print the corresponding help usage error message
|
|
Call typeMessage(intMainOption)
|
|
Wscript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
Case LCase(SUB_OPTION_VOLUME)
|
|
' Check if volume is given with help usage
|
|
If intParseCmdLine = CONST_SHOW_USAGE Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
If NOT component.getArguments(L_Volume_Text,strVolName,intArgIter,FALSE) Then
|
|
component.VBPrintf L_InvalidSyntax_ErrorMessage
|
|
Call typeMessage(intMainOption)
|
|
intParseCmdLine = CONST_ERROR
|
|
Exit Function
|
|
Else
|
|
If strVolName = "*" Then
|
|
objVols.Add LCase(strVolName), -1
|
|
Else
|
|
If NOT objVols.Exists(LCase(strVolName)) Then
|
|
objVols.Add LCase(strVolName), -1
|
|
End If
|
|
intVolumes = objVols.Count
|
|
End If
|
|
End If
|
|
intArgIter = intArgIter + 1
|
|
|
|
Case Else
|
|
' display the invalid param err msg first
|
|
component.VBPrintf L_InvalidParameter_ErrorMessage, _
|
|
Array(WScript.arguments.Item(intArgIter))
|
|
' then display the 'type ..usage' message
|
|
Select Case CInt(intMainOption)
|
|
Case CONST_CHANGE_OPTION
|
|
component.VBPrintf L_TypeChangeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case CONST_CREATE_OPTION
|
|
component.VBPrintf L_TypeCreateUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case CONST_DELETE_OPTION
|
|
component.VBPrintf L_TypeDeleteUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case CONST_QUERY_OPTION
|
|
component.VBPrintf L_TypeQueryUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case Else
|
|
component.VBPrintf L_TypeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
End Select
|
|
|
|
End Select
|
|
|
|
Else
|
|
' invalid argument specified
|
|
' display the invalid param err msg first
|
|
component.VBPrintf L_InvalidParameter_ErrorMessage, _
|
|
Array(WScript.arguments.Item(intArgIter))
|
|
' then display the 'type ..usage' message
|
|
Select Case CInt(intMainOption)
|
|
Case CONST_CHANGE_OPTION
|
|
component.VBPrintf L_TypeChangeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case CONST_CREATE_OPTION
|
|
component.VBPrintf L_TypeCreateUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case CONST_DELETE_OPTION
|
|
component.VBPrintf L_TypeDeleteUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case CONST_QUERY_OPTION
|
|
component.VBPrintf L_TypeQueryUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
Case Else
|
|
component.VBPrintf L_TypeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_PARAM)
|
|
End Select
|
|
|
|
End If
|
|
|
|
Loop
|
|
|
|
' check if the there is any volume(s) specified.
|
|
If objVols.Count = 0 Then
|
|
intVolumes = objVols.Count
|
|
End If
|
|
|
|
' Check if volumes | * is specified along with help
|
|
If (intVolumes > 0 AND intQCount = 1) Then
|
|
WScript.Echo(L_InvalidHelpUsage_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
' Check if two major operations are selected at a time
|
|
If ( intMainOptionNumber > 1 ) Then
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeUsage_Message,Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
ElseIf (intQcount = 0 AND intmainoption = 0) Then
|
|
intMainOption = CONST_QUERY_OPTION
|
|
End If
|
|
|
|
' check if NO major option(s) is specified, but other switches are specified
|
|
If ( intMainOptionNumber = 0 ) Then
|
|
If blnIntSizeSpecified OR _
|
|
blnMaxSizeSpecified OR _
|
|
blnFormatSpecified OR _
|
|
blnMachineSpecified OR _
|
|
blnUserSpecified OR _
|
|
blnPasswordSpecified OR _
|
|
blnNoHeader OR _
|
|
intVolumes > 0 Then
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' check if format is specified with create option
|
|
If (intMainOption = CONST_CREATE_OPTION) Then
|
|
If blnFormatSpecified Then
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeCreateUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' check if format is specified with change option
|
|
If (intMainOption = CONST_CHANGE_OPTION) Then
|
|
If blnFormatSpecified Then
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeChangeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' check if /Initsize, /Maxsize, /FO are specified
|
|
If (intMainOption = CONST_DELETE_OPTION) Then
|
|
If (blnIntSizeSpecified OR blnMaxSizeSpecified OR blnFormatSpecified OR blnSystemManaged) Then
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeDeleteUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' check if /Initsize, /Maxsize, are specified
|
|
If (intMainOption = CONST_QUERY_OPTION) Then
|
|
If (blnIntSizeSpecified OR blnMaxSizeSpecified OR blnSystemManaged) Then
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeQueryUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
End Function
|
|
|
|
'******************************************************************************
|
|
'* Function: ValidateArguments
|
|
'*
|
|
'* Purpose: Validates the command line arguments given by the user
|
|
'*
|
|
'* Input:
|
|
'* [out] strMachine machine to configure page files on
|
|
'* [out] strUserName user name to connect to the machine
|
|
'* [out] strPassword password for the user
|
|
'* [out] intIntSize the initial size for the page file
|
|
'* [out] intMaxSize the maximum size for the page file
|
|
'* [out] objVols the object containing volume names
|
|
'* [out] strFormat the query display format
|
|
'* [out] blnNoHeader the query display format
|
|
'* [out] intMainOption the main option specified
|
|
'*
|
|
'* Output: Returns true if all valid else displays error message and quits
|
|
'* Gets the password from the user if not specified along with User.
|
|
'*
|
|
'******************************************************************************
|
|
Private Function ValidateArguments ( ByRef strMachine, _
|
|
ByRef strUserName, _
|
|
ByRef strPassword, _
|
|
ByRef intIntSize, _
|
|
ByRef intMaxSize, _
|
|
ByRef objVols, _
|
|
ByRef strFormat, _
|
|
ByRef blnNoHeader, _
|
|
ByRef blnSystemManaged, _
|
|
ByRef blnInitSize, _
|
|
ByRef blnMaxSize, _
|
|
ByRef intMainOption)
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim strMatchPattern ' the pattern to be matched
|
|
Dim intVolumes ' to count the no.of volumes specified
|
|
Dim arrVolume ' array to store the volumes specified
|
|
Dim i ' Loop variable
|
|
|
|
' Initialization
|
|
intVolumes = CInt(objVols.Count)
|
|
arrVolume = objVols.Keys
|
|
ValidateArguments = TRUE
|
|
i = 0
|
|
|
|
' Check if invalid server name is given
|
|
If NOT IsEmpty(strMachine) Then
|
|
If Trim(strMachine) = vbNullString Then
|
|
WScript.Echo(L_InvalidServerName_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' Check if invalid user name is given
|
|
If NOT IsEmpty(strUserName) Then
|
|
If Trim(strUserName) = vbNullString Then
|
|
WScript.Echo(L_InvalidUserName_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' check if user is given without machine OR password
|
|
If ((strUserName <> VBEmpty) AND (strMachine = VBEmpty)) Then
|
|
WScript.Echo L_InvalidServerCredentials_ErrorMessage
|
|
component.VBPrintf L_TypeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
' check if password is given without user OR machine
|
|
ElseIf ((strPassword <> VBEmpty) AND (strUserName = VBEmpty))Then
|
|
WScript.Echo L_InvalidUserCredentials_ErrorMessage
|
|
component.VBPrintf L_TypeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
' Check if initial size is specified, validate if it is a poistive number
|
|
If Len(CStr(intIntSize)) > 0 Then
|
|
' Initsize should be numeric only
|
|
' chr(46) indicates "." (dot)
|
|
If NOT (IsNumeric(intIntSize) AND InStr(intIntSize,chr(46)) = 0 AND Instr(intIntSize,"-") = 0) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo L_InvalidInitSizeValue_ErrorMessage
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' Check if maximum size is specified, validate if it is a poistive number
|
|
If Len(CStr(intMaxSize)) > 0 Then
|
|
' Maxsize should be numeric only
|
|
' chr(46) indicates "." (dot)
|
|
If NOT (IsNumeric(intMaxSize) AND InStr(intMaxSize,chr(46)) = 0 AND Instr(intMaxSize,"-") = 0) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo L_InvalidMaxSizeValue_ErrorMessage
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
Select Case CInt(intMainOption)
|
|
|
|
Case CONST_CHANGE_OPTION
|
|
|
|
' Valid Cases : either (initsize + volume) OR (maxsize + volume)
|
|
' OR (initsize + maxsize + volume)
|
|
|
|
' If none of the parameters (initsize or maxsize) is specified
|
|
If blnSystemManaged = FALSE Then
|
|
If ( blnInitSize = FALSE AND blnMaxSize = FALSE ) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_NoneoftheSizeSpecified_ErrorMessage)
|
|
component.VBPrintf L_TypeChangeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
If (blnInitSize = TRUE AND Len(CStr(intIntSize)) = 0 ) Then
|
|
ValidateArguments = FALSE
|
|
Wscript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
If (blnMaxSize = TRUE AND Len(CStr(intMaxSize)) = 0 ) Then
|
|
ValidateArguments = FALSE
|
|
Wscript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
Else
|
|
If (blnInitSize = TRUE OR blnMaxSize = TRUE) Then
|
|
ValidateArguments = FALSE
|
|
Wscript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_CONST_NoneoftheSizes_AllowedWithSysManaged_Text)
|
|
component.VBPrintf L_TypeChangeUsage_Message, _
|
|
Array(Ucase(Wscript.ScriptName))
|
|
Wscript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' check if the volume is specified
|
|
If (objVols.Count = 0) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_VolumeNameNotSpecified_ErrorMessage)
|
|
component.VBPrintf L_TypeChangeUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
' check if volume name is valid
|
|
ElseIf isValidDrive(objVols,intMainOption) Then
|
|
ValidateArguments = TRUE
|
|
End If
|
|
|
|
Case CONST_CREATE_OPTION
|
|
If blnSystemManaged = FALSE Then
|
|
If ( blnInitSize = FALSE OR blnMaxSize = FALSE ) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_InitialSizeNotSpecified_ErrorMessage)
|
|
component.VBPrintf L_TypeCreateUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
If (blnInitSize = TRUE AND Len(CStr(intIntSize)) = 0 ) Then
|
|
ValidateArguments = FALSE
|
|
Wscript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
If (blnMaxSize = TRUE AND Len(CStr(intMaxSize)) = 0 ) Then
|
|
ValidateArguments = FALSE
|
|
Wscript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
Else
|
|
If (blnInitSize = TRUE OR blnMaxSize = TRUE) Then
|
|
ValidateArguments = FALSE
|
|
Wscript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_CONST_NoneoftheSizes_AllowedWithSysManaged_Text)
|
|
component.VBPrintf L_TypeCreateUsage_Message, _
|
|
Array(Ucase(Wscript.ScriptName))
|
|
Wscript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' volume name is required
|
|
If (objVols.Count = 0) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_VolumeNameNotSpecified_ErrorMessage)
|
|
component.VBPrintf L_TypeCreateUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
' check if volume name is valid
|
|
ElseIf isValidDrive(objVols,intMainOption) Then
|
|
ValidateArguments = TRUE
|
|
End If
|
|
|
|
Case CONST_DELETE_OPTION
|
|
|
|
' ONLY volume is required
|
|
If (objVols.Count = 0) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_VolumeNameNotSpecified_ErrorMessage)
|
|
component.VBPrintf L_TypeDeleteUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
' check if volume name is valid
|
|
ElseIf isValidDrive(objVols,intMainOption) Then
|
|
ValidateArguments = TRUE
|
|
End If
|
|
|
|
' Wild Card Character * is not allowed for /Delete option
|
|
If (objVols.Exists("*")) Then
|
|
ValidateArguments = FALSE
|
|
objVols.Remove "*"
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case CONST_QUERY_OPTION
|
|
|
|
' check if any format is specified.
|
|
If Len(strFormat) > 0 Then
|
|
' only table, list and csv display formats allowed
|
|
' PatternFormat_Text contains ^(table|list|csv)$
|
|
If CInt(component.matchPattern(PatternFormat_Text, strFormat)) = CONST_NO_MATCHES_FOUND Then
|
|
component.vbPrintf L_InvalidSyntax_ErrorMessage & " " & _
|
|
L_InvalidFormat_ErrorMessage, Array(strFormat)
|
|
component.VBPrintf L_TypeQueryUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
' Check if -nh is specified for LIST format
|
|
If (blnNoHeader) AND LCase(strFormat) = LCase(ListFormat_Text) then
|
|
WScript.Echo (L_NoHeaderNotAllowed_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
' Validation to check if volume names are specified with Query Option:
|
|
If (intVolumes <> 0) Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidSyntax_ErrorMessage)
|
|
component.VBPrintf L_TypeQueryUsage_Message, _
|
|
Array(UCase(WScript.ScriptName))
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
Case Else
|
|
|
|
' if intMainOption has some non-zero value means one operation is selected
|
|
If (intMainOption > 0) Then
|
|
' -operation & volname together are valid
|
|
ValidateArguments = TRUE
|
|
Else
|
|
ValidateArguments = FALSE
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
End Select
|
|
|
|
' verify If required credentials given
|
|
If (((NOT IsEmpty(strUserName)) AND (IsEmpty(strMachine))) OR _
|
|
((NOT IsEmpty(strPassword)) AND (IsEmpty(strUserName))) )Then
|
|
ValidateArguments = FALSE
|
|
WScript.Echo (L_InvalidCredentials_ErrorMessage)
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
|
|
' check if the machine name is specified using "\\" (UNC format)
|
|
If Left(strMachine,2) = UNC_FORMAT_SERVERNAME_PREFIX Then
|
|
If Len(strMachine) = 2 Then
|
|
WScript.Echo L_InvalidInput_ErrorMessage
|
|
WScript.Quit(EXIT_UNEXPECTED)
|
|
End If
|
|
' remove the "\\" from the front
|
|
strMachine = Mid(strMachine,3,Len(strMachine))
|
|
End If
|
|
|
|
' If password not specified with the user name, Then get it using cmdlib.wsc function
|
|
If ((NOT IsEmpty(strUserName)) AND (IsEmpty(strPassword)) OR strPassword = "*") Then
|
|
strPassword = component.getPassword()
|
|
End If
|
|
|
|
End Function
|
|
|
|
'******************************************************************************
|
|
'* Function: isValidDrive
|
|
'*
|
|
'* Purpose: To check if the specified volume is valid or not
|
|
'*
|
|
'* Input:
|
|
'* [in] objVols object that store the volumes specified
|
|
'* [in] intMainOption the main option specified
|
|
'*
|
|
'* Output: Returns TRUE or FALSE
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Function isValidDrive(ByRef objVols,ByVal intMainOption)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim intVolumes ' to count the no.of volumes specified
|
|
Dim arrVolume ' array to store the volumes specified
|
|
Dim i ' Loop variable
|
|
|
|
' Initialization
|
|
intVolumes = CInt(objVols.Count)
|
|
arrVolume = objVols.Keys
|
|
isValidDrive = FALSE
|
|
i = 0
|
|
|
|
' Check if the drive name is in correct Format [c-z]: or [C-Z]:
|
|
' This has to be checked for each Drive specified - Do While Loop
|
|
|
|
Do While (i < intVolumes)
|
|
' Volumes specified are valid for all option except Query
|
|
If intMainOption <> CONST_QUERY_OPTION Then
|
|
' Valid volume is either '*' OR a letter followed by a colon (total length = 2)
|
|
If ((Len(arrVolume(i)) = 2) AND (InStr(arrVolume(i),chr(58)) = 2) OR arrVolume(i) = "*") Then
|
|
' check if the volume name specified is in the format ^([c-zC-Z]:|\*)$
|
|
If CInt(component.matchPattern(L_VolumePatternFormat_Text,arrVolume(i))) = CONST_NO_MATCHES_FOUND Then
|
|
' Invalid Volume Names or junk data is specified
|
|
component.VBPrintf L_InvalidVolumeName_ErrorMessage, _
|
|
Array(arrVolume(i))
|
|
isValidDrive = FALSE
|
|
' remove the INVALID drive(s)
|
|
objVols.Remove arrVolume(i)
|
|
End If
|
|
Else
|
|
isValidDrive = FALSE
|
|
component.VBPrintf L_InvalidVolumeName_ErrorMessage, _
|
|
Array(arrVolume(i))
|
|
objVols.Remove arrVolume(i)
|
|
End If
|
|
' check the number of valid drives specified
|
|
If objVols.Count = 0 Then
|
|
WScript.Quit(EXIT_INVALID_INPUT)
|
|
End If
|
|
Else
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
WScript.Quit (EXIT_INVALID_INPUT)
|
|
End If
|
|
isValidDrive = isValidDrive OR TRUE
|
|
i = i + 1
|
|
Loop
|
|
|
|
End Function
|
|
|
|
'******************************************************************************
|
|
'* Sub: ProcessChange
|
|
'*
|
|
'* Purpose: Processes the /Change option and displays the changed
|
|
'* details of the page file
|
|
'*
|
|
'* Input:
|
|
'* [in] strMachine machine to configure page files on
|
|
'* [in] strUserName user name to connect to the machine
|
|
'* [in] strPassword password for the user
|
|
'* [in] intIntSize the initial size for the page file
|
|
'* [in] intMaxSize the maximum size for the page file
|
|
'* [in] objVols the object containing volume names
|
|
'*
|
|
'* Output: Displays error message and quits if connection fails
|
|
'*
|
|
'******************************************************************************
|
|
Private Sub ProcessChange( ByVal strMachine, _
|
|
ByVal strUserName, _
|
|
ByVal strPassword, _
|
|
ByVal intIntSize, _
|
|
ByVal intMaxSize, _
|
|
ByVal blnSystemManaged, _
|
|
ByVal objVols )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim intOldInitialSize ' to store the old intial size
|
|
Dim intOldMaximumSize ' to store the old maximum size
|
|
Dim arrVolume ' to store all the volumes specified
|
|
Dim intVolumes ' to store the no.of volumes specified
|
|
Dim strQuery ' to store the query for pagefiles
|
|
Dim strQueryDisk ' to store the query for disk
|
|
Dim strQueryComp ' to store the query for computersystem
|
|
Dim objService ' service object
|
|
Dim objInstance ' instance object
|
|
Dim objInst ' instance object
|
|
Dim objEnumerator ' collection set for query results
|
|
Dim objEnumforDisk ' collection set for query results
|
|
Dim objEnum ' collection set for query results
|
|
Dim blnBothSpecified ' flag to check if both initsize & maxsize are specified
|
|
Dim intFreeSpace ' to store total free space
|
|
Dim intFreeDiskSpace ' to store free disk space
|
|
Dim intCurrentSize ' to store the current pagefile size
|
|
Dim intDiskSize ' to store the disk size for the specified disk
|
|
Dim intMemSize ' to store physical memory size
|
|
Dim intCrashDump ' to store the current crash dump setting value
|
|
Dim strReply ' to store the user reply
|
|
Dim strDriveName ' to store the drive name
|
|
Dim strHostName ' to store the host name
|
|
Dim intMaxSizeUB ' to store the upper bound for maximum size
|
|
Dim i ' loop variable
|
|
|
|
' Establish a connection with the server.
|
|
If NOT component.wmiConnect(CONST_NAMESPACE_CIMV2 , _
|
|
strUserName , _
|
|
strPassword , _
|
|
strMachine , _
|
|
blnLocalConnection, _
|
|
objService ) Then
|
|
WScript.Echo(L_HintCheckConnection_Message)
|
|
WScript.Quit(EXIT_METHOD_FAIL)
|
|
End If
|
|
|
|
' Initialize variables
|
|
i = 0
|
|
intFreeSpace = 0
|
|
intFreeDiskSpace = 0
|
|
intCurrentSize = 0
|
|
blnBothSpecified = FALSE
|
|
intMaxSizeUB = 0
|
|
strQuery = "Select * From " & CLASS_PAGE_FILE_SETTING
|
|
|
|
If (objVols.Exists("*")) Then
|
|
Set objEnumerator = objService.ExecQuery(strQuery, "WQL", 0, null)
|
|
For each objInstance in objEnumerator
|
|
strDriveName = Mid(objInstance.Name,1,2)
|
|
If NOT objVols.Exists (LCase(strDriveName)) Then
|
|
objVols.add LCase(strDriveName), -1
|
|
End If
|
|
Next
|
|
objVols.remove "*"
|
|
End If
|
|
|
|
intVolumes = objVols.Count
|
|
arrVolume = objVols.keys
|
|
|
|
' get the host Name - used to get Crash Dump Settings
|
|
strQueryComp = "Select * From " & CLASS_COMPUTER_SYSTEM
|
|
Set objEnum = objService.ExecQuery(strQueryComp, "WQL", 0, null)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
|
|
For each objInst in objEnum
|
|
If NOT ISEmpty(objInst.Name) Then
|
|
strHostName = objInst.Name
|
|
Else
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
Next
|
|
|
|
' check if initsize and maxsize both are specified
|
|
If (Len(intIntSize) > 0 AND Len(intMaxSize) > 0) Then
|
|
blnBothSpecified = TRUE
|
|
End If
|
|
|
|
' check if no page files exist on the system.
|
|
strQuery = "Select * From " & CLASS_PAGE_FILE_SETTING
|
|
Set objEnumerator = objService.ExecQuery(strQuery, "WQL", 0, null)
|
|
If (objEnumerator.Count = 0) Then
|
|
WScript.Echo(L_NoPageFiles_Message)
|
|
WScript.Quit(EXIT_UNEXPECTED)
|
|
End If
|
|
|
|
' release the object for re-use.
|
|
Set objEnumerator = nothing
|
|
|
|
Do While( i < intVolumes )
|
|
' check if its a valid drive/volume - check from Win32_LogicalDisk
|
|
strQueryDisk = "Select * From " & CLASS_LOGICAL_DISK & _
|
|
" where DriveType = " & DRIVE_TYPE & " and DeviceID = '" & arrVolume(i) & "'"
|
|
Set objEnumforDisk = objService.ExecQuery(strQueryDisk, "WQL", 0, null)
|
|
If objEnumforDisk.Count > 0 Then
|
|
strQuery = "Select * From " & CLASS_PAGE_FILE_SETTING
|
|
strQuery = strQuery & " where NAME = '" & arrVolume(i) & _
|
|
"\" & PAGEFILE_DOT_SYS & "'"
|
|
Set objEnumerator = objService.ExecQuery(strQuery, "WQL", 0, null)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
' check if a page file exists on the specified volume
|
|
If (objEnumerator.Count > 0) Then
|
|
For each objInstance in objEnumerator
|
|
If blnSystemManaged = TRUE Then
|
|
If( objInstance.InitialSize = 0 AND objInstance.MaximumSize = 0 ) Then
|
|
Component.VBPrintf L_CONST_Already_SystemManaged_Text, Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
objInstance.InitialSize = CONST_SYSTEM_INIT_SIZE
|
|
objInstance.MaximumSize = CONST_SYSTEM_MAX_SIZE
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
Component.VBPrintf L_CannotCreate_ErrorMessage,Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf L_ChangeSystemSuccess_message, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnSuccessMsg = TRUE
|
|
Exit For
|
|
Else
|
|
strDriveName = Mid(objInstance.Name,1,2)
|
|
|
|
'If the page file was system managed, then, the user has to specify both
|
|
'initial and maximum sizes..
|
|
If (objInstance.InitialSize =0 AND objInstance.MaximumSize = 0 ) Then
|
|
If Not blnBothSpecified Then
|
|
component.VBPrintf L_CONST_Systemmanaged_Earlier_Text, Array(Ucase( arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
End If
|
|
If NOT blnBothSpecified Then
|
|
' check if initsize is given
|
|
If (intIntSize > 0) Then
|
|
' Check if initsize is greater than 2 MB
|
|
If CLng(intIntSize) >= CLng(INITIAL_SIZE_LB) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
' get the drive name first
|
|
strDriveName = Mid(objInstance.Name,1,2)
|
|
' get the free space available on the specified disk
|
|
intFreeDiskSpace = getFreeSpaceOnDisk(strDriveName,objService)
|
|
' get the current pagefile size
|
|
intCurrentSize = getCurrentPageFileSize(objService,objInstance)
|
|
' get the total free space
|
|
If Len(intCurrentSize) > 0 Then
|
|
intFreeSpace = intFreeDiskSpace + intCurrentSize
|
|
Else
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_QUERY_FAIL
|
|
End If
|
|
' Check if it is greater than free disk space
|
|
If CLng(intIntSize) > CLng(intFreeSpace) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf NotEnoughSpaceErrorMessage, Array( UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
Else
|
|
If CLng(intIntSize) > CLng(intFreeSpace) - 5 Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf AtLeastFiveMBErrorMessage, Array( UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
Else
|
|
' only one of initsize, maxsize is specified
|
|
' check if the specified initsize is less than existing maxsize
|
|
If (CInt(intIntSize) <= objInstance.MaximumSize) Then
|
|
' get the crash dump setting value
|
|
intCrashDump = GetCrashDumpSetting(strUserName,strPassword,strMachine)
|
|
' get the Physical Memory Size
|
|
intMemSize = GetPhysicalMemorySize(strHostName,objService)
|
|
' If the user has selected "yes" for the warning message
|
|
If isCrashDumpValueSet(intCrashDump,intIntSize,intMemSize,arrVolume(i)) Then
|
|
' Check if initsize is same as the present value
|
|
If (CInt(intIntSize) <> objInstance.InitialSize) Then
|
|
' store the old initsize value
|
|
intOldInitialSize = objInstance.InitialSize
|
|
' set the new initsize
|
|
objInstance.InitialSize = intIntSize
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UpdateFailed_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf ChangeIntSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldInitialSize),CInt(intIntSize))
|
|
blnSuccessMsg = TRUE
|
|
Exit For
|
|
Else
|
|
component.VBPrintf ChangeIntSkippingMessage, Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
|
|
' If User chooses No for CrashDumpSetting prompt
|
|
Else
|
|
' Do Nothing just continue looping
|
|
Exit For
|
|
End If
|
|
Else
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
End If
|
|
End If
|
|
Else
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InitialSizeRangeErrorMessage, _
|
|
Array(intMaxSizeUB, UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
Else
|
|
' Check if initsize specified as 0
|
|
If Len(intIntSize) > 0 Then
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InitialSizeRangeErrorMessage, _
|
|
Array(intMaxSizeUB, UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
End If ' initsize checked
|
|
|
|
' check if maxsize is given
|
|
If (intMaxSize > 0) Then
|
|
' get the free space available on the specified disk
|
|
intFreeDiskSpace = getFreeSpaceOnDisk(strDriveName,objService)
|
|
' get the current pagefile size
|
|
intCurrentSize = getCurrentPageFileSize(objService,objInstance)
|
|
' get the total free space
|
|
If Len(intCurrentSize) > 0 Then
|
|
intFreeSpace = intFreeDiskSpace + intCurrentSize
|
|
Else
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
' Get the Disk Size for the specified drive
|
|
intDiskSize = GetDiskSize(arrVolume(i),objService)
|
|
' check if maxsize is more than initsize
|
|
If (CLng(intMaxSize) > CLng(intDiskSize)) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf DiskTooSmallErrorMessage, Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
Else
|
|
If (CLng(intMaxSize) > CLng(intFreeSpace)) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf GrowsToFreeSpaceWarningMessage, _
|
|
Array(UCase(arrVolume(i)),intFreeSpace)
|
|
strReply = getReply()
|
|
If Trim(LCase(strReply)) = L_UserReplyYes_Text Then
|
|
' set the maxsize to be the free space on disk
|
|
intMaxSize = intFreeSpace
|
|
' check if the given maxsize is greater than the existing initial size.
|
|
If (CInt(intMaxSize) >= objInstance.InitialSize) Then
|
|
If (CInt(intMaxSize) <> objInstance.MaximumSize) Then
|
|
intOldMaximumSize = objInstance.MaximumSize
|
|
objInstance.MaximumSize = intMaxSize
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UpdateFailed_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf ChangeMaxSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldMaximumSize),CInt(intMaxSize))
|
|
blnSuccessMsg = TRUE
|
|
Exit For
|
|
Else
|
|
component.VBPrintf ChangeMaxSkippingMessage, Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
Else
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
ElseIf LCase(strReply) = L_UserReplyNo_Text Then
|
|
' Do Nothing continue with other drives
|
|
Exit For
|
|
Else
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
' Continue looping
|
|
Exit For
|
|
End If
|
|
Else
|
|
If (CInt(intMaxSize) >= objInstance.InitialSize) Then
|
|
If (CInt(intMaxSize) <> objInstance.MaximumSize) Then
|
|
intOldMaximumSize = objInstance.MaximumSize
|
|
objInstance.MaximumSize = intMaxSize
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UpdateFailed_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf ChangeMaxSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldMaximumSize),CInt(intMaxSize))
|
|
blnSuccessMsg = TRUE
|
|
Exit For
|
|
Else
|
|
component.VBPrintf ChangeMaxSkippingMessage, Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
Else
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
End If
|
|
End If
|
|
Else
|
|
' Check if maxsize specified as 0
|
|
If Len(intMaxSize) > 0 Then
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
End If ' maxsize checked
|
|
|
|
Else
|
|
|
|
' Case when both initsize and maxsize are selected
|
|
|
|
' check if maxsize is greater than initsize
|
|
' this will detect any overflow problems, if any
|
|
If CLng(intIntSize) > CLng(intMaxSize) Then
|
|
' check for overflows and clear the error
|
|
If Err.Number Then Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
|
|
If (intIntSize > 0) Then
|
|
' Check if initsize is greater than 2 MB
|
|
If CLng(intIntSize) >= CLng(INITIAL_SIZE_LB) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
|
|
' get the free space available on the specified disk
|
|
intFreeDiskSpace = getFreeSpaceOnDisk(strDriveName,objService)
|
|
' get the current pagefile size
|
|
intCurrentSize = getCurrentPageFileSize(objService,objInstance)
|
|
' get the total free space
|
|
If Len(intCurrentSize) > 0 Then
|
|
intFreeSpace = intFreeDiskSpace + intCurrentSize
|
|
Else
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
' check if it is greater than free disk space
|
|
If CLng(intIntSize) > CLng(intFreeSpace) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf NotEnoughSpaceErrorMessage, Array( UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
|
|
If CLng(intIntSize) > CLng(intFreeSpace) - 5 Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf AtLeastFiveMBErrorMessage, Array( UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
Else
|
|
' get the crash dump setting value
|
|
intCrashDump = GetCrashDumpSetting(strUserName,strPassword,strMachine)
|
|
' get the Physical Memory Size
|
|
intMemSize = GetPhysicalMemorySize(strHostName,objService)
|
|
' If the user has selected "yes" for the warning message
|
|
If isCrashDumpValueSet(intCrashDump,intIntSize,intMemSize,arrVolume(i)) Then
|
|
' store the old initsize value
|
|
intOldInitialSize = objInstance.InitialSize
|
|
' set the new initsize
|
|
objInstance.InitialSize = intIntSize
|
|
' check if maxsize is given
|
|
If (intMaxSize > 0) Then
|
|
' Get the Disk Size for the specified drive
|
|
intDiskSize = GetDiskSize(arrVolume(i),objService)
|
|
' check if maxsize is more than initsize
|
|
If (CLng(intMaxSize) > CLng(intDiskSize)) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf DiskTooSmallErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
Else
|
|
If (CLng(intMaxSize) > CLng(intFreeSpace)) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf GrowsToFreeSpaceWarningMessage, _
|
|
Array(UCase(arrVolume(i)),intFreeSpace)
|
|
strReply = getReply()
|
|
If Trim(LCase(strReply)) = L_UserReplyYes_Text Then
|
|
' set the maxsize to be the free space on disk
|
|
intMaxSize = intFreeSpace
|
|
intOldMaximumSize = objInstance.MaximumSize
|
|
objInstance.MaximumSize = intMaxSize
|
|
If ( CInt(intIntSize) <> intOldInitialSize ) Then
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UpdateFailed_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf ChangeIntSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldInitialSize),CInt(intIntSize))
|
|
blnSuccessMsg = TRUE
|
|
Else
|
|
component.VBPrintf ChangeIntSkippingMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
End If
|
|
If (CInt(intMaxSize) <> intOldMaximumSize) Then
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UpdateFailed_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf ChangeMaxSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldMaximumSize),CInt(intMaxSize))
|
|
blnSuccessMsg = TRUE
|
|
Exit For
|
|
Else
|
|
component.VBPrintf ChangeMaxSkippingMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
ElseIf LCase(strReply) = L_UserReplyNo_Text Then
|
|
Exit For
|
|
Else
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
Else
|
|
intOldMaximumSize = objInstance.MaximumSize
|
|
objInstance.MaximumSize = intMaxSize
|
|
objInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UpdateFailed_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
|
|
If (CInt(intIntSize) <> intOldInitialSize ) Then
|
|
component.VBPrintf ChangeIntSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldInitialSize),CInt(intIntSize))
|
|
blnSuccessMsg = TRUE
|
|
Else
|
|
component.VBPrintf ChangeIntSkippingMessage, Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
End If
|
|
|
|
If (CInt(intMaxSize) <> intOldMaximumSize) Then
|
|
component.VBPrintf ChangeMaxSuccessMessage, _
|
|
Array(UCase(arrVolume(i)),CInt(intOldMaximumSize),CInt(intMaxSize))
|
|
blnSuccessMsg = TRUE
|
|
Exit For
|
|
Else
|
|
component.VBPrintf ChangeMaxSkippingMessage, Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit For
|
|
End If
|
|
End If
|
|
End If
|
|
Else
|
|
' Check if maxsize specified as 0
|
|
If Len(intMaxSize) > 0 Then
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
End If ' maxsize checked
|
|
End If
|
|
End If
|
|
Else
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InitialSizeRangeErrorMessage, _
|
|
Array(intMaxSizeUB, UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
Else
|
|
' Check if initsize specified as 0
|
|
If Len(intIntSize) > 0 Then
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InitialSizeRangeErrorMessage, _
|
|
Array(intMaxSizeUB, UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
End If ' initsize checked
|
|
End If
|
|
End If
|
|
Next
|
|
Else
|
|
component.VBPrintf L_PageFileDoesNotExist_ErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
End If
|
|
Else
|
|
' the drive does not exist
|
|
component.VBPrintf L_InvalidVolumeName_ErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
' remove the drive name from the valid drives list
|
|
objVols.Remove arrVolume(i)
|
|
' decrement the loop count
|
|
i = i - 1
|
|
' check for the no.of valid drive names from the specified list.
|
|
If Cint(objVols.Count) = 0 Then
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
Else
|
|
intVolumes = objVols.Count
|
|
arrVolume = objVols.keys
|
|
End If
|
|
End If
|
|
i = i + 1
|
|
Loop
|
|
|
|
If blnSuccessMsg = TRUE then
|
|
WScript.Echo L_RestartComputer_Message
|
|
End If
|
|
If blnFailureMsg = TRUE Then
|
|
If blnSuccessMsg = TRUE Then
|
|
Wscript.Quit( EXIT_PARTIAL_SUCCESS)
|
|
else
|
|
Wscript.Quit( EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
End Sub
|
|
|
|
'******************************************************************************
|
|
'* Sub: ProcessCreate
|
|
'*
|
|
'* Purpose: Creates new page files with the given specifications
|
|
'*
|
|
'* Input:
|
|
'* [in] strMachine machine to configure page files on
|
|
'* [in] strUserName user name to connect to the machine
|
|
'* [in] strPassword password for the user
|
|
'* [in] intIntSize the initial size for the page file
|
|
'* [in] intMaxSize the maximum size for the page file
|
|
'* [in] objVols the object containing volume names
|
|
'*
|
|
'* Output: Displays error message and quits if connection fails
|
|
'*
|
|
'******************************************************************************
|
|
Private Sub ProcessCreate( ByVal strMachine, _
|
|
ByVal strUserName, _
|
|
ByVal strPassword, _
|
|
ByVal intIntSize, _
|
|
ByVal intMaxSize, _
|
|
ByVal blnSystemManaged, _
|
|
ByVal objVols )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim arrVolume ' to store all the volumes specified
|
|
Dim intVolumes ' to store the no.of volumes specified
|
|
Dim strQuery ' to store the query for pagefiles
|
|
Dim strQueryDisk ' to store the query for disk
|
|
Dim strQueryComp ' to store the query for getting host name
|
|
Dim objService ' service object
|
|
Dim objInst ' instance object
|
|
Dim objInstance ' instance object
|
|
Dim objEnum ' collection object for query results
|
|
Dim objEnumforDisk ' collection object for query results
|
|
|
|
Dim strHostName ' to store the host name
|
|
|
|
Dim i ' Loop variable
|
|
|
|
' variables used only if * is specified
|
|
Dim objEnumerator ' collection object for query results
|
|
|
|
i = 0
|
|
|
|
If NOT component.wmiConnect(CONST_NAMESPACE_CIMV2 , _
|
|
strUserName , _
|
|
strPassword , _
|
|
strMachine , _
|
|
blnLocalConnection , _
|
|
objService ) Then
|
|
WScript.Echo(L_HintCheckConnection_Message)
|
|
WScript.Quit(EXIT_METHOD_FAIL)
|
|
End If
|
|
|
|
If (objVols.Exists("*")) Then
|
|
' build the query
|
|
intVolumes = 0
|
|
' get all the drive names with drive type = 3 (other than floppy drive & CDROM Drive)
|
|
strQuery = "Select DeviceID From " & CLASS_LOGICAL_DISK & _
|
|
" where DriveType = " & DRIVE_TYPE
|
|
' execute the query
|
|
Set objEnumerator = objService.ExecQuery(strQuery, "WQL", 48, null)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
|
|
For each objInstance in objEnumerator
|
|
' check if the volumename is not an alias name and neither a mapped drive.
|
|
If IsValidPhysicalDrive(objService, objInstance.DeviceID) Then
|
|
' check if the volume name is specified more than once.
|
|
If NOT objVols.Exists(LCase(objInstance.DeviceID)) Then
|
|
objVols.Add LCase(objInstance.DeviceID),-1
|
|
End If
|
|
End If
|
|
Next
|
|
' Remove * from objVols after adding the drives to the object.
|
|
objVols.Remove "*"
|
|
End If
|
|
|
|
intVolumes = objVols.Count
|
|
arrVolume = objVols.Keys
|
|
|
|
' Get the host Name - used to get Crash Dump Settings
|
|
strQueryComp = "Select * From " & CLASS_COMPUTER_SYSTEM
|
|
Set objEnum = objService.ExecQuery(strQueryComp, "WQL", 0, null)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
|
|
For each objInst in objEnum
|
|
If NOT ISEmpty(objInst.Name) Then
|
|
strHostName = objInst.Name
|
|
Else
|
|
WSCript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
Next
|
|
|
|
' No wild Cards Specified
|
|
Do While( i < intVolumes )
|
|
|
|
strQueryDisk = "Select * From " & CLASS_LOGICAL_DISK & _
|
|
" where DriveType = " & DRIVE_TYPE & " and DeviceID = '" & arrVolume(i) & "'"
|
|
Set objEnumforDisk = objService.ExecQuery(strQueryDisk, "WQL", 0, null)
|
|
|
|
strQuery = "Select * From " & CLASS_PAGE_FILE_SETTING & _
|
|
" where Name = '" & arrVolume(i) & "\" & PAGEFILE_DOT_SYS & "'"
|
|
Set objEnum = objService.ExecQuery(strQuery, "WQL", 0, null)
|
|
|
|
' If valid drive and pagefile exists on that drive
|
|
If (objEnumforDisk.Count = 0 AND objEnum.Count = 0 ) Then
|
|
' the drive does not exist
|
|
component.VBPrintf L_InvalidVolumeName_ErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
bFailureMsg = TRUE
|
|
' remove the drive name from the valid drives list
|
|
objVols.Remove arrVolume(i)
|
|
' decrement the loop count
|
|
i = i - 1
|
|
' check for the no.of valid drive names from the specified list.
|
|
If Cint(objVols.Count) = 0 Then
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
Else
|
|
intVolumes = objVols.Count
|
|
arrVolume = objVols.keys
|
|
End If
|
|
Else
|
|
' SKIP - if at least one instance is found then dont create a new instance
|
|
If (objEnumforDisk.Count = 1 AND objEnum.Count = 1) Then
|
|
component.VBPrintf L_CreateSkipping_Message, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Else
|
|
' check if the volumename is an alias name or a mapped drive
|
|
If NOT IsValidPhysicalDrive(objService, arrVolume(i)) Then
|
|
component.VBPrintf L_InvalidPhysicalDrive_ErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Else
|
|
CreatePageFile objService, arrVolume, blnSystemManaged, _
|
|
intIntSize, intMaxSize, strMachine, strUserName, _
|
|
strPassword, strHostName, i
|
|
End If
|
|
End If
|
|
End If
|
|
i = i + 1
|
|
Loop
|
|
' Prompt for reboot if atleast one operation is successful
|
|
If blnSuccessMsg = TRUE then
|
|
WScript.Echo L_RestartComputer_Message
|
|
End If
|
|
' DEcide on the return level. If atleast one succeds, return partial success.. If all fails return complete failure
|
|
If blnFailureMsg = TRUE Then
|
|
If blnSuccessMsg = TRUE Then
|
|
Wscript.Quit( EXIT_PARTIAL_SUCCESS)
|
|
else
|
|
Wscript.Quit( EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
'**************************************************************************************************
|
|
'* sub: CreatePageFile
|
|
'*
|
|
'* Purpose: Creates new page file on a specified drive at the specified index
|
|
'*
|
|
'* INPUT:
|
|
'*
|
|
'* [IN] objService The WMI service object
|
|
'* [IN] arrVolume Array of volumes to create the page files on
|
|
'* [IN] blnSystemManaged Indicates whether the drive has to be system managed
|
|
'* [IN] intIntSize Indicates the InitialSize
|
|
'* [IN] intMaxSize Indicates the Maximum Size
|
|
'* [IN] strMachine The system to connect to
|
|
'* [IN] strUserName User name
|
|
'* [IN] strPassword Password
|
|
'* [IN] strHostName The host name for the remote machine
|
|
'* [IN] i The index of the drive name in arrVolume to create the page file
|
|
'*
|
|
'**************************************************************************************************
|
|
|
|
Private Sub CreatePageFile(ByVal objService, _
|
|
ByVal arrVolume, _
|
|
ByVal blnSystemManaged, _
|
|
ByVal intIntSize, _
|
|
ByVal intMaxSize, _
|
|
ByVal strMachine, _
|
|
ByVal strUserName, _
|
|
ByVal strPassword, _
|
|
ByVal strHostName, _
|
|
BYVal i)
|
|
ON ERROR RESUME NEXT
|
|
|
|
Dim objInstance ' instance object
|
|
Dim objNewInstance ' instance object
|
|
Dim intFreeSpace ' to store total free space
|
|
Dim intFreeDiskSpace ' to store free disk space
|
|
Dim intCurrentSize ' to store the current pagefile size
|
|
Dim intDiskSize ' to store the disk size for the specified disk
|
|
Dim intMemSize ' to store physical memory size
|
|
Dim intCrashDump ' to store the current crash dump setting value
|
|
Dim strReply ' to store the user reply
|
|
Dim intMaxSizeUB ' to store the upper bound for maximum size
|
|
|
|
intFreeSpace = 0
|
|
intFreeDiskSpace = 0
|
|
intCurrentSize = 0
|
|
intMaxSizeUB = 0
|
|
Err.Clear
|
|
' set the security privilege to allow pagefile creation
|
|
objService.Security_.Privileges.AddAsString("SeCreatePagefilePrivilege")
|
|
If Err.Number then
|
|
Err.Clear
|
|
WScript.Echo("ERROR: Failed to set the security privilege.")
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_METHOD_FAIL
|
|
End If
|
|
|
|
Set objInstance = objService.Get(CLASS_PAGE_FILE_SETTING)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
Component.VBPrintf L_CannotCreate_ErrorMessage,Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_METHOD_FAIL
|
|
End If
|
|
|
|
Set objNewInstance = objInstance.SpawnInstance_
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
Component.VBPrintf L_CannotCreate_ErrorMessage,Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
|
|
' append the filename to the volume name
|
|
objNewInstance.Name = UCase(arrVolume(i)) & PAGEFILE_DOT_SYS
|
|
|
|
|
|
'Check if the page file has to be managed by the system
|
|
If blnSystemManaged = TRUE Then
|
|
objNewInstance.InitialSize = CONST_SYSTEM_INIT_SIZE
|
|
objNewInstance.MaximumSize = CONST_SYSTEM_MAX_SIZE
|
|
objNewInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
Component.VBPrintf L_CannotCreate_ErrorMessage,Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf L_CreateSystemSuccess_message, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnSuccessMsg = TRUE
|
|
' If not System managed
|
|
Else
|
|
' check if maxsize is greater than initsize
|
|
' this will detect any overflow problems, if any
|
|
If ( CLng(intIntSize) > CLng(intMaxSize) ) Then
|
|
' check for overflows and clear the error
|
|
If Err.Number Then Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
Exit Sub
|
|
End If
|
|
|
|
' Check the initial size with the free space on the disk
|
|
If CLng(intIntSize) >= CLng(INITIAL_SIZE_LB) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
' get the free space on the specified disk
|
|
intFreeDiskSpace = getFreeSpaceOnDisk(arrVolume(i),objService)
|
|
|
|
' get the total free space Since its a new instane the current size willNOT be available. So the initial size is taken into considerarion for calculating the total free space.
|
|
intFreeSpace = intFreeDiskSpace
|
|
' Check if it greater than free disk space
|
|
If CLng(intIntSize) > CLng(intFreeSpace) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf NotEnoughSpaceErrorMessage, Array( UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit Sub
|
|
End If
|
|
|
|
If CLng(intIntSize) > CLng(intFreeSpace) - 5 Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf AtLeastFiveMBErrorMessage, Array( UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit Sub
|
|
End If
|
|
|
|
' get the crash dump setting value
|
|
intCrashDump = GetCrashDumpSetting(strUserName,strPassword,strMachine)
|
|
' get the Physical Memory Size
|
|
intMemSize = GetPhysicalMemorySize(strHostName,objService)
|
|
' check if the user has selected "yes" for the warning message
|
|
If isCrashDumpValueSet(intCrashDump,intIntSize,intMemSize,arrVolume(i)) Then
|
|
objNewInstance.InitialSize = CInt(intIntSize)
|
|
' Get the Disk Size for the specified drive
|
|
intDiskSize = GetDiskSize(arrVolume(i),objService)
|
|
If (CLng(intMaxSize) > CLng(intDiskSize)) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InsufficientMaxSizeErrorMessage, _
|
|
Array( UCase(arrVolume(i)) , intMaxSizeUB )
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf DiskTooSmallErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Exit Sub
|
|
ElseIf (CLng(intMaxSize) > CLng(intFreeSpace)) Then
|
|
' check for overflows
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf GrowsToFreeSpaceWarningMessage, _
|
|
Array(UCase(arrVolume(i)),intFreeSpace)
|
|
strReply = getReply()
|
|
If Trim(LCase(strReply)) = L_UserReplyYes_Text Then
|
|
' maxsize can grow only to the free disk space available.
|
|
' set the maxsize to the free space on disk.
|
|
intMaxSize = intFreeSpace
|
|
objNewInstance.MaximumSize = intMaxSize
|
|
objNewInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
Component.VBPrintf L_CannotCreate_ErrorMessage,Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf CreateSuccessMessage, _
|
|
Array(CInt(intIntSize),CInt(intMaxSize),UCase(arrVolume(i)))
|
|
blnSuccessMsg = TRUE
|
|
ElseIf LCase(strReply) = L_UserReplyNo_Text Then
|
|
Exit Sub
|
|
Else
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
Exit Sub
|
|
End If
|
|
Else
|
|
objNewInstance.MaximumSize = CInt(intMaxSize)
|
|
objNewInstance.Put_(CONST_WBEM_FLAG)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
Component.VBPrintf L_CannotCreate_ErrorMessage,Array(Ucase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
component.VBPrintf CreateSuccessMessage, _
|
|
Array(CInt(intIntSize),CInt(intMaxSize),UCase(arrVolume(i)))
|
|
blnSuccessMsg = TRUE
|
|
End If
|
|
End If 'End of IsCrashDumpset
|
|
Else 'If initial size is less than 2 MB
|
|
' get the upper bound allowed for maximum size
|
|
intMaxSizeUB = getMaxSizeUB(objService)
|
|
component.VBPrintf InitialSizeRangeErrorMessage, _
|
|
Array(intMaxSizeUB, UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
End If
|
|
End If
|
|
' End of system managed If condition
|
|
End Sub
|
|
|
|
'******************************************************************************
|
|
'* Sub: ProcessDelete
|
|
'*
|
|
'* Purpose: Deletes existing page files on the specified volumes
|
|
'*
|
|
'* Input:
|
|
'* [in] strMachine machine to configure page files on
|
|
'* [in] strUserName user name to connect to the machine
|
|
'* [in] strPassword password for the user
|
|
'* [in] objVols the object containing volume names
|
|
'*
|
|
'* Output: Displays error message and quits if connection fails
|
|
'*
|
|
'******************************************************************************
|
|
Private Sub ProcessDelete ( ByVal strMachine, _
|
|
ByVal strUserName, _
|
|
ByVal strPassword, _
|
|
ByVal blnSystemManaged, _
|
|
ByVal objVols )
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim arrVolume ' to store all the volumes specified
|
|
Dim intVolumes ' to store the no.of volumes specified
|
|
Dim objService ' service object
|
|
Dim objInstance ' instance object
|
|
Dim strQueryDisk ' to store the query for disk
|
|
Dim objEnumforDisk ' collection object for query results
|
|
Dim intMemSize ' to store physical memory size
|
|
Dim intCrashDump ' to store the current crash dump setting value
|
|
Dim strQueryComp ' to store the query for computersystem
|
|
Dim objEnum ' collection object for query results
|
|
Dim objInst ' instance object
|
|
Dim strHostName ' to store the host name
|
|
Dim i ' Loop variable
|
|
Dim strQueryPageFile ' to store the query for pagefiles
|
|
Dim objEnumPageFile ' collection object for pagefiles
|
|
|
|
' Establish connection to WMI to get pagefile info
|
|
If NOT component.wmiConnect(CONST_NAMESPACE_CIMV2 , _
|
|
strUserName , _
|
|
strPassword , _
|
|
strMachine , _
|
|
blnLocalConnection , _
|
|
objService ) Then
|
|
WScript.Echo(L_HintCheckConnection_Message)
|
|
WScript.Quit(EXIT_METHOD_FAIL)
|
|
End If
|
|
|
|
i = 0
|
|
intVolumes = objVols.Count
|
|
arrVolume = objVols.Keys
|
|
|
|
' Get the host Name - used to get Crash Dump Settings
|
|
strQueryComp = "Select * From " & CLASS_COMPUTER_SYSTEM
|
|
Set objEnum = objService.ExecQuery(strQueryComp, "WQL", 0, null)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
|
|
For each objInst in objEnum
|
|
If NOT ISEmpty(objInst.Name) Then
|
|
strHostName = objInst.Name
|
|
Else
|
|
WSCript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
Next
|
|
|
|
Do While( i < intVolumes )
|
|
strQueryDisk = "Select * From " & CLASS_LOGICAL_DISK & _
|
|
" where DriveType = " & DRIVE_TYPE & " and DeviceID = '" & arrVolume(i) & "'"
|
|
Set objEnumforDisk = objService.ExecQuery(strQueryDisk, "WQL", 0, null)
|
|
If objEnumforDisk.Count > 0 Then
|
|
Set objInstance = objService.Get(CLASS_PAGE_FILE_SETTING & "='" & _
|
|
arrVolume(i) & PAGEFILE_DOT_SYS & "'")
|
|
If Err.Number Then
|
|
Err.Clear
|
|
component.VBPrintf L_PageFileDoesNotExist_ErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
Else
|
|
intCrashDump = GetCrashDumpSetting(strUserName,strPassword,strMachine)
|
|
' get the Physical Memory Size
|
|
intMemSize = GetPhysicalMemorySize(strHostName,objService)
|
|
' If the user has selected "yes" for the warning message
|
|
' pass initsize as 0 because initsize = maxsize = 0 (assumed) after deletion
|
|
If isCrashDumpValueSet(intCrashDump,0,intMemSize,arrVolume(i)) Then
|
|
strQueryPageFile = "Select * from " & CLASS_PAGE_FILE_SETTING
|
|
Set objEnumPageFile = objService.ExecQuery(strQueryPageFile, "WQL", 0, null)
|
|
If objEnumPageFile.Count > 1 Then
|
|
' Delete the instance
|
|
objInstance.Delete_
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_InvalidInput_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
End If
|
|
|
|
component.VBPrintf L_DeleteSuccess_Message, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnSuccessMsg = TRUE
|
|
Else
|
|
component.VBPrintf CannotDeleteErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
End If
|
|
End If
|
|
End If
|
|
Else
|
|
' the drive does not exist
|
|
component.VBPrintf L_InvalidVolumeName_ErrorMessage, _
|
|
Array(UCase(arrVolume(i)))
|
|
blnFailureMsg = TRUE
|
|
' remove the drive name from the valid drives list
|
|
objVols.Remove arrVolume(i)
|
|
' decrement the loop count
|
|
i = i - 1
|
|
' check for the no.of valid drive names from the specified list.
|
|
If Cint(objVols.Count) = 0 Then
|
|
blnFailureMsg = TRUE
|
|
quitbasedonsuccess EXIT_INVALID_INPUT
|
|
Else
|
|
intVolumes = objVols.Count
|
|
arrVolume = objVols.keys
|
|
End If
|
|
End If
|
|
i = i + 1
|
|
Loop
|
|
|
|
' The instances of the following classes are also deleted along with the Win32_PageFile instances
|
|
' Win32_PageFileUsage - instances are deleted only after reboot
|
|
' Win32_PageFileSetting - instances are deleted automatically along with Win32_PageFile instances
|
|
|
|
If blnSuccessMsg = TRUE then
|
|
WScript.Echo L_RestartComputer_Message
|
|
End If
|
|
' DEcide on the return level. If atleast one succeds, return partial success.. If all fails return complete failure
|
|
If blnFailureMsg = TRUE Then
|
|
If blnSuccessMsg = TRUE Then
|
|
Wscript.Quit( EXIT_PARTIAL_SUCCESS)
|
|
else
|
|
Wscript.Quit( EXIT_INVALID_INPUT)
|
|
End If
|
|
End If
|
|
|
|
End sub
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: ProcessQuery
|
|
'*
|
|
'* Purpose: Displays the Page File Details in the specified format
|
|
'*
|
|
'* Input:
|
|
'* [in] strMachine machine to configure page files on
|
|
'* [in] strUserName user name to connect to the machine
|
|
'* [in] strPassword password for the user
|
|
'* [in] strFormat the query display format
|
|
'* [in] blnNoHeader flag to store if -nh is specified or not
|
|
'*
|
|
'* Output: Displays error message and quits if connection fails
|
|
'* Calls component.showResults() to display the page file
|
|
'* details
|
|
'*
|
|
'******************************************************************************
|
|
Private Sub ProcessQuery( ByVal strMachine, _
|
|
ByVal strUserName, _
|
|
ByVal strPassword, _
|
|
ByVal strFormat, _
|
|
ByVal blnSystemManaged, _
|
|
ByVal blnNoHeader )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim objEnumerator ' to store the results of the query is executed
|
|
Dim objInstance ' to refer to the instances of the objEnumerator
|
|
Dim strQuery ' to store the query obtained for given conditions
|
|
Dim intTotSize ' to store the total size on all drives
|
|
Dim intRecommendedSize ' to store the recommended size for all drives
|
|
Dim arrResultsDrives ' to store the columns of page file info.
|
|
Dim arrHeaderDrives ' to store the array header values
|
|
Dim arrMaxLengthDrives ' to store the maximum length for each column
|
|
Dim arrFinalResultsDrives ' used to send the arrResults to ShowResults()
|
|
Dim intColumnCountDrives ' number of columns to be displayed in the output
|
|
Dim blnPrintHeaderDrives ' variable which decides whether header is to be displayed or not
|
|
Dim arrResultsSummary ' to store the columns of page file info.
|
|
Dim arrHeaderSummary ' to store the array header values
|
|
Dim arrMaxLengthSummary ' to store the maximum length for each column
|
|
Dim arrFinalResultsSummary ' used to send the arrResults to ShowResults()
|
|
Dim intColumnCountSummary ' number of columns to be displayed in the output
|
|
Dim blnPrintHeaderSummary ' variable which decides whether header is to be displayed or not
|
|
Dim objDiskDriveInstance ' Instance for drive name
|
|
Dim objMemSizeInstance ' Instance for memory size
|
|
Dim arrblnNoDisplayDrives ' boolean variable for -noheader option
|
|
Dim arrblnNoDisplaySummary ' boolean variable for -noheader option
|
|
Dim objService ' service object
|
|
Dim strDriveName ' to store the drive name
|
|
Dim objUsageInstance ' Instance for PageFileUsage
|
|
|
|
' Initializing the blnPrintHeaders to true. Header should be printed by default
|
|
blnPrintHeaderDrives = TRUE
|
|
blnPrintHeaderSummary = TRUE
|
|
intTotSize = 0
|
|
|
|
If blnNoHeader Then
|
|
blnPrintHeaderDrives = FALSE
|
|
blnPrintHeaderSummary = FALSE
|
|
End If
|
|
|
|
' Establish connection to WMI to get pagefile information
|
|
If NOT component.wmiConnect(CONST_NAMESPACE_CIMV2 , _
|
|
strUserName , _
|
|
strPassword , _
|
|
strMachine , _
|
|
blnLocalConnection , _
|
|
objService ) Then
|
|
WScript.Echo(L_HintCheckConnection_Message)
|
|
WScript.Quit(EXIT_METHOD_FAIL)
|
|
End If
|
|
|
|
arrHeaderDrives = Array(L_ColHeaderHostname_Text , L_ColHeaderDrive_Text, _
|
|
L_ColHeaderVolumeLabel_Text, L_ColHeaderFileName_Text, _
|
|
L_ColHeaderInitialSize_Text, L_ColHeaderMaximumSize_Text, _
|
|
L_ColHeaderCurrentSize_Text, L_ColHeaderFreeSpace_Text,_
|
|
L_ColHeaderPageFileStatus_Text)
|
|
|
|
arrHeaderSummary = Array(L_ColHeaderHostname_Text, L_ColHeaderTotalMinimumSize_Text, _
|
|
L_ColHeaderTotalRecommendedSize_Text, L_ColHeaderTotalSize_Text)
|
|
|
|
' Data Lengths = (15,13,13,19,20,20,20,22)
|
|
arrMaxLengthDrives = Array(L_CONST_HOSTNAME_Length_Text, L_CONST_DRIVENAME_Length_Text, L_CONST_VOLLABEL_Length_Text, _
|
|
L_CONST_PAGEFILENAME_Length_Text, L_CONST_INTSIZE_Length_Text, L_CONST_MAXSIZE_Length_Text, _
|
|
L_CONST_CURRENTSIZE_Length_Text, L_CONST_FREESPACE_Length_Text, _
|
|
L_ColHeaderPageFileStatusLength_Text)
|
|
|
|
' Data Lengths = (15,33,37,40)
|
|
arrMaxLengthSummary = Array(L_CONST_HOSTNAME_Length_Text, L_CONST_TOTALMINSIZE_Length_Text,_
|
|
L_CONST_TOTALRECSIZE_Length_Text, L_CONST_TOTALSIZE_Length_Text)
|
|
|
|
arrblnNoDisplayDrives = Array(0,0,0,0,0,0,0,0,0)
|
|
arrblnNoDisplaySummary = Array(0,0,0,0)
|
|
|
|
' first initialize the array with N/A
|
|
arrResultsDrives = Array(L_Na_Text,L_Na_Text,L_Na_Text,L_Na_Text,L_Na_Text,L_Na_Text,_
|
|
L_Na_Text,L_Na_Text, L_Na_Text)
|
|
arrResultsSummary = Array(L_Na_Text,L_Na_Text,L_Na_Text,L_Na_Text)
|
|
|
|
' build the query
|
|
strQuery = "SELECT * FROM " & CLASS_PAGE_FILE_SETTING
|
|
|
|
' execute the query
|
|
Set objEnumerator = objService.ExecQuery(strQuery, "WQL", 0, null)
|
|
' check for any errors
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
WScript.Quit(EXIT_QUERY_FAIL)
|
|
End If
|
|
|
|
' If no.of pagefile instances are 0 (zero)
|
|
If (objEnumerator.Count = 0) Then
|
|
WScript.Echo(L_NoPageFiles_Message)
|
|
WScript.Quit(EXIT_UNEXPECTED)
|
|
End If
|
|
|
|
ReDim arrFinalResultsDrives(0)
|
|
ReDim arrFinalResultsSummary(0)
|
|
|
|
If(LCase(strFormat) <> "csv") Then
|
|
WScript.Echo("") ' Blank Line
|
|
End If
|
|
|
|
' Loop through all the instances for the first report
|
|
For each objInstance in objEnumerator
|
|
|
|
If NOT IsEmpty(objInstance.Name) Then
|
|
strDriveName = Mid(objInstance.Name,1,2)
|
|
End If
|
|
|
|
' check if it is a valid physical drive
|
|
If IsValidPhysicalDrive(objService,strDriveName) Then
|
|
|
|
If IsEmpty(objInstance.Name) Then
|
|
arrResultsDrives(1) = L_Na_Text
|
|
Else
|
|
strDriveName = Mid(objInstance.Name,1,2)
|
|
arrResultsDrives(1) = UCase(strDriveName)
|
|
End If
|
|
|
|
' to get the data from Win32_PageFileUsage
|
|
Set objUsageInstance = objService.Get(CLASS_PAGE_FILE_USAGE & "='" & objInstance.Name & "'")
|
|
|
|
' to get the current size
|
|
If Len(objUsageInstance.AllocatedBaseSize) = 0 Then
|
|
arrResultsDrives(6) = L_Na_Text
|
|
Else
|
|
arrResultsDrives(6) = objUsageInstance.AllocatedBaseSize & MEGA_BYTES
|
|
intTotSize = intTotSize + objUsageInstance.AllocatedBaseSize
|
|
End If
|
|
|
|
' To set the PageFile status field
|
|
If (objInstance.InitialSize = 0 AND objInstance.MaximumSize = 0) Then
|
|
arrResultsDrives(8) = L_CONST_System_Managed_Text
|
|
Else
|
|
arrResultsDrives(8) = L_Custom_Text
|
|
End If
|
|
|
|
|
|
' to get the data from Win32_LogicalDisk
|
|
Set objDiskDriveInstance = objService.Get(CLASS_LOGICAL_DISK & "='" & strDriveName & "'")
|
|
|
|
If Len(objDiskDriveInstance.VolumeName) = 0 Then
|
|
arrResultsDrives(2) = L_Na_Text
|
|
Else
|
|
arrResultsDrives(2) = objDiskDriveInstance.VolumeName
|
|
End If
|
|
|
|
If Len(objDiskDriveInstance.SystemName) = 0 Then
|
|
arrResultsDrives(0) = L_Na_Text
|
|
Else
|
|
arrResultsDrives(0) = objDiskDriveInstance.SystemName
|
|
arrResultsSummary(0) = objDiskDriveInstance.SystemName
|
|
End If
|
|
|
|
If (objDiskDriveInstance.FreeSpace) Then
|
|
arrResultsDrives(7) = Int(objDiskDriveInstance.FreeSpace/CONVERSION_FACTOR) + Int(objUsageInstance.AllocatedBaseSize) &_
|
|
MEGA_BYTES
|
|
Else
|
|
arrResultsDrives(7) = L_Na_Text
|
|
End If
|
|
|
|
If IsEmpty(objInstance.Name) Then
|
|
arrResultsDrives(3) = L_Na_Text
|
|
Else
|
|
arrResultsDrives(3) = objInstance.Name
|
|
End If
|
|
|
|
If objInstance.InitialSize Then
|
|
arrResultsDrives(4) = objInstance.InitialSize & MEGA_BYTES
|
|
Else
|
|
arrResultsDrives(4) = L_Na_Text
|
|
End If
|
|
|
|
If objInstance.MaximumSize Then
|
|
arrResultsDrives(5) = objInstance.MaximumSize & MEGA_BYTES
|
|
Else
|
|
arrResultsDrives(5) = L_Na_Text
|
|
End If
|
|
|
|
arrFinalResultsDrives(0) = arrResultsDrives
|
|
|
|
|
|
Call component.showResults(arrHeaderDrives, arrFinalResultsDrives, arrMaxLengthDrives, _
|
|
strFormat, blnPrintHeaderDrives, arrblnNoDisplayDrives)
|
|
blnPrintHeaderDrives = FALSE
|
|
|
|
End If
|
|
|
|
Next
|
|
WScript.Echo("")
|
|
|
|
' Display the summary report
|
|
arrResultsSummary(1) = INITIAL_SIZE_LB & MEGA_BYTES
|
|
Set objMemSizeInstance = objService.Get(CLASS_COMPUTER_SYSTEM & "='" & arrResultsDrives(0) & "'")
|
|
If objMemSizeInstance.TotalPhysicalMemory Then
|
|
intRecommendedSize = Int(Int(objMemSizeInstance.TotalPhysicalMemory/CONVERSION_FACTOR)* SIZE_FACTOR)
|
|
arrResultsSummary(2) = intRecommendedSize & MEGA_BYTES
|
|
Else
|
|
arrResultsSummary(2) = L_Na_Text
|
|
End If
|
|
|
|
arrResultsSummary(3) = intTotSize & MEGA_BYTES
|
|
arrFinalResultsSummary(0) = arrResultsSummary
|
|
|
|
Call component.showResults(arrHeaderSummary, arrFinalResultsSummary, arrMaxLengthSummary, strFormat, _
|
|
blnPrintHeaderSummary,arrblnNoDisplaySummary)
|
|
blnPrintHeaderSummary = FALSE
|
|
|
|
End Sub
|
|
|
|
'******************************************************************************
|
|
'* Function: IsValidPhysicalDrive
|
|
'*
|
|
'* Purpose: To check if the specified drive is a valid physical drive.
|
|
'* This check is done only for Win2K builds
|
|
'*
|
|
'* Input:
|
|
'* [in] objServiceParam service object to maintain wmi connection.
|
|
'* [in] strDriveName drive name whose validity has to be checked.
|
|
'*
|
|
'* Output: Returns TRUE or FALSE
|
|
'* TRUE - when the drive is a valid physical drive.
|
|
'* FALSE - when the drive is not a valid physical drive.
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function IsValidPhysicalDrive ( ByVal objServiceParam, _
|
|
ByVal strDriveName )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
CONST WIN2K_MAJOR_VERSION = 5000
|
|
CONST WINXP_MAJOR_VERSION = 5001
|
|
|
|
Dim strQuery ' to store the query to be executed
|
|
Dim objEnum ' collection object
|
|
Dim objInstance ' instance object
|
|
Dim strValidDrives ' to store all valid physical drives
|
|
Dim strVersion ' to store the OS version
|
|
Dim arrVersionElements ' to store the OS version elements
|
|
Dim CurrentMajorVersion ' the major version number
|
|
|
|
strValidDrives = ""
|
|
' by default set it to true
|
|
IsValidPhysicalDrive = TRUE
|
|
|
|
strquery = "Select * From " & CLASS_OPERATING_SYSTEM
|
|
set objEnum = objServiceParam.ExecQuery(strQuery,"WQL",48,null)
|
|
|
|
For each objInstance in objEnum
|
|
strVersion= objInstance.Version
|
|
Next
|
|
|
|
' OS Version : 5.1.xxxx(Windows XP), 5.0.xxxx(Windows 2000)
|
|
arrVersionElements = split(strVersion,".")
|
|
' converting to major version
|
|
CurrentMajorVersion = arrVersionElements(0) * 1000 + arrVersionElements(1)
|
|
|
|
' Determine the OS Type
|
|
' If the OS version is 5.1 or later, then NO NEED to validate.
|
|
' If the OS is Win2K, then validate the drive name.
|
|
If CInt(CurrentMajorVersion) <= CInt(WINXP_MAJOR_VERSION) Then
|
|
|
|
strQuery = "Select * From " & CLASS_PERFDISK_PHYSICAL_DISK
|
|
Set objEnum = objServiceParam.ExecQuery(strQuery, "WQL", 0, null)
|
|
|
|
For each objInstance in objEnum
|
|
' get all the instance except the last one
|
|
If (objInstance.Name <> "_Total") Then
|
|
strValidDrives = strValidDrives & " " & objInstance.Name
|
|
End If
|
|
Next
|
|
|
|
' check if the specified drive is present in the list of valid physical drives
|
|
If Instr(strValidDrives, UCase(strDriveName)) = 0 Then
|
|
IsValidPhysicalDrive = FALSE
|
|
End If
|
|
|
|
End If
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: getFreeSpaceOnDisk
|
|
'*
|
|
'* Purpose: To get the Free Space for the Specified Disk
|
|
'*
|
|
'* Input:
|
|
'* [in] strDriveName drive name whose free space is needed
|
|
'* [in] objServiceParam service object to maintain wmi connection
|
|
'*
|
|
'* Output: Returns the free space (in MB) on the specified disk.
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function getFreeSpaceOnDisk(ByVal strDriveName, ByVal objServiceParam)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim objValidDiskInst
|
|
|
|
Set objValidDiskInst = objServiceParam.Get(CLASS_LOGICAL_DISK & "='" & strDriveName & "'")
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
QuitbasedonSuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
getFreeSpaceOnDisk = Int(objValidDiskInst.FreeSpace/CONVERSION_FACTOR)
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: getCurrentPageFileSize
|
|
'*
|
|
'* Purpose: To get the current pagefile size on the specified drive
|
|
'*
|
|
'* Input:
|
|
'* [in] objService wbem service object
|
|
'* [in] objInstance instance of win32_pagefilesetting
|
|
'*
|
|
'* Output: current pagefile size
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function getCurrentPageFileSize(ByVal objService, ByVal objInstance)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim objUsageInstance
|
|
|
|
' get the data from Win32_PageFileUsage
|
|
Set objUsageInstance = objService.Get(CLASS_PAGE_FILE_USAGE & "='" & objInstance.Name & "'")
|
|
|
|
' return the current size ( allocated base size )
|
|
getCurrentPageFileSize = objUsageInstance.AllocatedBaseSize
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: GetDiskSize
|
|
'*
|
|
'* Purpose: To get the disk size for the specified drive
|
|
'*
|
|
'* Input:
|
|
'* [in] strDriveName drive name whose free space is needed
|
|
'* [in] objServiceParam service object to maintain wmi connection
|
|
'*
|
|
'* Output: Returns the total disk size in MB.
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function GetDiskSize(ByVal strDriveName, ByVal objServiceParam)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim objValidDiskInst ' object to store valid disk name
|
|
|
|
Set objValidDiskInst = objServiceParam.Get(CLASS_LOGICAL_DISK & "='" & strDriveName & "'")
|
|
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_UnableToRetrieveInfo_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
GetDiskSize = Int(objValidDiskInst.Size / CONVERSION_FACTOR)
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: GetPhysicalMemorySize
|
|
'*
|
|
'* Purpose: To get the physical memory size.
|
|
'*
|
|
'* Input:
|
|
'* [in] strHostName host name to connect to
|
|
'* [in] objServiceParam service object to maintain wmi connection
|
|
'*
|
|
'* Output: Returns the physical memory size in MB.
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function GetPhysicalMemorySize( ByVal strHostName, ByVal objServiceParam )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim objMemSizeInstance ' to store memory size
|
|
Dim intReturnValue ' to store return value
|
|
|
|
Set objMemSizeInstance = objServiceParam.Get(CLASS_COMPUTER_SYSTEM & "='" & strHostName & "'")
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo L_UnableToRetrieveInfo_ErrorMessage
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
If objMemSizeInstance.TotalPhysicalMemory Then
|
|
intReturnValue = Int(objMemSizeInstance.TotalPhysicalMemory/CONVERSION_FACTOR)
|
|
GetPhysicalMemorySize = intReturnValue
|
|
End If
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: getMaxSizeUB
|
|
'*
|
|
'* Purpose: To get the allowed upper bound for maximum size
|
|
'*
|
|
'* Input:
|
|
'* [in] objServiceParam service object to maintain wmi connection
|
|
'*
|
|
'* Output: Returns the upper bound for maximum size
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function getMaxSizeUB(objServiceParam)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
CONST PROCESSOR_X86_BASED = "X86"
|
|
CONST PROCESSOR_IA64_BASED = "IA64"
|
|
|
|
Dim objInstance ' object instance
|
|
Dim intReturnValue ' to store return value
|
|
Dim strProcessorType ' to store the processor type
|
|
Dim strQuery ' to store the query
|
|
Dim objEnum ' collection of objects
|
|
|
|
getMaxSizeUB = 0
|
|
|
|
strQuery = "Select * From " & CLASS_COMPUTER_SYSTEM
|
|
|
|
Set objEnum = objServiceParam.ExecQuery(strQuery,"WQL",48,null)
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo L_UnableToRetrieveInfo_ErrorMessage
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_QUERY_FAIL
|
|
End If
|
|
|
|
' The following code will handle only single processor environment
|
|
|
|
For each objInstance in objEnum
|
|
strProcessorType = objInstance.SystemType
|
|
Next
|
|
|
|
' check if its a 32-bit processor
|
|
If InStr( UCase(strProcessorType),PROCESSOR_X86_BASED ) > 0 Then
|
|
getMaxSizeUB = 4096
|
|
End If
|
|
|
|
' check if its a 64-bit processor
|
|
If Instr( UCase(strProcessorType),PROCESSOR_IA64_BASED ) > 0 Then
|
|
getMaxSizeUB = 33554432
|
|
End If
|
|
|
|
End Function
|
|
|
|
'******************************************************************************
|
|
'* Function: GetCrashDumpSetting
|
|
'*
|
|
'* Purpose: To get the Crash Dump Settings for the machine specified
|
|
'*
|
|
'* Input:
|
|
'* [in] strUserNameParam user name to connect to the machine
|
|
'* [in] strPasswordParam password for the user
|
|
'* [in] strMachineParam machine to get crash dump settings for
|
|
'*
|
|
'* Output: Returns the current crash dump setting value [ 0,1,2,3 ]
|
|
'* 0 - None
|
|
'* 1 - Complete Memory Dump
|
|
'* 2 - Kernel Memory Dump
|
|
'* 3 - Small Memory Dump
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function GetCrashDumpSetting( ByVal strUserNameParam, _
|
|
ByVal strPasswordParam, _
|
|
ByVal strMachineParam )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
CONST CONST_NAMESPACE_DEFAULT = "root\default" ' name space to connect to
|
|
CONST CONST_HKEY_LOCAL_MACHINE = 2147483650 ' registry value for HKEY_LOCAL_MACHINE
|
|
CONST CONST_KEY_VALUE_NAME = "CrashDumpEnabled" ' value name to be retrieved
|
|
CONST CONST_STD_REGISTRY_PROVIDER = "StdRegProv" ' standard registry provider
|
|
' the Sub Key Name
|
|
CONST CONST_CRASH_DUMP_REGKEY = "SYSTEM\CurrentControlSet\Control\CrashControl"
|
|
|
|
Dim objInstance ' to store the object instance
|
|
Dim objService ' service object
|
|
Dim intCrashDumpValue ' to store the crash dump setting value
|
|
Dim intReturnVal ' to store return value
|
|
|
|
' connect to the WMI name space
|
|
If NOT component.wmiConnect(CONST_NAMESPACE_DEFAULT , _
|
|
strUserNameParam , _
|
|
strPasswordParam , _
|
|
strMachineParam , _
|
|
blnLocalConnection , _
|
|
objService ) Then
|
|
WScript.Echo(L_HintCheckConnection_Message)
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_METHOD_FAIL
|
|
End If
|
|
|
|
' get the instance of the Standard Registry Provider
|
|
Set objInstance = objService.Get(CONST_STD_REGISTRY_PROVIDER)
|
|
|
|
' get the key value for from the registry
|
|
intReturnVal = objInstance.GetDWORDValue( CONST_HKEY_LOCAL_MACHINE, _
|
|
CONST_CRASH_DUMP_REGKEY, _
|
|
CONST_KEY_VALUE_NAME, _
|
|
intCrashDumpValue )
|
|
' check if any error has occured
|
|
If Err.Number <> 0 Then
|
|
Err.Clear
|
|
WScript.Echo(L_FailCreateObject_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_INVALID_PARAM
|
|
End If
|
|
|
|
' check for the return value after registry is accessed.
|
|
If intReturnVal = 0 Then
|
|
GetCrashDumpSetting = CInt(intCrashDumpValue)
|
|
Else
|
|
WScript.Echo(L_FailCreateObject_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_INVALID_PARAM
|
|
End If
|
|
|
|
End Function
|
|
|
|
|
|
' Function used to get the reply in y/n from the user
|
|
'******************************************************************************
|
|
'* Function: getReply
|
|
'*
|
|
'* Purpose: To get reply from the user
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: Prompts for a warning message and accepts the user's choice [y/n]
|
|
'*
|
|
'******************************************************************************
|
|
Private Function getReply()
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim objStdIn ' to store value from standard input
|
|
Dim strReply ' to store the user reply
|
|
|
|
WScript.Echo(L_PromptForContinueAnyWay_Message)
|
|
|
|
Set objStdIn = WScript.StdIn
|
|
|
|
If Err.Number Then
|
|
Err.Clear
|
|
WScript.Echo(L_FailCreateObject_ErrorMessage)
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_INVALID_PARAM
|
|
End If
|
|
|
|
strReply = objStdIn.ReadLine()
|
|
getReply = Trim(strReply)
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Function: isCrashDumpValueSet
|
|
'*
|
|
'* Purpose: To check if the crash dump value is set
|
|
'*
|
|
'* Input:
|
|
'* [in] intCrashDumpParam crash dump setting value
|
|
'* [in] intIntSizeParam initial size of the pagefile
|
|
'* [in] intMemSizeParam physical memory size
|
|
'* [in] strVolume drive/volume name
|
|
'*
|
|
'* Output: Returns TRUE or FALSE
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function isCrashDumpValueSet( ByVal intCrashDumpParam,_
|
|
ByVal intIntSizeParam, _
|
|
ByVal intMemSizeParam, _
|
|
ByVal strVolume )
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
' Constants for Crash Dump Settings
|
|
CONST NO_MEMORY_DUMP = 0
|
|
CONST COMPLETE_MEMORY_DUMP = 1
|
|
CONST KERNEL_MEMORY_DUMP = 2
|
|
CONST SMALL_MEMORY_DUMP = 3
|
|
|
|
Dim strReply ' to store user reply
|
|
Dim intSizeValue ' to store the size value used for comparison
|
|
|
|
' default value is NO [n]
|
|
strReply = L_UserReplyNo_Text
|
|
|
|
Select Case CInt(intCrashDumpParam)
|
|
|
|
Case COMPLETE_MEMORY_DUMP
|
|
If CInt(intIntSizeParam) < CInt(intMemSizeParam) Then
|
|
component.VBPrintf CrashDumpSettingWarningMessage, Array(UCase(strVolume),CInt(intMemSizeParam) & MEGA_BYTES)
|
|
' Ask for choice until a yes[y] or no[n] is given
|
|
Do
|
|
strReply = getReply()
|
|
If Trim(LCase(strReply)) = L_UserReplyYes_Text Then
|
|
isCrashDumpValueSet = TRUE
|
|
ElseIf Trim(LCase(strReply)) = L_UserReplyNo_Text Then
|
|
isCrashDumpValueSet = FALSE
|
|
Else
|
|
WScript.Echo(L_InvalidUserReply_ErrorMessage)
|
|
End If
|
|
Loop Until (Trim(LCase(strReply)) = L_UserReplyYes_Text OR Trim(LCase(strReply)) = L_UserReplyNo_Text)
|
|
Else
|
|
isCrashDumpValueSet = TRUE
|
|
End If
|
|
|
|
Case KERNEL_MEMORY_DUMP
|
|
|
|
' check if RAM size is less than or equal to 128 MB
|
|
If CInt(intMemSizeParam) <= 128 Then
|
|
' assign size value to be checked to 50 MB
|
|
intSizeValue = 50
|
|
Else
|
|
' check if RAM size is less than or equal to 4 GB
|
|
If CInt(intMemSizeParam) <= 4096 Then
|
|
' assign size value to be checked to 200 MB
|
|
intSizeValue = 200
|
|
Else
|
|
' check if RAM size is less than or equal to 8 GB
|
|
If CInt(intMemSizeParam) <= 8192 Then
|
|
' assign size value to be checked to 400 MB
|
|
intSizeValue = 400
|
|
Else
|
|
' assign size value to be checked to 800 MB
|
|
intSizeValue = 800
|
|
End If
|
|
End If
|
|
End If
|
|
|
|
If CInt(intIntSizeParam) < CInt(intSizeValue) Then
|
|
component.VBPrintf CrashDumpSettingWarningMessage, Array(UCase(strVolume),intSizeValue & MEGA_BYTES)
|
|
' Ask for choice until a yes[y] or no[n] is given
|
|
Do
|
|
strReply = getReply()
|
|
If Trim(LCase(strReply)) = L_UserReplyYes_Text Then
|
|
isCrashDumpValueSet = TRUE
|
|
ElseIf Trim(LCase(strReply)) = L_UserReplyNo_Text Then
|
|
isCrashDumpValueSet = FALSE
|
|
Else
|
|
WScript.Echo(L_InvalidUserReply_ErrorMessage)
|
|
End If
|
|
Loop Until (Trim(LCase(strReply)) = L_UserReplyYes_Text OR Trim(LCase(strReply)) = L_UserReplyNo_Text)
|
|
Else
|
|
isCrashDumpValueSet = TRUE
|
|
End If
|
|
|
|
Case SMALL_MEMORY_DUMP
|
|
|
|
' initial size should not be less than 64 KB ( less than or equal to 0 MB )
|
|
If CInt(intIntSizeParam) <= 0 Then
|
|
component.VBPrintf CrashDumpSettingWarningMessage, Array(UCase(strVolume),"64 KB")
|
|
' Ask for choice until a yes[y] or no[n] is given
|
|
Do
|
|
strReply = getReply()
|
|
If Trim(LCase(strReply)) = L_UserReplyYes_Text Then
|
|
isCrashDumpValueSet = TRUE
|
|
ElseIf Trim(LCase(strReply)) = L_UserReplyNo_Text Then
|
|
isCrashDumpValueSet = FALSE
|
|
Else
|
|
WScript.Echo(L_InvalidUserReply_ErrorMessage)
|
|
End If
|
|
Loop Until (Trim(LCase(strReply)) = L_UserReplyYes_Text OR Trim(LCase(strReply)) = L_UserReplyNo_Text)
|
|
Else
|
|
isCrashDumpValueSet = TRUE
|
|
End If
|
|
|
|
Case NO_MEMORY_DUMP
|
|
|
|
' Crash Dump values 0 has no problem
|
|
isCrashDumpValueSet = TRUE
|
|
|
|
End Select
|
|
|
|
End Function
|
|
|
|
'*******************************************************************************
|
|
'* sub: QuitBasedOnSuccess
|
|
'*
|
|
'* purpose: To quit the script based on the partial success of the operations
|
|
'*
|
|
'* Input: intReturnVal - Return value to be returned
|
|
'*
|
|
'******************************************************************************
|
|
sub QuitBasedOnSuccess(Byval intReturnVal )
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
|
|
' Prompt for reboot if at least one operation was successful.
|
|
If blnSuccessMsg = TRUE Then
|
|
WScript.Echo L_RestartComputer_Message
|
|
End If
|
|
|
|
' If zero has to be returned, return based on the failure status
|
|
If intReturnVal = EXIT_SUCCESS Then
|
|
If blnFailureMsg = TRUE Then
|
|
Wscript.Quit( EXIT_PARTIAL_SUCCESS )
|
|
Else
|
|
Wscript.Quit( EXIT_SUCCESS )
|
|
End If
|
|
|
|
'If other return levels are to be returned, just chck success value to return partial success value
|
|
Else
|
|
If blnSuccessMsg = TRUE Then
|
|
Wscript.Quit( EXIT_PARTIAL_SUCCESS )
|
|
Else
|
|
Wscript.Quit( intReturnVal)
|
|
End If
|
|
End If
|
|
|
|
End sub
|
|
|
|
'******************************************************************************
|
|
'* Sub: typeMessage
|
|
'*
|
|
'* Purpose: To print the type usage messages relevent to the main option
|
|
'* selected.
|
|
'*
|
|
'* Input: The main option selected.
|
|
'*
|
|
'* Output: Prints "type..usage" messages for the main option selected.
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Sub typeMessage(ByVal intMainOption)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Select Case CInt(intMainOption)
|
|
|
|
Case CONST_CHANGE_OPTION
|
|
component.VBPrintf L_TypeChangeUsage_Message,Array(UCase(WScript.ScriptName))
|
|
Case CONST_CREATE_OPTION
|
|
component.VBPrintf L_TypeCreateUsage_Message,Array(UCase(WScript.ScriptName))
|
|
Case CONST_DELETE_OPTION
|
|
component.VBPrintf L_TypeDeleteUsage_Message,Array(UCase(WScript.ScriptName))
|
|
Case CONST_QUERY_OPTION
|
|
component.VBPrintf L_TypeQueryUsage_Message,Array(UCase(WScript.ScriptName))
|
|
Case Else
|
|
component.VBPrintf L_TypeUsage_Message,Array(UCase(WScript.ScriptName))
|
|
|
|
End Select
|
|
|
|
End Sub
|
|
|
|
'******************************************************************************
|
|
'* Function: ExpandEnvironmentString()
|
|
'*
|
|
'* Purpose: This function expands the environment variables.
|
|
'*
|
|
'* Input: [in] strOriginalString the string that needs expansion.
|
|
'* Output: Returns ExpandedEnvironmentString
|
|
'*
|
|
'******************************************************************************
|
|
|
|
Private Function ExpandEnvironmentString(ByVal strOriginalString)
|
|
|
|
ON ERROR RESUME NEXT
|
|
Err.Clear
|
|
|
|
Dim ObjWshShell ' Object to hold Shell.
|
|
|
|
' Create the shell object.
|
|
Set ObjWshShell = CreateObject("WScript.Shell")
|
|
|
|
If Err.Number Then
|
|
WScript.Echo( L_FailCreateObject_ErrorMessage )
|
|
blnFailureMsg = TRUE
|
|
QuitBasedOnSuccess EXIT_METHOD_FAIL
|
|
End If
|
|
|
|
' Return the string.
|
|
ExpandEnvironmentString = ObjWshShell.ExpandEnvironmentStrings(strOriginalString)
|
|
|
|
End Function
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: ShowUsage
|
|
'*
|
|
'* Purpose: Shows the correct usage to the user.
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: Help messages are displayed on screen.
|
|
'*
|
|
'******************************************************************************
|
|
Sub ShowUsage()
|
|
|
|
WScript.Echo vbCr ' Line 1
|
|
WScript.Echo( L_ShowUsageLine02_Text ) ' Line 2
|
|
WScript.Echo vbCr ' Line 3
|
|
WScript.Echo( L_UsageDescription_Text ) ' Line 4
|
|
WScript.Echo( L_ShowUsageLine05_Text ) ' Line 5
|
|
WScript.Echo( L_ShowUsageLine06_Text ) ' Line 6
|
|
WScript.Echo vbCr ' Line 7
|
|
WScript.Echo( L_ShowUsageLine08_Text ) ' Line 8
|
|
WScript.Echo( L_ShowUsageLine09_Text ) ' Line 9
|
|
WScript.Echo( L_ShowUsageLine10_Text ) ' Line 10
|
|
WScript.Echo vbCr ' Line 11
|
|
WScript.Echo( L_ShowUsageLine12_Text ) ' Line 12
|
|
WScript.Echo vbCr ' Line 13
|
|
WScript.Echo( L_ShowUsageLine14_Text ) ' Line 14
|
|
WScript.Echo vbCr ' Line 15
|
|
WScript.Echo( L_ShowUsageLine16_Text ) ' Line 16
|
|
WScript.Echo( L_ShowUsageLine17_Text ) ' Line 17
|
|
WScript.Echo vbCr ' Line 18
|
|
WScript.Echo( L_ShowUsageLine19_Text ) ' Line 19
|
|
WScript.Echo( L_ShowUsageLine20_Text ) ' Line 20
|
|
WScript.Echo( L_ShowUsageLine21_Text ) ' Line 21
|
|
WScript.Echo( L_ShowUsageLine22_Text ) ' Line 22
|
|
WScript.Echo( L_ShowUsageLine23_Text ) ' Line 23
|
|
WScript.Echo( L_ShowUsageLine24_Text ) ' Line 24
|
|
WScript.Echo( L_ShowUsageLine25_Text ) ' Line 25
|
|
|
|
End Sub
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: ShowChangeUsage
|
|
'*
|
|
'* Purpose: Shows the correct usage to the user.
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: Help messages for the /Change o ption are displayed on screen.
|
|
'*
|
|
'******************************************************************************
|
|
Sub ShowChangeUsage()
|
|
|
|
WScript.Echo vbCr ' Line 1
|
|
WScript.Echo( L_ShowChangeUsageLine02_Text ) ' Line 2
|
|
WScript.Echo( L_ShowChangeUsageLine03_Text ) ' Line 3
|
|
WScript.Echo( L_ShowChangeUsageLine04_Text ) ' Line 4
|
|
WScript.Echo vbCr ' Line 5
|
|
WScript.Echo( L_UsageDescription_Text ) ' Line 6
|
|
WScript.Echo( L_ShowChangeUsageLine07_Text ) ' Line 7
|
|
WScript.Echo vbCr ' Line 8
|
|
WScript.Echo( L_UsageParamList_Text ) ' Line 9
|
|
WScript.Echo( L_UsageMachineName_Text ) ' Line 10
|
|
WScript.Echo vbCr ' Line 11
|
|
WScript.Echo( L_UsageUserNameLine1_Text ) ' Line 12
|
|
WScript.Echo( L_UsageUserNameLine2_Text ) ' Line 13
|
|
WScript.Echo vbCr ' Line 14
|
|
WScript.Echo( L_UsagePasswordLine1_Text ) ' Line 15
|
|
WScript.Echo( L_UsagePasswordLine2_Text ) ' Line 16
|
|
WScript.Echo vbCr ' Line 17
|
|
WScript.Echo( L_ShowChangeUsageLine18_Text ) ' Line 18
|
|
WScript.Echo( L_ShowChangeUsageLine19_Text ) ' Line 19
|
|
WScript.Echo vbCr ' Line 20
|
|
WScript.Echo( L_ShowChangeUsageLine21_Text ) ' Line 21
|
|
WScript.Echo( L_ShowChangeUsageLine22_Text ) ' Line 22
|
|
WScript.Echo vbCr ' Line 23
|
|
WScript.Echo( L_ShowChangeUsageLine24_Text ) ' Line 24
|
|
WScript.Echo( L_ShowChangeUsageLine25_Text ) ' Line 25
|
|
WScript.Echo vbCr ' Line 26
|
|
WScript.Echo( L_ShowChangeUsageLine27_Text ) ' Line 27
|
|
WScript.Echo( L_ShowChangeUsageLine28_Text ) ' Line 28
|
|
WScript.Echo( L_ShowChangeUsageLine29_Text ) ' Line 29
|
|
WScript.Echo( L_ShowChangeUsageLine30_Text ) ' Line 30
|
|
WScript.Echo vbCr ' Line 31
|
|
WScript.Echo( L_UsageExamples_Text ) ' Line 31
|
|
WScript.Echo( L_ShowChangeUsageLine33_Text ) ' Line 33
|
|
WScript.Echo( L_ShowChangeUsageLine34_Text ) ' Line 34
|
|
WScript.Echo( L_ShowChangeUsageLine35_Text ) ' Line 35
|
|
WScript.Echo( L_ShowChangeUsageLine36_Text ) ' Line 36
|
|
WScript.Echo( L_ShowChangeUsageLine37_Text ) ' Line 37
|
|
WScript.Echo( L_ShowChangeUsageLine38_Text ) ' Line 38
|
|
WScript.Echo( L_ShowChangeUsageLine39_Text ) ' Line 39
|
|
|
|
End Sub
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: ShowCreateUsage
|
|
'*
|
|
'* Purpose: Shows the correct usage to the user.
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: Help messages for the /Create option are displayed on screen.
|
|
'*
|
|
'******************************************************************************
|
|
Sub ShowCreateUsage()
|
|
|
|
WScript.Echo vbCr ' Line 1
|
|
WScript.Echo( L_ShowCreateUsageLine02_Text ) ' Line 2
|
|
WScript.Echo( L_ShowCreateUsageLine03_Text ) ' Line 3
|
|
WScript.Echo( L_ShowCreateUsageLine04_Text ) ' Line 4
|
|
WScript.Echo vbCr ' Line 5
|
|
WScript.Echo( L_UsageDescription_Text ) ' Line 6
|
|
WScript.Echo( L_ShowCreateUsageLine07_Text ) ' Line 7
|
|
WScript.Echo vbCr ' Line 8
|
|
WScript.Echo( L_UsageParamList_Text ) ' Line 9
|
|
WScript.Echo( L_UsageMachineName_Text ) ' Line 10
|
|
WScript.Echo vbCr ' Line 11
|
|
WScript.Echo( L_UsageUserNameLine1_Text ) ' Line 12
|
|
WScript.Echo( L_UsageUserNameLine2_Text ) ' Line 13
|
|
WScript.Echo vbCr ' Line 14
|
|
WScript.Echo( L_UsagePasswordLine1_Text ) ' Line 15
|
|
WScript.Echo( L_UsagePasswordLine2_Text ) ' Line 16
|
|
WScript.Echo vbCr ' Line 17
|
|
WScript.Echo( L_ShowCreateUsageLine18_Text ) ' Line 18
|
|
WScript.Echo( L_ShowCreateUsageLine19_Text ) ' Line 19
|
|
WScript.Echo vbCr ' Line 20
|
|
WScript.Echo( L_ShowCreateUsageLine21_Text ) ' Line 21
|
|
WScript.Echo( L_ShowCreateUsageLine22_Text ) ' Line 22
|
|
WScript.Echo vbCr ' Line 23
|
|
WScript.Echo( L_ShowCreateUsageLine24_Text ) ' Line 24
|
|
WScript.Echo( L_ShowCreateUsageLine25_Text ) ' Line 25
|
|
WScript.Echo vbCr ' Line 26
|
|
WScript.Echo( L_ShowCreateUsageLine27_Text ) ' Line 27
|
|
WScript.Echo( L_ShowCreateUsageLine28_Text ) ' Line 28
|
|
WScript.Echo( L_ShowCreateUsageLine29_Text ) ' Line 29
|
|
WScript.Echo( L_ShowCreateUsageLine30_Text ) ' Line 30
|
|
WScript.Echo vbCr ' Line 31
|
|
WScript.Echo( L_UsageExamples_Text ) ' Line 32
|
|
WScript.Echo( L_ShowCreateUsageLine33_Text ) ' Line 33
|
|
WScript.Echo( L_ShowCreateUsageLine34_Text ) ' Line 34
|
|
WScript.Echo( L_ShowCreateUsageLine35_Text ) ' Line 35
|
|
WScript.Echo( L_ShowCreateUsageLine36_Text ) ' Line 36
|
|
WScript.Echo( L_ShowCreateUsageLine37_Text ) ' Line 37
|
|
WScript.Echo( L_ShowCreateUsageLine38_Text ) ' Line 38
|
|
WScript.Echo( L_ShowCreateUsageLine39_Text ) ' Line 39
|
|
|
|
End Sub
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: ShowDeleteUsage
|
|
'*
|
|
'* Purpose: Shows the correct usage to the user.
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: Help messages for the /Delete option are displayed on screen.
|
|
'*
|
|
'******************************************************************************
|
|
Sub ShowDeleteUsage()
|
|
|
|
WScript.Echo vbCr ' Line 1
|
|
WScript.Echo( L_ShowDeleteUsageLine02_Text ) ' Line 2
|
|
WScript.Echo( L_ShowDeleteUsageLine03_Text ) ' Line 3
|
|
WScript.Echo vbCr ' Line 4
|
|
WScript.Echo( L_UsageDescription_Text ) ' Line 5
|
|
WScript.Echo( L_ShowDeleteUsageLine06_Text ) ' Line 6
|
|
WScript.Echo vbCr ' Line 7
|
|
WScript.Echo( L_UsageParamList_Text ) ' Line 8
|
|
WScript.Echo( L_UsageMachineName_Text ) ' Line 9
|
|
WScript.Echo vbCr ' Line 10
|
|
WScript.Echo( L_UsageUserNameLine1_Text ) ' Line 11
|
|
WScript.Echo( L_UsageUserNameLine2_Text ) ' Line 12
|
|
WScript.Echo vbCr ' Line 13
|
|
WScript.Echo( L_UsagePasswordLine1_Text ) ' Line 14
|
|
WScript.Echo( L_UsagePasswordLine2_Text ) ' Line 15
|
|
WScript.Echo vbCr ' Line 16
|
|
WScript.Echo( L_ShowDeleteUsageLine17_Text ) ' Line 17
|
|
WScript.Echo( L_ShowDeleteUsageLine18_Text ) ' Line 18
|
|
WScript.Echo( L_ShowDeleteUsageLine19_Text ) ' Line 19
|
|
WScript.Echo vbCr ' Line 20
|
|
WScript.Echo( L_UsageExamples_Text ) ' Line 21
|
|
WScript.Echo( L_ShowDeleteUsageLine22_Text ) ' Line 22
|
|
WScript.Echo( L_ShowDeleteUsageLine23_Text ) ' Line 23
|
|
WScript.Echo( L_ShowDeleteUsageLine24_Text ) ' Line 24
|
|
WScript.Echo( L_ShowDeleteUsageLine25_Text ) ' Line 25
|
|
|
|
End Sub
|
|
|
|
|
|
'******************************************************************************
|
|
'* Sub: ShowQueryUsage
|
|
'*
|
|
'* Purpose: Shows the correct usage to the user.
|
|
'*
|
|
'* Input: None
|
|
'*
|
|
'* Output: Help messages for the /Query option are displayed on screen.
|
|
'*
|
|
'******************************************************************************
|
|
Sub ShowQueryUsage()
|
|
|
|
WScript.Echo vbCr ' Line 1
|
|
WScript.Echo( L_ShowQueryUsageLine02_Text ) ' Line 2
|
|
WScript.Echo( L_ShowQueryUsageLine03_Text ) ' Line 3
|
|
WScript.Echo vbCr ' Line 4
|
|
WScript.Echo( L_UsageDescription_Text ) ' Line 5
|
|
WScript.Echo( L_ShowQueryUsageLine06_Text ) ' Line 6
|
|
WScript.Echo vbCr ' Line 7
|
|
WScript.Echo( L_UsageParamList_Text ) ' Line 8
|
|
WScript.Echo( L_UsageMachineName_Text ) ' Line 9
|
|
WScript.Echo vbCr ' Line 10
|
|
WScript.Echo( L_UsageUserNameLine1_Text ) ' Line 11
|
|
WScript.Echo( L_UsageUserNameLine2_Text ) ' Line 12
|
|
WScript.Echo vbCr ' Line 13
|
|
WScript.Echo( L_UsagePasswordLine1_Text ) ' Line 14
|
|
WScript.Echo( L_UsagePasswordLine2_Text ) ' Line 15
|
|
WScript.Echo vbCr ' Line 16
|
|
WScript.Echo( L_ShowQueryUsageLine17_Text ) ' Line 17
|
|
WScript.Echo( L_ShowQueryUsageLine18_Text ) ' Line 18
|
|
WScript.Echo( L_ShowQueryUsageLine19_Text ) ' Line 19
|
|
WScript.Echo vbCr ' Line 20
|
|
WScript.Echo( L_ShowQueryUsageLine21_Text ) ' Line 21
|
|
WScript.Echo( L_ShowQueryUsageLine22_Text ) ' Line 22
|
|
WScript.Echo vbCr ' Line 23
|
|
WScript.Echo( L_UsageExamples_Text ) ' Line 24
|
|
WScript.Echo( L_ShowQueryUsageLine25_Text ) ' Line 25
|
|
WScript.Echo( L_ShowQueryUsageLine26_Text ) ' Line 26
|
|
WScript.Echo( L_ShowQueryUsageLine27_Text ) ' Line 27
|
|
WScript.Echo( L_ShowQueryUsageLine28_Text ) ' Line 28
|
|
WScript.Echo( L_ShowQueryUsageLine29_Text ) ' Line 29
|
|
WScript.Echo( L_ShowQueryUsageLine30_Text ) ' Line 30
|
|
WScript.Echo( L_ShowQueryUsageLine31_Text ) ' Line 31
|
|
End Sub
|
|
|
|
'' SIG '' Begin signature block
|
|
'' SIG '' MIIaLwYJKoZIhvcNAQcCoIIaIDCCGhwCAQExDjAMBggq
|
|
'' SIG '' hkiG9w0CBQUAMGYGCisGAQQBgjcCAQSgWDBWMDIGCisG
|
|
'' SIG '' AQQBgjcCAR4wJAIBAQQQTvApFpkntU2P5azhDxfrqwIB
|
|
'' SIG '' AAIBAAIBAAIBAAIBADAgMAwGCCqGSIb3DQIFBQAEEHko
|
|
'' SIG '' YVpKucLx6zWsK5hurrSgghS8MIICvDCCAiUCEEoZ0jiM
|
|
'' SIG '' glkcpV1zXxVd3KMwDQYJKoZIhvcNAQEEBQAwgZ4xHzAd
|
|
'' SIG '' BgNVBAoTFlZlcmlTaWduIFRydXN0IE5ldHdvcmsxFzAV
|
|
'' SIG '' BgNVBAsTDlZlcmlTaWduLCBJbmMuMSwwKgYDVQQLEyNW
|
|
'' SIG '' ZXJpU2lnbiBUaW1lIFN0YW1waW5nIFNlcnZpY2UgUm9v
|
|
'' SIG '' dDE0MDIGA1UECxMrTk8gTElBQklMSVRZIEFDQ0VQVEVE
|
|
'' SIG '' LCAoYyk5NyBWZXJpU2lnbiwgSW5jLjAeFw05NzA1MTIw
|
|
'' SIG '' MDAwMDBaFw0wNDAxMDcyMzU5NTlaMIGeMR8wHQYDVQQK
|
|
'' SIG '' ExZWZXJpU2lnbiBUcnVzdCBOZXR3b3JrMRcwFQYDVQQL
|
|
'' SIG '' Ew5WZXJpU2lnbiwgSW5jLjEsMCoGA1UECxMjVmVyaVNp
|
|
'' SIG '' Z24gVGltZSBTdGFtcGluZyBTZXJ2aWNlIFJvb3QxNDAy
|
|
'' SIG '' BgNVBAsTK05PIExJQUJJTElUWSBBQ0NFUFRFRCwgKGMp
|
|
'' SIG '' OTcgVmVyaVNpZ24sIEluYy4wgZ8wDQYJKoZIhvcNAQEB
|
|
'' SIG '' BQADgY0AMIGJAoGBANMuIPBofCwtLoEcsQaypwu3EQ1X
|
|
'' SIG '' 2lPYdePJMyqy1PYJWzTz6ZD+CQzQ2xtauc3n9oixncCH
|
|
'' SIG '' Jet9WBBzanjLcRX9xlj2KatYXpYE/S1iEViBHMpxlNUi
|
|
'' SIG '' WC/VzBQFhDa6lKq0TUrp7jsirVaZfiGcbIbASkeXarSm
|
|
'' SIG '' NtX8CS3TtDmbAgMBAAEwDQYJKoZIhvcNAQEEBQADgYEA
|
|
'' SIG '' YVUOPnvHkhJ+ERCOIszUsxMrW+hE5At4nqR+86cHch7i
|
|
'' SIG '' We/MhOOJlEzbTmHvs6T7Rj1QNAufcFb2jip/F87lY795
|
|
'' SIG '' aQdzLrCVKIr17aqp0l3NCsoQCY/Os68olsR5KYSS3P+6
|
|
'' SIG '' Z0JIppAQ5L9h+JxT5ZPRcz/4/Z1PhKxV0f0RY2MwggQC
|
|
'' SIG '' MIIDa6ADAgECAhAIem1cb2KTT7rE/UPhFBidMA0GCSqG
|
|
'' SIG '' SIb3DQEBBAUAMIGeMR8wHQYDVQQKExZWZXJpU2lnbiBU
|
|
'' SIG '' cnVzdCBOZXR3b3JrMRcwFQYDVQQLEw5WZXJpU2lnbiwg
|
|
'' SIG '' SW5jLjEsMCoGA1UECxMjVmVyaVNpZ24gVGltZSBTdGFt
|
|
'' SIG '' cGluZyBTZXJ2aWNlIFJvb3QxNDAyBgNVBAsTK05PIExJ
|
|
'' SIG '' QUJJTElUWSBBQ0NFUFRFRCwgKGMpOTcgVmVyaVNpZ24s
|
|
'' SIG '' IEluYy4wHhcNMDEwMjI4MDAwMDAwWhcNMDQwMTA2MjM1
|
|
'' SIG '' OTU5WjCBoDEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4x
|
|
'' SIG '' HzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdvcmsx
|
|
'' SIG '' OzA5BgNVBAsTMlRlcm1zIG9mIHVzZSBhdCBodHRwczov
|
|
'' SIG '' L3d3dy52ZXJpc2lnbi5jb20vcnBhIChjKTAxMScwJQYD
|
|
'' SIG '' VQQDEx5WZXJpU2lnbiBUaW1lIFN0YW1waW5nIFNlcnZp
|
|
'' SIG '' Y2UwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB
|
|
'' SIG '' AQDAemGH67KnA2MbKxph3oC3FR2gi5A9uyeShBQ564XO
|
|
'' SIG '' KZIGZkikA0+N6E+n8K9e0S8Zx5HxtZ57kSHO6f/jTvD8
|
|
'' SIG '' r5VYuGMt5o72KRjNcI5Qw+2Wu0DbviXoQlXW9oXyBueL
|
|
'' SIG '' mRwx8wMP1EycJCrcGxuPgvOw76dN4xSn4I/Wx2jCYVip
|
|
'' SIG '' ctT4MEhP2S9vYyDZicqCe8JLvCjFgWjn5oJArEY6oPk/
|
|
'' SIG '' Ns1Mu1RCWnple/6E5MdHVKy5PeyAxxr3xDOBgckqlft/
|
|
'' SIG '' XjqHkBTbzC518u9r5j2pYL5CAapPqluoPyIxnxIV+XOh
|
|
'' SIG '' HoKLBCvqRgJMbY8fUC6VSyp4BoR0PZGPLEcxAgMBAAGj
|
|
'' SIG '' gbgwgbUwQAYIKwYBBQUHAQEENDAyMDAGCCsGAQUFBzAB
|
|
'' SIG '' hiRodHRwOi8vb2NzcC52ZXJpc2lnbi5jb20vb2NzcC9z
|
|
'' SIG '' dGF0dXMwCQYDVR0TBAIwADBEBgNVHSAEPTA7MDkGC2CG
|
|
'' SIG '' SAGG+EUBBwEBMCowKAYIKwYBBQUHAgEWHGh0dHBzOi8v
|
|
'' SIG '' d3d3LnZlcmlzaWduLmNvbS9ycGEwEwYDVR0lBAwwCgYI
|
|
'' SIG '' KwYBBQUHAwgwCwYDVR0PBAQDAgbAMA0GCSqGSIb3DQEB
|
|
'' SIG '' BAUAA4GBAC3zT2NgLBja9SQPUrMM67O8Z4XCI+2PRg3P
|
|
'' SIG '' Gk2+83x6IDAyGGiLkrsymfCTuDsVBid7PgIGAKQhkoQT
|
|
'' SIG '' CsWY5UBXxQUl6K+vEWqp5TvL6SP2lCldQFXzpVOdyDY6
|
|
'' SIG '' OWUIc3OkMtKvrL/HBTz/RezD6Nok0c5jrgmn++Ib4/1B
|
|
'' SIG '' CmqWMIIEEjCCAvqgAwIBAgIPAMEAizw8iBHRPvZj7N9A
|
|
'' SIG '' MA0GCSqGSIb3DQEBBAUAMHAxKzApBgNVBAsTIkNvcHly
|
|
'' SIG '' aWdodCAoYykgMTk5NyBNaWNyb3NvZnQgQ29ycC4xHjAc
|
|
'' SIG '' BgNVBAsTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEhMB8G
|
|
'' SIG '' A1UEAxMYTWljcm9zb2Z0IFJvb3QgQXV0aG9yaXR5MB4X
|
|
'' SIG '' DTk3MDExMDA3MDAwMFoXDTIwMTIzMTA3MDAwMFowcDEr
|
|
'' SIG '' MCkGA1UECxMiQ29weXJpZ2h0IChjKSAxOTk3IE1pY3Jv
|
|
'' SIG '' c29mdCBDb3JwLjEeMBwGA1UECxMVTWljcm9zb2Z0IENv
|
|
'' SIG '' cnBvcmF0aW9uMSEwHwYDVQQDExhNaWNyb3NvZnQgUm9v
|
|
'' SIG '' dCBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IB
|
|
'' SIG '' DwAwggEKAoIBAQCpAr3BcOY78k4bKJ+XeF4w6qKpjSVf
|
|
'' SIG '' +P6VTKO3/p2iID58UaKboo9gMmvRQmR57qx2yVTa8uuc
|
|
'' SIG '' hhyPn4Rms8VremIj1h083g8BkuiWxL8tZpqaaCaZ0Dos
|
|
'' SIG '' vwy1WCbBRucKPjiWLKkoOajsSYNC44QPu5psVWGsgnyh
|
|
'' SIG '' YC13TOmZtGQ7mlAcMQgkFJ+p55ErGOY9mGMUYFgFZZ8d
|
|
'' SIG '' N1KH96fvlALGG9O/VUWziYC/OuxUlE6u/ad6bXROrxjM
|
|
'' SIG '' lgkoIQBXkGBpN7tLEgc8Vv9b+6RmCgim0oFWV++2O14W
|
|
'' SIG '' gXcE2va+roCV/rDNf9anGnJcPMq88AijIjCzBoXJsyB3
|
|
'' SIG '' E4XfAgMBAAGjgagwgaUwgaIGA1UdAQSBmjCBl4AQW9Bw
|
|
'' SIG '' 72lyniNRfhSyTY7/y6FyMHAxKzApBgNVBAsTIkNvcHly
|
|
'' SIG '' aWdodCAoYykgMTk5NyBNaWNyb3NvZnQgQ29ycC4xHjAc
|
|
'' SIG '' BgNVBAsTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEhMB8G
|
|
'' SIG '' A1UEAxMYTWljcm9zb2Z0IFJvb3QgQXV0aG9yaXR5gg8A
|
|
'' SIG '' wQCLPDyIEdE+9mPs30AwDQYJKoZIhvcNAQEEBQADggEB
|
|
'' SIG '' AJXoC8CN85cYNe24ASTYdxHzXGAyn54Lyz4FkYiPyTrm
|
|
'' SIG '' IfLwV5MstaBHyGLv/NfMOztaqTZUaf4kbT/JzKreBXzd
|
|
'' SIG '' MY09nxBwarv+Ek8YacD80EPjEVogT+pie6+qGcgrNyUt
|
|
'' SIG '' vmWhEoolD2Oj91Qc+SHJ1hXzUqxuQzIH/YIX+OVnbA1R
|
|
'' SIG '' 9r3xUse958Qw/CAxCYgdlSkaTdUdAqXxgOADtFv0sd3I
|
|
'' SIG '' V+5lScdSVLa0AygS/5DW8AiPfriXxas3LOR65Kh343ag
|
|
'' SIG '' ANBqP8HSNorgQRKoNWobats14dQcBOSoRQTIWjM4bk0c
|
|
'' SIG '' DWK3CqKM09VUP0bNHFWmcNsSOoeTdZ+n0qAwggTJMIID
|
|
'' SIG '' saADAgECAhBqC5lPwADeqhHU2ECaqL7mMA0GCSqGSIb3
|
|
'' SIG '' DQEBBAUAMHAxKzApBgNVBAsTIkNvcHlyaWdodCAoYykg
|
|
'' SIG '' MTk5NyBNaWNyb3NvZnQgQ29ycC4xHjAcBgNVBAsTFU1p
|
|
'' SIG '' Y3Jvc29mdCBDb3Jwb3JhdGlvbjEhMB8GA1UEAxMYTWlj
|
|
'' SIG '' cm9zb2Z0IFJvb3QgQXV0aG9yaXR5MB4XDTAwMTIxMDA4
|
|
'' SIG '' MDAwMFoXDTA1MTExMjA4MDAwMFowgaYxCzAJBgNVBAYT
|
|
'' SIG '' AlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQH
|
|
'' SIG '' EwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29y
|
|
'' SIG '' cG9yYXRpb24xKzApBgNVBAsTIkNvcHlyaWdodCAoYykg
|
|
'' SIG '' MjAwMCBNaWNyb3NvZnQgQ29ycC4xIzAhBgNVBAMTGk1p
|
|
'' SIG '' Y3Jvc29mdCBDb2RlIFNpZ25pbmcgUENBMIIBIDANBgkq
|
|
'' SIG '' hkiG9w0BAQEFAAOCAQ0AMIIBCAKCAQEAooQVU9gLMA40
|
|
'' SIG '' lf86G8LzL3ttNyNN89KM5f2v/cUCNB8kx+Wh3FTsfgJ0
|
|
'' SIG '' R6vbMlgWFFEpOPF+srSMOke1OU5uVMIxDDpt+83Ny1Cc
|
|
'' SIG '' G66n2NlKJj+1xcuPluJJ8m3Y6ZY+3gXP8KZVN60vYM2A
|
|
'' SIG '' YUKhSVRKDxi3S9mTmTBaR3VktNO73barDJ1PuHM7GDqq
|
|
'' SIG '' tIeMsIiwTU8fThG1M4DfDTpkb0THNL1Kk5u8ph35BSNO
|
|
'' SIG '' YCmPzCryhJqZrajbCnB71jRBkKW3ZsdcGx2jMw6bVAMa
|
|
'' SIG '' P5iQuMznPQR0QxyP9znms6xIemsqDmIBYTl2bv0+mAdL
|
|
'' SIG '' FPEBRv0VAOBH2k/kBeSAJQIBA6OCASgwggEkMBMGA1Ud
|
|
'' SIG '' JQQMMAoGCCsGAQUFBwMDMIGiBgNVHQEEgZowgZeAEFvQ
|
|
'' SIG '' cO9pcp4jUX4Usk2O/8uhcjBwMSswKQYDVQQLEyJDb3B5
|
|
'' SIG '' cmlnaHQgKGMpIDE5OTcgTWljcm9zb2Z0IENvcnAuMR4w
|
|
'' SIG '' HAYDVQQLExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xITAf
|
|
'' SIG '' BgNVBAMTGE1pY3Jvc29mdCBSb290IEF1dGhvcml0eYIP
|
|
'' SIG '' AMEAizw8iBHRPvZj7N9AMBAGCSsGAQQBgjcVAQQDAgEA
|
|
'' SIG '' MB0GA1UdDgQWBBQpXLkbts0z7rueWX335couxA00KDAZ
|
|
'' SIG '' BgkrBgEEAYI3FAIEDB4KAFMAdQBiAEMAQTALBgNVHQ8E
|
|
'' SIG '' BAMCAUYwDwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0B
|
|
'' SIG '' AQQFAAOCAQEARVjimkF//J2/SHd3rozZ5hnFV7QavbS5
|
|
'' SIG '' XwKhRWo5Wfm5J5wtTZ78ouQ4ijhkIkLfuS8qz7fWBsrr
|
|
'' SIG '' Kr/gGoV821EIPfQi09TAbYiBFURfZINkxKmULIrbkDdK
|
|
'' SIG '' D7fo1GGPdnbh2SX/JISVjQRWVJShHDo+grzupYeMHIxL
|
|
'' SIG '' eV+1SfpeMmk6H1StdU3fZOcwPNtkSUT7+8QcQnHmoD1F
|
|
'' SIG '' 7msAn6xCvboRs1bk+9WiKoHYH06iVb4nj3Cmomwb/1SK
|
|
'' SIG '' gryBS6ahsWZ6qRenywbAR+ums+kxFVM9KgS//3NI3Isn
|
|
'' SIG '' Q/xj6O4kh1u+NtHoMfUy2V7feXq6MKxphkr7jBG/G41U
|
|
'' SIG '' WTCCBQ8wggP3oAMCAQICCmEHEUMAAAAAADQwDQYJKoZI
|
|
'' SIG '' hvcNAQEFBQAwgaYxCzAJBgNVBAYTAlVTMRMwEQYDVQQI
|
|
'' SIG '' EwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4w
|
|
'' SIG '' HAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xKzAp
|
|
'' SIG '' BgNVBAsTIkNvcHlyaWdodCAoYykgMjAwMCBNaWNyb3Nv
|
|
'' SIG '' ZnQgQ29ycC4xIzAhBgNVBAMTGk1pY3Jvc29mdCBDb2Rl
|
|
'' SIG '' IFNpZ25pbmcgUENBMB4XDTAyMDUyNTAwNTU0OFoXDTAz
|
|
'' SIG '' MTEyNTAxMDU0OFowgaExCzAJBgNVBAYTAlVTMRMwEQYD
|
|
'' SIG '' VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25k
|
|
'' SIG '' MR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24x
|
|
'' SIG '' KzApBgNVBAsTIkNvcHlyaWdodCAoYykgMjAwMiBNaWNy
|
|
'' SIG '' b3NvZnQgQ29ycC4xHjAcBgNVBAMTFU1pY3Jvc29mdCBD
|
|
'' SIG '' b3Jwb3JhdGlvbjCCASIwDQYJKoZIhvcNAQEBBQADggEP
|
|
'' SIG '' ADCCAQoCggEBAKqZvTmoGCf0Kz0LTD98dy6ny7XRjA3C
|
|
'' SIG '' OnTXk7XgoEs/WV7ORU+aeSnxScwaR+5Vwgg+EiD4VfLu
|
|
'' SIG '' X9Pgypa8MN7+WMgnMtCFVOjwkRC78yu+GeUDmwuGHfOw
|
|
'' SIG '' OYy4/QsdPHMmrFcryimiFZCCFeJ3o0BSA4udwnC6H+k0
|
|
'' SIG '' 9vM1kk5Vg/jaMLYg3lcGtVpCBt5Zy/Lfpr0VR3EZJSPS
|
|
'' SIG '' y2+bGXnfalvxdgV5KfzDVsqPRAiFVYrLyA9GS1XLjJZ3
|
|
'' SIG '' SofoqUEGx/8N6WhXY3LDaVe0Q88yOjDcG+nVQyYqef6V
|
|
'' SIG '' 2yJnJMkv0DTj5vtRSYa4PNAlX9bsngNhh6loQMf44gPm
|
|
'' SIG '' zwUCAwEAAaOCAUAwggE8MA4GA1UdDwEB/wQEAwIGwDAT
|
|
'' SIG '' BgNVHSUEDDAKBggrBgEFBQcDAzAdBgNVHQ4EFgQUa8jG
|
|
'' SIG '' USDwtC/ToLauf14msriHUikwgakGA1UdIwSBoTCBnoAU
|
|
'' SIG '' KVy5G7bNM+67nll99+XKLsQNNCihdKRyMHAxKzApBgNV
|
|
'' SIG '' BAsTIkNvcHlyaWdodCAoYykgMTk5NyBNaWNyb3NvZnQg
|
|
'' SIG '' Q29ycC4xHjAcBgNVBAsTFU1pY3Jvc29mdCBDb3Jwb3Jh
|
|
'' SIG '' dGlvbjEhMB8GA1UEAxMYTWljcm9zb2Z0IFJvb3QgQXV0
|
|
'' SIG '' aG9yaXR5ghBqC5lPwADeqhHU2ECaqL7mMEoGA1UdHwRD
|
|
'' SIG '' MEEwP6A9oDuGOWh0dHA6Ly9jcmwubWljcm9zb2Z0LmNv
|
|
'' SIG '' bS9wa2kvY3JsL3Byb2R1Y3RzL0NvZGVTaWduUENBLmNy
|
|
'' SIG '' bDANBgkqhkiG9w0BAQUFAAOCAQEANSP9E1T86dzw3QwU
|
|
'' SIG '' evqns879pzrIuuXn9gP7U9unmamgmzacA+uCRxwhvRTL
|
|
'' SIG '' 52dACccWkQJVzkNCtM0bXbDzMgQ9EuUdpwenj6N+RVV2
|
|
'' SIG '' G5aVkWnw3TjzSInvcEC327VVgMADxC62KNwKgg7HQ+N6
|
|
'' SIG '' SF24BomSQGxuxdz4mu8LviEKjC86te2nznGHaCPhs+QY
|
|
'' SIG '' fbhHAaUrxFjLsolsX/3TLMRvuCOyDf888hFFdPIJBpkY
|
|
'' SIG '' 3W/AhgEYEh0rFq9W72UzoepnTvRLgqvpD9wB+t9gf2ZH
|
|
'' SIG '' XcsscMx7TtkGuG6MDP5iHkL5k3yiqwqe0CMQrk17J5Fv
|
|
'' SIG '' Jr5o+qY/nyPryJ27hzGCBN0wggTZAgEBMIG1MIGmMQsw
|
|
'' SIG '' CQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQ
|
|
'' SIG '' MA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9z
|
|
'' SIG '' b2Z0IENvcnBvcmF0aW9uMSswKQYDVQQLEyJDb3B5cmln
|
|
'' SIG '' aHQgKGMpIDIwMDAgTWljcm9zb2Z0IENvcnAuMSMwIQYD
|
|
'' SIG '' VQQDExpNaWNyb3NvZnQgQ29kZSBTaWduaW5nIFBDQQIK
|
|
'' SIG '' YQcRQwAAAAAANDAMBggqhkiG9w0CBQUAoIGqMBkGCSqG
|
|
'' SIG '' SIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisGAQQBgjcC
|
|
'' SIG '' AQsxDjAMBgorBgEEAYI3AgEVMB8GCSqGSIb3DQEJBDES
|
|
'' SIG '' BBAZBnnYm2gRb/lDE2fqJ+IWME4GCisGAQQBgjcCAQwx
|
|
'' SIG '' QDA+oCaAJABwAGEAZwBlAGYAaQBsAGUAYwBvAG4AZgBp
|
|
'' SIG '' AGcALgB2AGIAc6EUgBJ3d3cubWljcm9zb2Z0LmNvbSAw
|
|
'' SIG '' DQYJKoZIhvcNAQEBBQAEggEAVrY7HUIi4Emzwy+RpCJA
|
|
'' SIG '' pVRYEi7yH9RDTWX+kPe/wdJpJpae9X7j4wU+C2oIywCF
|
|
'' SIG '' wCqxcE1HwYJu5MR4DV6EAcXJHs/eEuqU2qeMJh1zOmvy
|
|
'' SIG '' vFbVgTpsFcGSMOXvTRXjeTHSQFGfuP1FhU90ENIYrK/k
|
|
'' SIG '' RXUPH16d6rGQ8nBQUGi8uxzLOA94YXGfufMznaTCe6/z
|
|
'' SIG '' WLFioxEv9lpbaxIcnQjKXHCsnQLM557p1wGtb6/TtZuN
|
|
'' SIG '' veQbz6fcgJOZxLIk1B9Ffy90sO+YAvK6vgValTEZ1EFV
|
|
'' SIG '' lPBP13vTgdFH9ALo4BSeDKOHn8pxf3zW3+ZFJNQPRl7A
|
|
'' SIG '' o0fXKB0T5ni10KGCAkwwggJIBgkqhkiG9w0BCQYxggI5
|
|
'' SIG '' MIICNQIBATCBszCBnjEfMB0GA1UEChMWVmVyaVNpZ24g
|
|
'' SIG '' VHJ1c3QgTmV0d29yazEXMBUGA1UECxMOVmVyaVNpZ24s
|
|
'' SIG '' IEluYy4xLDAqBgNVBAsTI1ZlcmlTaWduIFRpbWUgU3Rh
|
|
'' SIG '' bXBpbmcgU2VydmljZSBSb290MTQwMgYDVQQLEytOTyBM
|
|
'' SIG '' SUFCSUxJVFkgQUNDRVBURUQsIChjKTk3IFZlcmlTaWdu
|
|
'' SIG '' LCBJbmMuAhAIem1cb2KTT7rE/UPhFBidMAwGCCqGSIb3
|
|
'' SIG '' DQIFBQCgWTAYBgkqhkiG9w0BCQMxCwYJKoZIhvcNAQcB
|
|
'' SIG '' MBwGCSqGSIb3DQEJBTEPFw0wMjEwMzAwMDE1NDdaMB8G
|
|
'' SIG '' CSqGSIb3DQEJBDESBBAeS2yNHwLSVyiXAZeQB+I2MA0G
|
|
'' SIG '' CSqGSIb3DQEBAQUABIIBAKffznG7CddPvTyv8VFLP8CJ
|
|
'' SIG '' KknWy7Jp8LJnptz+QdfY0ywUNxcjt5N2lBSy+Q6t93bz
|
|
'' SIG '' i6w6qQ6B3eZK7KtF2s0kWzSebRm9Mw0bcOxLWKz2FnuN
|
|
'' SIG '' BwhQp+CpJbKf6egJaqWfgbo7ULkrZhM9LqiBZE7OqLTn
|
|
'' SIG '' bRo22pHAgTEIo3wzO6ul203i98aJ1HMM42xKuqgFEe/9
|
|
'' SIG '' 6qDnWEvZZu/UpH7jU4PogKEZxH1EQrahyaVxHAwg6J1X
|
|
'' SIG '' uh55iLbkcXoKLJ19E/djijoX9qUnFp7Vccw6VebJU7QR
|
|
'' SIG '' eX4R20WeD9v/7C4K+VngvBiawLQf8p+FYya6uyIbg6Yt
|
|
'' SIG '' 7gGQq8NPq1M=
|
|
'' SIG '' End signature block
|