aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsyeyoung <cyong06@naver.com>2021-03-01 22:42:39 +0900
committersyeyoung <cyong06@naver.com>2021-03-01 22:42:39 +0900
commit7c65ce860af23f227d6f5d34c7eb2627ceb2cc27 (patch)
tree7054221d0f5dd28f9652cc1421ee70e81e9601e2
parentc8f4ff4acbd9c723e87b519b8516558a5ca97a65 (diff)
downloadSkyblock-Dungeons-Guide-7c65ce860af23f227d6f5d34c7eb2627ceb2cc27.tar.gz
Skyblock-Dungeons-Guide-7c65ce860af23f227d6f5d34c7eb2627ceb2cc27.tar.bz2
Skyblock-Dungeons-Guide-7c65ce860af23f227d6f5d34c7eb2627ceb2cc27.zip
stompp!!
-rwxr-xr-xbuild.gradle5
-rw-r--r--src/main/java/kr/syeyoung/dungeonsguide/stomp/StompClient.java52
2 files changed, 53 insertions, 4 deletions
diff --git a/build.gradle b/build.gradle
index a07e1efb..a8fa436b 100755
--- a/build.gradle
+++ b/build.gradle
@@ -93,10 +93,7 @@ processResources
shadowJar {
dependencies {
- include(dependency('io.vertx:vertx-auth-common:4.0.2'))
- include(dependency('io.vertx:vertx-bridge-common:4.0.2'))
- include(dependency('io.vertx:vertx-core:4.0.2'))
- include(dependency('io.vertx:vertx-stomp:4.0.2'))
+ include(dependency("org.java-websocket:Java-WebSocket:1.5.1"))
}
}
diff --git a/src/main/java/kr/syeyoung/dungeonsguide/stomp/StompClient.java b/src/main/java/kr/syeyoung/dungeonsguide/stomp/StompClient.java
index 248bf04b..0c938f3c 100644
--- a/src/main/java/kr/syeyoung/dungeonsguide/stomp/StompClient.java
+++ b/src/main/java/kr/syeyoung/dungeonsguide/stomp/StompClient.java
@@ -7,15 +7,67 @@ import org.java_websocket.server.DefaultSSLWebSocketServerFactory;
import sun.security.ssl.SSLSocketFactoryImpl;
import javax.net.ssl.SSLContext;
+import javax.net.ssl.SSLSocketFactory;
+import javax.net.ssl.TrustManagerFactory;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
import java.net.URI;
+import java.security.KeyManagementException;
+import java.security.KeyStore;
+import java.security.KeyStoreException;
+import java.security.NoSuchAlgorithmException;
+import java.security.cert.CertificateException;
+import java.security.cert.CertificateFactory;
+import java.security.cert.X509Certificate;
import java.util.HashMap;
import java.util.Map;
public class StompClient extends WebSocketClient implements StompInterface {
+ private SSLSocketFactory getSocketfactory() throws NoSuchAlgorithmException, KeyManagementException, CertificateException, KeyStoreException, IOException {
+ X509Certificate a = (X509Certificate) CertificateFactory.getInstance("X.509")
+ .generateCertificate(new ByteArrayInputStream(("-----BEGIN CERTIFICATE-----\n" +
+ "MIIEZTCCA02gAwIBAgIQQAF1BIMUpMghjISpDBbN3zANBgkqhkiG9w0BAQsFADA/\n" +
+ "MSQwIgYDVQQKExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMT\n" +
+ "DkRTVCBSb290IENBIFgzMB4XDTIwMTAwNzE5MjE0MFoXDTIxMDkyOTE5MjE0MFow\n" +
+ "MjELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUxldCdzIEVuY3J5cHQxCzAJBgNVBAMT\n" +
+ "AlIzMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuwIVKMz2oJTTDxLs\n" +
+ "jVWSw/iC8ZmmekKIp10mqrUrucVMsa+Oa/l1yKPXD0eUFFU1V4yeqKI5GfWCPEKp\n" +
+ "Tm71O8Mu243AsFzzWTjn7c9p8FoLG77AlCQlh/o3cbMT5xys4Zvv2+Q7RVJFlqnB\n" +
+ "U840yFLuta7tj95gcOKlVKu2bQ6XpUA0ayvTvGbrZjR8+muLj1cpmfgwF126cm/7\n" +
+ "gcWt0oZYPRfH5wm78Sv3htzB2nFd1EbjzK0lwYi8YGd1ZrPxGPeiXOZT/zqItkel\n" +
+ "/xMY6pgJdz+dU/nPAeX1pnAXFK9jpP+Zs5Od3FOnBv5IhR2haa4ldbsTzFID9e1R\n" +
+ "oYvbFQIDAQABo4IBaDCCAWQwEgYDVR0TAQH/BAgwBgEB/wIBADAOBgNVHQ8BAf8E\n" +
+ "BAMCAYYwSwYIKwYBBQUHAQEEPzA9MDsGCCsGAQUFBzAChi9odHRwOi8vYXBwcy5p\n" +
+ "ZGVudHJ1c3QuY29tL3Jvb3RzL2RzdHJvb3RjYXgzLnA3YzAfBgNVHSMEGDAWgBTE\n" +
+ "p7Gkeyxx+tvhS5B1/8QVYIWJEDBUBgNVHSAETTBLMAgGBmeBDAECATA/BgsrBgEE\n" +
+ "AYLfEwEBATAwMC4GCCsGAQUFBwIBFiJodHRwOi8vY3BzLnJvb3QteDEubGV0c2Vu\n" +
+ "Y3J5cHQub3JnMDwGA1UdHwQ1MDMwMaAvoC2GK2h0dHA6Ly9jcmwuaWRlbnRydXN0\n" +
+ "LmNvbS9EU1RST09UQ0FYM0NSTC5jcmwwHQYDVR0OBBYEFBQusxe3WFbLrlAJQOYf\n" +
+ "r52LFMLGMB0GA1UdJQQWMBQGCCsGAQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0B\n" +
+ "AQsFAAOCAQEA2UzgyfWEiDcx27sT4rP8i2tiEmxYt0l+PAK3qB8oYevO4C5z70kH\n" +
+ "ejWEHx2taPDY/laBL21/WKZuNTYQHHPD5b1tXgHXbnL7KqC401dk5VvCadTQsvd8\n" +
+ "S8MXjohyc9z9/G2948kLjmE6Flh9dDYrVYA9x2O+hEPGOaEOa1eePynBgPayvUfL\n" +
+ "qjBstzLhWVQLGAkXXmNs+5ZnPBxzDJOLxhF2JIbeQAcH5H0tZrUlo5ZYyOqA7s9p\n" +
+ "O5b85o3AM/OJ+CktFBQtfvBhcJVd9wvlwPsk+uyOy2HI7mNxKKgsBTt375teA2Tw\n" +
+ "UdHkhVNcsAKX1H7GNNLOEADksd86wuoXvg==\n" +
+ "-----END CERTIFICATE-----").getBytes()));
+
+ KeyStore b = KeyStore.getInstance(KeyStore.getDefaultType());
+ b.load(null, null);
+ b.setCertificateEntry(Integer.toString(1), a);
+
+ TrustManagerFactory c = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
+ c.init(b);
+
+ SSLContext d = SSLContext.getInstance("TLSv1.2");
+ d.init(null, c.getTrustManagers(), null);
+ return d.getSocketFactory();
+ }
public StompClient(URI serverUri, final String token, CloseListener closeListener) throws Exception {
super(serverUri);
this.closeListener = closeListener;
addHeader("Authorization", token);
+ setSocketFactory(getSocketfactory());
connectBlocking();
while(this.stompClientStatus == StompClientStatus.CONNECTING);