Automating and Securing Windows LAPS for Azure AD/Intune

I’m not writing a post covering Windows LAPS or how to set it up, there are many excellent articles out there which have you covered.

For this one, you can automate the setup, not only of the LAPS policy, but also creating a new local administrator on the device to use with it. It will even toggle the setting in AAD if you haven’t done so already!

The default configuration for Windows LAPS is to re-enable the default local admin (and you can also rename it), but the SID remains the same so fo extra security we will create a whole new user account.

And here is the new script. As usual you can find it on GitHub Here

Or on the PSGallery

Install-Script -Name configure-laps-intune

This script can take an account name parameter at the command line, or if one isn’t passed, it defaults to “lapsadmin”.

Whilst LAPS will handle the password moving forward, we want it to be secure from the start so it generates a random 20-digit password to be extra careful.

LAPS is then configured with these settings (the account name will match anything sent in the parameter)

LAPS Setting Screenshow
Backup to Azure AD Only
Password age 30 days
Admin account name lapsadmin
Fully complex 20 character password
Reset upon expiry

Finally, it assigns both policies to All Devices

42 thoughts on “Automating and Securing Windows LAPS for Azure AD/Intune”

  1. The description under Endpoint Security > Account Protection > LAPS Config incorrectly states lapsadmin even when a custom name is applied, same with the custom OMA-URI description.

    Reply
  2. Hi !
    First of all, great job, it works perfectly !
    Got a question though. I did launch the script by default using the PSGallery script, but didn’t not put any parameters, so it deployed with lapsadmin.
    Is there a way/script to delete this local admin everywhere so i can launch it again with the account name i wanted ?
    An other question, if someone “disappear” from intune device manager, (like he’s not connected for a long time, 1 year+), is it possible to recover his lapsadmin password somewhere ? Because the device is not listed anymore.

    Thank you !

    Reply
    • Hi,
      You could use an account protection policy, or a remediation to remove the user (net use delete)

      I dont think there is a way to find for old devices, you could check if the device still exists in Entra or Graph, but after a year that is a long shot.

      Reply
  3. Andrew, great script and I’ve used it with many different tenants. Ran into an issue with one of the tenants I manage where the systems don’t seem to be getting either the LAPS or Account creation policy. No errors and the policies have been in place over a week. Systems are checking in to Intune every day. Any ideas on what or where to check? The systems lapsadmin account has not been created at this time. Thanks.

    Reply
    • Hi, The first thing is to check in Entra and see if LAPS has been enabled centrally.
      Go to Devices – Overview – Device settings and look for:
      Enable Microsoft Entra Local Administrator Password Solution (LAPS)

      Reply
  4. You are a mad genius. Thank you.

    How to mod/cut off the script only to create the local admin user and to assign it to the administrators group?

    The reason: I already have LAPS enabled in intune and it works. Need a unified admin account on all intune joined windows devices because currently the intune laps policy applies only to devices that already have that particular admin account and ignores the rest of the devices.

    Thank you in advance.

    Reply
  5. My fault, I didn’t switch allDevicesAssignmentTarget for groupAssignmentTarget… It worked like a charm!
    Thanks again for sharing your knowledge!

    Reply
  6. It seems that “microsoft.graph.groupAssignmentTarget” does not have such a property (groupID):
    “The property ‘groupId’ does not exist on type ‘microsoft.management.services.api.allDevicesAssignmentTarget’.”
    Maybe be another microsoft.graph.XXX data type?

    Reply
  7. Hi again Andrew,
    sorry but I am not into Graph, Let’s say my group is “AADJ-Devices”, what line should I change?

    $lapsassignjson = @”
    {
    “assignments”: [
    {
    “target”: {
    “@odata.type”: “#microsoft.graph.allDevicesAssignmentTarget”
    }
    }
    ]
    }
    “@

    Reply
  8. Thank you again. I have installed but seeing errors on the devices it’s being pushed to: -2016281112, though when i look at the devices, the new user is there and in the administrators group on the system. Also not seeing the password in Intune. Anything I should be looking for? I’m missing?
    Setting name
    Setting status
    Error code
    Password [./Device/Vendor/MSFT/Accounts/Users/mediadmin/Password]
    Error
    -2016281112
    LocalUserGroup [./Device/Vendor/MSFT/Accounts/Users/m1admin/LocalUserGroup]
    Error
    -2016281112

    Reply
  9. Do I have to run it on each machine in the environment or just one machine and it will do the rest of the systems? Trying to implement LAPS in an AAD environment with a new local admin.

    Reply
  10. Sorry, a little dense today. I’ll run this PS once from my workstation and then it handles the rest? Or packaging this as a Win32 app to deploy as an app in Intune.

    Reply
  11. Hello Andrew,

    I have enabled it in the Azure tenant and then created the policy, however getting error “rotateLocalAdminPassword Failed” any idea?

    I have checked for other conflicting policies and disabled any that could be.

    I have an account created with that name.

    I have re-created the policy and left it with the default admin account to see if that works.

    all to no avail.

    Reply
  12. Sorry one further question. Will this setting automatically apply to any future devices that are connected to our Azure AD

    Reply
  13. Hi Andrew,

    Firstly thank you for this article & script.

    Please excuse my ignorance, as I am new to this, but once it password has been randomly selected, where would I be able to find the password when I need to log in with the local admin account?

    Thank you

    Reply
    • Hi,
      If you look at the Device details in Intune there is a new menu item called “Local Admin Password”. That will display the password for you.
      You can also access it through Azure AD Devices as well if you would prefer

      Hope this helps

      Reply

Leave a Comment