PGP public key decoding
Max Lapshin
max.lapshin@REDACTED
Sat Jul 10 01:43:21 CEST 2021
https://datatracker.ietf.org/doc/html/rfc4880
1. maybe it is not base64, but radix64 and it could be another thing?
2. is it really ASN?
On Fri, Jul 9, 2021 at 10:09 PM Serge <saleyn@REDACTED> wrote:
>
> Does anyone have an idea how to decode a PGP public key using public_key module?
>
> I am doing this:
>
> 1> {ok, B} = file:read_file(PGPPubKeyFile),
> 2> B1 = re:replace(B, <<"-----BEGIN PGP PUBLIC KEY BLOCK-----">>, <<"-----BEGIN RSA PUBLIC KEY-----">>, [{return, binary}]),
> 3> B2 = re:replace(B1, <<"-----END PGP PUBLIC KEY BLOCK-----">>, <<"-----END RSA PUBLIC KEY-----">>, [{return, binary}]),
> 4> B3 = re:replace(B2, <<"\n.+(\n-----END)">>, <<"\\1">>, [{return, binary}]), % Remove checksum
> 5> B4 = re:replace(B3, <<"\nVersion:.+\n\r?\n">>, <<"\n">>, [{return, binary}]), % Remove version
> 6> [Entry] = public_key:pem_decode(B4),
> 7> public_key:pem_entry_decode(Entry).
> ** exception error: no match of right hand side value {error,{asn1,{{wrong_tag,{{expected,16},
> {got,131097,{131097,<<"\r">>}}}},
> [{'OTP-PUB-KEY',match_tags,2,
> [{file,"OTP-PUB-KEY.erl"},{line,23999}]},
> {'OTP-PUB-KEY',dec_RSAPublicKey,2,
> [{file,"OTP-PUB-KEY.erl"},{line,2957}]},
> {'OTP-PUB-KEY',decode,2,
> [{file,"OTP-PUB-KEY.erl"},{line,1232}]},
> {public_key,der_decode,2,
> [{file,"public_key.erl"},{line,318}]},
> {erl_eval,do_apply,6,[{file,"erl_eval.erl"},{line,689}]},
> {shell,exprs,7,[{file,"shell.erl"},{line,686}]},
> {shell,eval_exprs,7,[{file,"shell.erl"},{line,642}]},
> {shell,eval_loop,3,[{file,"shell.erl"},{line,627}]}]}}}
> in function public_key:der_decode/2 (public_key.erl, line 322)
More information about the erlang-questions
mailing list