libvbuilder.sh.in 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  1. #!/bin/bash
  2. setup-vbuilder(){
  3. ## check $SUDO_USER and $USERHELPER_UID
  4. RPM_SIGN_USER=$SUDO_USER
  5. if [ -z "${RPM_SIGN_USER}" ]; then
  6. RPM_SIGN_USER=$(getent passwd $USERHELPER_UID | cut -d":" -f1)
  7. if [ -z "${RPM_SIGN_USER}" ]; then
  8. echo $"W: \$SUDO_USER and \$USERHELPER_UID are empty"
  9. return 1
  10. fi
  11. fi
  12. ## get $RPM_SIGN_USER's home directory
  13. HOME=$(getent passwd $RPM_SIGN_USER | cut -d":" -f6)
  14. ## load default settings
  15. VBUILDER_CONF=/etc/vbootstrap/vbuilder.conf
  16. if [ -r $VBUILDER_CONF ]; then
  17. . $VBUILDER_CONF
  18. [ $? -eq 1 ] && return 1
  19. fi
  20. [ -z "${DEFAULT_VERSION}" ] && \
  21. DEFAULT_VERSION=@@VBUILDER_DEFAULT_VERSION@@
  22. [ -z "${CATEGORIES}" ] && \
  23. CATEGORIES=@@VBUILDER_CATEGORIES@@
  24. [ -z "${VBOOTSTRAP_DIR}" ] && \
  25. VBOOTSTRAP_DIR=@@VBUILDER_VBOOTSTRAP_DIR@@
  26. [ -z "${UNIONFS_DIR}" ] && \
  27. UNIONFS_DIR=@@VBUILDER_UNIONFS_DIR@@
  28. [ -z "${CACHE_DIR}" ] && \
  29. CACHE_DIR=@@VBUILDER_CACHE_DIR@@
  30. [ -z "${BUILT_RPMS_DIR}" ] && \
  31. BUILT_RPMS_DIR=@@VBUILDER_BUILT_RPMS_DIR@@
  32. ## set default version for vbootstrap
  33. VERSION=$DEFAULT_VERSION
  34. ## set current stable relase version
  35. STABLE_VERSION=@@VBUILDER_STABLE_VERSION@@
  36. ## set boolian variables
  37. with_setup_vbootstrap=0
  38. with_dist_upgrade=0
  39. with_unionfs=0
  40. with_sign=0
  41. with_no_install=0
  42. with_login=0
  43. with_debug=0
  44. with_actions=0
  45. with_ix86_on_x86_64=0
  46. with_category_main=0
  47. with_category_plus=0
  48. with_category_nonfree=0
  49. with_category_test=0
  50. with_category_proposed_updates=0
  51. with_category_security=0
  52. return 0
  53. }
  54. setup-vbootstrap(){
  55. if [ ${with_setup_vbootstrap} -eq 0 ]; then
  56. with_setup_vbootstrap=1
  57. ## check debug mode
  58. [ ${with_debug} -eq 1 ] && \
  59. cat $VBUILDER_CONF && \
  60. set && set -x
  61. ## check some directories
  62. ## Note: create $BUILT_RPMS_DIR in RPM_Build()
  63. [ -d $VBOOTSTRAP_DIR ] || mkdir -p $VBOOTSTRAP_DIR
  64. [ -d $CACHE_DIR ] || mkdir -p $CACHE_DIR
  65. UARCH=$(uname -i)
  66. case "${UARCH}" in
  67. arm*)
  68. UARCH="arm"
  69. ;;
  70. esac
  71. case "${VARCH}" in
  72. arm*)
  73. VARCH="arm"
  74. ;;
  75. esac
  76. ## check a chroot archtecture
  77. if [ -z ${VARCH} ]; then
  78. VARCH=${UARCH}
  79. else
  80. case "${VARCH}" in
  81. i386|i686|x86_64)
  82. [ "$(uname -i)" = "ppc" -o "${UARCH}" = "arm" ] && \
  83. echo $"E: arch ${VARCH} is NOT supported on $(uname -i)" && return 1
  84. ;;
  85. ppc)
  86. [ "$(uname -i)" = "i386" -o "$(uname -i)" = "i686" -o "$(uname -i)" = "x86_64" -o "${UARCH}" = "arm" ] && \
  87. echo $"E: arch ${VARCH} is NOT supported on $(uname -i)" && return 1
  88. ;;
  89. arm)
  90. [ "${UARCH}" = "i386" -o "${UARCH}" = "i686" -o "${UARCH}" = "x86_64" -o "${UARCH}" = "ppc" ] && \
  91. echo $"E: arch ${VARCH} is NOT supported on ${UARCH}" && return 1
  92. ;;
  93. esac
  94. fi
  95. ##!! 4.2 is NO support on VARCH=x86_64
  96. if [ "${VERSION}" = "4.2" -a "${VARCH}" = "x86_64" ]; then
  97. echo $"E: ${VERSION} is NOT supported"
  98. return 1
  99. fi
  100. ##!! 4.2 is NO support on VARCH=arm
  101. if [ "${VERSION}" = "4.2" -a "${VARCH}" = "arm" ]; then
  102. echo $"E: ${VERSION} is NOT supported"
  103. return 1
  104. fi
  105. ## support i386 chroot on x86_64 below:
  106. [ "${VARCH}" != "${UARCH}" ] && \
  107. VERSION=${VERSION}_${VARCH} && \
  108. with_ix86_on_x86_64=1
  109. ## hack arm repository to local
  110. [ "${VARCH}" = "arm" ] && \
  111. VERSION=${VERSION}_${VARCH}
  112. ## check support ${VERSION}
  113. if [ -z "$(/usr/sbin/vbootstrap | sed -e s/^Usage:.*// -e s/^E:.*// | grep -m 1 ${VERSION})" ]; then
  114. echo $"E: ${VERSION} is NOT supported"
  115. return 1
  116. fi
  117. ## check ${VERSION} equals VineSeed*, when with_dist_upgrade=1
  118. if [ $with_dist_upgrade -eq 1 ]; then
  119. if [ "$(echo ${VERSION} | sed -e "s/\(VineSeed\).*/\1/")" != "VineSeed" ]; then
  120. echo $"E: version ${VERSION} does not support --dist-upgrade option"
  121. return 1
  122. fi
  123. fi
  124. ## set ${MAJOR_VERSION}
  125. MAJOR_VERSION=$(echo ${VERSION} | sed -e "s/_i[0-9]86//")
  126. ## check apt categories
  127. ## "main" category is unconditionally permited
  128. with_category_main=1
  129. for cat in $(echo ${CATEGORIES} | sed -e "s/,/ /"g); do
  130. case $cat in
  131. main)
  132. with_category_main=1
  133. ;;
  134. plus)
  135. with_category_plus=1
  136. ;;
  137. nonfree)
  138. with_category_nonfree=1
  139. ;;
  140. test)
  141. ## "test" category only exists in VineSeed
  142. [ "${MAJOR_VERSION}" = "VineSeed" ] || \
  143. echo $"E: No such category exists: $cat" && return 1
  144. with_category_test=1
  145. ;;
  146. proposed-updates)
  147. ##!! "proposed-updates" category does not exist in 4.2
  148. [ "${MAJOR_VERSION}" = "4.2" ] && \
  149. echo $"E: No such category exists: $cat" && return 1
  150. with_category_proposed_updates=1
  151. ;;
  152. security)
  153. ## "security" category does not exist in VineSeed
  154. [ "${MAJOR_VERSION}" = "VineSeed" ] && \
  155. echo $"E: No such category exists: $cat" && return 1
  156. with_category_security=1
  157. ;;
  158. *)
  159. echo $"E: No such category exists: $cat" && return 1
  160. ;;
  161. esac
  162. done
  163. ## check build target option ${TARGET}
  164. if [ ! -z "${TARGET}" ]; then
  165. RPM_TARGET_LIST="$(cat /usr/lib/rpm/rpmrc | grep arch_canon: | sed -e "s/arch_canon:[[:blank:]]*\(.*\):.*/\1/")"
  166. if [ -z "$(echo $RPM_TARGET_LIST | grep $TARGET)" ]; then
  167. echo $"E: rpm build target ${TARGET} is NOT supported"
  168. return 1
  169. fi
  170. fi
  171. ## set ${RPM_PKG_ARCH_LIST}
  172. RPM_PKG_ARCH_LIST="RPMS/i386 RPMS/i686 RPMS/x86_64 RPMS/ppc RPMS/noarch RPMS/armv3l RPMS/armv4l RPMS/armv4tl RPMS/armv5tejl RPMS/armv5tel RPMS/armv6l RPMS/armv7l SRPMS"
  173. [ -z "${TARGET}" ] || \
  174. RPM_PKG_ARCH_LIST="RPMS/${TARGET} ${RPM_PKG_ARCH_LIST}"
  175. fi
  176. ## set global variables
  177. BUILD_ROOT=${VBOOTSTRAP_DIR}/${VERSION}
  178. BUILD_USER=vbuilder
  179. BUILD_DIR=/home/${BUILD_USER}/rpm
  180. UNIONFS_ROOT=${UNIONFS_DIR}/${VERSION}
  181. ARCHIVES_DIR=${BUILD_ROOT}/var/cache/apt/archives
  182. EXTERNAL_ARCHIVES_DIR=${CACHE_DIR}/${VERSION}/apt/archives
  183. __chroot_sh="/usr/sbin/chroot ${BUILD_ROOT} /bin/sh -c -l"
  184. mkdir -p $VBOOTSTRAP_DIR
  185. return 0
  186. }
  187. setup-vbootstrap-rpm(){
  188. setup-vbootstrap || return 1
  189. ## check ${BUILD_ROOT}
  190. [ -d ${BUILD_ROOT} ] || Build
  191. ## setarch ix86 if ix86 chroot on x86_64 host
  192. [ $with_ix86_on_x86_64 -eq 1 ] && \
  193. __chroot_sh="/usr/sbin/chroot ${BUILD_ROOT} setarch ${VARCH} /bin/sh -c -l"
  194. DIST_RELEASE=$(cat ${BUILD_ROOT}/etc/vine-release | cut -f3 -d" " | cut -f1 -d.)
  195. if [ -f $RPM_PKG ]; then
  196. BASE_RPM_PKG=$(basename $RPM_PKG)
  197. cp -f $RPM_PKG $BUILD_ROOT${BUILD_DIR}
  198. else
  199. BASE_RPM_PKG=$RPM_PKG
  200. fi
  201. return 0
  202. }
  203. ## recover apt-get data on host/chroot
  204. apt-get-update(){
  205. case $1 in
  206. --host)
  207. echo -n $"apt-get update on host ... "
  208. apt-get -qq update > /dev/null 2>&1
  209. echo $"done."
  210. ;;
  211. --chroot)
  212. echo -n $"apt-get update on chroot ... "
  213. $__chroot_sh 'apt-get -qq update' > /dev/null 2>&1
  214. echo $"done."
  215. ;;
  216. *)
  217. echo apt-get-update: unknown option $1
  218. exit 1
  219. ;;
  220. esac
  221. }
  222. ## mount-chroot {|--umount} [file system|name]
  223. ## support file systems: /home /tmp /sys /proc /dev/shm /dev/pts /dev
  224. ## support names: vfs archives_dir
  225. ## NOTE: /tmp needs for applications which use X
  226. ## vfs is virtual file systems
  227. ## archives_dir uses to mount ${EXTERNAL_ARCHIVES_DIR} to ${ARCHIVES_DIR}
  228. ## unionfs_dir covers ${BUILD_ROOT} with unionfs
  229. mount-chroot(){
  230. if [ "$1" = "--umount" ]; then
  231. mount-chroot-umount $2 || return 1
  232. else
  233. mount-chroot-mount $1 || return 1
  234. fi
  235. return 0
  236. }
  237. ## mount-chroot-umount [file system|name]
  238. mount-chroot-umount(){
  239. local fs=$1
  240. case $fs in
  241. /home|/tmp|/sys|/proc|/dev/shm|/dev/pts|/dev)
  242. [ -d ${BUILD_ROOT}${fs} ] || return 1
  243. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] || \
  244. umount ${BUILD_ROOT}${fs}
  245. if [ ! -z "$(mount | grep ${BUILD_ROOT}${fs})" ]; then
  246. echo $"Retry lazy unmount ${BUILD_ROOT}${fs} ... "
  247. umount -l ${BUILD_ROOT}${fs}
  248. echo $"done."
  249. fi
  250. ;;
  251. vfs)
  252. for dir in /sys /proc /dev/shm /dev/pts /dev; do
  253. mount-chroot-umount ${dir} || return 1
  254. done
  255. ;;
  256. archives_dir)
  257. [ -d ${ARCHIVES_DIR} ] || return 1
  258. [ -z "$(mount | grep ${ARCHIVES_DIR})" ] || \
  259. umount ${ARCHIVES_DIR}
  260. ;;
  261. unionfs_dir)
  262. [ -d ${BUILD_ROOT} ] || return 1
  263. [ -z "$(mount | grep ${BUILD_ROOT} | grep unionfs)" ] || \
  264. umount ${BUILD_ROOT}
  265. if [ ! -z "$(mount | grep ${BUILD_ROOT} | grep unionfs)" ]; then
  266. echo $"Retry lazy unmount ${BUILD_ROOT} ... "
  267. umount -l ${BUILD_ROOT}
  268. echo $"done."
  269. fi
  270. ;;
  271. *)
  272. echo mount-chroot-umount: unknown file system $fs
  273. exit 1
  274. ;;
  275. esac
  276. return 0
  277. }
  278. ## mount-chroot-mount [file system|name]
  279. mount-chroot-mount(){
  280. local fs=$1
  281. case $fs in
  282. /home)
  283. [ -d ${BUILD_ROOT}${fs} ] || mkdir -p ${BUILD_ROOT}${fs}
  284. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] && \
  285. mount -o _netdev,rbind ${fs} ${BUILD_ROOT}${fs}
  286. ;;
  287. /tmp|/dev)
  288. [ -d ${BUILD_ROOT}${fs} ] || mkdir -p ${BUILD_ROOT}${fs}
  289. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] && \
  290. mount --bind -o _netdev ${fs} ${BUILD_ROOT}${fs}
  291. ;;
  292. /sys)
  293. [ -d ${BUILD_ROOT}${fs} ] || mkdir -p ${BUILD_ROOT}${fs}
  294. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] && \
  295. mount -o _netdev -t sysfs vbuildersysfs ${BUILD_ROOT}${fs}
  296. ;;
  297. /proc)
  298. [ -d ${BUILD_ROOT}${fs} ] || mkdir -p ${BUILD_ROOT}${fs}
  299. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] && \
  300. mount -o _netdev -t proc vbuilderproc ${BUILD_ROOT}${fs}
  301. ;;
  302. /dev/shm)
  303. [ -d ${BUILD_ROOT}${fs} ] || mkdir -p ${BUILD_ROOT}${fs}
  304. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] && \
  305. mount -o _netdev -t tmpfs vbuildertmpfs ${BUILD_ROOT}${fs}
  306. ;;
  307. /dev/pts)
  308. [ -d ${BUILD_ROOT}${fs} ] || mkdir -p ${BUILD_ROOT}${fs}
  309. [ -z "$(mount | grep ${BUILD_ROOT}${fs})" ] && \
  310. mount -o gid=5,mode=620,_netdev -t devpts vbuilderdevpts ${BUILD_ROOT}${fs}
  311. ;;
  312. vfs)
  313. for dir in /dev /dev/pts /dev/shm /proc /sys; do
  314. mount-chroot-mount ${dir} || return 1
  315. done
  316. ;;
  317. archives_dir)
  318. [ -d ${EXTERNAL_ARCHIVES_DIR} ] || mkdir -p ${EXTERNAL_ARCHIVES_DIR}
  319. [ -d ${ARCHIVES_DIR} ] || mkdir -p ${ARCHIVES_DIR}
  320. [ -z "$(mount | grep ${ARCHIVES_DIR})" ] && \
  321. mount --bind -o _netdev ${EXTERNAL_ARCHIVES_DIR} ${ARCHIVES_DIR}
  322. [ -d ${ARCHIVES_DIR}/partial ] || mkdir -p ${ARCHIVES_DIR}/partial
  323. ;;
  324. unionfs_dir)
  325. if [ $with_unionfs -eq 1 ]; then
  326. [ -d ${UNIONFS_ROOT} ] || mkdir -p ${UNIONFS_ROOT}
  327. [ -z "$(mount | grep ${UNIONFS_ROOT})" ] && \
  328. mount -t unionfs -o dirs=${UNIONFS_ROOT}=rw:${BUILD_ROOT}=ro unionfs ${BUILD_ROOT}
  329. unionctl ${BUILD_ROOT} --list
  330. fi
  331. ;;
  332. *)
  333. echo mount-chroot-mount: unknown file system $fs
  334. exit 1
  335. ;;
  336. esac
  337. return 0
  338. }
  339. ### end of file