summaryrefslogtreecommitdiffstats
path: root/meta-skeleton/recipes-skeleton/useradd/useradd-example.bb
diff options
context:
space:
mode:
Diffstat (limited to 'meta-skeleton/recipes-skeleton/useradd/useradd-example.bb')
-rw-r--r--meta-skeleton/recipes-skeleton/useradd/useradd-example.bb76
1 files changed, 76 insertions, 0 deletions
diff --git a/meta-skeleton/recipes-skeleton/useradd/useradd-example.bb b/meta-skeleton/recipes-skeleton/useradd/useradd-example.bb
new file mode 100644
index 0000000000..02d56f6abc
--- /dev/null
+++ b/meta-skeleton/recipes-skeleton/useradd/useradd-example.bb
@@ -0,0 +1,76 @@
1SUMMARY = "Example recipe for using inherit useradd"
2DESCRIPTION = "This recipe serves as an example for using features from useradd.bbclass"
3SECTION = "examples"
4PR = "r0"
5LICENSE = "MIT"
6LIC_FILES_CHKSUM = "file://${COREBASE}/LICENSE;md5=3f40d7994397109285ec7b81fdeb3b58 \
7 file://${COREBASE}/meta/COPYING.MIT;md5=3da9cfbcb788c80a0384361b4de20420"
8
9SRC_URI = "file://file1 \
10 file://file2 \
11 file://file3 \
12 file://file4"
13
14S = "${WORKDIR}"
15
16PACKAGES =+ "${PN}-user3"
17
18inherit useradd
19
20# Specify which package(s) should include the user/group code.
21# Make sure that any packages which install files owned by custom
22# users/groups are included here. The code which adds users and
23# groups is idempotent.
24USERADD_PACKAGES = "${PN} ${PN}-user3"
25
26# You *must* set USERADD_PARAM and/or GROUPADD_PARAM when
27# you inherit useradd.
28
29# USERADD_PARAM specifies command line options to pass to the
30# useradd command. Multiple users can be created by separating
31# the commands with a semicolon. Here we'll create two users,
32# user1 and user2:
33USERADD_PARAM_${PN} = "-u 1200 -d /home/user1 -r -s /bin/bash user1; -u 1201 -d /home/user2 -r -s /bin/bash user2"
34
35# user3 will be managed in the useradd-example-user3 pacakge:
36USERADD_PARAM_${PN}-user3 = "-u 1202 -d /home/user3 -r -s /bin/bash user3"
37
38# GROUPADD_PARAM works the same way, which you set to the options
39# you'd normally pass to the groupadd command. This will create
40# groups group1 and group2:
41GROUPADD_PARAM_${PN} = "-g 880 group1; -g 890 group2"
42
43# Likewise, we'll manage group3 in the useradd-example-user3 package:
44GROUPADD_PARAM_${PN}-user3 = "-g 900 group3"
45
46do_install () {
47 install -d -m 755 ${D}/usr/share/user1
48 install -d -m 755 ${D}/usr/share/user2
49 install -d -m 755 ${D}/usr/share/user3
50
51 install -p -m 644 file1 ${D}/usr/share/user1/
52 install -p -m 644 file2 ${D}/usr/share/user1/
53
54 install -p -m 644 file2 ${D}/usr/share/user2/
55 install -p -m 644 file3 ${D}/usr/share/user2/
56
57 install -p -m 644 file3 ${D}/usr/share/user3/
58 install -p -m 644 file4 ${D}/usr/share/user3/
59
60 # The new users and groups are created before the do_install
61 # step, so you are now free to make use of them:
62 chown -R user1 ${D}/usr/share/user1
63 chown -R user2 ${D}/usr/share/user2
64 chown -R user3 ${D}/usr/share/user3
65
66 chgrp -R group1 ${D}/usr/share/user1
67 chgrp -R group2 ${D}/usr/share/user2
68 chgrp -R group3 ${D}/usr/share/user3
69}
70
71FILES_${PN} = "/usr/share/user1/* /usr/share/user2/*"
72FILES_${PN}-user3 = "/usr/share/user3/*"
73
74# Prevents do_package failures with:
75# debugsources.list: No such file or directory:
76INHIBIT_PACKAGE_DEBUG_SPLIT = "1"