AD Inactive User Report


hi all,

i working automate inactive user reporting. have created script create report based on different ou's , save xls files in folder ou name. send reports divisions.

the requirement generate report in organisational excel template. have saved template shared folder. report getting generated fine first ou mentioned in input file next ou's headings getting created in correct row/coloumn , colour data not getting populated. there doing wrong.

==================================================================================

add-pssnapin quest.activeroles.admanagement
set-qadpssnapinsettings -defaultsizelimit 0
$reportmonth=get-date -format "mmm-yy"
$comparedate=get-date
$numberdays=90
get-content "d:\inactiveusers\oupath.txt" |
foreach-object{
$oupath=$_
$excel = new-object -com excel.application
$excel.visible = $true
$wbook = $excel.workbooks.open("d:\report.xls")
$wsheet = $excel.worksheets.item(1)
$wsheet.cells.item(17,3) = "name:"
$wsheet.cells.item(17,4) = "userid:"
$wsheet.cells.item(17,5) = "lastlogontimestamp:"
$workbook = $wsheet.usedrange
$wsheet.range("c$(17):f$(17)").interior.colorindex = 9
$wsheet.range("c$(17):f$(17)").font.colorindex = 2
$workbook.font.bold = $true
$introw=18
$disusers=get-qaduser -includedproperties displayname,samaccountname,lastlogontimestamp -searchroot "ou=$oupath,dc=domain,dc=com" | { ($comparedate-$_.lastlogontimestamp).days -gt $numberdays } | select name,displayname,description,samaccountname,lastlogontimestamp
foreach ($disabled in $disusers)
{
$wsheet.cells.item($introw,3) = $disabled.displayname
$wsheet.cells.item($introw,4) = $disabled.samaccountname
$wsheet.cells.item($introw,5) = $disabled.lastlogontimestamp
$introw++
}
$workbook.entirecolumn.autofit()
$excel.displayalerts=$true
$check = test-path -pathtype container y:\$reportmonth
if($check -eq $false){new-item y:\$reportmonth -type directory}
$wsheet.saveas("y:\$reportmonth\$oupath-inactiveusers.xls")
$excel.quit()
remove-variable * -force -erroraction silentlycontinue
}

i haven't tested code, looks need move parts of outside foreach-object loop.  try this:

add-pssnapin quest.activeroles.admanagement set-qadpssnapinsettings -defaultsizelimit 0  $reportmonth=get-date -format "mmm-yy" $comparedate=get-date $numberdays=90  $excel = new-object -com excel.application $excel.visible = $true $wbook = $excel.workbooks.open("d:\report.xls") $wsheet = $excel.worksheets.item(1) $wsheet.cells.item(17,3) = "name:" $wsheet.cells.item(17,4) = "userid:" $wsheet.cells.item(17,5) = "lastlogontimestamp:" $workbook = $wsheet.usedrange $wsheet.range("c$(17):f$(17)").interior.colorindex = 9 $wsheet.range("c$(17):f$(17)").font.colorindex = 2 $workbook.font.bold = $true $introw=18   get-content "d:\inactiveusers\oupath.txt" | foreach-object{     $oupath=$_          $disusers=get-qaduser -includedproperties displayname,samaccountname,lastlogontimestamp -searchroot "ou=$oupath,dc=domain,dc=com" | { ($comparedate-$_.lastlogontimestamp).days -gt $numberdays } | select name,displayname,description,samaccountname,lastlogontimestamp     foreach ($disabled in $disusers)     {         $wsheet.cells.item($introw,3) = $disabled.displayname         $wsheet.cells.item($introw,4) = $disabled.samaccountname         $wsheet.cells.item($introw,5) = $disabled.lastlogontimestamp         $introw++     } }  $workbook.entirecolumn.autofit() $excel.displayalerts=$true $check = test-path -pathtype container y:\$reportmonth if($check -eq $false){new-item y:\$reportmonth -type directory}  $wsheet.saveas("y:\$reportmonth\$oupath-inactiveusers.xls") $excel.quit() remove-variable * -force -erroraction silentlycontinue 



Windows Server  >  Windows PowerShell



Comments

Popular posts from this blog

Azure MFA with Azure AD and RDS

Failed to setup initiator portal. Error status is given in the dump data.

Invalid pointer on gpresult /h gpreport.html