idcer_impl.cpp 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640
  1. // dllmain.cpp : 定义 DLL 应用程序的入口点。
  2. #include "stdafx.h"
  3. #include "idcer_impl.h"
  4. #include <cstring>
  5. #include <cstdio>
  6. #include "log4vendor.h"
  7. #include <path.h>
  8. #ifdef RVC_OS_WIN
  9. #include <direct.h>
  10. #define GetCurrentDir _getcwd
  11. #else
  12. #define GetCurrentDir getcwd
  13. #endif // RVC_OS_WIN
  14. #define w 102 //头像宽度
  15. #define h 126 //头像高度
  16. #define DEFAULT_URL "http://localhost:8080/avs/imitate/simulateData"
  17. string get_current_directory() {
  18. char buff[256];
  19. GetCurrentDir(buff, 256);
  20. string current_working_directory(buff);
  21. return current_working_directory;
  22. }
  23. //string GetLocalIP()
  24. //{
  25. // hostent* ent = gethostbyname(NULL);
  26. // if (ent && ent->h_addr_list[0] != NULL)
  27. // {
  28. // int i = 0;
  29. // for (; ent->h_addr_list[i] != NULL; ++i)
  30. // {
  31. // struct in_addr* in = (struct in_addr*)ent->h_addr_list[i];
  32. // if (in->S_un.S_un_b.s_b1 == 99 || in->S_un.S_un_b.s_b1 == 10)
  33. // break;
  34. // }
  35. //
  36. // if (ent->h_addr_list[i] == NULL)
  37. // i = 0;
  38. //
  39. // auto in = (struct in_addr*)ent->h_addr_list[i];
  40. // char xIP[64] = {};
  41. // sprintf(xIP, "%d.%d.%d.%d", in->S_un.S_un_b.s_b1, in->S_un.S_un_b.s_b2, in->S_un.S_un_b.s_b3, in->S_un.S_un_b.s_b4);
  42. // LOG4VTM(INFO, "ip:" << xIP);
  43. //
  44. // return string(xIP);
  45. // }
  46. //}
  47. typedef unsigned short UINT16;
  48. typedef unsigned char UINT8;
  49. #ifdef RVC_OS_WIN
  50. char* ConvertGBKToUtf8(const char* gbk, int* n)
  51. {
  52. int len = MultiByteToWideChar(CP_ACP, 0, gbk, -1, NULL, 0);
  53. WCHAR* wszGBK = new WCHAR[len + 1];
  54. memset(wszGBK, 0, len * 2 + 2);
  55. MultiByteToWideChar(CP_ACP, 0, gbk, -1, wszGBK, len);
  56. len = WideCharToMultiByte(CP_UTF8, 0, wszGBK, -1, NULL, 0, NULL, NULL);
  57. char* szUtf8 = new char[len + 1];
  58. memset(szUtf8, 0, len + 1);
  59. WideCharToMultiByte(CP_UTF8, 0, wszGBK, -1, szUtf8, len, NULL, NULL);
  60. delete[] wszGBK;
  61. *n = len - 1;
  62. return szUtf8;
  63. }
  64. void ConvertGBKToUtf8(std::string& str)
  65. {
  66. int len = 0;
  67. char* dst = ConvertGBKToUtf8(str.c_str(), &len);
  68. str = dst;
  69. delete[] dst;
  70. }
  71. #endif // RVC_OS_WIN
  72. bool UTF8_to_UCS2(const UINT8* UINT8_code, UINT16* ucs2_code)
  73. {
  74. UINT16 temp1, temp2;
  75. bool is_unrecognized = false;
  76. UINT8* in = (UINT8*)UINT8_code;
  77. if (!UINT8_code || !ucs2_code)
  78. {
  79. return is_unrecognized;
  80. }
  81. while (*in != 0)
  82. {
  83. //1字节 0xxxxxxx
  84. //0x80=1000,0000,判断最高位是否为0,如果为0,那么是ASCII字符
  85. //不需要处理,直接拷贝即可
  86. if (0x00 == (*in & 0x80))
  87. {
  88. /* 1 byte UTF-8 Charater.*/
  89. *ucs2_code = *in;
  90. is_unrecognized = true;
  91. in += 1;
  92. }
  93. //2字节 110xxxxx 10xxxxxx
  94. //0xe0=1110,0000
  95. //0xc0=1100,0000
  96. else if (0xc0 == (*in & 0xe0) && 0x80 == (*(in + 1) & 0xc0))
  97. {
  98. /* 2 bytes UTF-8 Charater.*/
  99. //0x1f=0001,1111,获得第一个字节的后5位
  100. temp1 = (UINT16)(*in & 0x1f);
  101. //左移6位
  102. temp1 <<= 6;
  103. //0x3f=0011,1111,获得第二个字节的后6位
  104. //加上上面的5位一共有11位
  105. temp1 |= (UINT16)(*(in + 1) & 0x3f);
  106. *ucs2_code = temp1;
  107. is_unrecognized = true;
  108. in += 2;
  109. }
  110. //3字节 1110xxxx 10xxxxxx 10xxxxxx
  111. //中文要进入这一个分支
  112. else if (0xe0 == (*in & 0xf0) &&
  113. 0x80 == (*(in + 1) & 0xc0) &&
  114. 0x80 == (*(in + 2) & 0xc0)
  115. )
  116. {
  117. /* 3bytes UTF-8 Charater.*/
  118. //0x0f=0000,1111
  119. //取出第一个字节的低4位
  120. temp1 = (UINT16)(*in & 0x0f);
  121. temp1 <<= 12;
  122. //0x3f=0011,1111
  123. //取得第二个字节的低6位
  124. temp2 = (UINT16)(*(in + 1) & 0x3F);
  125. temp2 <<= 6;
  126. //取得第三个字节的低6位,最后组成16位
  127. temp1 = temp1 | temp2 | (UINT16)(*(in + 2) & 0x3F);
  128. *ucs2_code = temp1;
  129. //移动到下一个字符
  130. in += 3;
  131. is_unrecognized = true;
  132. }
  133. else
  134. {
  135. /* unrecognize byte. */
  136. *ucs2_code = 0x22e0;
  137. is_unrecognized = false;
  138. //直接退出循环
  139. break;
  140. }
  141. ucs2_code += 1;
  142. }
  143. return is_unrecognized;
  144. }
  145. std::string current_working_directory()
  146. {
  147. char buff[250];
  148. GetCurrentDir(buff, 250);
  149. std::string current_working_directory(buff);
  150. return current_working_directory;
  151. }
  152. void WriteBMP(char* img, const char* filename)
  153. {
  154. int l = (w * 3 + 3) / 4 * 4;
  155. int bmi[] = {
  156. l * h + 54,0,54,40,w,h,1 | 3 * 8 << 16,0,l * h,0,0,100,0 };
  157. FILE* fp = fopen(filename, "wb");
  158. fprintf(fp, "BM");
  159. fwrite(&bmi, 52, 1, fp);
  160. fwrite(img, 1, l * h, fp);
  161. fclose(fp);
  162. }
  163. IDCerClassImpl::IDCerClassImpl()
  164. :m_mode(0)
  165. {
  166. }
  167. IDCerClassImpl::~IDCerClassImpl()
  168. {
  169. }
  170. ErrorCodeEnum IDCerClassImpl::GetDevCategory(DevCategoryInfo& devCategory)
  171. {
  172. ErrorCodeEnum err = Error_Succeed;
  173. strcpy(devCategory.szModel, "STYLE=IG#FUNCTION=ITF#CODE=UCS2");
  174. strcpy(devCategory.szType, "szCategory");
  175. strcpy(devCategory.szVendor, "szVendor=cmbszSimulator");
  176. return err;
  177. }
  178. ErrorCodeEnum IDCerClassImpl::Reset()
  179. {
  180. ErrorCodeEnum err = Error_Succeed;
  181. m_mode = 0;
  182. return err;
  183. }
  184. ErrorCodeEnum IDCerClassImpl::IDCerAuthenticate()
  185. {
  186. bool flag = authHttpFunction();
  187. ErrorCodeEnum err = Error_Succeed;
  188. m_mode = 0;
  189. if (!flag)
  190. {
  191. err = Error_Dev_IDCardNotFound;
  192. }
  193. return err;
  194. }
  195. ErrorCodeEnum IDCerClassImpl::ForceIDEject()
  196. {
  197. ErrorCodeEnum err = Error_Succeed;
  198. m_mode = 0;
  199. return err;
  200. }
  201. ErrorCodeEnum IDCerClassImpl::ScanIDAndSaveImage()
  202. {
  203. ErrorCodeEnum err = Error_NotImpl;
  204. m_mode = 0;
  205. return err;
  206. }
  207. ErrorCodeEnum IDCerClassImpl::QueryCardPos(int& pos)
  208. {
  209. ErrorCodeEnum err = Error_Succeed;
  210. m_mode = 0;
  211. return err;
  212. }
  213. ErrorCodeEnum IDCerClassImpl::IDCerRFControl(bool bControl)
  214. {
  215. ErrorCodeEnum err = Error_Succeed;
  216. m_mode = 0;
  217. return err;
  218. }
  219. ErrorCodeEnum IDCerClassImpl::DevOpen(DWORD dwPort)
  220. {
  221. depCfgPath = get_current_directory() + SPLIT_SLASH_STR + "dep" + SPLIT_SLASH_STR + "cmbsz.ini";
  222. bool ret = iniRead.ReadConfig(depCfgPath);
  223. if (ret == false)
  224. {
  225. LOG4VTM(INFO, "dep ReadConfig is Error,cfg=" << depCfgPath);
  226. }
  227. ErrorCodeEnum err = Error_Succeed;
  228. return err;
  229. }
  230. ErrorCodeEnum IDCerClassImpl::DevClose()
  231. {
  232. ErrorCodeEnum err = Error_Succeed;
  233. return err;
  234. }
  235. ErrorCodeEnum IDCerClassImpl::IDCerGetData(IDCerInfo& idCerInfo)
  236. {
  237. ErrorCodeEnum err = Error_Succeed;
  238. memset(&idCerInfo, 0, sizeof(IDCerInfo));
  239. strcpy(idCerInfo.startDate.data, "2009.03.25");
  240. idCerInfo.startDate.dwSize = strlen("2009.03.25");
  241. strcpy(idCerInfo.endDate.data, "2029.03.24");
  242. idCerInfo.endDate.dwSize = strlen("2029.03.24");
  243. return err;
  244. }
  245. ErrorCodeEnum IDCerClassImpl::IDCerGetDataEx(IDCerInfoEx& idCerInfoEx)
  246. {
  247. ErrorCodeEnum err = Error_Succeed;
  248. memset(&idCerInfoEx, 0, sizeof(IDCerInfoEx));
  249. std::string path;
  250. path = current_working_directory();
  251. path = path + "/dep/zp.bmp";
  252. char img[w * h * 3];
  253. for (int i = 0; i < w * h * 3; i++)img[i] = rand() % 256;
  254. WriteBMP(img, path.c_str());
  255. bool testRe = exHttpFunction(idCerInfoEx);
  256. return err;
  257. }
  258. ErrorCodeEnum IDCerClassImpl::IDCerGetDataEx2(IDCerInfoEx2& idCerInfoEx2)
  259. {
  260. ErrorCodeEnum err = Error_Succeed;
  261. memset(&idCerInfoEx2, 0, sizeof(IDCerInfoEx2));
  262. std::string path;
  263. path = current_working_directory();
  264. path = path + "/dep/zp.bmp";
  265. char img[w * h * 3];
  266. for (int i = 0; i < w * h * 3; i++)img[i] = rand() % 256;
  267. WriteBMP(img, path.c_str());
  268. bool testRe = ex2HttpFunction(idCerInfoEx2);
  269. return err;
  270. }
  271. ErrorCodeEnum IDCerClassImpl::GetLastErr(DevErrorInfo& devErrInfo)
  272. {
  273. static int times = 0;
  274. char szMessage[128];
  275. sprintf(szMessage, "这是第 %d 条错误信息", ++times);
  276. strcpy(devErrInfo.szErrMsg, szMessage);
  277. devErrInfo.dwErrMsgLen = strlen(szMessage);
  278. return Error_Succeed;
  279. }
  280. bool IDCerClassImpl::authHttpFunction()
  281. {
  282. IHttpFunc* client;
  283. client = create_http(HttpsLogCallBack);
  284. IDCerDevReq idCerReq;
  285. IDCerDevRet idCerRet;
  286. idCerReq.ip = GetLocalIP();
  287. idCerReq.entityName = "IDCertificate";
  288. idCerReq.method = "readAndScan";
  289. idCerReq.adapterInterName = "IDCerAuthenticate";
  290. string url = GetSimulatorUrl();
  291. if (url.length() == 0)
  292. {
  293. url = DEFAULT_URL;
  294. }
  295. idCerReq.m_url = url;
  296. LOG4VTM(INFO, "请求地址:" << idCerReq.m_url.c_str());
  297. bool ret = client->Post(idCerReq, idCerRet);
  298. if (ret) {
  299. if (idCerRet.success == false)
  300. {
  301. LOG4VTM(INFO, "请求失败");
  302. return false;
  303. }
  304. if (idCerRet.result == true)
  305. {
  306. return true;
  307. }
  308. else
  309. {
  310. return false;
  311. }
  312. }
  313. else
  314. {
  315. LOG4VTM(INFO, "ret = 0, 请求失败");
  316. return false;
  317. }
  318. }
  319. bool IDCerClassImpl::exHttpFunction(IDCerInfoEx& idCerInfoEx)
  320. {
  321. IHttpFunc* client;
  322. client = create_http(HttpsLogCallBack);
  323. IDCerDevReq idCerReq;
  324. IDCerDevRet idCerRet;
  325. idCerReq.ip = GetLocalIP();
  326. idCerReq.entityName = "IDCertificate";
  327. idCerReq.method = "readAndScan";
  328. idCerReq.adapterInterName = "IDCerGetDataEx";
  329. string url = GetSimulatorUrl();
  330. if (url.length() == 0)
  331. {
  332. url = DEFAULT_URL;
  333. }
  334. idCerReq.m_url = url;
  335. LOG4VTM(INFO, "请求地址:" << idCerReq.m_url.c_str());
  336. bool ret = client->Post(idCerReq, idCerRet);
  337. if (ret) {
  338. if (!idCerRet.success)
  339. {
  340. LOG4VTM(INFO, "请求失败");
  341. return false;
  342. }
  343. std::strcpy(idCerInfoEx.name.data, idCerRet.name.c_str());
  344. idCerInfoEx.name.dwSize = strlen(idCerRet.name.c_str());
  345. std::strcpy(idCerInfoEx.sex.data, idCerRet.sex.c_str());
  346. idCerInfoEx.sex.dwSize = strlen(idCerRet.sex.c_str());
  347. std::strcpy(idCerInfoEx.nation.data, idCerRet.nation.c_str());
  348. idCerInfoEx.nation.dwSize = strlen(idCerRet.nation.c_str());
  349. std::strcpy(idCerInfoEx.birthday.data, idCerRet.birthday.c_str());
  350. idCerInfoEx.birthday.dwSize = strlen(idCerRet.birthday.c_str());
  351. std::strcpy(idCerInfoEx.address.data, idCerRet.address.c_str());
  352. idCerInfoEx.address.dwSize = strlen(idCerRet.address.c_str());
  353. if (strlen(idCerRet.idcode.c_str()) == 0)
  354. {
  355. idCerRet.idcode = "testnum00000";
  356. }
  357. std::strcpy(idCerInfoEx.idno.data, idCerRet.idcode.c_str());
  358. idCerInfoEx.idno.dwSize = strlen(idCerRet.idcode.c_str());
  359. std::strcpy(idCerInfoEx.department.data, idCerRet.department.c_str());
  360. idCerInfoEx.department.dwSize = strlen(idCerRet.department.c_str());
  361. std::strcpy(idCerInfoEx.startDate.data, idCerRet.startdate.c_str());
  362. idCerInfoEx.startDate.dwSize = strlen(idCerRet.startdate.c_str());
  363. std::strcpy(idCerInfoEx.endDate.data, idCerRet.enddate.c_str());
  364. idCerInfoEx.endDate.dwSize = strlen(idCerRet.enddate.c_str());
  365. std::strcpy(idCerInfoEx.englishName.data, idCerRet.englishname.c_str());
  366. idCerInfoEx.englishName.dwSize = strlen(idCerRet.englishname.c_str());
  367. std::strcpy(idCerInfoEx.nationality.data, idCerRet.nationality.c_str());
  368. idCerInfoEx.nationality.dwSize = strlen(idCerRet.nationality.c_str());
  369. std::strcpy(idCerInfoEx.idVersion.data, idCerRet.idversion.c_str());
  370. idCerInfoEx.idVersion.dwSize = strlen(idCerRet.idversion.c_str());
  371. std::strcpy(idCerInfoEx.idType.data, idCerRet.idtype.c_str());
  372. idCerInfoEx.idType.dwSize = strlen(idCerRet.idtype.c_str());
  373. std::strcpy(idCerInfoEx.reserved.data, idCerRet.reserved.c_str());
  374. idCerInfoEx.reserved.dwSize = strlen(idCerRet.reserved.c_str());
  375. return true;
  376. }
  377. else
  378. {
  379. LOG4VTM(INFO, "ret = 0, 请求失败");
  380. return false;
  381. }
  382. }
  383. bool IDCerClassImpl::ex2HttpFunction(IDCerInfoEx2& idCerInfoEx2)
  384. {
  385. IHttpFunc* client;
  386. client = create_http(HttpsLogCallBack);
  387. IDCerDevReq idCerReq;
  388. IDCerDevRet idCerRet;
  389. idCerReq.ip = GetLocalIP();
  390. idCerReq.entityName = "IDCertificate";
  391. idCerReq.adapterInterName = "IDCerGetDataEx2";
  392. string url = GetSimulatorUrl();
  393. if (url.length() == 0)
  394. {
  395. url = DEFAULT_URL;
  396. }
  397. idCerReq.m_url = url;
  398. LOG4VTM(INFO, "请求地址:" << idCerReq.m_url.c_str());
  399. bool ret = client->Post(idCerReq, idCerRet);
  400. if (ret) {
  401. if (!idCerRet.success)
  402. {
  403. LOG4VTM(INFO, "请求失败");
  404. return false;
  405. }
  406. #ifdef RVC_OS_WIN
  407. ConvertGBKToUtf8(idCerRet.name);
  408. ConvertGBKToUtf8(idCerRet.englishname);
  409. ConvertGBKToUtf8(idCerRet.sex);
  410. ConvertGBKToUtf8(idCerRet.birthday);
  411. ConvertGBKToUtf8(idCerRet.address);
  412. ConvertGBKToUtf8(idCerRet.department);
  413. ConvertGBKToUtf8(idCerRet.idcode);
  414. ConvertGBKToUtf8(idCerRet.startdate);
  415. ConvertGBKToUtf8(idCerRet.enddate);
  416. ConvertGBKToUtf8(idCerRet.nation);
  417. ConvertGBKToUtf8(idCerRet.nationality);
  418. #endif // RVC_OS_WIN
  419. char name[1024]; memset(name, 0, 1024);
  420. std::strcpy(name, idCerRet.name.c_str());
  421. UTF8_to_UCS2((UINT8*)name, (UINT16*)idCerInfoEx2.name.data);
  422. idCerInfoEx2.name.dwSize = strlen(idCerInfoEx2.name.data);
  423. char englishname[1024]; memset(englishname, 0, 1024);
  424. std::strcpy(englishname, idCerRet.englishname.c_str());
  425. UTF8_to_UCS2((UINT8*)englishname, (UINT16*)idCerInfoEx2.englishName.data);
  426. idCerInfoEx2.englishName.dwSize = strlen(idCerInfoEx2.englishName.data);
  427. char sex[1024]; memset(sex, 0, 1024);
  428. std::strcpy(sex, idCerRet.sex.c_str());
  429. UTF8_to_UCS2((UINT8*)sex, (UINT16*)idCerInfoEx2.sex.data);
  430. idCerInfoEx2.sex.dwSize = strlen(idCerInfoEx2.sex.data);
  431. char birthday[1024]; memset(birthday, 0, 1024);
  432. std::strcpy(birthday, idCerRet.birthday.c_str());
  433. UTF8_to_UCS2((UINT8*)birthday, (UINT16*)idCerInfoEx2.birthday.data);
  434. idCerInfoEx2.birthday.dwSize = strlen(idCerInfoEx2.birthday.data);
  435. char address[1024]; memset(address, 0, 1024);
  436. std::strcpy(address, idCerRet.address.c_str());
  437. UTF8_to_UCS2((UINT8*)address, (UINT16*)idCerInfoEx2.address.data);
  438. idCerInfoEx2.address.dwSize = strlen(idCerInfoEx2.address.data);
  439. char department[1024]; memset(department, 0, 1024);
  440. std::strcpy(department, idCerRet.department.c_str());
  441. UTF8_to_UCS2((UINT8*)department, (UINT16*)idCerInfoEx2.department.data);
  442. idCerInfoEx2.department.dwSize = strlen(idCerInfoEx2.department.data);
  443. char idno[1024]; memset(idno, 0, 1024);
  444. std::strcpy(idno, idCerRet.idcode.c_str());
  445. UTF8_to_UCS2((UINT8*)idno, (UINT16*)idCerInfoEx2.idno.data);
  446. idCerInfoEx2.idno.dwSize = strlen(idCerInfoEx2.idno.data);
  447. char startDate[1024]; memset(startDate, 0, 1024);
  448. std::strcpy(startDate, idCerRet.startdate.c_str());
  449. UTF8_to_UCS2((UINT8*)startDate, (UINT16*)idCerInfoEx2.startDate.data);
  450. idCerInfoEx2.startDate.dwSize = strlen(idCerInfoEx2.startDate.data);
  451. char endDate[1024]; memset(endDate, 0, 1024);
  452. std::strcpy(endDate, idCerRet.enddate.c_str());
  453. UTF8_to_UCS2((UINT8*)endDate, (UINT16*)idCerInfoEx2.endDate.data);
  454. idCerInfoEx2.endDate.dwSize = strlen(idCerInfoEx2.endDate.data);
  455. char nation[1024]; memset(nation, 0, 1024);
  456. std::strcpy(nation, idCerRet.nation.c_str());
  457. UTF8_to_UCS2((UINT8*)nation, (UINT16*)idCerInfoEx2.nation.data);
  458. idCerInfoEx2.nation.dwSize = strlen(idCerInfoEx2.nation.data);
  459. char nationality[1024]; memset(nationality, 0, 1024);
  460. std::strcpy(nationality, idCerRet.nationality.c_str());
  461. UTF8_to_UCS2((UINT8*)nationality, (UINT16*)idCerInfoEx2.nationality.data);
  462. idCerInfoEx2.nationality.dwSize = strlen(idCerInfoEx2.nationality.data);
  463. return true;
  464. }
  465. else
  466. {
  467. LOG4VTM(INFO, "ret = 0, 请求失败");
  468. return false;
  469. }
  470. }
  471. #ifdef RVC_OS_WIN
  472. BOOL APIENTRY DllMain(HMODULE hModule,
  473. DWORD ul_reason_for_call,
  474. LPVOID lpReserved
  475. )
  476. {
  477. switch (ul_reason_for_call)
  478. {
  479. case DLL_PROCESS_ATTACH:
  480. case DLL_THREAD_ATTACH:
  481. case DLL_THREAD_DETACH:
  482. case DLL_PROCESS_DETACH:
  483. break;
  484. }
  485. return TRUE;
  486. }
  487. #endif // RVC_OS_WIN
  488. DEVICEBASE_API ErrorCodeEnum CreateDevComponent(DeviceBaseClass*& pBaseObj)
  489. {
  490. pBaseObj = new IDCerClassImpl();
  491. if (pBaseObj == NULL)
  492. return Error_Resource;
  493. cmb::log_init_config config;
  494. config.dev_name = "vendor_IDCertificate";
  495. #ifdef RVC_OS_WIN
  496. config.log_dir = ("D:\\rvc\\dbg\\");
  497. #else
  498. config.log_dir = ("/opt/rvc/dbg/");
  499. #endif
  500. std::string str;
  501. cmb::log4vendor::init(config, str);
  502. printf("init after: %s\n", str.c_str());
  503. return Error_Succeed;
  504. }
  505. DEVICEBASE_API ErrorCodeEnum ReleaseDevComponent(DeviceBaseClass*& pBaseObj)
  506. {
  507. if (pBaseObj == NULL)
  508. return Error_Param;
  509. IDCerClassImpl* pTmp = (IDCerClassImpl*)(pBaseObj);
  510. delete pTmp;
  511. pTmp = NULL;
  512. pBaseObj = NULL;
  513. return Error_Succeed;
  514. }
  515. #ifdef NEWER_COMPILER_WORKAROUNDS
  516. DEVICEBASE_API ErrorCodeEnum GetDevAdapterVersion(DevSoftVersion& retVesion)
  517. {
  518. retVesion.wMajor = retVesion.wMinor = retVesion.wBuild = retVesion.wRevision = 0;
  519. return Error_Succeed;
  520. }
  521. #endif // NEWER_COMPILER_WORKAROUNDS