rbm.conf 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644
  1. # vim: filetype=yaml sw=2
  2. debug: '[% GET ! ENV.RBM_NO_DEBUG %]'
  3. compress_tar: gz
  4. output_dir: "out/[% project %]"
  5. tmp_dir: '[% c("basedir") %]/tmp'
  6. build_log: '[% GET ENV.RBM_LOGS_DIR ? ENV.RBM_LOGS_DIR : "logs" %]/[% project %][% IF c("var/osname") %]-[% c("var/osname") %][% END %].log'
  7. pkg_type: build
  8. steps:
  9. src-tarballs:
  10. compress_tar: xz
  11. src-tarballs: |
  12. #!/bin/bash
  13. set -e
  14. mkdir -p '[% dest_dir %]'
  15. mv -vf '[% project %]-[% c("version") %].tar.xz' '[% dest_dir %]/[% c("filename") %]'
  16. # buildconf contains build options that the user can change in rbm.local.conf
  17. # When adding a new option to buildconf, a default value should be defined
  18. # in var/build_id, so that changing this option does not affect the build_id.
  19. buildconf:
  20. num_procs: '[% GET ENV.RBM_NUM_PROCS ? ENV.RBM_NUM_PROCS : "4" %]'
  21. git_signtag_opt: '-s'
  22. var:
  23. torbrowser_version: '10.0a5'
  24. torbrowser_build: 'build2'
  25. torbrowser_incremental_from:
  26. - 10.0a4
  27. project_name: tor-browser
  28. multi_lingual: 0
  29. build_mar: 1
  30. # By default, we sort the list of installed packages. This allows sharing
  31. # containers with identical list of packages, even if they are not listed
  32. # in the same order. In the cases where the installation order is
  33. # important, sort_deps should be set to 0.
  34. sort_deps: 1
  35. build_id: '[% sha256(c("var/build_id_txt", { buildconf => { num_procs => 4 } })).substr(0, 6) %]'
  36. build_id_txt: |
  37. [% c("version") %]
  38. [% IF c("git_hash") || c("hg_hash"); GET c("abbrev"); END; %]
  39. [% IF c("var/container/use_container") && ! c("var/container/global_disable") -%]
  40. [% c("var/container/suite") %]
  41. [% c("var/container/arch") %]
  42. [% END -%]
  43. input_files: [% c("input_files_id") %]
  44. build:
  45. [% SET step = c("step") -%]
  46. [% c(step, { filename => 'f', output_dir => '/out', norec => {} }) %]
  47. container:
  48. dir: '[% c("rbm_tmp_dir") %]/rbm-containers/[% sha256(c("build_id")) %]'
  49. user: rbm
  50. disable_network:
  51. # disable network in the build scripts
  52. build: 1
  53. input_files_list: |
  54. [% FOREACH file IN c("input_files_by_name").keys.sort -%]
  55. [% c("input_files_by_name/" _ file) %]
  56. [% END -%]
  57. faketime: "faketime -f \"[% USE date; GET date.format(c('timestamp'), format = '%Y-%m-%d %H:%M:%S') %]\""
  58. touch: "[% USE date %]touch -m -t [% date.format(c('timestamp'), format = '%Y%m%d%H%M') %]"
  59. locale_ja: ja
  60. locales:
  61. - ar
  62. - ca
  63. - cs
  64. - da
  65. - de
  66. - el
  67. - es-AR
  68. - es-ES
  69. - fa
  70. - fr
  71. - ga-IE
  72. - he
  73. - hu
  74. - id
  75. - is
  76. - it
  77. - '[% c("var/locale_ja") %]'
  78. - ka
  79. - ko
  80. - lt
  81. - mk
  82. - ms
  83. - nb-NO
  84. - nl
  85. - pl
  86. - pt-BR
  87. - ro
  88. - ru
  89. - sv-SE
  90. - th
  91. - tr
  92. - vi
  93. - zh-CN
  94. - zh-TW
  95. sign_build: '[% ENV.RBM_SIGN_BUILD %]'
  96. sign_build_gpg_opts: '[% ENV.RBM_GPG_OPTS %]'
  97. rezip: |
  98. rezip_tmpdir=$(mktemp -d)
  99. mkdir -p "$rezip_tmpdir/z"
  100. unzip -d "$rezip_tmpdir/z" -- [% c("rezip_file") %] || [ $? -lt 3 ]
  101. pushd "$rezip_tmpdir/z"
  102. [% c("zip", {
  103. zip_src => [ '.' ],
  104. zip_args => '$rezip_tmpdir/new.zip',
  105. }) %]
  106. popd
  107. mv -f -- "$rezip_tmpdir/new.zip" [% c("rezip_file") %]
  108. rm -Rf "$rezip_tmpdir"
  109. set_default_env: |
  110. set -e
  111. [% FOREACH env = c('ENV') -%]
  112. export [% env.key %]="[% env.value %]"
  113. [% END -%]
  114. rootdir=$(pwd)
  115. export SHELL=/bin/bash
  116. export HOME=$rootdir
  117. umask 0022
  118. [% IF c("var/container/global_disable") -%]
  119. rm -Rf /var/tmp/build /var/tmp/dist
  120. [% END -%]
  121. DOCSDIR_project: '[% project %]'
  122. set_PTDIR_DOCSDIR: |
  123. PTDIR="$distdir/TorBrowser/Tor/PluggableTransports"
  124. DOCSDIR="$distdir/TorBrowser/Docs/[% c("var/DOCSDIR_project") %]"
  125. targets:
  126. notarget: linux-x86_64
  127. noint:
  128. debug: 0
  129. release:
  130. var:
  131. release: 1
  132. channel: release
  133. alpha:
  134. var:
  135. alpha: 1
  136. channel: alpha
  137. nightly:
  138. fetch: 1
  139. var:
  140. nightly: 1
  141. channel: nightly
  142. torbrowser_version: |
  143. [%
  144. IF ENV.TORBROWSER_NIGHTLY_VERSION;
  145. GET ENV.TORBROWSER_NIGHTLY_VERSION;
  146. ELSIF c("var/testbuild");
  147. GET "testbuild";
  148. ELSE;
  149. GET c("var_p/nightly_torbrowser_version");
  150. END;
  151. -%]
  152. # For nightly builds, we support updates for a limited set of locales
  153. mar_locales:
  154. - de
  155. - es-ES
  156. - fr
  157. - ru
  158. max_torbrowser_incremental_from: 2
  159. build_infos_json: 1
  160. torbrowser-testbuild:
  161. - testbuild
  162. - alpha
  163. testbuild:
  164. var:
  165. testbuild: 1
  166. # Don't create mar files to save time
  167. build_mar: 0
  168. # The common-stretch target is used to build components that are common to all
  169. # platforms, using Debian stretch.
  170. common-stretch:
  171. var:
  172. common: 1
  173. container:
  174. suite: stretch
  175. arch: amd64
  176. pre_pkginst: ''
  177. deps:
  178. - build-essential
  179. - python
  180. - automake
  181. - libtool
  182. - zip
  183. - unzip
  184. torbrowser-android-all:
  185. - android-all
  186. # For now we still need both android-fenix and android. We don't need the
  187. # prefix for the other -all pieces as they are only used for Fenix anyway.
  188. - android-fenix
  189. - android
  190. android-all:
  191. arch: all
  192. var:
  193. android-all: 1
  194. osname: android-all
  195. torbrowser-android-fenix-armv7:
  196. - android-fenix-armv7
  197. - android-armv7
  198. - android-fenix
  199. - android
  200. torbrowser-android-armv7:
  201. - android-armv7
  202. - android
  203. android-fenix-armv7:
  204. var:
  205. cross_prefix: armv7a-linux-androideabi
  206. android-armv7:
  207. arch: armv7
  208. var:
  209. android-armv7: 1
  210. osname: android-armv7
  211. toolchain_arch: arm
  212. configure_host: arm-linux-androideabi
  213. abi: armeabi-v7a
  214. torbrowser-android-fenix-x86:
  215. - android-fenix-x86
  216. - android-x86
  217. - android-fenix
  218. - android
  219. torbrowser-android-x86:
  220. - android-x86
  221. - android
  222. android-fenix-x86:
  223. var:
  224. cross_prefix: i686-linux-android
  225. android-x86:
  226. arch: x86
  227. var:
  228. android-x86: 1
  229. osname: android-x86
  230. toolchain_arch: x86
  231. configure_host: i686-linux-android
  232. abi: x86
  233. torbrowser-android-fenix-x86_64:
  234. - android-fenix-x86_64
  235. - android-x86_64
  236. - android-fenix
  237. - android
  238. torbrowser-android-x86_64:
  239. - android-x86_64
  240. - android
  241. android-fenix-x86_64:
  242. var:
  243. cross_prefix: x86_64-linux-android
  244. android-x86_64:
  245. arch: x86_64
  246. var:
  247. android-x86_64: 1
  248. osname: android-x86_64
  249. toolchain_arch: x86_64
  250. configure_host: x86_64-linux-android
  251. abi: x86_64
  252. torbrowser-android-fenix-aarch64:
  253. - android-fenix-aarch64
  254. - android-aarch64
  255. - android-fenix
  256. - android
  257. torbrowser-android-aarch64:
  258. - android-aarch64
  259. - android
  260. android-fenix-aarch64:
  261. var:
  262. cross_prefix: aarch64-linux-android
  263. android-aarch64:
  264. arch: aarch64
  265. var:
  266. android-aarch64: 1
  267. osname: android-aarch64
  268. toolchain_arch: arm64
  269. configure_host: aarch64-linux-android
  270. abi: arm64-v8a
  271. android-fenix:
  272. var:
  273. android-fenix: 1
  274. compiler: fenix-android-toolchain
  275. CC: '[% c("var/cross_prefix") %][% c("var/android_min_api") %]-clang'
  276. CXX: '[% c("var/cross_prefix") %][% c("var/android_min_api") %]-clang'
  277. configure_opt: '--host=[% c("var/cross_prefix") %] CC=[% c("var/CC") %] [% c("var/configure_opt_project") %]'
  278. android:
  279. var:
  280. android: 1
  281. compiler: android-toolchain
  282. android_min_api: '[% GET c("var/android_min_api_" _ c("arch")) %]'
  283. # API 16 is the minimum we currently support for 32 bit on Android
  284. android_min_api_armv7: 16
  285. android_min_api_x86: 16
  286. # API 21 is the minimum we currently support for 64 bit on Android
  287. android_min_api_x86_64: 21
  288. android_min_api_aarch64: 21
  289. CC: '$ANDROID_NDK_HOME/[% c("var/toolchain_arch") %]/bin/clang'
  290. CXX: '$ANDROID_NDK_HOME/[% c("var/toolchain_arch") %]/bin/clang++'
  291. # We only build snowflake on the alpha and nightly
  292. # channels for now.
  293. snowflake: '[% c("var/alpha") || c("var/nightly") %]'
  294. container:
  295. suite: buster
  296. arch: amd64
  297. disable_network:
  298. # Disable network in the script for merging GeckoView .aar files
  299. merge_aars: 1
  300. deps:
  301. - build-essential
  302. - python
  303. - automake
  304. - libtool
  305. - zip
  306. - unzip
  307. - libtinfo5
  308. configure_opt: CC=clang --host=[% c("var/configure_host") %] [% c("var/configure_opt_project") %]
  309. pre_pkginst: |
  310. SNAPSHOT_VERSION=20191201T212855Z
  311. OPENJDK_URL=https://snapshot.debian.org/archive/debian/$SNAPSHOT_VERSION/pool/main/o/openjdk-8
  312. JDK_VERSION=8u232-b09-1~deb9u1_amd64
  313. apt-get install -y -q wget ca-certificates-java
  314. wget $OPENJDK_URL/openjdk-8-jdk-headless_$JDK_VERSION.deb
  315. wget $OPENJDK_URL/openjdk-8-jre-headless_$JDK_VERSION.deb
  316. echo 92b4f8fb77d793a86e0b03b3b0750592b40a26a5d75956d10dd984a7b3aad4c9 openjdk-8-jdk-headless_$JDK_VERSION.deb | sha256sum -c
  317. echo 84bf52b6cce20ead08b0d5b9fd9b81b4aa3da385ca951b313fe11d5cb1aa4d17 openjdk-8-jre-headless_$JDK_VERSION.deb | sha256sum -c
  318. dpkg -i ./openjdk-8-jre-headless_$JDK_VERSION.deb ./openjdk-8-jdk-headless_$JDK_VERSION.deb
  319. torbrowser-linux-x86_64:
  320. - linux-x86_64
  321. - linux
  322. torbrowser-linux-x86_64-debug:
  323. - linux-debug
  324. - linux-x86_64
  325. - linux
  326. torbrowser-linux-i686:
  327. - linux-i686
  328. - linux
  329. linux-x86_64:
  330. arch: x86_64
  331. var:
  332. linux-x86_64: 1
  333. osname: linux-x86_64
  334. # We only support RLBox on the nightly channel and x86_64 for now
  335. rlbox: '[% c("var/nightly") %]'
  336. linux-i686:
  337. arch: i686
  338. var:
  339. linux-i686: 1
  340. osname: linux-i686
  341. configure_opt: '--host=i686-linux-gnu CFLAGS=-m32 CXXFLAGS=-m32 LDFLAGS=-m32 [% c("var/configure_opt_project") %]'
  342. linux:
  343. var:
  344. linux: 1
  345. compiler: gcc
  346. configure_opt: '[% c("var/configure_opt_project") %]'
  347. # We only build snowflake on the alpha and nightly
  348. # channels for now.
  349. snowflake: '[% c("var/alpha") || c("var/nightly") %]'
  350. # Only build Namecoin for nightly
  351. namecoin: '[% c("var/nightly") %]'
  352. container:
  353. suite: wheezy
  354. arch: amd64
  355. pre_pkginst: dpkg --add-architecture i386
  356. deps:
  357. - libc6-dev-i386
  358. - lib32stdc++6
  359. - build-essential
  360. - python
  361. - bison
  362. - hardening-wrapper
  363. - automake
  364. - libtool
  365. - zip
  366. - unzip
  367. linux-debug:
  368. var:
  369. asan: 1
  370. torbrowser-windows-i686:
  371. - windows-i686
  372. - windows
  373. torbrowser-windows-x86_64:
  374. - windows-x86_64
  375. - windows
  376. windows-x86_64:
  377. arch: x86_64
  378. var:
  379. windows-x86_64: 1
  380. windows-i686: 0
  381. osname: windows-x86_64
  382. # HEASLR is 64 bit only (see bug 12968)
  383. flag_HEASLR: '-Wl,--high-entropy-va'
  384. windows-i686:
  385. arch: i686
  386. var:
  387. windows-i686: 1
  388. windows-x86_64: 0
  389. osname: windows-i686
  390. windows:
  391. var:
  392. windows: 1
  393. container:
  394. suite: buster
  395. arch: amd64
  396. configure_opt: '--host=[% c("arch") %]-w64-mingw32 CFLAGS="[% c("var/CFLAGS") %]" LDFLAGS="[% c("var/LDFLAGS") %]" [% c("var/configure_opt_project") %]'
  397. CFLAGS: '-fstack-protector-strong -fno-strict-overflow -Wno-missing-field-initializers -Wformat -Wformat-security [% c("var/flag_mwindows") %]'
  398. LDFLAGS: '-Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -Wl,--no-insert-timestamp -lssp -L$gcclibs [% c("var/flag_HEASLR") %] [% c("var/flag_mwindows") %]'
  399. flag_mwindows: '-mwindows'
  400. compiler: mingw-w64
  401. faketime_path: /usr/lib/x86_64-linux-gnu/faketime/libfaketime.so.1
  402. # We only build snowflake on the alpha and nightly
  403. # channels for now.
  404. snowflake: '[% c("var/alpha") || c("var/nightly") %]'
  405. # Only build Namecoin for nightly
  406. namecoin: '[% c("var/nightly") %]'
  407. deps:
  408. - build-essential
  409. - python
  410. - bison
  411. - automake
  412. - libtool
  413. - zip
  414. - unzip
  415. torbrowser-osx-x86_64:
  416. - osx-x86_64
  417. osx-x86_64:
  418. arch: x86_64
  419. var:
  420. osx: 1
  421. osname: osx-x86_64
  422. container:
  423. suite: buster
  424. arch: amd64
  425. compiler: 'macosx-toolchain'
  426. configure_opt: '--host=x86_64-apple-darwin CC="x86_64-apple-darwin-clang [% c("var/FLAGS") %]" CXX="x86_64-apple-darwin-clang++ [% c("var/FLAGS") %]" [% c("var/configure_opt_project") %]'
  427. FLAGS: "-target x86_64-apple-darwin -B $cctoolsdir -isysroot $sysrootdir"
  428. LDFLAGS: "-Wl,-syslibroot,$sysrootdir -Wl,-dead_strip -Wl,-pie"
  429. macosx_deployment_target: '10.9'
  430. locale_ja: ja-JP-mac
  431. # We only support RLBox on the nightly channel for now
  432. rlbox: '[% c("var/nightly") %]'
  433. # We only build snowflake on the alpha and nightly
  434. # channels for now.
  435. snowflake: '[% c("var/alpha") || c("var/nightly") %]'
  436. deps:
  437. - build-essential
  438. - python
  439. - automake
  440. - libtool
  441. - zip
  442. - unzip
  443. faketime_path: /usr/lib/x86_64-linux-gnu/faketime/libfaketime.so.1
  444. set_PTDIR_DOCSDIR: |
  445. PTDIR="$distdir/Contents/MacOS/Tor/PluggableTransports"
  446. DOCSDIR="$distdir/Contents/Resources/TorBrowser/Docs/[% c("var/DOCSDIR_project") %]"
  447. # The no_build_id target can be useful if you want to quickly display
  448. # a build template or other option but don't want to spend time to
  449. # compute the various build ids
  450. no_build_id:
  451. # The defaut timestamp value will use the commit time of the
  452. # selected commit for the project, which will require cloning the
  453. # git repository if it is not present. When we use the no_build_id
  454. # target to display a script, we usually don't care about such
  455. # details, so we set timestamp to 0 to avoid unnecessary cloning.
  456. timestamp: 0
  457. var:
  458. build_id: 1
  459. no_containers:
  460. var:
  461. container:
  462. global_disable: 1
  463. # change the default gpg_wrapper to allow git tag signed using an
  464. # expired key.
  465. # https://bugs.torproject.org/19737
  466. gpg_wrapper: |
  467. #!/bin/bash
  468. export LC_ALL=C
  469. [%
  470. IF c('gpg_keyring');
  471. SET gpg_kr = '--keyring ' _ path(c('gpg_keyring'), path(c('gpg_keyring_dir'))) _ ' --no-default-keyring';
  472. END;
  473. -%]
  474. gpg_verify=0
  475. for opt in "$@"
  476. do
  477. test "$opt" = '--verify' && gpg_verify=1
  478. done
  479. if [ $gpg_verify = 1 ]
  480. then
  481. [% c('gpg_bin') %] [% c('gpg_args') %] --with-fingerprint [% gpg_kr %] "$@" | sed 's/^\[GNUPG:\] EXPKEYSIG /\[GNUPG:\] GOODSIG /'
  482. exit ${PIPESTATUS[0]}
  483. else
  484. exec [% c('gpg_bin') %] [% c('gpg_args') %] --with-fingerprint [% gpg_kr %] "$@"
  485. fi
  486. remote_start: '[% IF c("var/container/use_container") && ! c("var/container/global_disable") %][% c("runc/remote_start") %][% END %]'
  487. remote_exec: '[% IF c("var/container/use_container") && ! c("var/container/global_disable") %][% c("runc/remote_exec") %][% END %]'
  488. remote_put: '[% IF c("var/container/use_container") && ! c("var/container/global_disable") %][% c("runc/remote_put") %][% END %]'
  489. remote_get: '[% IF c("var/container/use_container") && ! c("var/container/global_disable") %][% c("runc/remote_get") %][% END %]'
  490. remote_finish: '[% IF c("var/container/use_container") && ! c("var/container/global_disable") %][% c("runc/remote_finish") %][% END %]'
  491. runc:
  492. remote_start: |
  493. #!/bin/sh
  494. set -e
  495. if [ $(ls -1 '[% c("remote_srcdir", { error_if_undef => 1 }) %]/container-image_'* | wc -l) -ne 1 ]
  496. then
  497. echo "Can't find container image in input files" >&2
  498. ls -l '[% c("remote_srcdir") %]' >&2
  499. exit 1
  500. fi
  501. mkdir -p '[% c("var/container/dir") %]'/rootfs/rbm
  502. sudo tar -C '[% c("var/container/dir") %]'/rootfs -xf $(ls -1 '[% c("remote_srcdir", { error_if_undef => 1 }) %]/container-image_'*)
  503. [% SET user = c("var/container/user") -%]
  504. [% c("remote_exec", { exec_as_root => 1, exec_cmd => 'id ' _ user
  505. _ ' >/dev/null 2>&1 || adduser -m ' _ user _ ' || useradd -m ' _ user }) %]
  506. remote_exec: |
  507. #!/bin/sh
  508. set -e
  509. [% IF c("interactive") -%]
  510. echo Container directory: [% shell_quote(c("var/container/dir")) %]
  511. [% END -%]
  512. mkdir -p '[% c("var/container/dir", { error_if_undef => 1 }) %]'/rootfs/rbm
  513. echo '#!/bin/sh' > '[% c("var/container/dir") %]'/rootfs/rbm/cmd
  514. echo [% shell_quote(c('exec_cmd')) %] >> '[% c("var/container/dir") %]'/rootfs/rbm/cmd
  515. echo '#!/bin/sh' > '[% c("var/container/dir") %]'/rootfs/rbm/run
  516. [% IF c('exec_as_root'); SET user = 'root'; ELSE; SET user = c("var/container/user", { error_if_undef => 1 }); END; %]
  517. echo 'su - [% user %] -c /rbm/cmd' >> '[% c("var/container/dir") %]'/rootfs/rbm/run
  518. chmod +x '[% c("var/container/dir") %]'/rootfs/rbm/cmd
  519. chmod +x '[% c("var/container/dir") %]'/rootfs/rbm/run
  520. cat > '[% c("var/container/dir") %]'/config.json << EOF
  521. [% INCLUDE 'runc-config.json' %]
  522. EOF
  523. [% IF c("var/container/disable_network/" _ c("exec_name")) -%]
  524. sudo ip netns add 'rbm-[% sha256(c("build_id", { error_if_undef => 1 })) %]'
  525. # make sure the lo interface is up (see bug 31293)
  526. sudo ip netns exec 'rbm-[% sha256(c("build_id", { error_if_undef => 1 })) %]' ip link set lo up
  527. [% END -%]
  528. sudo runc [% IF c("var_p/runc100") %]run[% ELSE %]start[% END %] -b '[% c("var/container/dir") %]' rbm-[% sha256(c("build_id", { error_if_undef => 1 })) %] [% IF c("runc_hide_stderr") %]2>/dev/null[% END %]
  529. [% IF c("var/container/disable_network/" _ c("exec_name")) -%]
  530. sudo ip netns delete 'rbm-[% sha256(c("build_id", { error_if_undef => 1 })) %]'
  531. [% END -%]
  532. remote_put: |
  533. #!/bin/sh
  534. set -e
  535. [%
  536. SET src = shell_quote(c('put_src', { error_if_undef => 1 }));
  537. SET dst = shell_quote(c('put_dst', { error_if_undef => 1 }));
  538. -%]
  539. sudo mkdir -p '[% c("var/container/dir") %]'/rootfs/[% dst %]
  540. sudo cp -aP [% src %] '[% c("var/container/dir") %]'/rootfs/[% dst %]
  541. # On Ubuntu, the /root/.profile file contains a `mesg n` line which is
  542. # producing some `stdin: is not a tty` messages. To hide them, we hide
  543. # stderr from this part by setting runc_hide_stderr.
  544. [% c("remote_exec", { exec_as_root => 1, exec_cmd => 'chown -R ' _ c("var/container/user") _ ' ' _ dst, runc_hide_stderr => 1 }) %]
  545. remote_get: |
  546. #!/bin/sh
  547. set -e
  548. [%
  549. SET src = shell_quote(c('get_src', { error_if_undef => 1 }));
  550. SET dst = shell_quote(c('get_dst', { error_if_undef => 1 }));
  551. -%]
  552. mkdir -p [% dst %]
  553. srcdir='[% c("var/container/dir", { error_if_undef => 1 }) %]'/rootfs/[% src %]
  554. sudo chown -R $(whoami) "$srcdir"
  555. if [ $(ls -1 "$srcdir"/* 2> /dev/null | wc -l) -gt 0 ]
  556. then
  557. for file in "$srcdir"/*
  558. do
  559. bname="$(basename "$file")"
  560. test -e [% dst %]/"$bname" && rm -Rf [% dst %]/"$bname"
  561. mv -f "$file" [% dst %]/
  562. done
  563. fi
  564. remote_finish: |
  565. #!/bin/sh
  566. set -e
  567. sudo rm -Rf '[% c("var/container/dir", { error_if_undef => 1 }) %]'/rootfs '[% c("var/container/dir", { error_if_undef => 1 }) %]'/config.json
  568. rmdir '[% c("var/container/dir") %]'
  569. ENV:
  570. TZ: UTC
  571. LC_ALL: C
  572. --- |
  573. # This part of the file contains options written in perl
  574. use IO::CaptureOutput qw(capture_exec);
  575. (
  576. var_p => {
  577. # runc100 is true if we are using runc >= 1.0.0
  578. # we assume that any version that is not 0.1.1 is >= 1.0.0
  579. runc100 => sub {
  580. my ($out) = capture_exec('sudo', 'runc', '--version');
  581. return !($out =~ m/^runc version 0.1.1/);
  582. },
  583. # runc_spec100 is true if runc spec is at least 1.0.0
  584. # We will need to update this when there is a new spec version available
  585. runc_spec100 => sub {
  586. my ($out) = capture_exec('sudo', 'runc', '--version');
  587. return $out =~ m/^.*spec: 1\.[0-9]+\.[0-9]+(?:-dev)?$/m;
  588. },
  589. nightly_torbrowser_version => sub {
  590. state $version = '';
  591. return $version if $version;
  592. my (undef, undef, undef, $day, $mon, $year) = gmtime;
  593. $version = sprintf("tbb-nightly.%u.%02u.%02u", $year + 1900, $mon + 1, $day);
  594. return $version;
  595. },
  596. nightly_torbrowser_incremental_from => sub {
  597. my ($project, $options) = @_;
  598. my $nightly_dir = project_config($project, 'basedir', $options) . '/nightly';
  599. my $current_version = project_config($project, 'var/torbrowser_version', $options);
  600. use Path::Tiny;
  601. return [] unless -d $nightly_dir;
  602. my @dirs = sort map { $_->basename } path($nightly_dir)->children(qr/^tbb-nightly\./);
  603. my $nb_incr = project_config($project, ['var', 'max_torbrowser_incremental_from'], $options);
  604. my @res;
  605. while ($nb_incr > 0) {
  606. my $dir = pop @dirs;
  607. last unless $dir;
  608. next if $dir eq $current_version;
  609. $nb_incr--;
  610. push @res, $dir;
  611. }
  612. return [@res];
  613. },
  614. },
  615. )