build 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. #!/bin/bash
  2. [% c("var/set_default_env") -%]
  3. [% IF ! c("var/linux-cross") %]
  4. [% pc(c('var/compiler'), 'var/setup', { compiler_tarfile => c('input_files_by_name/' _ c('var/compiler')) }) %]
  5. [% END %]
  6. mkdir -p /var/tmp/dist
  7. distdir=/var/tmp/dist/[% project %]
  8. mkdir -p /var/tmp/build
  9. mkdir -p [% dest_dir _ '/' _ c('filename') %]
  10. [% IF c("var/windows") %]
  11. # Setting up fxc2
  12. tar -C /var/tmp/dist -xf [% c('input_files_by_name/fxc2') %]
  13. export PATH="/var/tmp/dist/fxc2/bin:$PATH"
  14. # fxc2 requires Wine.
  15. export WINEARCH=[% IF c("var/windows-x86_64") %]win64[% ELSE %]win32[% END %]
  16. export HOME=/var/tmp/home
  17. mkdir -p $HOME
  18. WINEROOT=$HOME/.wine/drive_c
  19. wine wineboot -i
  20. # Setting up stack protector support
  21. tar -C /var/tmp/dist -xf [% c('input_files_by_name/mingw-w64') %]
  22. cp /var/tmp/dist/mingw-w64/gcclibs/{libssp.a,libssp_nonshared.a} /var/tmp/dist/mingw-w64-clang/[% c("arch") %]-w64-mingw32/lib/
  23. [% END -%]
  24. [% IF ! c("var/linux-ppc64le") %]
  25. tar -C /var/tmp/dist -xf [% c('input_files_by_name/rust') %]
  26. [% END %]
  27. [% IF c("var/linux-cross") %]
  28. # rustup expects Wheezy openssl, so we provide it here
  29. export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/var/tmp/dist/rust/lib_host"
  30. [% END %]
  31. tar -C /var/tmp/dist -xf [% c('input_files_by_name/cbindgen') %]
  32. tar -C /var/tmp/dist -xf [% c('input_files_by_name/nasm') %]
  33. tar -C /var/tmp/dist -xf [% c('input_files_by_name/python') %]
  34. tar -C /var/tmp/dist -xf [% c('input_files_by_name/node') %]
  35. export PATH="/var/tmp/dist/rust/bin:/var/tmp/dist/cbindgen:/var/tmp/dist/nasm/bin:/var/tmp/dist/python/bin:/var/tmp/dist/node/bin:$PATH"
  36. tar -C /var/tmp/dist -xf [% c('input_files_by_name/clang') %]
  37. export LLVM_CONFIG="/var/tmp/dist/clang/bin/llvm-config"
  38. [% IF c("var/linux") || c("var/android") %]
  39. tar -C /var/tmp/dist -xf $rootdir/[% c('input_files_by_name/binutils') %]
  40. export PATH="/var/tmp/dist/binutils/bin:$PATH"
  41. # Use clang for everything on Linux and Android now if we don't build with
  42. # ASan.
  43. [% IF ! c("var/asan") -%]
  44. export PATH="/var/tmp/dist/clang/bin:$PATH"
  45. [% END -%]
  46. [% END -%]
  47. tar -C /var/tmp/build -xf [% project %]-[% c('version') %].tar.gz
  48. [% IF c("var/osx") %]
  49. mkdir -p "$distdir/Tor Browser.app/Contents/MacOS"
  50. [% ELSE %]
  51. mkdir -p $distdir/Browser
  52. [% END %]
  53. cd /var/tmp/build/[% project %]-[% c("version") %]
  54. mv -f $rootdir/[% c('input_files_by_name/mozconfig') %] .mozconfig
  55. [% IF c("var/asan") -%]
  56. mv -f .mozconfig-asan .mozconfig
  57. # Without disabling LSan our build is blowing up:
  58. # https://bugs.torproject.org/10599#comment:52
  59. export ASAN_OPTIONS="detect_leaks=0"
  60. [% END -%]
  61. [% IF c("var/android") %]
  62. export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
  63. gradle_repo=/var/tmp/dist/gradle-dependencies
  64. export GRADLE_MAVEN_REPOSITORIES="file://$gradle_repo"
  65. export GRADLE_FLAGS="--no-daemon --offline"
  66. # Move Gradle Repo to hard-coded location. This location is embedded in the file
  67. # chrome/toolkit/content/global/buildconfig.html so needs to be standard for reproducibility
  68. mv $rootdir/[% c('input_files_by_name/gradle-dependencies') %] $gradle_repo
  69. cp -r $gradle_repo/m2/* $gradle_repo
  70. # Move Android library dependencies so they will be included in the apk during the build
  71. cp $rootdir/[% c('input_files_by_name/topl') %]/* mobile/android/app
  72. cp $rootdir/[% c('input_files_by_name/tor-android-service') %]/* mobile/android/app
  73. # Move emulator to location that firefox build expects
  74. mkdir /var/tmp/dist/android-toolchain/android-sdk-linux/emulator
  75. cp /var/tmp/dist/android-toolchain/android-sdk-linux/tools/emulator /var/tmp/dist/android-toolchain/android-sdk-linux/emulator
  76. # Prepare building the multi-locale .apk including our own strings
  77. mkdir -p /var/tmp/dist/locales
  78. tar -C /var/tmp/dist/locales -xf $rootdir/[% c('input_files_by_name/firefox-locale-bundle') %]
  79. tar -C /var/tmp/dist -xf $rootdir/[% c('input_files_by_name/tba-translation') %]
  80. [% END %]
  81. eval $(perl $rootdir/get-moz-build-date [% c("var/copyright_year") %] [% c("var/torbrowser_version") %])
  82. if [ -z $MOZ_BUILD_DATE ]
  83. then
  84. echo "MOZ_BUILD_DATE is not set"
  85. exit 1
  86. fi
  87. [% IF c("var/windows") %]
  88. # Make sure widl is not inserting random timestamps, see #21837.
  89. export WIDL_TIME_OVERRIDE="0"
  90. patch -p1 < $rootdir/nsis-uninstall.patch
  91. # Make sure we link without inserting timestamps in general.
  92. export LDFLAGS="-Wl,--no-insert-timestamp"
  93. [% END -%]
  94. [% IF c("var/linux-arm") %]
  95. patch -p1 < $rootdir/linux-arm-neon.patch
  96. patch -p1 < $rootdir/linux-arm-wasm.patch
  97. [% END %]
  98. [% IF c("var/linux-ppc64le") %]
  99. patch -p1 < $rootdir/linux-ppc64le-mpcpucache.patch
  100. [% END %]
  101. [% IF c("var/namecoin") %]
  102. patch -p1 < $rootdir/namecoin-etld.patch
  103. [% END -%]
  104. [% IF ! c("var/android") %]
  105. # Place a copy of the Tor Launcher sources under browser/extensions
  106. tar -C browser/extensions -xf $rootdir/[% c('input_files_by_name/tor-launcher') %]
  107. [% END -%]
  108. [% IF c("var/namecoin") %]
  109. pushd toolkit/torproject/torbutton
  110. patch -p1 < $rootdir/namecoin-torbutton.patch
  111. popd
  112. [% END %]
  113. [% IF c("var/nightly") -%]
  114. # Add nightly mar signing key (#33403)
  115. cp $rootdir/nightly-marsigner.der toolkit/mozapps/update/updater/nightly_aurora_level3_primary.der
  116. cp $rootdir/nightly-marsigner.der toolkit/mozapps/update/updater/nightly_aurora_level3_secondary.der
  117. # Set app.update.url for nightly (#33402)
  118. sed -i 's|pref("app\.update\.url",.*|pref("app.update.url", "https://nightlies.tbb.torproject.org/nightly-updates/updates/nightly-[% c("var/osname") %]/%CHANNEL%/%BUILD_TARGET%/%VERSION%/%LOCALE%");|' browser/app/profile/firefox.js
  119. [% END -%]
  120. rm -f configure
  121. rm -f js/src/configure
  122. # Android does not support --enable-bundled-fonts option
  123. ./mach configure --with-tor-browser-version=[% c("var/torbrowser_version") %] --with-distribution-id=org.torproject --enable-update-channel=[% c("var/channel") %] [% IF ! c("var/android") %]--enable-bundled-fonts[% END -%] --with-branding=[% c("var/branding_directory") %]
  124. ./mach build --verbose
  125. [% IF c("var/android") %]
  126. # Building a multi-locale .apk
  127. [% FOREACH lang = c('var/locales');
  128. SET lang = tmpl(lang);
  129. # mk is unavailable on mobile.
  130. NEXT IF lang == 'mk'; %]
  131. # Copy our torbrowser_strings.dtd at the right place
  132. cp /var/tmp/dist/tba-translation/[% lang %]/torbrowser_strings.dtd /var/tmp/dist/locales/[% lang %]/mobile/android/base/
  133. ./mach build chrome-[% lang %];
  134. [% END %]
  135. # Include localization for all available locales.
  136. # mk is excluded above because Mozilla does not provide mk localization.
  137. # mk is included here because we may have localization for torbutton.
  138. export MOZ_CHROME_MULTILOCALE='[% tmpl(c('var/locales').join(' ')) %]'
  139. ./mach android assemble-app
  140. AB_CD=multi ./mach package
  141. # Copy the result over and return. There is nothing more to do for mobile.
  142. cp obj-*/dist/*unsigned-unaligned.apk [% dest_dir _ '/' _ c('filename') %]/tor-browser-unsigned-unaligned.apk
  143. [% RETURN %]
  144. [% END %]
  145. ./mach build stage-package
  146. [% IF c("var/osx") %]
  147. cp -a obj-macos/dist/firefox/* $distdir
  148. # Remove firefox-bin (we don't use it, see ticket #10126)
  149. rm -f "$distdir/Tor Browser.app/Contents/MacOS/firefox-bin"
  150. # Adjust the Info.plist file
  151. INFO_PLIST="$distdir/Tor Browser.app/Contents/Info.plist"
  152. mv "$INFO_PLIST" tmp.plist
  153. python $rootdir/fix-info-plist.py '[% c("var/torbrowser_version") %]' '[% c("var/copyright_year") %]' < tmp.plist > "$INFO_PLIST"
  154. rm -f tmp.plist
  155. [% END %]
  156. [% IF c("var/linux") %]
  157. [% IF c("var/linux-x86_64") %]
  158. cp obj-*/testing/geckodriver/x86_64-unknown-linux-gnu/release/geckodriver $distdir
  159. [% END %]
  160. cp -a obj-*/dist/firefox/* $distdir/Browser/
  161. # Remove firefox-bin (we don't use it, see ticket #10126)
  162. rm -f $distdir/Browser/firefox-bin
  163. # TODO: There goes FIPS-140.. We could upload these somewhere unique and
  164. # subsequent builds could test to see if they've been uploaded before...
  165. # But let's find out if it actually matters first..
  166. rm -f $distdir/Browser/*.chk
  167. # Replace firefox by a wrapper script (#25485)
  168. mv $distdir/Browser/firefox $distdir/Browser/firefox.real
  169. mv $rootdir/start-firefox $distdir/Browser/firefox
  170. chmod 755 $distdir/Browser/firefox
  171. [% END %]
  172. [% IF c("var/windows") %]
  173. cp -a obj-*/dist/firefox/* $distdir/Browser/
  174. cp -a /var/tmp/dist/fxc2/bin/d3dcompiler_47.dll $distdir/Browser
  175. [% END %]
  176. [% IF c("var/linux-cross") -%]
  177. #cp -a /var/tmp/dist/gcc-cross/[% c("var/crosstarget") %]/lib/libssp.so* $distdir/Browser
  178. [% END %]
  179. # Make MAR-based update tools available for use during the bundle phase.
  180. # Note that mar and mbsdiff are standalone tools, compiled for the build
  181. # host's architecture. We also include signmar, certutil, and the libraries
  182. # they require; these utilities and libraries are built for the target
  183. # architecture.
  184. MARTOOLS=$distdir/mar-tools
  185. mkdir -p $MARTOOLS
  186. cp -p config/createprecomplete.py $MARTOOLS/
  187. cp -p tools/update-packaging/*.sh $MARTOOLS/
  188. cp -p obj-*/dist/host/bin/mar $MARTOOLS/
  189. cp -p obj-*/dist/host/bin/mbsdiff $MARTOOLS/
  190. [% IF c("var/linux") || c("var/osx") %]
  191. cp -p obj-*/dist/bin/signmar $MARTOOLS/
  192. cp -p obj-*/dist/bin/certutil $MARTOOLS/
  193. cp -p obj-*/dist/bin/modutil $MARTOOLS/
  194. cp -p obj-*/dist/bin/pk12util $MARTOOLS/
  195. cp -p obj-*/dist/bin/shlibsign $MARTOOLS/
  196. [% IF c("var/linux") %]
  197. NSS_LIBS="libfreeblpriv3.so libmozsqlite3.so libnss3.so libnssckbi.so libnssdbm3.so libnssutil3.so libsmime3.so libsoftokn3.so libssl3.so"
  198. NSPR_LIBS="libnspr4.so libplc4.so libplds4.so"
  199. [% ELSE %]
  200. NSS_LIBS="libfreebl3.dylib libmozglue.dylib libnss3.dylib libnssckbi.dylib libnssdbm3.dylib libsoftokn3.dylib"
  201. # No NSPR_LIBS for macOS
  202. NSPR_LIBS=""
  203. [% END %]
  204. for LIB in $NSS_LIBS $NSPR_LIBS; do
  205. cp -p obj-*/dist/bin/$LIB $MARTOOLS/
  206. done
  207. [% END %]
  208. [% IF c("var/windows") %]
  209. cp -p obj-*/dist/bin/signmar.exe $MARTOOLS/
  210. cp -p obj-*/dist/bin/certutil.exe $MARTOOLS/
  211. cp -p obj-*/dist/bin/modutil.exe $MARTOOLS/
  212. cp -p obj-*/dist/bin/pk12util.exe $MARTOOLS/
  213. cp -p obj-*/dist/bin/shlibsign.exe $MARTOOLS/
  214. NSS_LIBS="freebl3.dll mozglue.dll nss3.dll nssckbi.dll nssdbm3.dll softokn3.dll"
  215. for LIB in $NSS_LIBS; do
  216. cp -p obj-*/dist/bin/$LIB $MARTOOLS/
  217. done
  218. [% END %]
  219. cd $distdir
  220. [% IF c("var/linux-x86_64") %]
  221. # No need for an unstripped geckodriver
  222. strip geckodriver
  223. mkdir -p $distdir/Debug/Browser/gtk2
  224. [% IF c("var/linux-cross") %]
  225. TARGET_OBJCOPY=[% c("var/crosstarget") %]-objcopy
  226. TARGET_STRIP=[% c("var/crosstarget") %]-strip
  227. [% ELSE %]
  228. TARGET_OBJCOPY=objcopy
  229. TARGET_STRIP=strip
  230. [% END %]
  231. # Strip and generate debuginfo for the firefox binary that we keep, all *.so
  232. # files, the plugin-container, and the updater (see ticket #10126)
  233. for LIB in Browser/*.so Browser/gtk2/*.so Browser/firefox.real Browser/plugin-container Browser/updater
  234. do
  235. $TARGET_OBJCOPY --only-keep-debug $LIB Debug/$LIB
  236. $TARGET_STRIP $LIB
  237. $TARGET_OBJCOPY --add-gnu-debuglink=./Debug/$LIB $LIB
  238. done
  239. [% END %]
  240. # Re-zipping the omni.ja files is not needed to make them reproductible,
  241. # however if we don't re-zip them, the files become corrupt when we
  242. # update them using 'zip' and firefox will silently fail to load some
  243. # parts.
  244. [% IF c("var/windows") || c("var/linux") %]
  245. [% c("var/rezip", { rezip_file => 'Browser/omni.ja' }) %]
  246. [% c("var/rezip", { rezip_file => 'Browser/browser/omni.ja' }) %]
  247. [% ELSIF c("var/osx") %]
  248. [% c("var/rezip", { rezip_file => '"Tor Browser.app/Contents/Resources/omni.ja"' }) %]
  249. [% c("var/rezip", { rezip_file => '"Tor Browser.app/Contents/Resources/browser/omni.ja"' }) %]
  250. [% END %]
  251. [%
  252. IF c("var/osx");
  253. SET browserdir='"Tor Browser.app/Contents"';
  254. ELSE;
  255. SET browserdir='Browser';
  256. END;
  257. %]
  258. [% IF c("var/linux") %]
  259. [% IF c("var/linux-cross") %]
  260. clang++ --target=[% c("var/crosstarget") %] $rootdir/abicheck.cc -o Browser/abicheck
  261. [% ELSE %]
  262. /var/tmp/dist/gcc/bin/g++ $rootdir/abicheck.cc -o Browser/abicheck
  263. [% END %]
  264. [% END %]
  265. [% c('tar', {
  266. tar_src => [ browserdir ],
  267. tar_args => '-czf ' _ dest_dir _ '/' _ c('filename') _ '/tor-browser.tar.gz',
  268. }) %]
  269. [% IF c("var/linux-x86_64") %]
  270. [% c('tar', {
  271. tar_src => [ 'Debug' ],
  272. tar_args => '-cJf ' _ dest_dir _ '/' _ c('filename') _ '/tor-browser-debug.tar.xz',
  273. }) %]
  274. [% c('tar', {
  275. tar_src => [ 'geckodriver' ],
  276. tar_args => '-cJf ' _ dest_dir _ '/' _ c('filename') _ '/geckodriver-linux64.tar.xz',
  277. }) %]
  278. [% END %]
  279. [% c('zip', {
  280. zip_src => [ 'mar-tools' ],
  281. zip_args => dest_dir _ '/' _ c('filename') _ '/' _ c('var/martools_filename'),
  282. }) %]
  283. [% IF c("var/build_infos_json") -%]
  284. cat > "[% dest_dir _ '/' _ c('filename') _ '/build-infos.json' %]" << EOF_BUILDINFOS
  285. {
  286. "firefox_platform_version" : "[% c("var/firefox_platform_version") %]",
  287. "firefox_buildid" : "$MOZ_BUILD_DATE"
  288. }
  289. EOF_BUILDINFOS
  290. [% END -%]