final class sun.security.ssl.DHKeyExchange$DHEPossessionGenerator implements sun.security.ssl.SSLPossessionGenerator
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.DHKeyExchange$DHEPossessionGenerator
  super_class: java.lang.Object
{
  private static final boolean useSmartEphemeralDHKeys;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final boolean useLegacyEphemeralDHKeys;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int customizedDHKeySize;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final boolean exportable;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=1, args_size=0
         0: .line 273
            ldc "jdk.tls.ephemeralDHKeySize"
         1: .line 272
            invokestatic sun.security.action.GetPropertyAction.privilegedGetProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* property */
        start local 0 // java.lang.String property
         2: .line 274
            aload 0 /* property */
            ifnull 3
            aload 0 /* property */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 7
         3: .line 275
      StackMap locals: java.lang.String
      StackMap stack:
            iconst_0
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useLegacyEphemeralDHKeys:Z
         4: .line 276
            iconst_0
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useSmartEphemeralDHKeys:Z
         5: .line 277
            iconst_m1
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
         6: .line 278
            goto 34
      StackMap locals:
      StackMap stack:
         7: ldc "matched"
            aload 0 /* property */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 12
         8: .line 279
            iconst_0
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useLegacyEphemeralDHKeys:Z
         9: .line 280
            iconst_1
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useSmartEphemeralDHKeys:Z
        10: .line 281
            iconst_m1
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
        11: .line 282
            goto 34
      StackMap locals:
      StackMap stack:
        12: ldc "legacy"
            aload 0 /* property */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 17
        13: .line 283
            iconst_1
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useLegacyEphemeralDHKeys:Z
        14: .line 284
            iconst_0
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useSmartEphemeralDHKeys:Z
        15: .line 285
            iconst_m1
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
        16: .line 286
            goto 34
        17: .line 287
      StackMap locals:
      StackMap stack:
            iconst_0
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useLegacyEphemeralDHKeys:Z
        18: .line 288
            iconst_0
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useSmartEphemeralDHKeys:Z
        19: .line 294
            aload 0 /* property */
            invokestatic java.lang.Integer.parseUnsignedInt:(Ljava/lang/String;)I
            putstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
        20: .line 295
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
            sipush 1024
            if_icmplt 23
        21: .line 296
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
            sipush 8192
            if_icmpgt 23
        22: .line 297
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
            bipush 63
            iand
            ifeq 34
        23: .line 298
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
        24: .line 299
            new java.lang.StringBuilder
            dup
            ldc "Unsupported customized DH key size: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        25: .line 300
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ". "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        26: .line 301
            ldc "The key size must be multiple of 64, "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        27: .line 302
            ldc "and range from 1024 to 8192 (inclusive)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        28: .line 299
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 298
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 304
      StackMap locals:
      StackMap stack: java.lang.NumberFormatException
            pop
        31: .line 305
            new java.lang.IllegalArgumentException
            dup
        32: .line 306
            ldc "Invalid system property jdk.tls.ephemeralDHKeySize"
        33: .line 305
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // java.lang.String property
        34: .line 309
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            2   34     0  property  Ljava/lang/String;
      Exception table:
        from    to  target  type
          19    30      30  Class java.lang.NumberFormatException

  private void <init>(boolean);
    descriptor: (Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.DHKeyExchange$DHEPossessionGenerator this
        start local 1 // boolean exportable
         0: .line 312
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 313
            aload 0 /* this */
            iload 1 /* exportable */
            putfield sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.exportable:Z
         2: .line 314
            return
        end local 1 // boolean exportable
        end local 0 // sun.security.ssl.DHKeyExchange$DHEPossessionGenerator this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lsun/security/ssl/DHKeyExchange$DHEPossessionGenerator;
            0    3     1  exportable  Z
    MethodParameters:
            Name  Flags
      exportable  

  public sun.security.ssl.SSLPossession createPossession(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLPossession;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=2
        start local 0 // sun.security.ssl.DHKeyExchange$DHEPossessionGenerator this
        start local 1 // sun.security.ssl.HandshakeContext context
         0: .line 320
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useLegacyEphemeralDHKeys:Z
            ifne 14
         1: .line 321
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.clientRequestedNamedGroups:Ljava/util/List;
            ifnull 14
         2: .line 322
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.clientRequestedNamedGroups:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifne 14
         3: .line 325
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
         4: .line 326
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         5: .line 327
            iconst_1
            anewarray sun.security.ssl.NamedGroup$NamedGroupType
            dup
            iconst_0
         6: .line 328
            getstatic sun.security.ssl.NamedGroup$NamedGroupType.NAMED_GROUP_FFDHE:Lsun/security/ssl/NamedGroup$NamedGroupType;
            aastore
         7: .line 329
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.clientRequestedNamedGroups:Ljava/util/List;
         8: .line 324
            invokestatic sun.security.ssl.SupportedGroupsExtension$SupportedGroups.getPreferredGroup:(Lsun/security/ssl/ProtocolVersion;Ljava/security/AlgorithmConstraints;[Lsun/security/ssl/NamedGroup$NamedGroupType;Ljava/util/List;)Lsun/security/ssl/NamedGroup;
         9: .line 323
            astore 2 /* preferableNamedGroup */
        start local 2 // sun.security.ssl.NamedGroup preferableNamedGroup
        10: .line 330
            aload 2 /* preferableNamedGroup */
            ifnull 14
        11: .line 331
            new sun.security.ssl.DHKeyExchange$DHEPossession
            dup
            aload 2 /* preferableNamedGroup */
        12: .line 332
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
        13: .line 331
            invokespecial sun.security.ssl.DHKeyExchange$DHEPossession.<init>:(Lsun/security/ssl/NamedGroup;Ljava/security/SecureRandom;)V
            areturn
        end local 2 // sun.security.ssl.NamedGroup preferableNamedGroup
        14: .line 375
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.exportable:Z
            ifeq 15
            sipush 512
            goto 16
      StackMap locals:
      StackMap stack:
        15: sipush 1024
      StackMap locals:
      StackMap stack: int
        16: istore 3 /* keySize */
        start local 3 // int keySize
        17: .line 376
            aload 0 /* this */
            getfield sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.exportable:Z
            ifne 35
        18: .line 377
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useLegacyEphemeralDHKeys:Z
            ifeq 21
        19: .line 378
            sipush 768
            istore 3 /* keySize */
        20: .line 379
            goto 35
      StackMap locals: sun.security.ssl.DHKeyExchange$DHEPossessionGenerator sun.security.ssl.HandshakeContext top int
      StackMap stack:
        21: getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.useSmartEphemeralDHKeys:Z
            ifeq 33
        22: .line 380
            aconst_null
            astore 4 /* key */
        start local 4 // java.security.PrivateKey key
        23: .line 382
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
        24: .line 381
            astore 5 /* shc */
        start local 5 // sun.security.ssl.ServerHandshakeContext shc
        25: .line 383
            aload 5 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.interimAuthn:Lsun/security/ssl/SSLPossession;
            instanceof sun.security.ssl.X509Authentication$X509Possession
            ifeq 27
        26: .line 384
            aload 5 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.interimAuthn:Lsun/security/ssl/SSLPossession;
            checkcast sun.security.ssl.X509Authentication$X509Possession
            getfield sun.security.ssl.X509Authentication$X509Possession.popPrivateKey:Ljava/security/PrivateKey;
            astore 4 /* key */
        27: .line 387
      StackMap locals: java.security.PrivateKey sun.security.ssl.ServerHandshakeContext
      StackMap stack:
            aload 4 /* key */
            ifnull 35
        28: .line 388
            aload 4 /* key */
            invokestatic sun.security.util.KeyUtil.getKeySize:(Ljava/security/Key;)I
            istore 6 /* ks */
        start local 6 // int ks
        29: .line 400
            iload 6 /* ks */
            sipush 1024
            if_icmpgt 30
            sipush 1024
            goto 31
      StackMap locals: int
      StackMap stack:
        30: sipush 2048
      StackMap locals:
      StackMap stack: int
        31: istore 3 /* keySize */
        end local 6 // int ks
        end local 5 // sun.security.ssl.ServerHandshakeContext shc
        end local 4 // java.security.PrivateKey key
        32: .line 402
            goto 35
      StackMap locals:
      StackMap stack:
        33: getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
            ifle 35
        34: .line 403
            getstatic sun.security.ssl.DHKeyExchange$DHEPossessionGenerator.customizedDHKeySize:I
            istore 3 /* keySize */
        35: .line 407
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.DHKeyExchange$DHEPossession
            dup
        36: .line 408
            iload 3 /* keySize */
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
        37: .line 407
            invokespecial sun.security.ssl.DHKeyExchange$DHEPossession.<init>:(ILjava/security/SecureRandom;)V
            areturn
        end local 3 // int keySize
        end local 1 // sun.security.ssl.HandshakeContext context
        end local 0 // sun.security.ssl.DHKeyExchange$DHEPossessionGenerator this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   38     0                  this  Lsun/security/ssl/DHKeyExchange$DHEPossessionGenerator;
            0   38     1               context  Lsun/security/ssl/HandshakeContext;
           10   14     2  preferableNamedGroup  Lsun/security/ssl/NamedGroup;
           17   38     3               keySize  I
           23   32     4                   key  Ljava/security/PrivateKey;
           25   32     5                   shc  Lsun/security/ssl/ServerHandshakeContext;
           29   32     6                    ks  I
    MethodParameters:
         Name  Flags
      context  
}
SourceFile: "DHKeyExchange.java"
NestHost: sun.security.ssl.DHKeyExchange
InnerClasses:
  final DHEPossession = sun.security.ssl.DHKeyExchange$DHEPossession of sun.security.ssl.DHKeyExchange
  private final DHEPossessionGenerator = sun.security.ssl.DHKeyExchange$DHEPossessionGenerator of sun.security.ssl.DHKeyExchange
  final NamedGroupType = sun.security.ssl.NamedGroup$NamedGroupType of sun.security.ssl.NamedGroup
  SupportedGroups = sun.security.ssl.SupportedGroupsExtension$SupportedGroups of sun.security.ssl.SupportedGroupsExtension
  final X509Possession = sun.security.ssl.X509Authentication$X509Possession of sun.security.ssl.X509Authentication