makeusers-syntax.txt 3.3 KB

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