- # TODO: Since we should have a known-good username and password at this stage it's unwise to re-use the existing credentials, can we simply drop the test?
- if ! security find-internet-password -s ${PrintServer} >/dev/null 2>&1; then
- security -v add-internet-password -a "${Workgroup}\\${Username}" -s ${PrintServer} \
- -w "${Password}" -D "Network Password" -r "smb " -l "${QueueName}" \
- -T /System/Library/CoreServices/NetAuthAgent.app -T 'group://NetAuth' \
- -T /System/Library/CoreServices/NetAuthAgent.app/Contents/MacOS/NetAuthSysAgent >/dev/null 2>&1
+ security -v add-internet-password -U -a "${Workgroup}\\${Username}" -s "${PrintServer}" \
+ -w "${Password}" -D "Network Password" -r "smb " -l "${QueueName}" \
+ -T /System/Library/CoreServices/NetAuthAgent.app -T 'group://NetAuth' \
+ -T /System/Library/CoreServices/NetAuthAgent.app/Contents/MacOS/NetAuthSysAgent >/dev/null 2>&1
+
+ # Make sure the password has the correct ACL ref https://mostlikelee.com/blog-1/2017/9/16/scripting-the-macos-keychain-partition-ids
+ OS_Min_Vers=$(sw_vers | grep ProductVersion | awk '{print $2}' | cut -d "." -f2)
+ if [ "${OS_Min_Vers}" -ge 12 ]; then
+ echo -e "\nNOTE: You need to provide your local Mac password again here in order to give the printing system access to your credentials.\n"
+ security set-internet-password-partition-list -S "apple-tool:,apple:" -s "${PrintServer}" > /dev/null