Script to find the user account


Recommended Posts

Hi Guys,

I have recently taken over a network where it appears the user folders are never maintained, would someone be able to code a script for me that will list the folders that dont have a user account in AD, and possibly move the folders around according to the OU structure.

Link to comment
https://www.neowin.net/forum/topic/666588-script-to-find-the-user-account/
Share on other sites

... oh wow

i'm not sure if this can be done

Sure it can :) ... With a bit of work!

I have recently taken over a network where it appears the user folders are never maintained, would someone be able to code a script for me that will list the folders that dont have a user account in AD...

You're in luck as I've just gone through this exercise for our organisation specifically to identify orphaned home directories and how much space they were consuming. You should be able to easily adapt this VB script :) Just change the strHomeDirPath & strDomain variables and run it from a Command Prompt (e.g., cscript myvbscript.vbs)...

' Force explicit variable declaration
Option Explicit

' Required to catch & continue on from errors
On Error Resume Next

' Declare and initialise constants
Const ADS_NAME_INITTYPE_GC = 3
Const ADS_NAME_TYPE_1779 = 1
Const ADS_NAME_TYPE_NT4 = 3

' Declare variables
Dim objFSO, objFolder, objSubFolder, colSubFolders, objNameTranslate, objUser
Dim strDomain, strHomeDirPath, strUserName, strUserNameDN
Dim intFolderSize

' Initialise variables
strHomeDirPath = "D:\Home\"
strDomain = "MYDOMAIN"
Set objNameTranslate = CreateObject("NameTranslate")
Set objFSO = CreateObject("Scripting.FileSystemObject")
Set objFolder = objFSO.GetFolder(strHomeDirPath)
Set colSubFolders = objFolder.SubFolders

' Output the column headings for our .csv formatted dump
WScript.Echo "Folder Name"& "," & "AD User Name" & "," & "Folder Size" & "," & "Valid/Invalid AD User"

' Loop through all home directories
For Each objSubFolder in colSubFolders
	' Get the folder name (i.e., username)
	strUserName = objSubFolder.Name

	' Translate the username to a distinguished name
	objNameTranslate.Init ADS_NAME_INITTYPE_GC, ""
	objNameTranslate.Set ADS_NAME_TYPE_NT4, strDomain & "\" & strUserName
	strUserNameDN = objNameTranslate.Get(ADS_NAME_TYPE_1779)

	' Get the folder size in megabytes with 1 decimal point
	intFolderSize = Round(objSubFolder.Size / 1024 / 1024, 1)

	' Check if translation failed (i.e., user does not exist in Active Directory)
	If Err.Number <> 0 Then
		' The user no longer exists in Active Directory; don't do anything
		WScript.Echo strUserName & "," & "," & intFolderSize & "," & "invalid"
	Else
		' The user exists in Active Directory; bind to the user using the LDAP provider and get their Display Name
		Set objUser = GetObject("LDAP://" & strUserNameDN)
		WScript.Echo strUserName & "," & objUser.displayName & "," & intFolderSize & "," & "valid"
	End If

	' Clear any errors before looping again
	Err.Clear
Next

' Object destruction
Set objFSO = Nothing
Set colSubFolders = Nothing
Set objFolder = Nothing
Set objSubFolder = Nothing
Set objNameTranslate = Nothing
Set objUser = Nothing

' Quit
WScript.Quit

That'll give you a comma separated file which you can import into Excel (or Numbers if you're a Mac fan given your signature? :p) if you need to produce a report/manipulate the data further - or you could directly send the output to a file to make it easier to work with immediately e.g., cscript myvbscript.vbs > myoutputfile.csv. If you're wanting to move/delete the orphaned home directories right away, just add the required code into the Else branch of the If/Else statement.

As for the second part of your request...

... possibly move the folders around according to the OU structure

I'm not entirely sure what you want to do here. Are you asking whether you can use a script to move a user's home directory to another folder based on the user's Organisational Unit? Or...?

Edited by fault
This topic is now closed to further replies.
  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Posts

    • "The 2TB Samsung 990 PRO NVMe SSD hits lowest price in over three months¨ I'd prefer to see the lowest price in over a year
    • Glad these prices are starting to come down, but that is still crazy. I bought the 2TB 9100 Pro (slightly more expensive version with PCIe 5.0) last year for $240.
    • The 2TB Samsung 990 PRO NVMe SSD hits lowest price in over three months by Sayan Sen Yesterday, we covered a really good deal wherein you can get a 4TB TeamGroup T-FORCE G50 NVMe PCIe Gen4 SSD for a low price of just $400 with a special discount coupon. That's just $100 per TB, making it a very good offer during these hard times. The deal is still live, so you can check it out in its dedicated article here if you do not want to miss out. Meanwhile, if you don't have that kind of budget but still wish to buy an SSD for a good price, the 2TB variant of the TeamGroup SSD at $280 its lowest price in over three months. Meanwhile, those seeking 2TB but faster performance can check out Samsung's 990 PRO, which has hit the lowest price also in the last quarter or so, as it's on sale for $370 (purchase links under the specs table down below). Thus, you want a faster drive, get the 990 Pro, or you want more capacity, grab the TeamGroup 4TB linked in the first para. The 990 PRO is a PCIe Gen4 NVMe SSD and still one of the fastest drives available today for under $500. Speaking of fast, sequential reads and writes are rated at 7450 MB/s and 6900 MB/s, respectively. The random throughputs for reads and writes are 1400K IOPS and 1550K IOPS, respectively. The 990 PRO is based on Samsung's 7th Gen V-NAND flash, and it too is TLC. It packs 2 gigs of LPDDR4 DRAM cache, which helps the random performance. The endurance rating for this is 1200 TBW (terabytes written), which should be sufficient for most users. The Samsung 990 PRO is compatible with the PlayStation 5, but if you are going to use the 990 PRO on a PC, check out the Samsung Magician app that lets you track your drive's health, update its firmware, customize various settings, and more. The tech specs are given below: Specification TeamGroup T-FORCE G50 2TB Samsung 990 PRO 2TB Interface PCIe 4.0 x4, NVMe 1.4 PCIe Gen 4.0 x4, NVMe 2.0 Form Factor M.2 2280 M.2 2280 Controller InnoGrit Controller Samsung In-house Controller NAND Flash 3D TLC 3D TLC DRAM Cache None (HMB supported) 2GB LPDDR4 Sequential Read (Max) 5,000 MB/s 7,450 MB/s Sequential Write (Max) 4,500 MB/s 6,900 MB/s Random Read (4K) Up to 600,000 IOPS Up to 1,400,000 IOPS Random Write (4K) Up to 700,000 IOPS Up to 1,550,000 IOPS TBW (Endurance) 1,300 TBW 1,200 TBW MTBF 3,000,000 hours 1,500,000 hours Operating Temperature 0°C to 70°C 0°C to 70°C Storage Temperature -40°C to 85°C -40°C to 85°C Shock Resistance 1,500G / 0.5ms 1,500G / 0.5ms Heatsink Patented Graphene Heat Spreader No Get them at the links below: Samsung 990 PRO SSD 2TB (MZ-V9P2T0B/AM): $369.99 (Sold and Shipped by Amazon US) TEAMGROUP T-Force G50 2TB SSD (TM8FFE002T0C129): $279.99 (Sold by TeamGroup, Shipped by Amazon US) Good to know This Amazon deal is U.S. specific, and not available in other regions unless specified. We only use first-party seller links (at the time of article publishing); ensure that you purchase from a first-party seller link only. Check out Today's Deals on Amazon | or our recent tech deals. Become a Prime member (for Students or SNAP) via Neowin Get Prime Access - Prime for half price (for qualifying Medicaid, EBT, SNAP) Subscribe to Prime Video, Audible Plus, Music Unlimited or Kindle Unlimited via Neowin As an Amazon Associate, we earn from qualifying purchases.
    • If you can't spell a simple word that 2nd graders learn, your entire argument is suspect.
    • And here goes the "Won't someone think of the children" brigade. Get stuffed mate. This has NOTHING to do with making the internet safe. It's about tracking adults, spying on your online activity, and sending the boys around when they don't like something you post. Also, again, parliament have voted TWICE against this, and Starmer is going ahead anyway. THAT is anti-democratic bullsh**. They will use this law to track you, they will use this law to control you, and they will use this law to punish you if they don't like what you do, even if it's legal. And your data? Say bye bye to that. It'll be on the darkweb in weeks. I'm not some rando online. I've been an IT professional for 40 years, many of it in security. I know exactly what this means and what will happen to your data. I do not consent and I will not comply.
  • Recent Achievements

    • First Post
      Jocimo earned a badge
      First Post
    • Week One Done
      suprememobiles48 earned a badge
      Week One Done
    • One Month Later
      Windows Guy earned a badge
      One Month Later
    • One Month Later
      Prasann earned a badge
      One Month Later
    • Week One Done
      Prasann earned a badge
      Week One Done
  • Popular Contributors

    1. 1
      +primortal
      520
    2. 2
      +Edouard
      174
    3. 3
      PsYcHoKiLLa
      90
    4. 4
      Steven P.
      81
    5. 5
      ATLien_0
      70
  • Tell a friend

    Love Neowin? Tell a friend!