Список всех пользователей и групп
Я пытаюсь получить список всех пользователей и всех групп на Mac OS X 10.5+. Как я могу это сделать?
Например, Список всех пользователей на моей машине должен вернуться:
_amavisd, _appowner, _appserver, _ard, _atsserver, _calendar, _carddav, _clamav, _coreaudiod, _cvmsroot, _cvs, _cyrus, _devdocs, _dovecot, _eppc, _installer, _jabber, _lda, _locationd, _lp, _mailman, _mcxalr, _mdnsresponder, _mysql, _pcastagent, _pcastserver, _postfix, _qtss, _sandbox, _screensaver, _securityagent, _serialnumberd, _softwareupdate, _spotlight, _sshd, _svn, _teamsserver, _timezone, _tokend, _trustevaluationagent, _unknown, _update_sharing, _usbmuxd, _uucp, _windowserver, _www, _xgridagent, _xgridcontroller, daemon, dave, nobody, root
(это было тщательно составлено вручную).
Как я могу получить этот список (и соответствующий список всех групп) программно? Я открыт для альтернативных (не основанных на c) решений, таких как Applescript, commandline и т. д.
Обновление долгое время позже
Ответ TALlama побудил меня исследовать API для открытия каталога, и я обнаружил, что этот список можно легко получить программно:
#import <OpenDirectory/OpenDirectory.h>
ODSession *s = [ODSession defaultSession];
ODNode *root = [ODNode nodeWithSession:s name:@"/Local/Default" error:nil];
ODQuery *q = [ODQuery queryWithNode:root forRecordTypes:kODRecordTypeUsers attribute:nil matchType:0 queryValues:nil returnAttributes:nil maximumResults:0 error:nil];
NSArray *results = [q resultsAllowingPartial:NO error:nil];
for (ODRecord *r in results) {
NSLog(@"%@", [r recordName]);
}
, который будет регистрировать имена пользователей каждого пользователя в системе. Подстановка в kODRecordTypeGroups
даст вам список всех групп.
Метод -[ODQuery resultsAllowingPartial:error:]
являетсяблокирующим вызовом , поэтому вы либо хотите выполнить этот код в фоновом потоке, либо использовать <ODQueryDelegate>
для агрегирования результатов.
5 ответов:
Инструмент, который вам нужен, почти наверняка dscl. Самый короткий способ сделать это уже был указан:
$ dscl . list /users $ dscl . list /groups
Если вы хотите вывести информацию о каждом пользователе, используйте
readall
:$ dscl . readall /users $ dscl . readall /groups
И если вам нужно программно проанализировать указанную информацию, используйте-plist, чтобы облегчить себе жизнь:
$ dscl -plist . readall /users $ dscl -plist . readall /groups
Подход с открытым каталогом (от: http://rickcogley.blogspot.com/2008/11/listing-open-directory-users-on-os-x.html):
dscacheutil -q user dscacheutil -q group
Возьмите каждую строку из соответствующего вывода, начинающегося с " name:", удалите "name:", и у вас будет свой список. Если у вас нет dscacheutil, вы можете использовать ручные команды:
root# dscl localhost list /Local/Default/Users root# dscl localhost list /LDAPv3/127.0.0.1/Users
Подход старой школы для перед открытым каталогом....(вздыхать): Для списка пользователей:
- возьмите файл /etc / passwd из система.
- разделить его на строки
- разбить каждую строку на": "
- Возьмите первый символ для каждой строки
Для списка групп:
- возьмите файл / etc / group из системы.
- разделить его на строки
- разбить каждую строку на": "
- Возьмите первый символ для каждой строки
Проверьте, например, dsexport .
Вот несколько примеров:
dsexport /tmp/export.out /Local/Default dsRecTypeStandard:Groups dsexport /tmp/export.out /Local/Default dsRecTypeStandard:Users
Выходы немного мусор, но что-то вроде sed может очистить их для вас.