mirror of
https://github.com/f-droid/fdroidserver.git
synced 2025-09-13 22:42:29 +03:00
add some example plugins for repo key extraction and migration
This commit is contained in:
parent
d16ccc6d6c
commit
c8f21bf0e0
5 changed files with 177 additions and 0 deletions
41
examples/fdroid_nitrokeyimport.py
Normal file
41
examples/fdroid_nitrokeyimport.py
Normal file
|
@ -0,0 +1,41 @@
|
|||
#!/usr/bin/env python3
|
||||
|
||||
from argparse import ArgumentParser
|
||||
from fdroidserver import common
|
||||
from fdroidserver.common import FDroidPopen
|
||||
from fdroidserver.exception import BuildException
|
||||
|
||||
fdroid_summary = 'import the local keystore into a SmartCard HSM'
|
||||
|
||||
|
||||
def main():
|
||||
parser = ArgumentParser()
|
||||
common.setup_global_opts(parser)
|
||||
options = parser.parse_args()
|
||||
config = common.read_config(options)
|
||||
env_vars = {
|
||||
'LC_ALL': 'C.UTF-8',
|
||||
'FDROID_KEY_STORE_PASS': config['keystorepass'],
|
||||
'FDROID_KEY_PASS': config['keypass'],
|
||||
'SMARTCARD_PIN': str(config['smartcard_pin']),
|
||||
}
|
||||
p = FDroidPopen([config['keytool'], '-importkeystore',
|
||||
'-srcalias', config['repo_keyalias'],
|
||||
'-srckeystore', config['keystore'],
|
||||
'-srcstorepass:env', 'FDROID_KEY_STORE_PASS',
|
||||
'-srckeypass:env', 'FDROID_KEY_PASS',
|
||||
'-destalias', config['repo_keyalias'],
|
||||
'-destkeystore', 'NONE',
|
||||
'-deststoretype', 'PKCS11',
|
||||
'-providerName', 'SunPKCS11-OpenSC',
|
||||
'-providerClass', 'sun.security.pkcs11.SunPKCS11',
|
||||
'-providerArg', 'opensc-fdroid.cfg',
|
||||
'-deststorepass:env', 'SMARTCARD_PIN',
|
||||
'-J-Djava.security.debug=sunpkcs11'],
|
||||
envs=env_vars)
|
||||
if p.returncode != 0:
|
||||
raise BuildException("Failed to import into HSM!", p.output)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
Loading…
Add table
Add a link
Reference in a new issue