makeusers-syntax.txt 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. // -*- mode:doc -*- ;
  2. [[makeuser-syntax]]
  3. Makeuser syntax documentation
  4. -----------------------------
  5. The syntax to create users is inspired by the makedev syntax, above, but
  6. is specific to Buildroot.
  7. The syntax for adding a user is a space-separated list of fields, one
  8. user per line; the fields are:
  9. |=================================================================
  10. |username |uid |group |gid |password |home |shell |groups |comment
  11. |=================================================================
  12. Where:
  13. - +username+ is the desired user name (aka login name) for the user.
  14. It can not be +root+, and must be unique.
  15. - +uid+ is the desired UID for the user. It must be unique, and not
  16. +0+. If set to +-1+, then a unique UID will be computed by Buildroot
  17. in the range [1000...1999]
  18. - +group+ is the desired name for the user's main group. It can not
  19. be +root+. If the group does not exist, it will be created.
  20. - +gid+ is the desired GID for the user's main group. It must be unique,
  21. and not +0+. If set to +-1+, and the group does not already exist, then
  22. a unique GID will be computed by Buildroot in the range [1000..1999]
  23. - +password+ is the crypt(3)-encoded password. If prefixed with +!+,
  24. then login is disabled. If prefixed with +=+, then it is interpreted
  25. as clear-text, and will be crypt-encoded (using MD5). If prefixed with
  26. +!=+, then the password will be crypt-encoded (using MD5) and login
  27. will be disabled. If set to +*+, then login is not allowed.
  28. - +home+ is the desired home directory for the user. If set to '-', no
  29. home directory will be created, and the user's home will be +/+.
  30. Explicitly setting +home+ to +/+ is not allowed.
  31. - +shell+ is the desired shell for the user. If set to +-+, then
  32. +/bin/false+ is set as the user's shell.
  33. - +groups+ is the comma-separated list of additional groups the user
  34. should be part of. If set to +-+, then the user will be a member of
  35. no additional group. Missing groups will be created with an arbitrary
  36. +gid+.
  37. - +comment+ (aka https://en.wikipedia.org/wiki/Gecos_field[GECOS]
  38. field) is an almost-free-form text.
  39. There are a few restrictions on the content of each field:
  40. * except for +comment+, all fields are mandatory.
  41. * except for +comment+, fields may not contain spaces.
  42. * no field may contain a colon (+:+).
  43. If +home+ is not +-+, then the home directory, and all files below,
  44. will belong to the user and its main group.
  45. Examples:
  46. ----
  47. foo -1 bar -1 !=blabla /home/foo /bin/sh alpha,bravo Foo user
  48. ----
  49. This will create this user:
  50. - +username+ (aka login name) is: +foo+
  51. - +uid+ is computed by Buildroot
  52. - main +group+ is: +bar+
  53. - main group +gid+ is computed by Buildroot
  54. - clear-text +password+ is: +blabla+, will be crypt(3)-encoded, and login is disabled.
  55. - +home+ is: +/home/foo+
  56. - +shell+ is: +/bin/sh+
  57. - +foo+ is also a member of +groups+: +alpha+ and +bravo+
  58. - +comment+ is: +Foo user+
  59. ----
  60. test 8000 wheel -1 = - /bin/sh - Test user
  61. ----
  62. This will create this user:
  63. - +username+ (aka login name) is: +test+
  64. - +uid+ is : +8000+
  65. - main +group+ is: +wheel+
  66. - main group +gid+ is computed by Buildroot, and will use the value defined in the rootfs skeleton
  67. - +password+ is empty (aka no password).
  68. - +home+ is +/+ but will not belong to +test+
  69. - +shell+ is: +/bin/sh+
  70. - +test+ is not a member of any additional +groups+
  71. - +comment+ is: +Test user+