|
|
- #! /usr/bin/env python3
-
- import rsa
- import json
- from binascii import hexlify
-
- # TODO path discovery
- versions_info = json.load(open('update/versions.json'))
- if 'signature' in versions_info:
- del versions_info['signature']
-
-
- print('Enter the PKCS1 private key, followed by a blank line:')
- privkey = ''
- while True:
- try:
- line = input()
- except EOFError:
- break
- if line == '':
- break
- privkey += line + '\n'
- privkey = bytes(privkey, 'ascii')
- privkey = rsa.PrivateKey.load_pkcs1(privkey)
-
- signature = hexlify(rsa.pkcs1.sign(json.dumps(versions_info, sort_keys=True).encode('utf-8'), privkey, 'SHA-256')).decode()
- print('signature: ' + signature)
-
- versions_info['signature'] = signature
- json.dump(versions_info, open('update/versions.json', 'w'), indent=4, sort_keys=True)
|