2023-06-15 01:35:37 +00:00
|
|
|
|
#include "pch.h"
|
|
|
|
|
#include "tunnel.h"
|
|
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
|
|
#include "usrerr.h"
|
|
|
|
|
#include "logs/fmtlog.h"
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
PROTO_CRYPTO_TYPE proCryptoType;
|
|
|
|
|
char proKeyBuf[CRYPTO_MAX][256];
|
2023-06-15 06:16:52 +00:00
|
|
|
|
fmtlog::LogLevel logLevel;
|
2023-06-15 01:35:37 +00:00
|
|
|
|
} SDK_CONFIG, *PSDK_CONFIG;
|
|
|
|
|
|
|
|
|
|
static SDK_CONFIG g_globalConfig;
|
|
|
|
|
|
|
|
|
|
NETTUNNELSDK_API int TunnelSDKInitEnv()
|
|
|
|
|
{
|
|
|
|
|
memset(&g_globalConfig, 0, sizeof(SDK_CONFIG));
|
2023-06-15 06:16:52 +00:00
|
|
|
|
g_globalConfig.logLevel = fmtlog::OFF;
|
2023-06-15 01:35:37 +00:00
|
|
|
|
return ERR_SUCCESS;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NETTUNNELSDK_API void InitTunnelSDKLog(const char* pLogFile, LOG_LEVEL level)
|
|
|
|
|
{
|
|
|
|
|
char buf[MAX_PATH] = {0};
|
|
|
|
|
static fmtlog::LogLevel lv[LOG_MAX] = {fmtlog::DBG, fmtlog::INF, fmtlog::WRN, fmtlog::ERR,};
|
|
|
|
|
|
|
|
|
|
//::MessageBoxA(NULL, pLogFile, NULL, MB_OK);
|
|
|
|
|
if (pLogFile && strlen(pLogFile) > 0)
|
|
|
|
|
{
|
|
|
|
|
strncpy_s(buf, pLogFile, MAX_PATH);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
GetCurrentDirectory(MAX_PATH, buf);
|
|
|
|
|
strcat_s(buf, "\\tunnelsdk.log");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fmtlog::setLogFile(buf, false);
|
|
|
|
|
fmtlog::setHeaderPattern("[{YmdHMSe}][{l}][{s}] ");
|
|
|
|
|
fmtlog::setFlushDelay(1000000);
|
|
|
|
|
fmtlog::setLogLevel(lv[level]);
|
|
|
|
|
|
2023-06-15 06:16:52 +00:00
|
|
|
|
g_globalConfig.logLevel = lv[level];
|
|
|
|
|
|
2023-06-15 01:35:37 +00:00
|
|
|
|
FMTLOG(lv[level], "Log({1}):{0}", buf, (int)level);
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-15 06:16:52 +00:00
|
|
|
|
NETTUNNELSDK_API void TunnelLogEnable(bool enLog)
|
|
|
|
|
{
|
|
|
|
|
if (enLog)
|
|
|
|
|
{
|
|
|
|
|
fmtlog::setLogLevel(g_globalConfig.logLevel);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
fmtlog::setLogLevel(fmtlog::OFF);
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-15 01:35:37 +00:00
|
|
|
|
|
|
|
|
|
NETTUNNELSDK_API int SetProtocolEncryptType(PROTO_CRYPTO_TYPE type, const char* pProKey)
|
|
|
|
|
{
|
2023-06-15 06:16:52 +00:00
|
|
|
|
if (type > CRYPTO_BASE64 && type < CRYPTO_MAX)
|
2023-06-15 01:35:37 +00:00
|
|
|
|
{
|
|
|
|
|
if (pProKey == nullptr || strlen(pProKey) < 8)
|
|
|
|
|
{
|
|
|
|
|
return -ERR_INPUT_PARAMS;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
g_globalConfig.proCryptoType = type;
|
|
|
|
|
strncpy_s(g_globalConfig.proKeyBuf[type], pProKey, 256);
|
|
|
|
|
|
|
|
|
|
logd("Protocol crypto type: {0} with key [{1}]", (int)type, pProKey? pProKey : "");
|
|
|
|
|
|
|
|
|
|
return ERR_SUCCESS;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NETTUNNELSDK_API int CreateTunnel(LPCSTR lpszMsg)
|
|
|
|
|
{
|
|
|
|
|
OutputDebugStringA(lpszMsg);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NETTUNNELSDK_API const char* TestMessage()
|
|
|
|
|
{
|
|
|
|
|
return "Test Message";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NETTUNNELSDK_API int Add(int a, int b)
|
|
|
|
|
{
|
|
|
|
|
return a + b;
|
|
|
|
|
}
|