1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.handler.codec.quic;
17
18
19
20
21 final class BoringSSLCertificateCallbackTask extends BoringSSLTask {
22 private final byte[] keyTypeBytes;
23 private final byte[][] asn1DerEncodedPrincipals;
24 private final String[] authMethods;
25 private final BoringSSLCertificateCallback callback;
26
27
28 private long key;
29 private long chain;
30
31 BoringSSLCertificateCallbackTask(long ssl, byte[] keyTypeBytes, byte[][] asn1DerEncodedPrincipals,
32 String[] authMethods, BoringSSLCertificateCallback callback) {
33
34 super(ssl);
35
36 this.keyTypeBytes = keyTypeBytes;
37 this.asn1DerEncodedPrincipals = asn1DerEncodedPrincipals;
38 this.authMethods = authMethods;
39 this.callback = callback;
40 }
41
42
43 @Override
44 protected void runTask(long ssl, TaskCallback taskCallback) {
45 try {
46 long[] result = callback.handle(ssl, keyTypeBytes, asn1DerEncodedPrincipals, authMethods);
47 if (result == null) {
48 taskCallback.onResult(ssl, 0);
49 } else {
50 this.key = result[0];
51 this.chain = result[1];
52 taskCallback.onResult(ssl, 1);
53 }
54 } catch (Exception e) {
55
56
57
58 taskCallback.onResult(ssl, 0);
59 }
60 }
61
62 @Override
63 protected void destroy() {
64 if (key != 0) {
65 BoringSSL.EVP_PKEY_free(key);
66 key = 0;
67 }
68 if (chain != 0) {
69 BoringSSL.CRYPTO_BUFFER_stack_free(chain);
70 chain = 0;
71 }
72 }
73 }