final class org.apache.hc.client.http.impl.auth.NTLMEngineImpl extends java.lang.Object implements org.apache.hc.client.http.impl.auth.NTLMEngine
{
private static final java.nio.charset.Charset UNICODE_LITTLE_UNMARKED;
private static final java.nio.charset.Charset DEFAULT_CHARSET;
static final int FLAG_REQUEST_UNICODE_ENCODING;
static final int FLAG_REQUEST_OEM_ENCODING;
static final int FLAG_REQUEST_TARGET;
static final int FLAG_REQUEST_SIGN;
static final int FLAG_REQUEST_SEAL;
static final int FLAG_REQUEST_LAN_MANAGER_KEY;
static final int FLAG_REQUEST_NTLMv;
static final int FLAG_DOMAIN_PRESENT;
static final int FLAG_WORKSTATION_PRESENT;
static final int FLAG_REQUEST_ALWAYS_SIGN;
static final int FLAG_REQUEST_NTLM2_SESSION;
static final int FLAG_REQUEST_VERSION;
static final int FLAG_TARGETINFO_PRESENT;
static final int FLAG_REQUEST_128BIT_KEY_EXCH;
static final int FLAG_REQUEST_EXPLICIT_KEY_EXCH;
static final int FLAG_REQUEST_56BIT_ENCRYPTION;
static final int MSV_AV_EOL;
static final int MSV_AV_NB_COMPUTER_NAME;
static final int MSV_AV_NB_DOMAIN_NAME;
static final int MSV_AV_DNS_COMPUTER_NAME;
static final int MSV_AV_DNS_DOMAIN_NAME;
static final int MSV_AV_DNS_TREE_NAME;
static final int MSV_AV_FLAGS;
static final int MSV_AV_TIMESTAMP;
static final int MSV_AV_SINGLE_HOST;
static final int MSV_AV_TARGET_NAME;
static final int MSV_AV_CHANNEL_BINDINGS;
static final int MSV_AV_FLAGS_ACCOUNT_AUTH_CONSTAINED;
static final int MSV_AV_FLAGS_MIC;
static final int MSV_AV_FLAGS_UNTRUSTED_TARGET_SPN;
private static final java.security.SecureRandom RND_GEN;
private static final byte[] SIGNATURE;
private static final byte[] SIGN_MAGIC_SERVER;
private static final byte[] SIGN_MAGIC_CLIENT;
private static final byte[] SEAL_MAGIC_SERVER;
private static final byte[] SEAL_MAGIC_CLIENT;
private static final byte[] MAGIC_TLS_SERVER_ENDPOINT;
private static final java.lang.String TYPE_1_MESSAGE;
private static byte[] getNullTerminatedAsciiString(java.lang.String)
{
byte[] v, v;
java.nio.charset.Charset v;
int v, v, v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
v = lengthof v;
v = v + 1;
v = newarray (byte)[v];
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = lengthof v;
v[v] = 0;
return v;
}
void <init>()
{
org.apache.hc.client.http.impl.auth.NTLMEngineImpl v;
v := @this: org.apache.hc.client.http.impl.auth.NTLMEngineImpl;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static java.lang.String getResponseFor(java.lang.String, java.lang.String, char[], java.lang.String, java.lang.String) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message v;
int v;
char[] v;
java.lang.String v, v, v, v, v, v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: char[];
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("");
if v == 0 goto label;
label:
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String getType1Message(java.lang.String,java.lang.String)>(v, v);
goto label;
label:
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getChallenge()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: int getFlags()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: java.lang.String getTarget()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getTargetInfo()>();
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String getType3Message(java.lang.String,char[],java.lang.String,java.lang.String,byte[],int,java.lang.String,byte[])>(v, v, v, v, v, v, v, v);
label:
return v;
}
static java.lang.String getResponseFor(java.lang.String, java.lang.String, char[], java.lang.String, java.lang.String, java.security.cert.Certificate) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v;
int v;
java.lang.String v, v, v, v, v, v, v;
boolean v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message v, v;
java.security.cert.Certificate v;
char[] v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: char[];
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.security.cert.Certificate;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("");
if v == 0 goto label;
label:
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message: void <init>(java.lang.String,java.lang.String)>(v, v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message: java.lang.String getResponse()>();
goto label;
label:
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message: void <init>(java.lang.String,java.lang.String)>(v, v);
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getChallenge()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: int getFlags()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: java.lang.String getTarget()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getTargetInfo()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message: byte[] getBytes()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getBytes()>();
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String getType3Message(java.lang.String,char[],java.lang.String,java.lang.String,byte[],int,java.lang.String,byte[],java.security.cert.Certificate,byte[],byte[])>(v, v, v, v, v, v, v, v, v, v, v);
label:
return v;
}
static java.lang.String getType1Message(java.lang.String, java.lang.String)
{
java.lang.String v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String TYPE_1_MESSAGE>;
return v;
}
static java.lang.String getType3Message(java.lang.String, char[], java.lang.String, java.lang.String, byte[], int, java.lang.String, byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message v;
int v;
char[] v;
java.lang.String v, v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: char[];
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message: void <init>(java.lang.String,java.lang.String,java.lang.String,char[],byte[],int,java.lang.String,byte[])>(v, v, v, v, v, v, v, v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message: java.lang.String getResponse()>();
return v;
}
static java.lang.String getType3Message(java.lang.String, char[], java.lang.String, java.lang.String, byte[], int, java.lang.String, byte[], java.security.cert.Certificate, byte[], byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message v;
java.security.cert.Certificate v;
int v;
char[] v;
java.lang.String v, v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: char[];
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v := @parameter: java.security.cert.Certificate;
v := @parameter: byte[];
v := @parameter: byte[];
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message: void <init>(java.lang.String,java.lang.String,java.lang.String,char[],byte[],int,java.lang.String,byte[],java.security.cert.Certificate,byte[],byte[])>(v, v, v, v, v, v, v, v, v, v, v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type3Message: java.lang.String getResponse()>();
return v;
}
private static int readULong(byte[], int)
{
byte[] v;
short v, v, v, v;
byte v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v = lengthof v;
v = v + 4;
if v >= v goto label;
return 0;
label:
v = v[v];
v = v & 255;
v = v + 1;
v = v[v];
v = v & 255;
v = v << 8;
v = v | v;
v = v + 2;
v = v[v];
v = v & 255;
v = v << 16;
v = v | v;
v = v + 3;
v = v[v];
v = v & 255;
v = v << 24;
v = v | v;
return v;
}
private static int readUShort(byte[], int)
{
byte[] v;
short v, v;
byte v, v;
int v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v = lengthof v;
v = v + 2;
if v >= v goto label;
return 0;
label:
v = v[v];
v = v & 255;
v = v + 1;
v = v[v];
v = v & 255;
v = v << 8;
v = v | v;
return v;
}
private static byte[] readSecurityBuffer(byte[], int)
{
byte[] v, v, v;
int v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: int readUShort(byte[],int)>(v, v);
v = v + 4;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: int readULong(byte[],int)>(v, v);
v = lengthof v;
v = v + v;
if v >= v goto label;
v = newarray (byte)[v];
return v;
label:
v = newarray (byte)[v];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, v, v, 0, v);
return v;
}
private static byte[] makeRandomChallenge(java.util.Random)
{
java.lang.Throwable v;
byte[] v;
java.util.Random v;
v := @parameter: java.util.Random;
v = newarray (byte)[8];
entermonitor v;
label:
virtualinvoke v.<java.util.Random: void nextBytes(byte[])>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private static byte[] makeSecondaryKey(java.util.Random)
{
java.lang.Throwable v;
byte[] v;
java.util.Random v;
v := @parameter: java.util.Random;
v = newarray (byte)[16];
entermonitor v;
label:
virtualinvoke v.<java.util.Random: void nextBytes(byte[])>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
static byte[] hmacMD5(byte[], byte[])
{
byte[] v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5 v;
v := @parameter: byte[];
v := @parameter: byte[];
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void <init>(byte[])>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: byte[] getOutput()>();
return v;
}
static byte[] RC4(byte[], byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v;
javax.crypto.spec.SecretKeySpec v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
javax.crypto.Cipher v;
java.lang.Exception v;
java.lang.String v;
v := @parameter: byte[];
v := @parameter: byte[];
label:
v = staticinvoke <javax.crypto.Cipher: javax.crypto.Cipher getInstance(java.lang.String)>("RC4");
v = new javax.crypto.spec.SecretKeySpec;
specialinvoke v.<javax.crypto.spec.SecretKeySpec: void <init>(byte[],java.lang.String)>(v, "RC4");
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key)>(1, v);
v = virtualinvoke v.<javax.crypto.Cipher: byte[] doFinal(byte[])>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
}
static byte[] ntlm2SessionResponse(byte[], byte[], byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v, v, v;
java.security.MessageDigest v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
java.lang.Exception v;
java.lang.String v;
boolean v;
v := @parameter: byte[];
v := @parameter: byte[];
v := @parameter: byte[];
label:
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.MessageDigest getMD5()>();
virtualinvoke v.<java.security.MessageDigest: void update(byte[])>(v);
virtualinvoke v.<java.security.MessageDigest: void update(byte[])>(v);
v = virtualinvoke v.<java.security.MessageDigest: byte[] digest()>();
v = newarray (byte)[8];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, 8);
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] lmResponse(byte[],byte[])>(v, v);
label:
return v;
label:
v := @caughtexception;
v = v instanceof org.apache.hc.client.http.impl.auth.NTLMEngineException;
if v == 0 goto label;
throw v;
label:
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
}
private static byte[] lmHash(char[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v, v, v;
javax.crypto.Cipher v;
java.nio.charset.Charset v;
int v, v, v, v, v;
java.lang.String v, v;
org.apache.hc.client.http.utils.ByteArrayBuilder v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
char v, v;
java.lang.Exception v;
java.security.Key v, v;
char[] v, v;
v := @parameter: char[];
label:
v = lengthof v;
v = newarray (char)[v];
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v[v];
v = staticinvoke <java.lang.Character: char toUpperCase(char)>(v);
v[v] = v;
v = v + 1;
goto label;
label:
v = new org.apache.hc.client.http.utils.ByteArrayBuilder;
specialinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: void <init>()>();
v = virtualinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: org.apache.hc.client.http.utils.ByteArrayBuilder append(char[])>(v);
v = virtualinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: byte[] toByteArray()>();
v = lengthof v;
v = staticinvoke <java.lang.Math: int min(int,int)>(v, 14);
v = newarray (byte)[14];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.Key createDESKey(byte[],int)>(v, 0);
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.Key createDESKey(byte[],int)>(v, 7);
v = "KGS!@#$%";
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
v = staticinvoke <javax.crypto.Cipher: javax.crypto.Cipher getInstance(java.lang.String)>("DES/ECB/NoPadding");
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key)>(1, v);
v = virtualinvoke v.<javax.crypto.Cipher: byte[] doFinal(byte[])>(v);
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key)>(1, v);
v = virtualinvoke v.<javax.crypto.Cipher: byte[] doFinal(byte[])>(v);
v = newarray (byte)[16];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, 8);
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 8, 8);
label:
return v;
label:
v := @caughtexception;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
}
private static byte[] ntlmHash(char[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$MD4 v;
org.apache.hc.client.http.utils.ByteArrayBuilder v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
java.nio.charset.Charset v, v;
char[] v;
v := @parameter: char[];
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
if v != null goto label;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String)>("Unicode not supported");
throw v;
label:
v = new org.apache.hc.client.http.utils.ByteArrayBuilder;
specialinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: void <init>()>();
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
v = virtualinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: org.apache.hc.client.http.utils.ByteArrayBuilder charset(java.nio.charset.Charset)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: org.apache.hc.client.http.utils.ByteArrayBuilder append(char[])>(v);
v = virtualinvoke v.<org.apache.hc.client.http.utils.ByteArrayBuilder: byte[] toByteArray()>();
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$MD4;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$MD4: void <init>()>();
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$MD4: void update(byte[])>(v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$MD4: byte[] getOutput()>();
return v;
}
private static byte[] lmv2Hash(java.lang.String, java.lang.String, byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
java.nio.charset.Charset v, v, v;
java.util.Locale v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5 v;
java.lang.String v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
if v != null goto label;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String)>("Unicode not supported");
throw v;
label:
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void <init>(byte[])>(v);
v = <java.util.Locale: java.util.Locale ROOT>;
v = virtualinvoke v.<java.lang.String: java.lang.String toUpperCase(java.util.Locale)>(v);
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
if v == null goto label;
v = <java.util.Locale: java.util.Locale ROOT>;
v = virtualinvoke v.<java.lang.String: java.lang.String toUpperCase(java.util.Locale)>(v);
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
label:
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: byte[] getOutput()>();
return v;
}
private static byte[] ntlmv2Hash(java.lang.String, java.lang.String, byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
java.nio.charset.Charset v, v, v;
java.util.Locale v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5 v;
java.lang.String v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
if v != null goto label;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String)>("Unicode not supported");
throw v;
label:
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void <init>(byte[])>(v);
v = <java.util.Locale: java.util.Locale ROOT>;
v = virtualinvoke v.<java.lang.String: java.lang.String toUpperCase(java.util.Locale)>(v);
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
if v == null goto label;
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
label:
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: byte[] getOutput()>();
return v;
}
private static byte[] lmResponse(byte[], byte[]) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v, v, v, v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
javax.crypto.Cipher v;
java.lang.Exception v;
java.security.Key v, v, v;
java.lang.String v;
v := @parameter: byte[];
v := @parameter: byte[];
label:
v = newarray (byte)[21];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, 16);
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.Key createDESKey(byte[],int)>(v, 0);
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.Key createDESKey(byte[],int)>(v, 7);
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.Key createDESKey(byte[],int)>(v, 14);
v = staticinvoke <javax.crypto.Cipher: javax.crypto.Cipher getInstance(java.lang.String)>("DES/ECB/NoPadding");
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key)>(1, v);
v = virtualinvoke v.<javax.crypto.Cipher: byte[] doFinal(byte[])>(v);
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key)>(1, v);
v = virtualinvoke v.<javax.crypto.Cipher: byte[] doFinal(byte[])>(v);
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key)>(1, v);
v = virtualinvoke v.<javax.crypto.Cipher: byte[] doFinal(byte[])>(v);
v = newarray (byte)[24];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, 8);
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 8, 8);
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 16, 8);
label:
return v;
label:
v := @caughtexception;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
}
private static byte[] lmv2Response(byte[], byte[], byte[])
{
byte[] v, v, v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5 v;
int v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: byte[];
v := @parameter: byte[];
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void <init>(byte[])>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: void update(byte[])>(v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$HMACMD5: byte[] getOutput()>();
v = lengthof v;
v = lengthof v;
v = v + v;
v = newarray (byte)[v];
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = lengthof v;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
return v;
}
private static byte[] encodeLong(int)
{
int v;
byte[] v;
v := @parameter: int;
v = newarray (byte)[4];
staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: void encodeLong(byte[],int,int)>(v, 0, v);
return v;
}
private static void encodeLong(byte[], int, int)
{
byte[] v;
int v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
v = v + 0;
v = v & 255;
v[v] = v;
v = v + 1;
v = v >> 8;
v = v & 255;
v[v] = v;
v = v + 2;
v = v >> 16;
v = v & 255;
v[v] = v;
v = v + 3;
v = v >> 24;
v = v & 255;
v[v] = v;
return;
}
private static byte[] createBlob(byte[], byte[], byte[])
{
byte[] v, v, v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: byte[];
v := @parameter: byte[];
v = newarray (byte)[4];
v[0] = 1;
v[1] = 1;
v[2] = 0;
v[3] = 0;
v = newarray (byte)[4];
v[0] = 0;
v[1] = 0;
v[2] = 0;
v[3] = 0;
v = newarray (byte)[4];
v[0] = 0;
v[1] = 0;
v[2] = 0;
v[3] = 0;
v = newarray (byte)[4];
v[0] = 0;
v[1] = 0;
v[2] = 0;
v[3] = 0;
v = lengthof v;
v = lengthof v;
v = v + v;
v = lengthof v;
v = v + v;
v = v + 8;
v = lengthof v;
v = v + v;
v = lengthof v;
v = v + v;
v = lengthof v;
v = v + v;
v = newarray (byte)[v];
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = lengthof v;
v = 0 + v;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
v = lengthof v;
v = v + v;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
v = lengthof v;
v = v + v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, 8);
v = v + 8;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
v = lengthof v;
v = v + v;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
v = lengthof v;
v = v + v;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
v = lengthof v;
return v;
}
private static java.security.Key createDESKey(byte[], int)
{
byte[] v, v, v;
javax.crypto.spec.SecretKeySpec v;
byte v, v, v, v, v, v, v, v, v, v, v, v, v, v;
short v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v = newarray (byte)[7];
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, v, v, 0, 7);
v = newarray (byte)[8];
v = v[0];
v[0] = v;
v = v[0];
v = v << 7;
v = v[1];
v = v & 255;
v = v >>> 1;
v = v | v;
v[1] = v;
v = v[1];
v = v << 6;
v = v[2];
v = v & 255;
v = v >>> 2;
v = v | v;
v[2] = v;
v = v[2];
v = v << 5;
v = v[3];
v = v & 255;
v = v >>> 3;
v = v | v;
v[3] = v;
v = v[3];
v = v << 4;
v = v[4];
v = v & 255;
v = v >>> 4;
v = v | v;
v[4] = v;
v = v[4];
v = v << 3;
v = v[5];
v = v & 255;
v = v >>> 5;
v = v | v;
v[5] = v;
v = v[5];
v = v << 2;
v = v[6];
v = v & 255;
v = v >>> 6;
v = v | v;
v[6] = v;
v = v[6];
v = v << 1;
v[7] = v;
staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: void oddParity(byte[])>(v);
v = new javax.crypto.spec.SecretKeySpec;
specialinvoke v.<javax.crypto.spec.SecretKeySpec: void <init>(byte[],java.lang.String)>(v, "DES");
return v;
}
private static void oddParity(byte[])
{
byte[] v;
byte v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
boolean v;
v := @parameter: byte[];
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v[v];
v = v >>> 7;
v = v >>> 6;
v = v ^ v;
v = v >>> 5;
v = v ^ v;
v = v >>> 4;
v = v ^ v;
v = v >>> 3;
v = v ^ v;
v = v >>> 2;
v = v ^ v;
v = v >>> 1;
v = v ^ v;
v = v & 1;
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
if v == 0 goto label;
v = v[v];
v = v | 1;
v[v] = v;
goto label;
label:
v = v[v];
v = v & -2;
v[v] = v;
label:
v = v + 1;
goto label;
label:
return;
}
private static java.nio.charset.Charset getCharset(int) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
java.nio.charset.Charset v, v, v;
int v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineException v;
v := @parameter: int;
v = v & 1;
if v != 0 goto label;
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset DEFAULT_CHARSET>;
return v;
label:
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
if v != null goto label;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineException;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineException: void <init>(java.lang.String)>("Unicode not supported");
throw v;
label:
v = <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED>;
return v;
}
static void writeUShort(byte[], int, int)
{
byte[] v;
int v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
v = v & 255;
v[v] = v;
v = v + 1;
v = v >> 8;
v = v & 255;
v[v] = v;
return;
}
static void writeULong(byte[], int, int)
{
byte[] v;
int v, v, v, v, v, v, v, v, v, v, v, v;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
v = v & 255;
v[v] = v;
v = v + 1;
v = v >> 8;
v = v & 255;
v[v] = v;
v = v + 2;
v = v >> 16;
v = v & 255;
v[v] = v;
v = v + 3;
v = v >> 24;
v = v & 255;
v[v] = v;
return;
}
static int F(int, int, int)
{
int v, v, v, v, v, v, v, v;
v := @parameter: int;
v := @parameter: int;
v := @parameter: int;
v = v & v;
v = (int) -1;
v = v ^ v;
v = v & v;
v = v | v;
return v;
}
static int G(int, int, int)
{
int v, v, v, v, v, v, v, v;
v := @parameter: int;
v := @parameter: int;
v := @parameter: int;
v = v & v;
v = v & v;
v = v | v;
v = v & v;
v = v | v;
return v;
}
static int H(int, int, int)
{
int v, v, v, v, v;
v := @parameter: int;
v := @parameter: int;
v := @parameter: int;
v = v ^ v;
v = v ^ v;
return v;
}
static int rotintlft(int, int)
{
int v, v, v, v, v, v;
v := @parameter: int;
v := @parameter: int;
v = v << v;
v = 32 - v;
v = v >>> v;
v = v | v;
return v;
}
static java.security.MessageDigest getMD5()
{
java.security.MessageDigest v;
java.security.NoSuchAlgorithmException v;
java.lang.RuntimeException v;
java.lang.String v, v;
label:
v = staticinvoke <java.security.MessageDigest: java.security.MessageDigest getInstance(java.lang.String)>("MD5");
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
v = virtualinvoke v.<java.security.NoSuchAlgorithmException: java.lang.String getMessage()>();
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[])>("MD5 message digest doesn\'t seem to exist - fatal error: \u0001");
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.security.NoSuchAlgorithmException from label to label with label;
}
public java.lang.String generateType1Msg(java.lang.String, java.lang.String) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
java.lang.String v, v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl v;
v := @this: org.apache.hc.client.http.impl.auth.NTLMEngineImpl;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String getType1Message(java.lang.String,java.lang.String)>(v, v);
return v;
}
public java.lang.String generateType3Msg(java.lang.String, char[], java.lang.String, java.lang.String, java.lang.String) throws org.apache.hc.client.http.impl.auth.NTLMEngineException
{
byte[] v, v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message v;
int v;
char[] v;
java.lang.String v, v, v, v, v, v;
v := @this: org.apache.hc.client.http.impl.auth.NTLMEngineImpl;
v := @parameter: java.lang.String;
v := @parameter: char[];
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getChallenge()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: int getFlags()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: java.lang.String getTarget()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type2Message: byte[] getTargetInfo()>();
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String getType3Message(java.lang.String,char[],java.lang.String,java.lang.String,byte[],int,java.lang.String,byte[])>(v, v, v, v, v, v, v, v);
return v;
}
static void <clinit>()
{
byte[] v, v, v, v, v, v;
java.lang.Exception v;
org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message v;
java.security.SecureRandom v;
java.nio.charset.Charset v, v, v;
java.lang.String v, v;
v = staticinvoke <java.nio.charset.Charset: java.nio.charset.Charset forName(java.lang.String)>("UnicodeLittleUnmarked");
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset UNICODE_LITTLE_UNMARKED> = v;
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.nio.charset.Charset DEFAULT_CHARSET> = v;
v = null;
label:
v = staticinvoke <java.security.SecureRandom: java.security.SecureRandom getInstance(java.lang.String)>("SHA1PRNG");
label:
goto label;
label:
v := @caughtexception;
label:
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.security.SecureRandom RND_GEN> = v;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] getNullTerminatedAsciiString(java.lang.String)>("NTLMSSP");
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] SIGNATURE> = v;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] getNullTerminatedAsciiString(java.lang.String)>("session key to server-to-client signing key magic constant");
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] SIGN_MAGIC_SERVER> = v;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] getNullTerminatedAsciiString(java.lang.String)>("session key to client-to-server signing key magic constant");
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] SIGN_MAGIC_CLIENT> = v;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] getNullTerminatedAsciiString(java.lang.String)>("session key to server-to-client sealing key magic constant");
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] SEAL_MAGIC_SERVER> = v;
v = staticinvoke <org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] getNullTerminatedAsciiString(java.lang.String)>("session key to client-to-server sealing key magic constant");
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] SEAL_MAGIC_CLIENT> = v;
v = "tls-server-end-point:";
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: byte[] MAGIC_TLS_SERVER_ENDPOINT> = v;
v = new org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message;
specialinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message: void <init>()>();
v = virtualinvoke v.<org.apache.hc.client.http.impl.auth.NTLMEngineImpl$Type1Message: java.lang.String getResponse()>();
<org.apache.hc.client.http.impl.auth.NTLMEngineImpl: java.lang.String TYPE_1_MESSAGE> = v;
return;
catch java.lang.Exception from label to label with label;
}
}