check.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #define _XOPEN_SOURCE 700
  2. #include <errno.h>
  3. #include <grp.h>
  4. #include <locale.h>
  5. #include <stdarg.h>
  6. #include <stdio.h>
  7. #include <stdlib.h>
  8. #include <string.h>
  9. #include <syslog.h>
  10. #include <pwd.h>
  11. #include <unistd.h>
  12. #include "check.h"
  13. static char *progname = NULL;
  14. void fatal(int include_errno, char *fmt, ...)
  15. {
  16. fprintf(stderr, "%s: ", progname);
  17. va_list ap;
  18. va_start(ap, fmt);
  19. vfprintf(stderr, fmt, ap);
  20. va_end(ap);
  21. if (include_errno) {
  22. fprintf(stderr, ": %s", strerror(errno));
  23. }
  24. fputc('\n', stderr);
  25. exit(EXIT_FAILURE);
  26. }
  27. static char *get_username(void)
  28. {
  29. struct passwd *pwd = getpwuid(getuid());
  30. if (pwd == NULL) {
  31. fatal(1, "unable to determine user name");
  32. }
  33. return pwd->pw_name;
  34. }
  35. static char *get_groupname(void)
  36. {
  37. struct group *grp = getgrgid(getgid());
  38. if (grp == NULL) {
  39. fatal(1, "unable to determine group name");
  40. }
  41. return grp->gr_name;
  42. }
  43. static char *get_command(int argc, char *argv[])
  44. {
  45. if (argc < 2) {
  46. fatal(1, "missing operands");
  47. }
  48. return argv[1];
  49. }
  50. int main(int argc, char *argv[])
  51. {
  52. setlocale(LC_ALL, "");
  53. progname = argv[0];
  54. char *cmd = get_command(argc, argv);
  55. char *user = get_username();
  56. char *group = get_groupname();
  57. openlog(PRIVEXEC_LOG_ID, LOG_PID, LOG_AUTH);
  58. syslog(LOG_INFO, "checking %s:%s for permission to run %s",
  59. user, group, cmd);
  60. switch (get_permission(user, group, cmd)) {
  61. case AUTHENTICATE:
  62. syslog(LOG_INFO, "%s:%s requires authentication to run %s",
  63. user, group, cmd);
  64. if (authenticate(user) != 0) {
  65. syslog(LOG_NOTICE, "%s:%s failed authentication for %s",
  66. user, group, cmd);
  67. fatal(0, "bad authentication");
  68. }
  69. /* FALLTHRU */
  70. case AUTHORIZED:
  71. syslog(LOG_INFO, "%s:%s authorized to run %s",
  72. user, group, cmd);
  73. return 0;
  74. case DENIED:
  75. syslog(LOG_NOTICE,
  76. "%s:%s explicitly denied permission to run %s",
  77. user, group, cmd);
  78. fatal(0, "explicitly denied");
  79. return 1;
  80. case UNKNOWN:
  81. default:
  82. syslog(LOG_NOTICE,
  83. "%s:%s denied permission to run %s by default",
  84. user, group, cmd);
  85. fatal(0, "denied by default");
  86. }
  87. return 1;
  88. }