munkireport / laps
macOSLAPS module for munkireport.
Installs: 5 412
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 6
Open Issues: 0
README
This module uses a modified version of Joshua Miller's macOSLAPS script: https://github.com/joshua-d-miller/macOSLAPS-Legacy
Configuration
The macOSLAPS module requires an encryption key before it will work. The key can be generated by going to the macOSLAPS Management page under the Admin tab. laps_password_decrypt_enabled controls all global password decrypting. If it is set to FALSE, MunkiReport will never return plaintext password. view_laps_password is an array of users that you want to grant permission to view the passwords. If commented out all users will be able to view the passwords.
The configuration can be changed by adding them to the server environment variables or the .env
file.
LAPS_ENCRYPTION_KEY=
LAPS_PASSWORD_DECRYPT_ENABLED=TRUE
VIEW_LAPS_PASSWORD=
Table Schema
The table provides the following information per client:
- useraccount - User account of local admin whose password MunkiReport has
- password - Encrypted password of local admin account
- dateset - Epoch of when password was last set
- dateexpires - Epoch of when password expired
- script_enabled - Boolean of if password changing is enabled on client
- days_till_expiration - Number of days between changing password
- alpha_numeric_only - Boolean of if password should only contain alphanumeric characters
- keychain_remove - Boolean of if local admin keychain should be deleted when password is changed
- pass_length - Length of the new password
- remote_management - Boolean of if remote management is enabled
- audit - JSON array of auditing records
Remarks
Module requires a crypto key. It can be made by calling vendor/defuse/php-encryption/bin/generate-defuse-key
in the root of the munkireport directory or by visiting the macOSLAPS Management page in the Admin dropdown menu. Add the resulting key to config.php
as $conf['laps_encryption_key'] = 'def00000505fe726...34'
. The local password is encrypted before it enters the database and is decrypted after retrieval. Don't lose the encryption key or your local passwords are lost forever!
To control password decryption, you can set $conf['laps_password_decrypt_enabled']
to FALSE
. This will globally disable the show password buttons in the UI and sending the decrypted password out via API. To limit password decryption to only certain users, add their username to the $conf['view_laps_password']
array. If this array is commented out, everyone will be able to view the password or access them via the API. The $conf['laps_password_decrypt_enabled']
config overrides the $conf['view_laps_password']
config when disabling all password viewing.
This module will not run if Joshua Miller's script/binary is installed, as they will conflict and cause problems.
macOSLAPS script is triggered and run by MunkiReport's preflight script.
Uses similar preferences to the macOSLAPS script and will respect profiles if used. Preference domain is org.munkireport.laps
and has the following options:
LocalAdminAccount
- Short username of the local admin account to cycle the password for, default isadmin
PasswordLength
- Length of password to set, default is12
DaysTillExpiration
- How long until the password is reset, default is60
RemoveKeyChain
- Remove the keychain of the local admin, default isTrue
AlphaNumericOnly
- Use only alphanumeric characters when making the password, default isTrue
RemovePassChars
- Characters to not include in the password, default is'{}[]|
Enabled
- If set toTrue
macOSLAPS script will change password when it expires, default isTrue
RemoteManagementEnabled
- IfTrue
script will prioritize settings pulled from MunkiReport's database over local preferences, defaults, and profiles, default isTrue
Module will delete cached password after it verifies password is stored on MunkiReport server. This script will not (yet) change the local admin user's FileVault 2 password, if that account is authorized to unlock the drive.
Client log can be found at /Library/Logs/macOSLAPS.log
Module supports remote management under the Admin>macOSLAPS Management page. Clients will first populate preferences with built in defaults or from profile on first run, unless client is already in MunkiReport's laps
table. Available in the macOSLAPS Admin page are options to configure supported remote management settings, force the password to be cycled, and viewing of the audit trail. All actions are audited server side. The audit trail is viewable within the macOSLAPS Management page for either one serial number or all audit logs.