PoshCode Archive  Artifact [8ab3cf6003]

Artifact 8ab3cf600357e82da5407ad0cabdfdd6151ebe030784ed70982ef8f9b3ec62cb:

  • File Exch07-Quota-Report.ps1 — part of check-in [f73175edc4] at 2018-06-10 13:04:49 on branch trunk — Power Shell 1 script used to grab mailbox stats for a Exchange 2007 server. It saves the information into a .csv file by changing the $OUTFILE variable. (user: Hinkle size: 2774)

# encoding: ascii
# api: powershell
# title: Exch07 Quota Report
# description: Power Shell 1 script used to grab mailbox stats for a Exchange 2007 server.  It saves the information into a .csv file by changing the $OUTFILE variable.
# version: 0.1
# type: class
# author: Hinkle
# license: CC0
# x-poshcode-id: 2086
# x-archived: 2010-08-22T00:44:54
#
# The script is pretty basic but it’s a simple way of having a history of how people use their inbox space.  There is no method for managing the saved files.  I just make it a point to delete them when I run my months end maintenance.
#
#Get information on everybodies inbox and spit it out with total sizes #in MB.  Sorts the list by StorageLimitStatus
#NOTE THAT I HAD TO USE ASCII WITH OUT-FILE AS NO OTHER ENCODING WOULD #PROPERLY IMPORT CSV INTO EXCEL

#create a date var to stick in the filename
$date = get-date -Format MM-dd-yyyy

#create a outfile var so we only have to update it in one spot
$OUTFILE = "C:\Net_Admin_Stuff\usage_reports\daily_storage_limits\Daily_Storage_Limits-$date.csv" 

#Create the default db send/receive quota divided by 1024 to convert KB to MB.
$DEFAULTSENDQUOTA = 510000/1024

#Create a header to display at the top.
$HEADER = "Display Name,Storage Limit Status,Item Count,Total Item Size (MB),Deleted Item Count,Total Deleted Item Size (MB),Prohibit Send/Receive Quota (MB),Quota Source"
$HEADER | Out-File $OUTFILE -Append -Encoding Ascii

#Get mailbox stats for all users, sort by Storage Limit Status and go through each users objects
Get-MailboxStatistics |  where {$_.ObjectClass -eq 'Mailbox'} | Sort-Object StorageLimitStatus | ForEach-Object {		
	#Get the current user so we can grab some information from the get-mailbox command	
	$CURUSER = get-mailbox -Identity $_.Identity   

	#if the current user is using db defaults it will show a value of unlimited, which can't be calculated.    
	#Push the default value into the field when this happens  
	#Label where the source of the quota came from	
	If ($CURUSER.UseDatabaseQuotaDefaults -eq $true) 
	{
 		$QUOTASRC = $CURUSER.Database	  
		$SENDQUOTA = $DEFAULTSENDQUOTA	
	}   
	else  
	{    
		$QUOTASRC = "User Profile"    
		$SENDQUOTA = $CURUSER.ProhibitSendReceiveQuota.Value.ToMB()	  
	}	

	#Generate useable vars for each of the objects that we're going to work with.	
	$DNAME = $_.DisplayName;	
	$SLSTATUS = $_.StorageLimitStatus;	
	$ICOUNT = $_.ItemCount;	
	$TISIZE = $_.TotalItemSize.Value.ToMB();	
	$DICOUNT = $_.DeletedItemCount;	
	$TDISIZE = $_.TotalDeletedItemSize.Value.ToMB();	

	#spit out our information into a single row	
	"$DNAME,$SLSTATUS,$ICOUNT,$TISIZE,$DICOUNT,$TDISIZE,$SENDQUOTA,$QUOTASRC" 
} | Out-File $OUTFILE -Append -Encoding Ascii