Is there a way to identify whether the logged in account is local account or active directory account on OS X? If yes, how can we retrieve the domain name?
Read logged in user's domain on OS X
1.5k Views Asked by Seema Kadavan At
2
There are 2 best solutions below
Related Questions in OBJECTIVE-C
- Add Okta user to Okta group Python sdk
- Okta api python sdk throwing json error
- How to diagnose a E0000022?
- Okta how to pass groups in assertion SAML
- What is the maximum number of applications that can be activated on the Okta sandbox?
- Authentication using SAML and OKTA through SSO service of Bluemix is going into a loop
- Getting Users SessionID from Okta Sign-in Wudget
- How to deep-link directly to an app in Okta Mobile on iOS
- Authenticating JIRA API with okta SSO
- Why Keystore is needed when using SSO (SAMLv2)
Related Questions in XCODE
- Add Okta user to Okta group Python sdk
- Okta api python sdk throwing json error
- How to diagnose a E0000022?
- Okta how to pass groups in assertion SAML
- What is the maximum number of applications that can be activated on the Okta sandbox?
- Authentication using SAML and OKTA through SSO service of Bluemix is going into a loop
- Getting Users SessionID from Okta Sign-in Wudget
- How to deep-link directly to an app in Okta Mobile on iOS
- Authenticating JIRA API with okta SSO
- Why Keystore is needed when using SSO (SAMLv2)
Related Questions in MACOS
- Add Okta user to Okta group Python sdk
- Okta api python sdk throwing json error
- How to diagnose a E0000022?
- Okta how to pass groups in assertion SAML
- What is the maximum number of applications that can be activated on the Okta sandbox?
- Authentication using SAML and OKTA through SSO service of Bluemix is going into a loop
- Getting Users SessionID from Okta Sign-in Wudget
- How to deep-link directly to an app in Okta Mobile on iOS
- Authenticating JIRA API with okta SSO
- Why Keystore is needed when using SSO (SAMLv2)
Related Questions in TERMINAL
- Add Okta user to Okta group Python sdk
- Okta api python sdk throwing json error
- How to diagnose a E0000022?
- Okta how to pass groups in assertion SAML
- What is the maximum number of applications that can be activated on the Okta sandbox?
- Authentication using SAML and OKTA through SSO service of Bluemix is going into a loop
- Getting Users SessionID from Okta Sign-in Wudget
- How to deep-link directly to an app in Okta Mobile on iOS
- Authenticating JIRA API with okta SSO
- Why Keystore is needed when using SSO (SAMLv2)
Related Questions in DSCL
- Add Okta user to Okta group Python sdk
- Okta api python sdk throwing json error
- How to diagnose a E0000022?
- Okta how to pass groups in assertion SAML
- What is the maximum number of applications that can be activated on the Okta sandbox?
- Authentication using SAML and OKTA through SSO service of Bluemix is going into a loop
- Getting Users SessionID from Okta Sign-in Wudget
- How to deep-link directly to an app in Okta Mobile on iOS
- Authenticating JIRA API with okta SSO
- Why Keystore is needed when using SSO (SAMLv2)
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
You can create a
CBUserIdentity
for the user from their username:Then, you can obtain that user identity's authority:
Then, you can see if that is the local authority (the alternative is the managed authority):
The authority has a
localizedName
property, but that's not likely to include the domain name, I don't think. I don't know how to get that.Update:
This is an approach using the Open Directory API:
At this point, you can query the record for some of its attributes. One that may be of interest might be
kODAttributeTypeMetaNodeLocation
:For a local account, the meta node location should be "/Local/Default". I tested with an LDAP account and that gave ""/LDAPv3/my.ldap.server.example.com". I don't have an Active Directory account to test with.
Alternatively, you can try
kODAttributeTypeMetaRecordName
. For a local account, that returnednil
. For an LDAP account, it gave the fully distinguished name: "uid=ken,ou=People,dc=example,dc=com". Again, I don't know what it would do for an Active Directory account.You can log the record to see other attributes that are available. That will show the attribute keys as string values. You can look here to try to find a symbolic constant for the one(s) of interest, or check /System/Library/Frameworks/OpenDirectory.framework/Frameworks/CFOpenDirectory.framework/Headers/CFOpenDirectoryConstants.h for some which aren't documented.
Once you find what you really care about, you can maybe simplify the query by requesting just those instead of
kODAttributeTypeStandardOnly
. Also, you should consider running the query asynchronously rather than synchronously as I did in my example code.