From c1d82282d96ec39075e93b774d3db70db7b84bd0 Mon Sep 17 00:00:00 2001 From: Bananymous Date: Fri, 18 Aug 2023 15:36:51 +0300 Subject: [PATCH] Id: Print username corresponding to uid/euid Also print euid and egid if they differ from uid or gid. --- userspace/id/CMakeLists.txt | 2 +- userspace/id/main.cpp | 31 ++++++++++++++++++++++++++++++- 2 files changed, 31 insertions(+), 2 deletions(-) diff --git a/userspace/id/CMakeLists.txt b/userspace/id/CMakeLists.txt index 1cf2c33d2b..3da67b0ae9 100644 --- a/userspace/id/CMakeLists.txt +++ b/userspace/id/CMakeLists.txt @@ -8,7 +8,7 @@ set(SOURCES add_executable(id ${SOURCES}) target_compile_options(id PUBLIC -O2 -g) -target_link_libraries(id PUBLIC libc) +target_link_libraries(id PUBLIC libc ban) add_custom_target(id-install COMMAND cp ${CMAKE_CURRENT_BINARY_DIR}/id ${BANAN_BIN}/ diff --git a/userspace/id/main.cpp b/userspace/id/main.cpp index 567be5745b..1cf102b755 100644 --- a/userspace/id/main.cpp +++ b/userspace/id/main.cpp @@ -1,7 +1,36 @@ #include #include +#include int main() { - printf("uid %u, gid %u, euid %u, egid %u\n", getuid(), getgid(), geteuid(), getegid()); + uid_t uid = getuid(); + uid_t euid = geteuid(); + + gid_t gid = getgid(); + gid_t egid = getegid(); + + passwd* pw_uid = getpwuid(uid); + if (pw_uid == nullptr) + { + fprintf(stderr, "Unknown user #%d\n", uid); + return 1; + } + + passwd* pw_euid = getpwuid(euid); + if (pw_euid == nullptr) + { + fprintf(stderr, "Unknown user #%d\n", euid); + return 1; + } + + printf("uid=%u(%s)", uid, pw_uid->pw_name); + if (uid != euid) + printf(",euid=%u(%s)",euid, pw_euid->pw_name); + + printf(" gid=%u", gid); + if (gid != egid) + printf(",egid=%u", egid); + + printf("\n"); }