public class org.apache.logging.log4j.core.net.UrlConnectionFactory extends java.lang.Object
{
private static final int DEFAULT_TIMEOUT;
private static final int connectTimeoutMillis;
private static final int readTimeoutMillis;
private static final java.lang.String JSON;
private static final java.lang.String XML;
private static final java.lang.String PROPERTIES;
private static final java.lang.String TEXT;
private static final java.lang.String HTTP;
private static final java.lang.String HTTPS;
private static final java.lang.String JAR;
private static final java.lang.String DEFAULT_ALLOWED_PROTOCOLS;
private static final java.lang.String NO_PROTOCOLS;
public static final java.lang.String ALLOWED_PROTOCOLS;
public void <init>()
{
org.apache.logging.log4j.core.net.UrlConnectionFactory v;
v := @this: org.apache.logging.log4j.core.net.UrlConnectionFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static java.net.URLConnection createConnection(java.net.URL, long, org.apache.logging.log4j.core.net.ssl.SslConfiguration, org.apache.logging.log4j.core.util.AuthorizationProvider) throws java.io.IOException
{
java.net.HttpURLConnection v;
java.net.URL v;
byte v;
javax.net.ssl.HostnameVerifier v;
boolean v, v, v, v, v, v, v, v, v, v;
org.apache.logging.log4j.core.util.AuthorizationProvider v;
javax.net.ssl.SSLSocketFactory v;
java.util.List v;
org.apache.logging.log4j.core.net.ssl.SslConfiguration v;
java.lang.String[] v, v;
long v;
org.apache.logging.log4j.util.PropertiesUtil v;
java.net.URLConnection v, v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.net.ProtocolException v, v, v;
java.lang.Object v;
v := @parameter: java.net.URL;
v := @parameter: long;
v := @parameter: org.apache.logging.log4j.core.net.ssl.SslConfiguration;
v := @parameter: org.apache.logging.log4j.core.util.AuthorizationProvider;
v = staticinvoke <org.apache.logging.log4j.util.PropertiesUtil: org.apache.logging.log4j.util.PropertiesUtil getProperties()>();
v = virtualinvoke v.<org.apache.logging.log4j.util.PropertiesUtil: java.lang.String getStringProperty(java.lang.String,java.lang.String)>("log4j.Configuration.allowedProtocols", "https, file, jar");
v = staticinvoke <org.apache.logging.log4j.util.Strings: java.lang.String toRootLowerCase(java.lang.String)>(v);
v = staticinvoke <org.apache.logging.log4j.util.Strings: java.lang.String[] splitList(java.lang.String)>(v);
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 1 goto label;
v = "_none";
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new java.net.ProtocolException;
specialinvoke v.<java.net.ProtocolException: void <init>(java.lang.String)>("No external protocols have been enabled");
throw v;
label:
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
if v != null goto label;
v = new java.net.ProtocolException;
v = virtualinvoke v.<java.net.URL: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("No protocol was specified on \u0001");
specialinvoke v.<java.net.ProtocolException: void <init>(java.lang.String)>(v);
throw v;
label:
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.net.ProtocolException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Protocol \u has not been enabled as an allowed protocol");
specialinvoke v.<java.net.ProtocolException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("http");
if v != 0 goto label;
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("https");
if v == 0 goto label;
label:
v = virtualinvoke v.<java.net.URL: java.net.URLConnection openConnection()>();
if v == null goto label;
interfaceinvoke v.<org.apache.logging.log4j.core.util.AuthorizationProvider: void addAuthorization(java.net.URLConnection)>(v);
label:
virtualinvoke v.<java.net.HttpURLConnection: void setAllowUserInteraction(boolean)>(0);
virtualinvoke v.<java.net.HttpURLConnection: void setDoOutput(boolean)>(1);
virtualinvoke v.<java.net.HttpURLConnection: void setDoInput(boolean)>(1);
virtualinvoke v.<java.net.HttpURLConnection: void setRequestMethod(java.lang.String)>("GET");
v = (int) 60000;
virtualinvoke v.<java.net.HttpURLConnection: void setConnectTimeout(int)>(v);
v = (int) 60000;
virtualinvoke v.<java.net.HttpURLConnection: void setReadTimeout(int)>(v);
v = virtualinvoke v.<java.net.URL: java.lang.String getFile()>();
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>("\\.");
v = lengthof v;
v = v - 1;
v = v[v];
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = staticinvoke <org.apache.logging.log4j.core.net.UrlConnectionFactory: boolean isXml(java.lang.String)>(v);
if v == 0 goto label;
v = "application/xml";
goto label;
label:
v = staticinvoke <org.apache.logging.log4j.core.net.UrlConnectionFactory: boolean isJson(java.lang.String)>(v);
if v == 0 goto label;
v = "application/json";
goto label;
label:
v = staticinvoke <org.apache.logging.log4j.core.net.UrlConnectionFactory: boolean isProperties(java.lang.String)>(v);
if v == 0 goto label;
v = "text/x-java-properties";
goto label;
label:
v = "text/plain";
label:
virtualinvoke v.<java.net.HttpURLConnection: void setRequestProperty(java.lang.String,java.lang.String)>("Content-Type", v);
v = v cmp 0L;
if v <= 0 goto label;
virtualinvoke v.<java.net.HttpURLConnection: void setIfModifiedSince(long)>(v);
label:
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("https");
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.net.ssl.SslConfiguration: javax.net.ssl.SSLSocketFactory getSslSocketFactory()>();
virtualinvoke v.<javax.net.ssl.HttpsURLConnection: void setSSLSocketFactory(javax.net.ssl.SSLSocketFactory)>(v);
v = virtualinvoke v.<org.apache.logging.log4j.core.net.ssl.SslConfiguration: boolean isVerifyHostName()>();
if v != 0 goto label;
v = <org.apache.logging.log4j.core.net.ssl.LaxHostnameVerifier: javax.net.ssl.HostnameVerifier INSTANCE>;
virtualinvoke v.<javax.net.ssl.HttpsURLConnection: void setHostnameVerifier(javax.net.ssl.HostnameVerifier)>(v);
label:
v = v;
goto label;
label:
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("jar");
if v == 0 goto label;
v = virtualinvoke v.<java.net.URL: java.net.URLConnection openConnection()>();
virtualinvoke v.<java.net.URLConnection: void setUseCaches(boolean)>(0);
goto label;
label:
v = virtualinvoke v.<java.net.URL: java.net.URLConnection openConnection()>();
label:
return v;
}
public static java.net.URLConnection createConnection(java.net.URL) throws java.io.IOException
{
java.net.URL v;
org.apache.logging.log4j.core.net.ssl.SslConfiguration v;
org.apache.logging.log4j.core.util.AuthorizationProvider v;
org.apache.logging.log4j.util.PropertiesUtil v;
java.net.URLConnection v;
java.lang.String v, v;
boolean v, v, v;
v := @parameter: java.net.URL;
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("https");
if v != 0 goto label;
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("http");
if v == 0 goto label;
label:
v = staticinvoke <org.apache.logging.log4j.util.PropertiesUtil: org.apache.logging.log4j.util.PropertiesUtil getProperties()>();
v = staticinvoke <org.apache.logging.log4j.core.config.ConfigurationFactory: org.apache.logging.log4j.core.util.AuthorizationProvider authorizationProvider(org.apache.logging.log4j.util.PropertiesUtil)>(v);
v = staticinvoke <org.apache.logging.log4j.core.net.ssl.SslConfigurationFactory: org.apache.logging.log4j.core.net.ssl.SslConfiguration getSslConfiguration()>();
v = staticinvoke <org.apache.logging.log4j.core.net.UrlConnectionFactory: java.net.URLConnection createConnection(java.net.URL,long,org.apache.logging.log4j.core.net.ssl.SslConfiguration,org.apache.logging.log4j.core.util.AuthorizationProvider)>(v, 0L, v, v);
goto label;
label:
v = virtualinvoke v.<java.net.URL: java.net.URLConnection openConnection()>();
v = v instanceof java.net.JarURLConnection;
if v == 0 goto label;
virtualinvoke v.<java.net.URLConnection: void setUseCaches(boolean)>(0);
label:
return v;
}
private static boolean isXml(java.lang.String)
{
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("xml");
return v;
}
private static boolean isJson(java.lang.String)
{
java.lang.String v;
boolean v, v, v;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("json");
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("jsn");
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private static boolean isProperties(java.lang.String)
{
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("properties");
return v;
}
}