3 # Copyright 2013 The Chromium Authors. All rights reserved.
4 # Use of this source code is governed by a BSD-style license that can be
5 # found in the LICENSE file.
6 """Signs and zipaligns APK.
15 from util
import build_utils
17 def RenameInflateAndAddPageAlignment(
18 rezip_apk_jar_path
, in_zip_file
, out_zip_file
):
28 build_utils
.CheckOutput(rezip_apk_cmd
)
31 def ReorderAndAlignApk(rezip_apk_jar_path
, in_zip_file
, out_zip_file
):
41 build_utils
.CheckOutput(rezip_apk_cmd
)
44 def JarSigner(key_path
, key_name
, key_passwd
, unsigned_path
, signed_path
):
45 shutil
.copy(unsigned_path
, signed_path
)
48 '-sigalg', 'MD5withRSA',
50 '-keystore', key_path
,
51 '-storepass', key_passwd
,
55 build_utils
.CheckOutput(sign_cmd
)
58 def AlignApk(zipalign_path
, unaligned_path
, final_path
):
65 build_utils
.CheckOutput(align_cmd
)
69 parser
= optparse
.OptionParser()
70 build_utils
.AddDepfileOption(parser
)
72 parser
.add_option('--rezip-apk-jar-path',
73 help='Path to the RezipApk jar file.')
74 parser
.add_option('--zipalign-path', help='Path to the zipalign tool.')
75 parser
.add_option('--unsigned-apk-path', help='Path to input unsigned APK.')
76 parser
.add_option('--final-apk-path',
77 help='Path to output signed and aligned APK.')
78 parser
.add_option('--key-path', help='Path to keystore for signing.')
79 parser
.add_option('--key-passwd', help='Keystore password')
80 parser
.add_option('--key-name', help='Keystore name')
81 parser
.add_option('--stamp', help='Path to touch on success.')
82 parser
.add_option('--load-library-from-zip-file', type='int',
83 help='If non-zero, build the APK such that the library can be loaded ' +
84 'directly from the zip file using the crazy linker. The library ' +
85 'will be renamed, uncompressed and page aligned.')
87 options
, _
= parser
.parse_args()
89 with tempfile
.NamedTemporaryFile() as signed_apk_path_tmp
, \
90 tempfile
.NamedTemporaryFile() as apk_to_sign_tmp
:
92 if options
.load_library_from_zip_file
:
93 # We alter the name of the library so that the Android Package Manager
94 # does not extract it into a separate file. This must be done before
95 # signing, as the filename is part of the signed manifest. At the same
96 # time we uncompress the library, which is necessary so that it can be
97 # loaded directly from the APK.
98 # Move the library to a page boundary by adding a page alignment file.
99 apk_to_sign
= apk_to_sign_tmp
.name
100 RenameInflateAndAddPageAlignment(
101 options
.rezip_apk_jar_path
, options
.unsigned_apk_path
, apk_to_sign
)
103 apk_to_sign
= options
.unsigned_apk_path
105 signed_apk_path
= signed_apk_path_tmp
.name
106 JarSigner(options
.key_path
, options
.key_name
, options
.key_passwd
,
107 apk_to_sign
, signed_apk_path
)
109 if options
.load_library_from_zip_file
:
110 # Reorder the contents of the APK. This re-establishes the canonical
111 # order which means the library will be back at its page aligned location.
112 # This step also aligns uncompressed items to 4 bytes.
114 options
.rezip_apk_jar_path
, signed_apk_path
, options
.final_apk_path
)
116 # Align uncompressed items to 4 bytes
117 AlignApk(options
.zipalign_path
, signed_apk_path
, options
.final_apk_path
)
120 build_utils
.WriteDepfile(
121 options
.depfile
, build_utils
.GetPythonDependencies())
124 build_utils
.Touch(options
.stamp
)
127 if __name__
== '__main__':