Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/test/javax/net/ssl/TLSCommon/CipherSuite.java
38853 views
/*1* Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* SSL/TLS cipher suites.25*/26public enum CipherSuite {2728TLS_DHE_RSA_WITH_CHACHA20_POLY1305_SHA256(290xCCAA, KeyExAlgorithm.DHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),30TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256(310xCCA9, KeyExAlgorithm.ECDHE_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),32TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256(330xCCA8, KeyExAlgorithm.ECDHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),34TLS_ECDH_RSA_WITH_AES_256_GCM_SHA384(350xC032, KeyExAlgorithm.ECDH_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),36TLS_ECDH_RSA_WITH_AES_128_GCM_SHA256(370xC031, KeyExAlgorithm.ECDH_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),38TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384(390xC030, KeyExAlgorithm.ECDHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),40TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256(410xC02F, KeyExAlgorithm.ECDHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),42TLS_ECDH_ECDSA_WITH_AES_256_GCM_SHA384(430xC02E, KeyExAlgorithm.ECDH_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),44TLS_ECDH_ECDSA_WITH_AES_128_GCM_SHA256(450xC02D, KeyExAlgorithm.ECDH_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),46TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384(470xC02C, KeyExAlgorithm.ECDHE_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),48TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256(490xC02B, KeyExAlgorithm.ECDHE_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),50TLS_ECDH_RSA_WITH_AES_256_CBC_SHA384(510xC02A, KeyExAlgorithm.ECDH_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),52TLS_ECDH_RSA_WITH_AES_128_CBC_SHA256(530xC029, KeyExAlgorithm.ECDH_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),54TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384(550xC028, KeyExAlgorithm.ECDHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),56TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256(570xC027, KeyExAlgorithm.ECDHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),58TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA384(590xC026, KeyExAlgorithm.ECDH_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),60TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA(610xC025, KeyExAlgorithm.ECDH_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),62TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA256(630xC025, KeyExAlgorithm.ECDH_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),64TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384(650xC024, KeyExAlgorithm.ECDHE_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),66TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256(670xC023, KeyExAlgorithm.ECDHE_ECDSA, Protocol.TLSV1_2, Protocol.TLSV1_2),68TLS_ECDH_anon_WITH_AES_256_CBC_SHA(690xC019, KeyExAlgorithm.ECDH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),70TLS_ECDH_anon_WITH_AES_128_CBC_SHA(710xC018, KeyExAlgorithm.ECDH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),72TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA(730xC017, KeyExAlgorithm.ECDH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),74TLS_ECDH_anon_WITH_RC4_128_SHA(750xC016, KeyExAlgorithm.ECDH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),76TLS_ECDH_anon_WITH_NULL_SHA(770xC015, KeyExAlgorithm.ECDH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),78TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA(790xC014, KeyExAlgorithm.ECDHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),80TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA(810xC013, KeyExAlgorithm.ECDHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),82TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA(830xC012, KeyExAlgorithm.ECDHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),84TLS_ECDHE_RSA_WITH_RC4_128_SHA(850xC011, KeyExAlgorithm.ECDHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),86TLS_ECDHE_RSA_WITH_NULL_SHA(870xC010, KeyExAlgorithm.ECDHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),88TLS_ECDH_RSA_WITH_AES_256_CBC_SHA(890xC00F, KeyExAlgorithm.ECDH_RSA, Protocol.SSLV3, Protocol.TLSV1_2),90TLS_ECDH_RSA_WITH_AES_128_CBC_SHA(910xC00E, KeyExAlgorithm.ECDH_RSA, Protocol.SSLV3, Protocol.TLSV1_2),92TLS_ECDH_RSA_WITH_3DES_EDE_CBC_SHA(930xC00D, KeyExAlgorithm.ECDH_RSA, Protocol.SSLV3, Protocol.TLSV1_2),94TLS_ECDH_RSA_WITH_RC4_128_SHA(950xC00C, KeyExAlgorithm.ECDH_RSA, Protocol.SSLV3, Protocol.TLSV1_2),96TLS_ECDH_RSA_WITH_NULL_SHA(970xC00B, KeyExAlgorithm.ECDH_RSA, Protocol.SSLV3, Protocol.TLSV1_2),98TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA(990xC00A, KeyExAlgorithm.ECDHE_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),100TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA(1010xC009, KeyExAlgorithm.ECDHE_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),102TLS_ECDHE_ECDSA_WITH_3DES_EDE_CBC_SHA(1030xC008, KeyExAlgorithm.ECDHE_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),104TLS_ECDHE_ECDSA_WITH_RC4_128_SHA(1050xC007, KeyExAlgorithm.ECDHE_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),106TLS_ECDHE_ECDSA_WITH_NULL_SHA(1070xC006, KeyExAlgorithm.ECDHE_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),108TLS_ECDH_ECDSA_WITH_3DES_EDE_CBC_SHA(1090xC003, KeyExAlgorithm.ECDH_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),110TLS_ECDH_ECDSA_WITH_RC4_128_SHA(1110xC002, KeyExAlgorithm.ECDH_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),112TLS_ECDH_ECDSA_WITH_NULL_SHA(1130xC001, KeyExAlgorithm.ECDH_ECDSA, Protocol.SSLV3, Protocol.TLSV1_2),114TLS_EMPTY_RENEGOTIATION_INFO_SCSV(1150x00FF, KeyExAlgorithm.SCSV, Protocol.SSLV3, Protocol.TLSV1_2),116TLS_AES_256_GCM_SHA384(1170x1302, null, Protocol.TLSV1_3, Protocol.TLSV1_3),118TLS_AES_128_GCM_SHA256(1190x1301, null, Protocol.TLSV1_3, Protocol.TLSV1_3),120TLS_DH_anon_WITH_AES_256_GCM_SHA384(1210x00A7, KeyExAlgorithm.DH_ANON, Protocol.TLSV1_2, Protocol.TLSV1_2),122TLS_DH_anon_WITH_AES_128_GCM_SHA256(1230x00A6, KeyExAlgorithm.DH_ANON, Protocol.TLSV1_2, Protocol.TLSV1_2),124TLS_DHE_DSS_WITH_AES_256_GCM_SHA384(1250x00A3, KeyExAlgorithm.DHE_DSS, Protocol.TLSV1_2, Protocol.TLSV1_2),126TLS_DHE_DSS_WITH_AES_128_GCM_SHA256(1270x00A2, KeyExAlgorithm.DHE_DSS, Protocol.TLSV1_2, Protocol.TLSV1_2),128TLS_DHE_RSA_WITH_AES_256_GCM_SHA384(1290x009F, KeyExAlgorithm.DHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),130TLS_DHE_RSA_WITH_AES_128_GCM_SHA256(1310x009E, KeyExAlgorithm.DHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),132TLS_RSA_WITH_AES_256_GCM_SHA384(1330x009D, KeyExAlgorithm.RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),134TLS_RSA_WITH_AES_128_GCM_SHA256(1350x009C, KeyExAlgorithm.RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),136TLS_DH_anon_WITH_AES_256_CBC_SHA256(1370x006D, KeyExAlgorithm.DH_ANON, Protocol.TLSV1_2, Protocol.TLSV1_2),138TLS_DH_anon_WITH_AES_128_CBC_SHA256(1390x006C, KeyExAlgorithm.DH_ANON, Protocol.TLSV1_2, Protocol.TLSV1_2),140TLS_DHE_RSA_WITH_AES_256_CBC_SHA256(1410x006B, KeyExAlgorithm.DHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),142TLS_DHE_DSS_WITH_AES_256_CBC_SHA256(1430x006A, KeyExAlgorithm.DHE_DSS, Protocol.TLSV1_2, Protocol.TLSV1_2),144TLS_DHE_RSA_WITH_AES_128_CBC_SHA256(1450x0067, KeyExAlgorithm.DHE_RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),146TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA(1470x004C, KeyExAlgorithm.ECDH_ECDSA, Protocol.TLSV1, Protocol.TLSV1_2),148TLS_DHE_DSS_WITH_AES_128_CBC_SHA256(1490x0040, KeyExAlgorithm.DHE_DSS, Protocol.TLSV1_2, Protocol.TLSV1_2),150TLS_RSA_WITH_AES_256_CBC_SHA256(1510x003D, KeyExAlgorithm.RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),152TLS_RSA_WITH_AES_128_CBC_SHA256(1530x003C, KeyExAlgorithm.RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),154TLS_RSA_WITH_NULL_SHA256(1550x003B, KeyExAlgorithm.RSA, Protocol.TLSV1_2, Protocol.TLSV1_2),156TLS_DH_anon_WITH_AES_256_CBC_SHA(1570x003A, KeyExAlgorithm.DH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),158TLS_DHE_RSA_WITH_AES_256_CBC_SHA(1590x0039, KeyExAlgorithm.DHE_RSA, Protocol.TLSV1, Protocol.TLSV1_2),160TLS_DHE_DSS_WITH_AES_256_CBC_SHA(1610x0038, KeyExAlgorithm.DHE_DSS, Protocol.TLSV1_2, Protocol.TLSV1_2),162TLS_RSA_WITH_AES_256_CBC_SHA(1630x0035, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2),164TLS_DH_anon_WITH_AES_128_CBC_SHA(1650x0034, KeyExAlgorithm.DH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),166TLS_DHE_RSA_WITH_AES_128_CBC_SHA(1670x0033, KeyExAlgorithm.DHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),168TLS_DHE_DSS_WITH_AES_128_CBC_SHA(1690x0032, KeyExAlgorithm.DHE_DSS, Protocol.TLSV1_2, Protocol.TLSV1_2),170TLS_RSA_WITH_AES_128_CBC_SHA(1710x002F, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2),172TLS_KRB5_WITH_3DES_EDE_CBC_MD5(1730x0023, KeyExAlgorithm.KRB5, Protocol.SSLV3, Protocol.TLSV1_2),174TLS_KRB5_WITH_DES_CBC_MD5(1750x0022,KeyExAlgorithm.KRB5, Protocol.SSLV3, Protocol.TLSV1_1),176TLS_KRB5_WITH_3DES_EDE_CBC_SHA(1770x001F, KeyExAlgorithm.KRB5, Protocol.SSLV3, Protocol.TLSV1_2),178TLS_KRB5_WITH_DES_CBC_SHA(1790x001E, KeyExAlgorithm.KRB5, Protocol.SSLV3, Protocol.TLSV1_2),180SSL_DH_anon_WITH_3DES_EDE_CBC_SHA(1810x001B, KeyExAlgorithm.DH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),182SSL_DH_anon_WITH_DES_CBC_SHA(1830x001A, KeyExAlgorithm.DH_ANON, Protocol.SSLV3, Protocol.TLSV1_1),184SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA(1850x0019, KeyExAlgorithm.DH_ANON_EXPORT, Protocol.SSLV3, Protocol.TLSV1),186SSL_DH_anon_WITH_RC4_128_MD5(1870x0018, KeyExAlgorithm.DH_ANON, Protocol.SSLV3, Protocol.TLSV1_2),188SSL_DH_anon_EXPORT_WITH_RC4_40_MD5(1890x0017, KeyExAlgorithm.DH_ANON_EXPORT, Protocol.SSLV3, Protocol.TLSV1),190SSL_DHE_RSA_WITH_3DES_EDE_CBC_SHA(1910x0016, KeyExAlgorithm.DHE_RSA, Protocol.SSLV3, Protocol.TLSV1_2),192SSL_DHE_RSA_WITH_DES_CBC_SHA(1930x0015, KeyExAlgorithm.DHE_RSA, Protocol.SSLV3, Protocol.TLSV1_1),194SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA(1950x0014, KeyExAlgorithm.DHE_RSA_EXPORT, Protocol.SSLV3, Protocol.TLSV1),196SSL_DHE_DSS_WITH_3DES_EDE_CBC_SHA(1970x0013, KeyExAlgorithm.DHE_DSS, Protocol.SSLV3, Protocol.TLSV1_2),198SSL_DHE_DSS_WITH_DES_CBC_SHA(1990x0012, KeyExAlgorithm.DHE_DSS, Protocol.SSLV3, Protocol.TLSV1_1),200SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA(2010x0011, KeyExAlgorithm.DHE_DSS_EXPORT, Protocol.SSLV3, Protocol.TLSV1),202SSL_RSA_WITH_3DES_EDE_CBC_SHA(2030x000A, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2),204SSL_RSA_WITH_DES_CBC_SHA(2050x0009, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_1),206SSL_RSA_EXPORT_WITH_DES40_CBC_SHA(2070x0008, KeyExAlgorithm.RSA_EXPORT, Protocol.SSLV3, Protocol.TLSV1),208SSL_RSA_WITH_RC4_128_SHA(2090x0005, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2),210SSL_RSA_WITH_RC4_128_MD5(2110x0004, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2),212SSL_RSA_EXPORT_WITH_RC4_40_MD5(2130x0003, KeyExAlgorithm.RSA_EXPORT, Protocol.SSLV3, Protocol.TLSV1),214SSL_RSA_WITH_NULL_SHA(2150x0002, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2),216SSL_RSA_WITH_NULL_MD5(2170x0001, KeyExAlgorithm.RSA, Protocol.SSLV3, Protocol.TLSV1_2);218219public final int id;220public final KeyExAlgorithm keyExAlgorithm;221public final Protocol startProtocol;222public final Protocol endProtocol;223224private CipherSuite(225int id,226KeyExAlgorithm keyExAlgorithm,227Protocol startProtocol,228Protocol endProtocol) {229this.id = id;230this.keyExAlgorithm = keyExAlgorithm;231this.startProtocol = startProtocol;232this.endProtocol = endProtocol;233}234235public boolean supportedByProtocol(Protocol protocol) {236return startProtocol.id <= protocol.id237&& protocol.id <= endProtocol.id;238}239240public static CipherSuite cipherSuite(String name) {241return CipherSuite.valueOf(CipherSuite.class, name);242}243}244245246