|
|
@@ -12,40 +12,14 @@ namespace Shadowsocks.Encryption |
|
|
|
public class Sodium
|
|
|
|
{
|
|
|
|
const string DLLNAME = "libsscrypto";
|
|
|
|
const string DLLNAME2 = "libsscrypto2";
|
|
|
|
|
|
|
|
static Sodium()
|
|
|
|
{
|
|
|
|
LoadSSCryptoLibrary();
|
|
|
|
LoadSSCrypto2Library();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void LoadSSCryptoLibrary()
|
|
|
|
{
|
|
|
|
string tempPath = Utils.GetTempPath();
|
|
|
|
string dllPath = tempPath + "/libsscrypto.dll";
|
|
|
|
try
|
|
|
|
{
|
|
|
|
FileManager.UncompressFile(dllPath, Resources.libsscrypto_dll);
|
|
|
|
LoadLibrary(dllPath);
|
|
|
|
}
|
|
|
|
catch (IOException)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
Console.WriteLine(e.ToString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void LoadSSCrypto2Library()
|
|
|
|
{
|
|
|
|
string tempPath = Utils.GetTempPath();
|
|
|
|
string dllPath = tempPath + "/libsscrypto2.dll";
|
|
|
|
try
|
|
|
|
{
|
|
|
|
FileManager.UncompressFile(dllPath, Resources.libsscrypto2_dll);
|
|
|
|
LoadLibrary(dllPath);
|
|
|
|
}
|
|
|
|
catch (IOException)
|
|
|
|
{
|
|
|
@@ -54,22 +28,23 @@ namespace Shadowsocks.Encryption |
|
|
|
{
|
|
|
|
Console.WriteLine(e.ToString());
|
|
|
|
}
|
|
|
|
LoadLibrary(dllPath);
|
|
|
|
}
|
|
|
|
|
|
|
|
[DllImport("Kernel32.dll")]
|
|
|
|
private static extern IntPtr LoadLibrary(string path);
|
|
|
|
|
|
|
|
[DllImport(DLLNAME, CallingConvention = CallingConvention.Cdecl)]
|
|
|
|
public extern static void crypto_stream_salsa20_xor_ic(byte[] c, byte[] m, ulong mlen, byte[] n, ulong ic, byte[] k);
|
|
|
|
public extern static int crypto_stream_salsa20_xor_ic(byte[] c, byte[] m, ulong mlen, byte[] n, ulong ic, byte[] k);
|
|
|
|
|
|
|
|
[DllImport(DLLNAME, CallingConvention = CallingConvention.Cdecl)]
|
|
|
|
public extern static void crypto_stream_chacha20_xor_ic(byte[] c, byte[] m, ulong mlen, byte[] n, ulong ic, byte[] k);
|
|
|
|
public extern static int crypto_stream_chacha20_xor_ic(byte[] c, byte[] m, ulong mlen, byte[] n, ulong ic, byte[] k);
|
|
|
|
|
|
|
|
[DllImport(DLLNAME2, CallingConvention = CallingConvention.Cdecl)]
|
|
|
|
[DllImport(DLLNAME, CallingConvention = CallingConvention.Cdecl)]
|
|
|
|
public extern static int ss_gen_crc(byte[] buf, ref int buf_offset, ref int data_len,
|
|
|
|
byte[] crc_buf, ref int crc_idx, int buf_size);
|
|
|
|
|
|
|
|
[DllImport(DLLNAME2, CallingConvention = CallingConvention.Cdecl)]
|
|
|
|
[DllImport(DLLNAME, CallingConvention = CallingConvention.Cdecl)]
|
|
|
|
public extern static int ss_onetimeauth(byte[] auth,
|
|
|
|
byte[] msg, int msg_len,
|
|
|
|
byte[] iv, int iv_len,
|
|
|
|