io: use opendirectory for UID/GID lookups on macOS
macOS has no concept of a chroot-specific UID/GID database, as the database is actually LDAP. ref #10794cute-signatures
parent
9d07d07fe4
commit
03a5e6d9b9
10
src/io.c
10
src/io.c
|
@ -1187,8 +1187,11 @@ static void idcache_load_users(int root_fd, struct apk_id_hash *idh)
|
||||||
do {
|
do {
|
||||||
#ifdef HAVE_FGETPWENT_R
|
#ifdef HAVE_FGETPWENT_R
|
||||||
fgetpwent_r(in, &pwent, buf, sizeof(buf), &pwd);
|
fgetpwent_r(in, &pwent, buf, sizeof(buf), &pwd);
|
||||||
#else
|
#elif !defined(__APPLE__)
|
||||||
pwd = fgetpwent(in);
|
pwd = fgetpwent(in);
|
||||||
|
#else
|
||||||
|
# warning macOS does not support nested /etc/passwd databases, using system one.
|
||||||
|
pwd = getpwent();
|
||||||
#endif
|
#endif
|
||||||
if (!pwd) break;
|
if (!pwd) break;
|
||||||
idcache_add(idh, APK_BLOB_STR(pwd->pw_name), pwd->pw_uid);
|
idcache_add(idh, APK_BLOB_STR(pwd->pw_name), pwd->pw_uid);
|
||||||
|
@ -1217,8 +1220,11 @@ static void idcache_load_groups(int root_fd, struct apk_id_hash *idh)
|
||||||
do {
|
do {
|
||||||
#ifdef HAVE_FGETGRENT_R
|
#ifdef HAVE_FGETGRENT_R
|
||||||
fgetgrent_r(in, &grent, buf, sizeof(buf), &grp);
|
fgetgrent_r(in, &grent, buf, sizeof(buf), &grp);
|
||||||
#else
|
#elif !defined(__APPLE__)
|
||||||
grp = fgetgrent(in);
|
grp = fgetgrent(in);
|
||||||
|
#else
|
||||||
|
# warning macOS does not support nested /etc/group databases, using system one.
|
||||||
|
grp = getgrent();
|
||||||
#endif
|
#endif
|
||||||
if (!grp) break;
|
if (!grp) break;
|
||||||
idcache_add(idh, APK_BLOB_STR(grp->gr_name), grp->gr_gid);
|
idcache_add(idh, APK_BLOB_STR(grp->gr_name), grp->gr_gid);
|
||||||
|
|
Loading…
Reference in New Issue