2020-04-02 21:29:16 +02:00
|
|
|
from io import BytesIO
|
|
|
|
|
2020-03-08 12:51:33 +01:00
|
|
|
import gnupg
|
|
|
|
|
|
|
|
from app.config import GNUPGHOME
|
|
|
|
|
|
|
|
gpg = gnupg.GPG(gnupghome=GNUPGHOME)
|
2020-03-13 12:54:52 +01:00
|
|
|
gpg.encoding = "utf-8"
|
2020-03-08 12:51:33 +01:00
|
|
|
|
2020-03-08 23:07:23 +01:00
|
|
|
|
2020-03-08 12:51:33 +01:00
|
|
|
class PGPException(Exception):
|
|
|
|
pass
|
|
|
|
|
2020-03-08 23:07:23 +01:00
|
|
|
|
2020-03-08 12:51:33 +01:00
|
|
|
def load_public_key(public_key: str) -> str:
|
|
|
|
"""Load a public key into keyring and return the fingerprint. If error, raise Exception"""
|
|
|
|
import_result = gpg.import_keys(public_key)
|
|
|
|
try:
|
|
|
|
return import_result.fingerprints[0]
|
|
|
|
except Exception as e:
|
|
|
|
raise PGPException("Cannot load key") from e
|
|
|
|
|
|
|
|
|
2020-04-02 21:29:16 +02:00
|
|
|
def encrypt_file(data: BytesIO, fingerprint: str) -> str:
|
|
|
|
r = gpg.encrypt_file(data, fingerprint, always_trust=True)
|
2020-03-08 12:51:33 +01:00
|
|
|
if not r.ok:
|
|
|
|
raise PGPException("Cannot encrypt")
|
|
|
|
|
|
|
|
return str(r)
|