Skip to content

An easy-to-use asynchronous secure with SSL cross-platform network library

License

Notifications You must be signed in to change notification settings

OughtToPrevail/AsyncSSLNetwork

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

AsyncSSLNetwork

AsyncSSLNetwork short for Asynchronous Secure Socket Layer Network is a library which implements the AsyncNetwork library with the additional feature of SSL sockets.

Features

  • Cross platform
  • Asynchronous
  • Uses Java's SSLEngine
  • Easy-to-use

Maven

<dependency>
  <groupId>com.github.oughttoprevail</groupId>
  <artifactId>AsyncSSLNetwork</artifactId>
  <version>1.2.3</version>
</dependency>

How to use

To create a client you would:

SSLClientSocket socket = new SSLClientSocket(SSLContextFactory.createContext("Client.jks", "Client Password".toCharArray()));
socket.connect(new InetSocketAddress("localhost", 6000));
socket.onConnect(() ->
{
	System.out.println("Established connection");
	socket.getSSLEngine().setEnabledCipherSuites(socket.getSSLEngine().getSupportedCipherSuites());
	socket.onHandshakeComplete(() ->
	{
		System.out.println("Handshake successful");
		WritablePacketBuilder.create().putString("Hello? are you there?").build().writeAndClose(socket);
		ReadablePacketBuilder.create().aString().build().read(socket, readResult -> System.out.println((String) readResult.poll()));
		socket.onDisconnect(disconnectionType -> System.out.println("Disconnected: " + disconnectionType));
	});
	socket.beginHandshake();
});

Note: you don't have to use SSLContextFactory, if you have your own SSLContext, you can use it

SSLServerSocket serverSocket = new SSLServerSocket(SSLContextFactory.createContext("Server.jks", "Hello World!".toCharArray()));
serverSocket.onSSLConnection(socket ->
{
	System.out.println("Established connection");
	socket.onException(Throwable::printStackTrace);
	SSLEngine sslEngine = socket.getSSLEngine();
	sslEngine.setEnabledCipherSuites(new String[]{"TLS_ECDH_anon_WITH_AES_256_CBC_SHA"});
	socket.onHandshakeComplete(() ->
	{
		System.out.println("Handshake successful");
		ReadablePacketBuilder.create().aString().build().read(socket, readResult -> System.out.println((String) readResult.poll()));
		WritablePacketBuilder.create().putString("Hello there! How are you today?").build().writeAndClose(socket);
		socket.onDisconnect(disconnectionType -> System.out.println("Disconnected: " + disconnectionType));
	});
	socket.beginHandshake();
});
serverSocket.bindLocalHost(6000);
while(true);

Note: I am using "anon" in my cipher suite because I am not using a certificate in my TrustManager, you should not be using it, also, SSLContextFactory is not a class in the project, it's only in test\java directory, to create a simple SSLContext, it should only be used for testing, for actual production you should use an SSLContext with certificates, proper keystores and truststores and with your own attributes.

And you're finished! Now you can use AsyncSSLNetwork to protect your networks.

About

An easy-to-use asynchronous secure with SSL cross-platform network library

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages