PoshCode Archive  Artifact [19a54c2e63]

Artifact 19a54c2e634115c8de0cac8831e7915b1b507651cdaaecf4d0f43afc060cfc6d:

  • File Get-DiskSizeInfo.ps1 — part of check-in [6a76286f46] at 2018-06-10 13:33:18 on branch trunk — Winter Scripting Games 2013 – Practice Event #1 (user: LazyWinAdmin size: 3980)

# encoding: ascii
# api: powershell
# title: Get-DiskSizeInfo
# description: Winter Scripting Games 2013 – Practice Event #1
# version: 0.1
# type: function
# author: LazyWinAdmin
# license: CC0
# function: Get-DiskSizeInfo
# x-poshcode-id: 3937
# x-archived: 2015-05-12T00:05:02
# x-published: 2015-02-10T20:02:00
#
# Here is my script for the first event of Winter Scripting Game 2013
# Blog Post: http://www.lazywinadmin.com/2013/02/winter-scripting-games-2013-practice.html
# Sizing up the Disks
# You have been asked to create a Windows PowerShell advanced function named Get-DiskSizeInfo. It must accept one or more computer names, and use WMI or CIM to query each computer. For each computer, it must display the percentage of free space, drive letter, total size in gigabytes, and free space in gigabytes. If a specified computer cannot be contacted, the function must log the computer name to C:\Errors.txt and display no error message.
# Minimum Requirements:
# Optional Criteria:
# -Display optional verbose output showing the computer name being contacted
#
Function Get-DiskSizeInfo {
        <#
        .DESCRIPTION
        Check the Disk(s) Size and remaining freespace.

        .PARAMETER ComputerName
        Specify the computername(s)

        .INPUTS
        System.String

        .OUTPUTS
        System.Management.Automation.PSObject

        .EXAMPLE
        Get-DiskSizeInfo
        
        Get the drive(s), Disk(s) space, and the FreeSpace (GB and Percentage)

        .EXAMPLE
        Get-DiskSizeInfo -ComputerName SERVER01,SERVER02

        Get the drive(s), Disk(s) space, and the FreeSpace (GB and Percentage)
	on the Computers SERVER01 and SERVER02

		.EXAMPLE
        Get-Content Computers.txt | Get-DiskSizeInfo

        Get the drive(s), Disk(s) space, and the FreeSpace (GB and Percentage)
	for each computers listed in Computers.txt

        .NOTES
    	NAME  : Get-DiskSizeInfo
	AUTHOR: Francois-Xavier Cat
	EMAIL : fxcat@LazyWinAdmin.com
	DATE  : 2013/02/05 
	
	.LINK
	http://lazywinadmin.com

        #>

	[CmdletBinding()]
	param(
		[Parameter(ValueFromPipeline=$True)]
		[string[]]$ComputerName = $env:COMPUTERNAME
	)
	BEGIN {# Setup
		}
	PROCESS {
		Foreach ($Computer in $ComputerName) {
			
			Write-Verbose -Message "ComputerName: $Computer - Getting Disk(s) information..."
			try {
	            # Set all the parameters required for our query
				$params = @{'ComputerName'=$Computer;
	            			'Class'='Win32_LogicalDisk';
							'Filter'="DriveType=3";
							'ErrorAction'='SilentlyContinue'}
				$TryIsOK = $True
				
				# Run the query against the current $Computer	
				$Disks = Get-WmiObject @params
			}#Try
			
			Catch {
            	"$Computer" | Out-File -Append -FilePath c:\Errors.txt
            	$TryIsOK = $False
        	}#Catch
			
			if ($TryIsOK) {
				Write-Verbose -Message "ComputerName: $Computer - Formating information for each disk(s)"
            	foreach ($disk in $Disks) {
					
                	# Prepare the Information output
					Write-Verbose -Message "ComputerName: $Computer - $($Disk.deviceid)"
					$output =	 	@{'ComputerName'=$computer;
                    				'Drive'=$disk.deviceid;
									'FreeSpace(GB)'=("{0:N2}" -f($disk.freespace/1GB));
									'Size(GB)'=("{0:N2}" -f($disk.size/1GB));
									'PercentFree'=("{0:P2}" -f(($disk.Freespace/1GB) / ($disk.Size/1GB)))}
					
					# Create a new PowerShell object for the output
					$object = New-Object -TypeName PSObject -Property $output
                	$object.PSObject.TypeNames.Insert(0,'Report.DiskSizeInfo')
					
                	# Output the disk information
					Write-Output -InputObject $object
					
            	}#foreach ($disk in $disks)
				
        	}#if ($TryIsOK)
			
    	}#Foreach ($Computer in $ComputerName)
		
	}#PROCESS
    END {# Cleanup
		}
}#Function Get-DiskSizeInfo