deluser.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * deluser/delgroup implementation for busybox
  4. *
  5. * Copyright (C) 1999 by Lineo, inc. and John Beppu
  6. * Copyright (C) 1999,2000,2001 by John Beppu <beppu@codepoet.org>
  7. * Copyright (C) 2007 by Tito Ragusa <farmatito@tiscali.it>
  8. *
  9. * Licensed under GPL version 2, see file LICENSE in this tarball for details.
  10. *
  11. */
  12. #include "libbb.h"
  13. static int del_line_matching(char **args, const char *filename)
  14. {
  15. if (ENABLE_FEATURE_DEL_USER_FROM_GROUP && args[2]) {
  16. return update_passwd(filename, args[2], NULL, args[1]);
  17. }
  18. return update_passwd(filename, args[1], NULL, NULL);
  19. }
  20. int deluser_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
  21. int deluser_main(int argc, char **argv)
  22. {
  23. if (argc != 2
  24. && (!ENABLE_FEATURE_DEL_USER_FROM_GROUP
  25. || (applet_name[3] != 'g' || argc != 3))
  26. ) {
  27. bb_show_usage();
  28. }
  29. if (geteuid())
  30. bb_error_msg_and_die(bb_msg_perm_denied_are_you_root);
  31. if ((ENABLE_FEATURE_DEL_USER_FROM_GROUP && argc != 3)
  32. || ENABLE_DELUSER
  33. || (ENABLE_DELGROUP && ENABLE_DESKTOP)
  34. ) {
  35. if (ENABLE_DELUSER
  36. && (!ENABLE_DELGROUP || applet_name[3] == 'u')
  37. ) {
  38. if (del_line_matching(argv, bb_path_passwd_file) < 0)
  39. return EXIT_FAILURE;
  40. if (ENABLE_FEATURE_SHADOWPASSWDS) {
  41. del_line_matching(argv, bb_path_shadow_file);
  42. }
  43. } else if (ENABLE_DESKTOP && ENABLE_DELGROUP && getpwnam(argv[1]))
  44. bb_error_msg_and_die("can't remove primary group of user %s", argv[1]);
  45. }
  46. if (del_line_matching(argv, bb_path_group_file) < 0)
  47. return EXIT_FAILURE;
  48. if (ENABLE_FEATURE_SHADOWPASSWDS) {
  49. del_line_matching(argv, bb_path_gshadow_file);
  50. }
  51. return EXIT_SUCCESS;
  52. }