Skip to content

Commit

Permalink
Merge pull request quarkusio#28077 from cescoffier/netty-4.1.82
Browse files Browse the repository at this point in the history
Update to Netty 4.1.82 and Brotli4J 1.8.0
  • Loading branch information
cescoffier authored Sep 21, 2022
2 parents 8de3274 + b7954d1 commit 84f953c
Show file tree
Hide file tree
Showing 2 changed files with 78 additions and 2 deletions.
4 changes: 2 additions & 2 deletions bom/application/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -133,8 +133,8 @@
<infinispan.version>13.0.10.Final</infinispan.version>
<infinispan.protostream.version>4.4.3.Final</infinispan.protostream.version>
<caffeine.version>2.9.3</caffeine.version>
<netty.version>4.1.79.Final</netty.version>
<brotli4j.version>1.7.1</brotli4j.version>
<netty.version>4.1.82.Final</netty.version>
<brotli4j.version>1.8.0</brotli4j.version>
<reactive-streams.version>1.0.3</reactive-streams.version>
<jboss-logging.version>3.5.0.Final</jboss-logging.version>
<mutiny.version>1.7.0</mutiny.version>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,26 @@
import static io.netty.handler.codec.http.HttpHeaderValues.X_DEFLATE;
import static io.netty.handler.codec.http.HttpHeaderValues.X_GZIP;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.nio.ByteBuffer;
import java.security.InvalidAlgorithmParameterException;
import java.security.KeyException;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.Provider;
import java.security.cert.X509Certificate;
import java.security.spec.InvalidKeySpecException;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Queue;
import java.util.Set;
import java.util.concurrent.LinkedBlockingDeque;
import java.util.function.BooleanSupplier;

import javax.crypto.NoSuchPaddingException;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLEngine;
import javax.net.ssl.SSLException;
Expand All @@ -29,6 +38,7 @@

import io.netty.bootstrap.AbstractBootstrapConfig;
import io.netty.bootstrap.ChannelFactory;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.Channel;
import io.netty.channel.ChannelFuture;
Expand Down Expand Up @@ -549,6 +559,72 @@ private void setOpensslEngineSocketFd(Channel c) {
}
}

@TargetClass(className = "io.netty.handler.ssl.PemReader")
final class Alias_PemReader {

@Alias
public static ByteBuf readPrivateKey(File keyFile) {
return null;
}

@Alias
public static ByteBuf readPrivateKey(InputStream in) throws KeyException {
return null;
}
}

/**
* If BouncyCastle is not on the classpath, we must not try to read the PEM file using the BouncyCatle PEM reader.
*/
@TargetClass(className = "io.netty.handler.ssl.SslContext", onlyWith = IsBouncyNotThere.class)
final class Target_SslContext {

@Substitute
protected static PrivateKey toPrivateKey(File keyFile, String keyPassword) throws NoSuchAlgorithmException,
NoSuchPaddingException, InvalidKeySpecException,
InvalidAlgorithmParameterException,
KeyException, IOException {
if (keyFile == null) {
return null;
}

return getPrivateKeyFromByteBuffer(Alias_PemReader.readPrivateKey(keyFile), keyPassword);
}

@Substitute
protected static PrivateKey toPrivateKey(InputStream keyInputStream, String keyPassword)
throws NoSuchAlgorithmException,
NoSuchPaddingException, InvalidKeySpecException,
InvalidAlgorithmParameterException,
KeyException, IOException {
if (keyInputStream == null) {
return null;
}

return getPrivateKeyFromByteBuffer(Alias_PemReader.readPrivateKey(keyInputStream), keyPassword);
}

@Alias
private static PrivateKey getPrivateKeyFromByteBuffer(ByteBuf encodedKeyBuf, String keyPassword)
throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeySpecException,
InvalidAlgorithmParameterException, KeyException, IOException {
return null;
}
}

class IsBouncyNotThere implements BooleanSupplier {

@Override
public boolean getAsBoolean() {
try {
NettySubstitutions.class.getClassLoader().loadClass("org.bouncycastle.openssl.PEMParser");
return false;
} catch (Exception e) {
return true;
}
}
}

class NettySubstitutions {

}

0 comments on commit 84f953c

Please sign in to comment.