final class sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer implements sun.security.ssl.SSLExtension$ExtensionConsumer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer
super_class: java.lang.Object
{
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 // sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer this
0: .line 443
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 445
return
end local 0 // sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/SignatureAlgorithmsExtension$CRSignatureSchemesConsumer;
public void consume(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage, java.nio.ByteBuffer);
descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;Ljava/nio/ByteBuffer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=12, args_size=4
start local 0 // sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
start local 3 // java.nio.ByteBuffer buffer
0: .line 450
aload 1 /* context */
checkcast sun.security.ssl.ClientHandshakeContext
astore 4 /* chc */
start local 4 // sun.security.ssl.ClientHandshakeContext chc
1: .line 456
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
2: .line 457
getstatic sun.security.ssl.SSLExtension.CR_SIGNATURE_ALGORITHMS:Lsun/security/ssl/SSLExtension;
3: .line 456
invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
4: .line 457
ifne 8
5: .line 458
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
6: .line 459
ldc "No available signature_algorithms extension for client certificate authentication"
7: .line 458
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
8: .line 466
StackMap locals: sun.security.ssl.ClientHandshakeContext
StackMap stack:
new sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec
dup
aload 3 /* buffer */
invokespecial sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec.<init>:(Ljava/nio/ByteBuffer;)V
astore 5 /* spec */
start local 5 // sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec spec
9: .line 467
goto 12
end local 5 // sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec spec
StackMap locals:
StackMap stack: java.io.IOException
10: astore 6 /* ioe */
start local 6 // java.io.IOException ioe
11: .line 468
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
aload 6 /* ioe */
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
end local 6 // java.io.IOException ioe
start local 5 // sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec spec
12: .line 471
StackMap locals: sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec
StackMap stack:
new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
astore 6 /* knownSignatureSchemes */
start local 6 // java.util.List knownSignatureSchemes
13: .line 472
aload 5 /* spec */
getfield sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec.signatureSchemes:[I
dup
astore 10
arraylength
istore 9
iconst_0
istore 8
goto 19
StackMap locals: sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage java.nio.ByteBuffer sun.security.ssl.ClientHandshakeContext sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec java.util.List top int int int[]
StackMap stack:
14: aload 10
iload 8
iaload
istore 7 /* id */
start local 7 // int id
15: .line 473
iload 7 /* id */
invokestatic sun.security.ssl.SignatureScheme.valueOf:(I)Lsun/security/ssl/SignatureScheme;
astore 11 /* ss */
start local 11 // sun.security.ssl.SignatureScheme ss
16: .line 474
aload 11 /* ss */
ifnull 18
17: .line 475
aload 6 /* knownSignatureSchemes */
aload 11 /* ss */
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 11 // sun.security.ssl.SignatureScheme ss
end local 7 // int id
18: .line 472
StackMap locals:
StackMap stack:
iinc 8 1
StackMap locals:
StackMap stack:
19: iload 8
iload 9
if_icmplt 14
20: .line 481
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.handshakeExtensions:Ljava/util/Map;
21: .line 482
getstatic sun.security.ssl.SSLExtension.CR_SIGNATURE_ALGORITHMS:Lsun/security/ssl/SSLExtension;
aload 5 /* spec */
22: .line 481
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
23: .line 485
return
end local 6 // java.util.List knownSignatureSchemes
end local 5 // sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec spec
end local 4 // sun.security.ssl.ClientHandshakeContext chc
end local 3 // java.nio.ByteBuffer buffer
end local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/SignatureAlgorithmsExtension$CRSignatureSchemesConsumer;
0 24 1 context Lsun/security/ssl/ConnectionContext;
0 24 2 message Lsun/security/ssl/SSLHandshake$HandshakeMessage;
0 24 3 buffer Ljava/nio/ByteBuffer;
1 24 4 chc Lsun/security/ssl/ClientHandshakeContext;
9 10 5 spec Lsun/security/ssl/SignatureAlgorithmsExtension$SignatureSchemesSpec;
12 24 5 spec Lsun/security/ssl/SignatureAlgorithmsExtension$SignatureSchemesSpec;
11 12 6 ioe Ljava/io/IOException;
13 24 6 knownSignatureSchemes Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;
15 18 7 id I
16 18 11 ss Lsun/security/ssl/SignatureScheme;
Exception table:
from to target type
8 9 10 Class java.io.IOException
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
buffer
}
SourceFile: "SignatureAlgorithmsExtension.java"
NestHost: sun.security.ssl.SignatureAlgorithmsExtension
InnerClasses:
abstract ExtensionConsumer = sun.security.ssl.SSLExtension$ExtensionConsumer of sun.security.ssl.SSLExtension
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
private final CRSignatureSchemesConsumer = sun.security.ssl.SignatureAlgorithmsExtension$CRSignatureSchemesConsumer of sun.security.ssl.SignatureAlgorithmsExtension
final SignatureSchemesSpec = sun.security.ssl.SignatureAlgorithmsExtension$SignatureSchemesSpec of sun.security.ssl.SignatureAlgorithmsExtension