これを使用dsconfigad -show
すると、出力を解析して、コンピューターがActiveDirectoryドメインにバインドされているかどうかを判断できます。
問題は、ユーザーがローカルユーザーアカウントとしてログオンしている場合でも、ActiveDirectoryドメインが返されることです。
注:理想的には、10.5でも機能するソリューションが必要です。
質問に答えない同様の投稿:
これを使用dsconfigad -show
すると、出力を解析して、コンピューターがActiveDirectoryドメインにバインドされているかどうかを判断できます。
問題は、ユーザーがローカルユーザーアカウントとしてログオンしている場合でも、ActiveDirectoryドメインが返されることです。
注:理想的には、10.5でも機能するソリューションが必要です。
質問に答えない同様の投稿:
ユーザーがローカルアカウントまたは任意のネットワークディレクトリアカウント(ActiveDirまたはOpenDir)を持っているかどうかを検出する方法を探していました。したがって、OpenDirectoryフレームワークを使用して行ったことは次のようになります。
だからこのようなもの:
static BOOL isLocalUser = NO;
static BOOL shouldKeepRunning = YES; // global
-(BOOL)isLocalUser
{
isLocalUser = NO; // set default to NO here
NSError* err;
ODSession *mySession = [ODSession defaultSession];
ODNode *myNode = [ODNode nodeWithSession:mySession type:kODNodeTypeLocalNodes error:&err];
ODQuery *myQuery = [ODQuery queryWithNode: myNode
forRecordTypes: kODRecordTypeUsers
attribute: kODAttributeTypeNFSHomeDirectory
matchType: kODMatchEqualTo
queryValues: NSHomeDirectory()
returnAttributes: kODAttributeTypeStandardOnly
maximumResults: 0
error: &err];
[myQuery retain];
[myQuery setDelegate: self];
[myQuery scheduleInRunLoop: [NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode];
NSRunLoop *theRunLoop = [NSRunLoop currentRunLoop];
while (shouldKeepRunning && [theRunLoop runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]]);
return isLocalUser;
}
- (void)query:(ODQuery *)inSearch foundResults:(NSArray *)inResults error:(NSError *)inError
{
if (!inResults && !inError)
{
[inSearch removeFromRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode];
[inSearch release];
shouldKeepRunning = NO; // end of search
}
...
// check what you found here
// if found any nodes, user is local so
isLocalUser = YES;
}
もう1つのアイデアは、IDサービスを使用することです。
お役に立てれば。