CDSIncCctvCtlrF.cpp 46 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSIncCctvCtlrF.h"
  4. #include "ITS_OPLibF.h"
  5. //---------------------------------------------------------------------------
  6. #pragma package(smart_init)
  7. //---------------------------------------------------------------------------
  8. TIncCctvCtlr::TIncCctvCtlr()
  9. {
  10. }
  11. //---------------------------------------------------------------------------
  12. TIncCctvCtlr::~TIncCctvCtlr()
  13. {
  14. }
  15. //---------------------------------------------------------------------------
  16. //---------------------------------------------------------------------------
  17. TIncCctvCtlrManager *IncCctvCtlrManager = NULL;
  18. //---------------------------------------------------------------------------
  19. TIncCctvCtlrManager::TIncCctvCtlrManager()
  20. {
  21. FImgStream = NULL;
  22. }
  23. //---------------------------------------------------------------------------
  24. TIncCctvCtlrManager::~TIncCctvCtlrManager()
  25. {
  26. FLists.RemoveAll();
  27. if (FImgStream) delete FImgStream;
  28. FImgStream = NULL;
  29. }
  30. //---------------------------------------------------------------------------
  31. bool TIncCctvCtlrManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  32. {
  33. String sQry;
  34. TADOQuery *pADO = NULL;
  35. sQry = "SELECT A.* \r\n"
  36. " FROM VW_INC_CCTV_CTLR A \r\n";
  37. " WHERE A.DEL_YN = 'N' \r\n";
  38. FLists.Lock();
  39. try
  40. {
  41. FLists.RemoveAll();
  42. try
  43. {
  44. pADO = new TADOQuery(NULL);
  45. pADO->Close();
  46. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  47. pADO->SQL->Clear();
  48. pADO->SQL->Text = sQry;
  49. pADO->Prepared = true;
  50. pADO->Open();
  51. for( ; !pADO->Eof; pADO->Next())
  52. {
  53. TIncCctvCtlr *pObj = new TIncCctvCtlr();
  54. #if 0
  55. pObj->CTLR_NMBR = pADO->FieldByName("CCTV_CTLR_NMBR")->AsString; // N NUMBER(10) N CCTV 제어기 번호
  56. pObj->NAME = pADO->FieldByName("CCTV_NM")->AsString.Trim(); // N VARCHAR2(40) Y CCTV 명칭
  57. pObj->CCTV_TYPE_CD = pADO->FieldByName("CCTV_TYPE_CD")->AsString.Trim(); // N VARCHAR2(7) Y CCTV 유형
  58. pObj->CCTV_CTLR_LOCAL_NO = pADO->FieldByName("CCTV_CTLR_LOCAL_NO")->AsInteger; // N NUMBER(5) Y CCTV 제어기 지역번호
  59. pObj->STRM_STOR_ADDR = pADO->FieldByName("STRM_STOR_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 스트리밍 저장 주소
  60. pObj->INTR_RTSP_ADDR = pADO->FieldByName("INTR_RTSP_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 내부 RTSP 주소
  61. pObj->INTR_RTMP_ADDR = pADO->FieldByName("INTR_RTMP_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 내부 RTMP 주소
  62. pObj->INTR_HTTP_ADDR = pADO->FieldByName("INTR_HTTP_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 내부 HTTP 주소
  63. pObj->CCTV_SBST_DSPL_YN = pADO->FieldByName("CCTV_SBST_DSPL_YN")->AsString.Trim(); // N CHAR(1) Y 'N' CCTV 대체 표출 여부
  64. pObj->SYOP_CNTL_YN = pADO->FieldByName("SYOP_CNTL_YN")->AsString.Trim(); // N CHAR(1) Y 'N' 운영자 제어 여부
  65. pObj->CCTV_IP = pADO->FieldByName("CCTV_IP")->AsString.Trim(); // N VARCHAR2(20) Y 목포 CCTV 제어 IP
  66. pObj->CCTV_PORT = pADO->FieldByName("CCTV_PORT")->AsInteger; // N NUMBER(5) Y 1852 목포 CCTV 제어 PORT
  67. pObj->CCTV_ID = pADO->FieldByName("CCTV_ID")->AsString.Trim(); // N VARCHAR2(20) Y 'root' 목포 CCTV 제어 ID
  68. pObj->CCTV_PSWD = pADO->FieldByName("CCTV_PSWD")->AsString.Trim(); // N VARCHAR2(20) Y '1234' 목포 CCTV 제어 PSWD
  69. pObj->CCTV_CHNL = pADO->FieldByName("CCTV_CHNL")->AsInteger; // N NUMBER(5) Y 1 목포 CCTV 제어 CHANNEL
  70. #else
  71. pObj->CTLR_NMBR = pADO->FieldByName("CCTV_MNGM_NMBR")->AsString; // N NUMBER(10) N CCTV 제어기 번호
  72. pObj->NAME = pADO->FieldByName("ISTL_LCTN_NM")->AsString.Trim(); // N VARCHAR2(40) Y CCTV 명칭
  73. #endif
  74. pObj->CTLR_ID = pADO->FieldByName("CCTV_CTLR_ID")->AsString.Trim(); // N VARCHAR2(30) Y CCTV 제어기 ID
  75. pObj->CTLR_IP = pADO->FieldByName("CCTV_CTLR_IP")->AsString.Trim(); // N VARCHAR2(20) Y CCTV 제어기 아이피
  76. pObj->CTLR_PORT = pADO->FieldByName("CCTV_CTLR_PORT")->AsInteger; // N NUMBER(5) Y CCTV 제어기 포트
  77. pObj->ISTL_LCTN_NM = pADO->FieldByName("ISTL_LCTN_NM")->AsString.Trim(); // N VARCHAR2(40) Y 설치 위치 명
  78. pObj->X_CRDN = pADO->FieldByName("X_CRDN")->AsFloat; // N NUMBER(11,8) Y X 좌표
  79. pObj->Y_CRDN = pADO->FieldByName("Y_CRDN")->AsFloat; // N NUMBER(10,8) Y Y 좌표
  80. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString.Trim(); // N CHAR(1) Y 'N' 삭제 여부
  81. pObj->CCTV_CAPT_IP = pADO->FieldByName("CCTV_CAPT_IP")->AsString.Trim(); // N VARCHAR2(20) Y CCTV 자막기 아이피
  82. pObj->CCTV_CAPT_PORT = pADO->FieldByName("CCTV_CAPT_PORT")->AsString.Trim(); // N VARCHAR2(5) Y CCTV 자막기 포트
  83. pObj->CCTV_FIBR_IP = pADO->FieldByName("CCTV_FIBR_IP")->AsString.Trim(); // N VARCHAR2(20) Y CCTV 광장비 아이피
  84. pObj->CCTV_ENCD_IP = pADO->FieldByName("CCTV_ENCD_IP")->AsString.Trim(); // N VARCHAR2(20) Y CCTV 인코더 아이피
  85. pObj->STRM_SVR_IP = pADO->FieldByName("STRM_SVR_IP")->AsString.Trim(); // N VARCHAR2(20) Y 스트리밍 서버 아이피
  86. pObj->STRM_SVR_PORT = pADO->FieldByName("STRM_SVR_PORT")->AsString.Trim(); // N VARCHAR2(5) Y 스트리밍 서버 포트
  87. pObj->STRM_SESN_NM = pADO->FieldByName("STRM_SESN_NM")->AsString.Trim(); // N VARCHAR2(200) Y 스트리밍 세션 명
  88. pObj->STRM_RTSP_ADDR = pADO->FieldByName("STRM_RTSP_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 스트리밍 RTSP 주소
  89. pObj->STRM_RTMP_ADDR = pADO->FieldByName("STRM_RTMP_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 스트리밍 RTMP 주소
  90. pObj->STRM_HTTP_ADDR = pADO->FieldByName("STRM_HTTP_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 스트리밍 HTTP 주소
  91. //pObj->CCTV_SBST_IMGN = pADO->FieldByName("CCTV_SBST_IMGN")->AsString.Trim(); // N BLOB Y CCTV 대체 영상
  92. pObj->STRM_ADDR = pObj->STRM_SESN_NM;
  93. pObj->FULL_STRM_ADDR = "";
  94. pObj->STATE.Comm = cctv_error;
  95. FLists.Push(pObj->CTLR_NMBR, pObj);
  96. pObj->Completed = true;
  97. }
  98. }
  99. catch(EDatabaseError &E)
  100. {
  101. DBERRORMSG("TIncCctvCtlrManager::LoadFromDb", String(E.ClassName()), E.Message, sQry);
  102. throw Exception(String(E.ClassName()) + E.Message);
  103. }
  104. catch(Exception &e)
  105. {
  106. DBERRORMSG("TIncCctvCtlrManager::LoadFromDb", String(e.ClassName()), e.Message, sQry);
  107. throw Exception(String(e.ClassName()) + e.Message);
  108. }
  109. }
  110. __finally
  111. {
  112. if (pADO)
  113. {
  114. pADO->Close();
  115. delete pADO;
  116. }
  117. FLists.UnLock();
  118. }
  119. return true;
  120. }
  121. //---------------------------------------------------------------------------
  122. bool TIncCctvCtlrManager::LoadStatusFromDb(TADOConnection *ADbConn/*=NULL*/)
  123. {
  124. String sQry;
  125. TADOQuery *pADO = NULL;
  126. sQry = "SELECT * \r\n"
  127. " FROM TB_CCTV_CTLR_STTS A, \r\n"
  128. " VW_INC_CCTV_CTLR B \r\n"
  129. " WHERE A.CCTV_CTLR_NMBR = B.CCTV_CTLR_NMBR \r\n"
  130. " AND A.UPDT_DT >= TO_CHAR(SYSDATE-2/1440, 'YYYYMMDDHH24MISS') \r\n";
  131. FLists.Lock();
  132. try
  133. {
  134. TIncCctvCtlr *pObj = NULL;
  135. try
  136. {
  137. int nORD;
  138. pADO = new TADOQuery(NULL);
  139. pADO->Close();
  140. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  141. pADO->SQL->Clear();
  142. pADO->SQL->Text = sQry;
  143. pADO->Prepared = true;
  144. pADO->Open();
  145. for( ; !pADO->Eof; pADO->Next())
  146. {
  147. String CCTV_CTLR_NMBR = pADO->FieldByName("CCTV_CTLR_NMBR")->AsString;
  148. pObj = FLists.Find(CCTV_CTLR_NMBR);
  149. if (!pObj) continue;
  150. String UPDT_DT = pADO->FieldByName("UPDT_DT")->AsString;
  151. String CONN_STTS_CD = pADO->FieldByName("CONN_STTS_CD")->AsString;
  152. if (CONN_STTS_CD != "CMS0")
  153. {
  154. //통신장애
  155. continue;
  156. }
  157. pObj->STATE.Comm = (CONN_STTS_CD == "CMS0") ? cctv_normal : cctv_error;
  158. }
  159. }
  160. catch(EDatabaseError &E)
  161. {
  162. DBERRORLOG("TIncCctvCtlrManager::LoadStatusFromDb", String(E.ClassName()), E.Message, sQry);
  163. throw Exception(String(E.ClassName()) + E.Message);
  164. }
  165. catch(Exception &e)
  166. {
  167. DBERRORLOG("TIncCctvCtlrManager::LoadStatusFromDb", String(e.ClassName()), e.Message, sQry);
  168. throw Exception(String(e.ClassName()) + e.Message);
  169. }
  170. }
  171. __finally
  172. {
  173. FLists.UnLock();
  174. if (pADO)
  175. {
  176. pADO->Close();
  177. delete pADO;
  178. }
  179. }
  180. return true;
  181. }
  182. //---------------------------------------------------------------------------
  183. bool TIncCctvCtlrManager::DeleteCctv(TIncCctvCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  184. {
  185. String sQry;
  186. TADOQuery *pADO = NULL;
  187. sQry = "UPDATE VW_INC_CCTV_CTLR \r\n"
  188. " SET DEL_YN = 'Y' \r\n"
  189. " WHERE CCTV_CTLR_NMBR = :p01 \r\n";
  190. try
  191. {
  192. try
  193. {
  194. pADO = new TADOQuery(NULL);
  195. pADO->Close();
  196. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  197. pADO->SQL->Clear();
  198. pADO->SQL->Text = sQry;
  199. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  200. pADO->ExecSQL();
  201. sQry = "DELETE TB_FCLT_INFR \r\n"
  202. " WHERE FCLT_ID = :p01 \r\n";
  203. pADO->SQL->Clear();
  204. pADO->SQL->Text = sQry;
  205. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_ID;
  206. pADO->ExecSQL();
  207. return true;
  208. }
  209. catch(EDatabaseError &E)
  210. {
  211. DBERRORLOG("TIncCctvCtlrManager::DeleteCctv", String(E.ClassName()), E.Message, sQry);
  212. throw Exception(String(E.ClassName()) + E.Message);
  213. }
  214. catch(Exception &e)
  215. {
  216. DBERRORLOG("TIncCctvCtlrManager::DeleteCctv", String(e.ClassName()), e.Message, sQry);
  217. throw Exception(String(e.ClassName()) + e.Message);
  218. }
  219. }
  220. __finally
  221. {
  222. if (pADO)
  223. {
  224. pADO->Close();
  225. delete pADO;
  226. }
  227. }
  228. return true;
  229. }
  230. //---------------------------------------------------------------------------
  231. bool TIncCctvCtlrManager::InsertCctv(TIncCctvCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  232. {
  233. String sQry;
  234. TADOQuery *pADO = NULL;
  235. sQry = "MERGE INTO VW_INC_CCTV_CTLR L \r\n"
  236. "USING (SELECT \r\n"
  237. " :p01 AS CCTV_CTLR_NMBR, \r\n"
  238. " :p02 AS CCTV_CTLR_ID, \r\n"
  239. " :p03 AS CCTV_NM, \r\n"
  240. " :p04 AS CCTV_CTLR_IP, \r\n"
  241. " :p05 AS CCTV_CTLR_PORT, \r\n"
  242. " :p06 AS CCTV_CTLR_LOCAL_NO, \r\n"
  243. " :p07 AS CCTV_TYPE_CD, \r\n"
  244. " :p08 AS ISTL_LCTN_NM, \r\n"
  245. " :p09 AS X_CRDN, \r\n"
  246. " :p10 AS Y_CRDN, \r\n"
  247. " :p11 AS DEL_YN, \r\n"
  248. " :p12 AS STRM_SVR_IP, \r\n"
  249. " :p13 AS STRM_SESN_NM, \r\n"
  250. " :p14 AS STRM_RTSP_ADDR, \r\n"
  251. " :p15 AS STRM_RTMP_ADDR, \r\n"
  252. " :p16 AS STRM_HTTP_ADDR, \r\n"
  253. " :p17 AS CCTV_IP, \r\n"
  254. " :p18 AS CCTV_PORT, \r\n"
  255. " :p19 AS CCTV_ID, \r\n"
  256. " :p20 AS CCTV_PSWD, \r\n"
  257. " :p21 AS CCTV_CHNL \r\n"
  258. " FROM DUAL) M \r\n"
  259. " ON (L.CCTV_CTLR_NMBR = M.CCTV_CTLR_NMBR) \r\n"
  260. "WHEN MATCHED THEN \r\n"
  261. " UPDATE SET L.CCTV_CTLR_ID = M.CCTV_CTLR_ID, \r\n"
  262. " L.CCTV_NM = M.CCTV_NM, \r\n"
  263. " L.CCTV_CTLR_IP = M.CCTV_CTLR_IP, \r\n"
  264. " L.CCTV_CTLR_PORT = M.CCTV_CTLR_PORT, \r\n"
  265. " L.CCTV_CTLR_LOCAL_NO = M.CCTV_CTLR_LOCAL_NO, \r\n"
  266. " L.CCTV_TYPE_CD = M.CCTV_TYPE_CD, \r\n"
  267. " L.ISTL_LCTN_NM = M.ISTL_LCTN_NM, \r\n"
  268. " L.X_CRDN = M.X_CRDN, \r\n"
  269. " L.Y_CRDN = M.Y_CRDN, \r\n"
  270. " L.DEL_YN = M.DEL_YN, \r\n"
  271. " L.STRM_SVR_IP = M.STRM_SVR_IP, \r\n"
  272. " L.STRM_SESN_NM = M.STRM_SESN_NM, \r\n"
  273. " L.STRM_RTSP_ADDR = M.STRM_RTSP_ADDR, \r\n"
  274. " L.STRM_RTMP_ADDR = M.STRM_RTMP_ADDR, \r\n"
  275. " L.STRM_HTTP_ADDR = M.STRM_HTTP_ADDR, \r\n"
  276. " L.CCTV_IP = M.CCTV_IP, \r\n"
  277. " L.CCTV_PORT = M.CCTV_PORT, \r\n"
  278. " L.CCTV_ID = M.CCTV_ID, \r\n"
  279. " L.CCTV_PSWD = M.CCTV_PSWD, \r\n"
  280. " L.CCTV_CHNL = M.CCTV_CHNL \r\n"
  281. "WHEN NOT MATCHED THEN \r\n"
  282. " INSERT ( \r\n"
  283. " CCTV_CTLR_NMBR, \r\n"
  284. " CCTV_CTLR_ID, \r\n"
  285. " CCTV_NM, \r\n"
  286. " CCTV_CTLR_IP, \r\n"
  287. " CCTV_CTLR_PORT, \r\n"
  288. " CCTV_CTLR_LOCAL_NO, \r\n"
  289. " CCTV_TYPE_CD, \r\n"
  290. " ISTL_LCTN_NM, \r\n"
  291. " X_CRDN, \r\n"
  292. " Y_CRDN, \r\n"
  293. " DEL_YN, \r\n"
  294. " STRM_SVR_IP, \r\n"
  295. " STRM_SESN_NM , \r\n"
  296. " STRM_RTSP_ADDR, \r\n"
  297. " STRM_RTMP_ADDR, \r\n"
  298. " STRM_HTTP_ADDR, \r\n"
  299. " CCTV_IP, \r\n"
  300. " CCTV_PORT, \r\n"
  301. " CCTV_ID, \r\n"
  302. " CCTV_PSWD, \r\n"
  303. " CCTV_CHNL \r\n"
  304. " ) \r\n"
  305. " VALUES ( \r\n"
  306. " M.CCTV_CTLR_NMBR, \r\n"
  307. " M.CCTV_CTLR_ID, \r\n"
  308. " M.CCTV_NM, \r\n"
  309. " M.CCTV_CTLR_IP, \r\n"
  310. " M.CCTV_CTLR_PORT, \r\n"
  311. " M.CCTV_CTLR_LOCAL_NO, \r\n"
  312. " M.CCTV_TYPE_CD, \r\n"
  313. " M.ISTL_LCTN_NM, \r\n"
  314. " M.X_CRDN, \r\n"
  315. " M.Y_CRDN, \r\n"
  316. " M.DEL_YN, \r\n"
  317. " M.STRM_SVR_IP, \r\n"
  318. " M.STRM_SESN_NM , \r\n"
  319. " M.STRM_RTSP_ADDR, \r\n"
  320. " M.STRM_RTMP_ADDR, \r\n"
  321. " M.STRM_HTTP_ADDR, \r\n"
  322. " M.CCTV_IP, \r\n"
  323. " M.CCTV_PORT, \r\n"
  324. " M.CCTV_ID, \r\n"
  325. " M.CCTV_PSWD, \r\n"
  326. " M.CCTV_CHNL \r\n"
  327. " ) \r\n";
  328. try
  329. {
  330. try
  331. {
  332. pADO = new TADOQuery(NULL);
  333. pADO->Close();
  334. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  335. pADO->SQL->Clear();
  336. pADO->SQL->Text = sQry;
  337. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  338. pADO->Parameters->ParamByName("p02")->Value = AObj->CTLR_ID;
  339. pADO->Parameters->ParamByName("p03")->Value = AObj->NAME;
  340. pADO->Parameters->ParamByName("p04")->Value = AObj->CTLR_IP;
  341. pADO->Parameters->ParamByName("p05")->Value = AObj->CTLR_PORT;
  342. pADO->Parameters->ParamByName("p06")->Value = AObj->CTLR_LOCAL_NO;
  343. pADO->Parameters->ParamByName("p07")->Value = AObj->TYPE_CD;
  344. pADO->Parameters->ParamByName("p08")->Value = AObj->ISTL_LCTN_NM;
  345. pADO->Parameters->ParamByName("p09")->Value = AObj->X_CRDN;
  346. pADO->Parameters->ParamByName("p10")->Value = AObj->Y_CRDN;
  347. pADO->Parameters->ParamByName("p11")->Value = AObj->DEL_YN;
  348. pADO->Parameters->ParamByName("p12")->Value = AObj->STRM_SVR_IP;
  349. pADO->Parameters->ParamByName("p13")->Value = AObj->STRM_SESN_NM;
  350. pADO->Parameters->ParamByName("p14")->Value = AObj->STRM_RTSP_ADDR;
  351. pADO->Parameters->ParamByName("p15")->Value = AObj->STRM_RTMP_ADDR;
  352. pADO->Parameters->ParamByName("p16")->Value = AObj->STRM_HTTP_ADDR;
  353. pADO->Parameters->ParamByName("p17")->Value = AObj->CCTV_IP;
  354. pADO->Parameters->ParamByName("p18")->Value = AObj->CCTV_PORT;
  355. pADO->Parameters->ParamByName("p19")->Value = AObj->CCTV_ID;
  356. pADO->Parameters->ParamByName("p20")->Value = AObj->CCTV_PSWD;
  357. pADO->Parameters->ParamByName("p21")->Value = AObj->CCTV_CHNL;
  358. pADO->ExecSQL();
  359. return MergeFcltInfo(AObj, ADbConn);
  360. }
  361. catch(EDatabaseError &E)
  362. {
  363. DBERRORLOG("TIncCctvCtlrManager::InsertCctv", String(E.ClassName()), E.Message, sQry);
  364. throw Exception(String(E.ClassName()) + E.Message);
  365. }
  366. catch(Exception &e)
  367. {
  368. DBERRORLOG("TIncCctvCtlrManager::InsertCctv", String(e.ClassName()), e.Message, sQry);
  369. throw Exception(String(e.ClassName()) + e.Message);
  370. }
  371. }
  372. __finally
  373. {
  374. if (pADO)
  375. {
  376. pADO->Close();
  377. delete pADO;
  378. }
  379. }
  380. return true;
  381. }
  382. //---------------------------------------------------------------------------
  383. bool TIncCctvCtlrManager::UpdateCctv(TIncCctvCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  384. {
  385. return MergeCctv(AObj, ADbConn);
  386. }
  387. //---------------------------------------------------------------------------
  388. bool TIncCctvCtlrManager::MergeCctv(TIncCctvCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  389. {
  390. String sQry;
  391. TADOQuery *pADO = NULL;
  392. sQry = "MERGE INTO VW_INC_CCTV_CTLR L \r\n"
  393. "USING (SELECT \r\n"
  394. " :p01 AS CCTV_CTLR_NMBR, \r\n"
  395. " :p02 AS CCTV_CTLR_ID, \r\n"
  396. " :p03 AS CCTV_NM, \r\n"
  397. " :p04 AS CCTV_CTLR_IP, \r\n"
  398. " :p05 AS CCTV_CTLR_PORT, \r\n"
  399. " :p06 AS CCTV_CTLR_LOCAL_NO, \r\n"
  400. " :p07 AS CCTV_TYPE_CD, \r\n"
  401. " :p08 AS ISTL_LCTN_NM, \r\n"
  402. " :p09 AS X_CRDN, \r\n"
  403. " :p10 AS Y_CRDN, \r\n"
  404. " :p11 AS DEL_YN, \r\n"
  405. " :p12 AS STRM_SVR_IP, \r\n"
  406. " :p13 AS STRM_SESN_NM, \r\n"
  407. " :p14 AS STRM_RTSP_ADDR, \r\n"
  408. " :p15 AS STRM_RTMP_ADDR, \r\n"
  409. " :p16 AS STRM_HTTP_ADDR, \r\n"
  410. " :p17 AS CCTV_IP, \r\n"
  411. " :p18 AS CCTV_PORT, \r\n"
  412. " :p19 AS CCTV_ID, \r\n"
  413. " :p20 AS CCTV_PSWD, \r\n"
  414. " :p21 AS CCTV_CHNL \r\n"
  415. " FROM DUAL) M \r\n"
  416. " ON (L.CCTV_CTLR_NMBR = M.CCTV_CTLR_NMBR) \r\n"
  417. "WHEN MATCHED THEN \r\n"
  418. " UPDATE SET L.CCTV_CTLR_ID = M.CCTV_CTLR_ID, \r\n"
  419. " L.CCTV_NM = M.CCTV_NM, \r\n"
  420. " L.CCTV_CTLR_IP = M.CCTV_CTLR_IP, \r\n"
  421. " L.CCTV_CTLR_PORT = M.CCTV_CTLR_PORT, \r\n"
  422. " L.CCTV_CTLR_LOCAL_NO = M.CCTV_CTLR_LOCAL_NO, \r\n"
  423. " L.CCTV_TYPE_CD = M.CCTV_TYPE_CD, \r\n"
  424. " L.ISTL_LCTN_NM = M.ISTL_LCTN_NM, \r\n"
  425. " L.X_CRDN = M.X_CRDN, \r\n"
  426. " L.Y_CRDN = M.Y_CRDN, \r\n"
  427. " L.DEL_YN = M.DEL_YN, \r\n"
  428. " L.STRM_SVR_IP = M.STRM_SVR_IP, \r\n"
  429. " L.STRM_SESN_NM = M.STRM_SESN_NM, \r\n"
  430. " L.STRM_RTSP_ADDR = M.STRM_RTSP_ADDR, \r\n"
  431. " L.STRM_RTMP_ADDR = M.STRM_RTMP_ADDR, \r\n"
  432. " L.STRM_HTTP_ADDR = M.STRM_HTTP_ADDR, \r\n"
  433. " L.CCTV_IP = M.CCTV_IP, \r\n"
  434. " L.CCTV_PORT = M.CCTV_PORT, \r\n"
  435. " L.CCTV_ID = M.CCTV_ID, \r\n"
  436. " L.CCTV_PSWD = M.CCTV_PSWD, \r\n"
  437. " L.CCTV_CHNL = M.CCTV_CHNL \r\n"
  438. "WHEN NOT MATCHED THEN \r\n"
  439. " INSERT ( \r\n"
  440. " CCTV_CTLR_NMBR, \r\n"
  441. " CCTV_CTLR_ID, \r\n"
  442. " CCTV_NM, \r\n"
  443. " CCTV_CTLR_IP, \r\n"
  444. " CCTV_CTLR_PORT, \r\n"
  445. " CCTV_CTLR_LOCAL_NO, \r\n"
  446. " CCTV_TYPE_CD, \r\n"
  447. " ISTL_LCTN_NM, \r\n"
  448. " X_CRDN, \r\n"
  449. " Y_CRDN, \r\n"
  450. " DEL_YN, \r\n"
  451. " STRM_SVR_IP, \r\n"
  452. " STRM_SESN_NM , \r\n"
  453. " STRM_RTSP_ADDR, \r\n"
  454. " STRM_RTMP_ADDR, \r\n"
  455. " STRM_HTTP_ADDR, \r\n"
  456. " CCTV_IP, \r\n"
  457. " CCTV_PORT, \r\n"
  458. " CCTV_ID, \r\n"
  459. " CCTV_PSWD, \r\n"
  460. " CCTV_CHNL \r\n"
  461. " ) \r\n"
  462. " VALUES ( \r\n"
  463. " M.CCTV_CTLR_NMBR, \r\n"
  464. " M.CCTV_CTLR_ID, \r\n"
  465. " M.CCTV_NM, \r\n"
  466. " M.CCTV_CTLR_IP, \r\n"
  467. " M.CCTV_CTLR_PORT, \r\n"
  468. " M.CCTV_CTLR_LOCAL_NO, \r\n"
  469. " M.CCTV_TYPE_CD, \r\n"
  470. " M.ISTL_LCTN_NM, \r\n"
  471. " M.X_CRDN, \r\n"
  472. " M.Y_CRDN, \r\n"
  473. " M.DEL_YN, \r\n"
  474. " M.STRM_SVR_IP, \r\n"
  475. " M.STRM_SESN_NM , \r\n"
  476. " M.STRM_RTSP_ADDR, \r\n"
  477. " M.STRM_RTMP_ADDR, \r\n"
  478. " M.STRM_HTTP_ADDR, \r\n"
  479. " M.CCTV_IP, \r\n"
  480. " M.CCTV_PORT, \r\n"
  481. " M.CCTV_ID, \r\n"
  482. " M.CCTV_PSWD, \r\n"
  483. " M.CCTV_CHNL \r\n"
  484. " ) \r\n";
  485. try
  486. {
  487. try
  488. {
  489. pADO = new TADOQuery(NULL);
  490. pADO->Close();
  491. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  492. pADO->SQL->Clear();
  493. pADO->SQL->Text = sQry;
  494. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  495. pADO->Parameters->ParamByName("p02")->Value = AObj->CTLR_ID;
  496. pADO->Parameters->ParamByName("p03")->Value = AObj->NAME;
  497. pADO->Parameters->ParamByName("p04")->Value = AObj->CTLR_IP;
  498. pADO->Parameters->ParamByName("p05")->Value = AObj->CTLR_PORT;
  499. pADO->Parameters->ParamByName("p06")->Value = AObj->CTLR_LOCAL_NO;
  500. pADO->Parameters->ParamByName("p07")->Value = AObj->TYPE_CD;
  501. pADO->Parameters->ParamByName("p08")->Value = AObj->ISTL_LCTN_NM;
  502. pADO->Parameters->ParamByName("p09")->Value = AObj->X_CRDN;
  503. pADO->Parameters->ParamByName("p10")->Value = AObj->Y_CRDN;
  504. pADO->Parameters->ParamByName("p11")->Value = AObj->DEL_YN;
  505. pADO->Parameters->ParamByName("p12")->Value = AObj->STRM_SVR_IP;
  506. pADO->Parameters->ParamByName("p13")->Value = AObj->STRM_SESN_NM;
  507. pADO->Parameters->ParamByName("p14")->Value = AObj->STRM_RTSP_ADDR;
  508. pADO->Parameters->ParamByName("p15")->Value = AObj->STRM_RTMP_ADDR;
  509. pADO->Parameters->ParamByName("p16")->Value = AObj->STRM_HTTP_ADDR;
  510. pADO->Parameters->ParamByName("p17")->Value = AObj->CCTV_IP;
  511. pADO->Parameters->ParamByName("p18")->Value = AObj->CCTV_PORT;
  512. pADO->Parameters->ParamByName("p19")->Value = AObj->CCTV_ID;
  513. pADO->Parameters->ParamByName("p20")->Value = AObj->CCTV_PSWD;
  514. pADO->Parameters->ParamByName("p21")->Value = AObj->CCTV_CHNL;
  515. pADO->ExecSQL();
  516. return MergeFcltInfo(AObj, ADbConn);
  517. }
  518. catch(EDatabaseError &E)
  519. {
  520. DBERRORLOG("TIncCctvCtlrManager::MergeCctv", String(E.ClassName()), E.Message, sQry);
  521. throw Exception(String(E.ClassName()) + E.Message);
  522. }
  523. catch(Exception &e)
  524. {
  525. DBERRORLOG("TIncCctvCtlrManager::MergeCctv", String(e.ClassName()), e.Message, sQry);
  526. throw Exception(String(e.ClassName()) + e.Message);
  527. }
  528. }
  529. __finally
  530. {
  531. if (pADO)
  532. {
  533. pADO->Close();
  534. delete pADO;
  535. }
  536. }
  537. return true;
  538. }
  539. //---------------------------------------------------------------------------
  540. bool TIncCctvCtlrManager::MergeFcltInfo(TIncCctvCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  541. {
  542. String sQry;
  543. TADOQuery *pADO = NULL;
  544. sQry = "MERGE INTO TB_FCLT_INFR L \r\n"
  545. "USING (SELECT :p01 AS FCLT_ID, \r\n"
  546. " :p02 AS FCLT_TYPE, \r\n"
  547. " :p03 AS FCLT_LCTN \r\n"
  548. " FROM DUAL) M \r\n"
  549. " ON (L.FCLT_ID = M.FCLT_ID AND L.FCLT_TYPE = M.FCLT_TYPE) \r\n"
  550. "WHEN MATCHED \r\n"
  551. "THEN \r\n"
  552. " UPDATE SET L.FCLT_LCTN = M.FCLT_LCTN, \r\n"
  553. " L.DEL_YN = 'N' \r\n"
  554. "WHEN NOT MATCHED \r\n"
  555. "THEN \r\n"
  556. " INSERT ( FCLT_ID, FCLT_TYPE, FCLT_LCTN) \r\n"
  557. " VALUES (M.FCLT_ID, M.FCLT_TYPE, M.FCLT_LCTN) \r\n";
  558. try
  559. {
  560. try
  561. {
  562. pADO = new TADOQuery(NULL);
  563. pADO->Close();
  564. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  565. pADO->SQL->Clear();
  566. pADO->SQL->Text = sQry;
  567. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_ID;
  568. pADO->Parameters->ParamByName("p02")->Value = "ICAM";
  569. pADO->Parameters->ParamByName("p03")->Value = AObj->NAME;
  570. pADO->ExecSQL();
  571. return true;
  572. }
  573. catch(EDatabaseError &E)
  574. {
  575. DBERRORLOG("TIncCctvCtlrManager::MergeFcltInfo", String(E.ClassName()), E.Message, sQry);
  576. throw Exception(String(E.ClassName()) + E.Message);
  577. }
  578. catch(Exception &e)
  579. {
  580. DBERRORLOG("TIncCctvCtlrManager::MergeFcltInfo", String(e.ClassName()), e.Message, sQry);
  581. throw Exception(String(e.ClassName()) + e.Message);
  582. }
  583. }
  584. __finally
  585. {
  586. if (pADO)
  587. {
  588. pADO->Close();
  589. delete pADO;
  590. }
  591. }
  592. return true;
  593. }
  594. //---------------------------------------------------------------------------
  595. bool TIncCctvCtlrManager::GetNextCctvId(int &ANmbr, int &AId, TADOConnection *ADbConn/*=NULL*/)
  596. {
  597. String sQry;
  598. TADOQuery *pADO = NULL;
  599. sQry = "SELECT NVL(MAX(CCTV_CTLR_NMBR), 10000) + 1 AS NEWID FROM VW_INC_CCTV_CTLR \r\n";
  600. try
  601. {
  602. try
  603. {
  604. pADO = new TADOQuery(NULL);
  605. pADO->Close();
  606. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  607. pADO->SQL->Clear();
  608. pADO->SQL->Text = sQry;
  609. pADO->Prepared = true;
  610. pADO->Open();
  611. ANmbr = pADO->FieldByName("NEWID")->AsInteger;
  612. AId = ANmbr / 10000;
  613. return true;
  614. }
  615. catch(EDatabaseError &E)
  616. {
  617. DBERRORLOG("TIncCctvCtlrManager::GetNextCctvId", String(E.ClassName()), E.Message, sQry);
  618. throw Exception(String(E.ClassName()) + E.Message);
  619. }
  620. catch(Exception &e)
  621. {
  622. DBERRORLOG("TIncCctvCtlrManager::GetNextCctvId", String(e.ClassName()), e.Message, sQry);
  623. throw Exception(String(e.ClassName()) + e.Message);
  624. }
  625. }
  626. __finally
  627. {
  628. if (pADO)
  629. {
  630. pADO->Close();
  631. delete pADO;
  632. }
  633. }
  634. return false;
  635. }
  636. //---------------------------------------------------------------------------
  637. bool TIncCctvCtlrManager::LoadPreSet(TADOConnection *ADbConn/*=NULL*/)
  638. {
  639. String sQry;
  640. TADOQuery *pADO = NULL;
  641. FLists.Lock();
  642. try
  643. {
  644. FOR_STL(TIncCctvCtlr*, pObj, FLists)
  645. {
  646. pObj->FLists.RemoveAll();
  647. }
  648. }
  649. __finally
  650. {
  651. FLists.UnLock();
  652. }
  653. sQry = "SELECT B.* \r\n"
  654. " FROM VW_INC_CCTV_CTLR A, \r\n"
  655. " TB_CCTV_PSET B \r\n"
  656. " WHERE A.CCTV_CTLR_NMBR = B.CCTV_CTLR_NMBR \r\n"
  657. " ORDER BY B.CCTV_CTLR_NMBR, B.PSET_NMBR \r\n";
  658. try
  659. {
  660. String CCTV_CTLR_NMBR;
  661. FLists.Lock();
  662. try
  663. {
  664. pADO = new TADOQuery(NULL);
  665. pADO->Close();
  666. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  667. pADO->SQL->Clear();
  668. pADO->SQL->Text = sQry;
  669. pADO->Prepared = true;
  670. pADO->Open();
  671. for( ; !pADO->Eof; pADO->Next())
  672. {
  673. CCTV_CTLR_NMBR = pADO->FieldByName("CCTV_CTLR_NMBR")->AsString;
  674. TIncCctvCtlr *pCctv = FLists.Find(String(CCTV_CTLR_NMBR));
  675. if (!pCctv) continue;
  676. TIncCctvPset *pObj = new TIncCctvPset();
  677. if (pObj)
  678. {
  679. pObj->CCTV_CTLR_NMBR = CCTV_CTLR_NMBR;
  680. pObj->PSET_NMBR = pADO->FieldByName("PSET_NMBR")->AsInteger;
  681. pObj->PSET_NM = pADO->FieldByName("PSET_NM")->AsString;
  682. pObj->PAN = pADO->FieldByName("PAN")->AsInteger;
  683. pObj->TILT = pADO->FieldByName("TILT")->AsInteger;
  684. pObj->ZOOM = pADO->FieldByName("ZOOM")->AsInteger;
  685. pObj->FOCS = pADO->FieldByName("FOCS")->AsInteger;
  686. pObj->ANGLE = pADO->FieldByName("ANGLE")->AsInteger;
  687. pObj->DFLT_YN = pADO->FieldByName("DFLT_YN")->AsString;
  688. pObj->DEL_YN = "N";
  689. pCctv->FLists.Push(pObj->PSET_NMBR, pObj);
  690. }
  691. }
  692. }
  693. catch(EDatabaseError &E)
  694. {
  695. DBERRORMSG("TIncCctvCtlrManager::LoadPreSet", String(E.ClassName()), E.Message, sQry);
  696. throw Exception(String(E.ClassName()) + E.Message);
  697. }
  698. catch(Exception &e)
  699. {
  700. DBERRORMSG("TIncCctvCtlrManager::LoadPreSet", String(e.ClassName()), e.Message, sQry);
  701. throw Exception(String(e.ClassName()) + e.Message);
  702. }
  703. }
  704. __finally
  705. {
  706. if (pADO)
  707. {
  708. pADO->Close();
  709. delete pADO;
  710. }
  711. FLists.UnLock();
  712. }
  713. return true;
  714. }
  715. //---------------------------------------------------------------------------
  716. bool TIncCctvCtlrManager::SavePreSet(TIncCctvCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  717. {
  718. String sQry;
  719. TADOQuery *pADO = NULL;
  720. try
  721. {
  722. try
  723. {
  724. pADO = new TADOQuery(NULL);
  725. pADO->Close();
  726. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  727. sQry = "DELETE FROM TB_CCTV_PSET WHERE CCTV_CTLR_NMBR = :p01";
  728. pADO->SQL->Clear();
  729. pADO->SQL->Text = sQry;
  730. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  731. pADO->ExecSQL();
  732. sQry = "INSERT INTO TB_CCTV_PSET( \r\n"
  733. " CCTV_CTLR_NMBR, \r\n"
  734. " PSET_NMBR, \r\n"
  735. " PSET_NM, \r\n"
  736. " PAN, \r\n"
  737. " TILT, \r\n"
  738. " ZOOM, \r\n"
  739. " FOCS, \r\n"
  740. " DFLT_YN ) \r\n"
  741. " VALUES(:p01, :p02, :p03, :p04, :p05, :p06, :p07, :p08) \r\n";
  742. pADO->SQL->Clear();
  743. pADO->SQL->Text = sQry;
  744. FOR_STL(TIncCctvPset *, pObj, AObj->FLists)
  745. {
  746. if (pObj->DEL_YN != "N") continue;
  747. pADO->Parameters->ParamByName("p01")->Value = pObj->CCTV_CTLR_NMBR;
  748. pADO->Parameters->ParamByName("p02")->Value = pObj->PSET_NMBR;
  749. pADO->Parameters->ParamByName("p03")->Value = pObj->PSET_NM;
  750. pADO->Parameters->ParamByName("p04")->Value = pObj->PAN;
  751. pADO->Parameters->ParamByName("p05")->Value = pObj->TILT;
  752. pADO->Parameters->ParamByName("p06")->Value = pObj->ZOOM;
  753. pADO->Parameters->ParamByName("p07")->Value = pObj->FOCS;
  754. pADO->Parameters->ParamByName("p08")->Value = pObj->DFLT_YN;
  755. pADO->ExecSQL();
  756. }
  757. return true;
  758. }
  759. catch(EDatabaseError &E)
  760. {
  761. DBERRORLOG("TIncCctvCtlrManager::SavePreSet", String(E.ClassName()), E.Message, sQry);
  762. throw Exception(String(E.ClassName()) + E.Message);
  763. }
  764. catch(Exception &e)
  765. {
  766. DBERRORLOG("TIncCctvCtlrManager::SavePreSet", String(e.ClassName()), e.Message, sQry);
  767. throw Exception(String(e.ClassName()) + e.Message);
  768. }
  769. }
  770. __finally
  771. {
  772. if (pADO)
  773. {
  774. pADO->Close();
  775. delete pADO;
  776. }
  777. }
  778. return true;
  779. }
  780. //---------------------------------------------------------------------------
  781. bool TIncCctvCtlrManager::DeletePreSet(TIncCctvCtlr *AObj, int APsetNmbr, TADOConnection *ADbConn/*=NULL*/)
  782. {
  783. String sQry;
  784. TADOQuery *pADO = NULL;
  785. TIncCctvPset* pObj = AObj->FLists.Find(APsetNmbr);
  786. if (!pObj) return false;
  787. sQry = "DELETE FROM TB_CCTV_PSET WHERE CCTV_CTLR_NMBR = :p01 AND PSET_NMBR = :p02";
  788. try
  789. {
  790. try
  791. {
  792. pADO = new TADOQuery(NULL);
  793. pADO->Close();
  794. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  795. pADO->SQL->Clear();
  796. pADO->SQL->Text = sQry;
  797. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  798. pADO->Parameters->ParamByName("p02")->Value = APsetNmbr;
  799. pADO->ExecSQL();
  800. pObj->DEL_YN = "Y";
  801. return true;
  802. }
  803. catch(EDatabaseError &E)
  804. {
  805. DBERRORLOG("TIncCctvCtlrManager::DeletePreSet", String(E.ClassName()), E.Message, sQry);
  806. throw Exception(String(E.ClassName()) + E.Message);
  807. }
  808. catch(Exception &e)
  809. {
  810. DBERRORLOG("TIncCctvCtlrManager::DeletePreSet", String(e.ClassName()), e.Message, sQry);
  811. throw Exception(String(e.ClassName()) + e.Message);
  812. }
  813. }
  814. __finally
  815. {
  816. if (pADO)
  817. {
  818. pADO->Close();
  819. delete pADO;
  820. }
  821. }
  822. return true;
  823. }
  824. //---------------------------------------------------------------------------
  825. bool TIncCctvCtlrManager::MergePreSet(TIncCctvCtlr *AObj, TIncCctvPset* APset, TADOConnection *ADbConn/*=NULL*/)
  826. {
  827. String sQry;
  828. TADOQuery *pADO = NULL;
  829. try
  830. {
  831. try
  832. {
  833. pADO = new TADOQuery(NULL);
  834. pADO->Close();
  835. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  836. sQry = "MERGE INTO TB_CCTV_PSET L \r\n"
  837. "USING (SELECT \r\n"
  838. " :p01 AS CCTV_CTLR_NMBR, \r\n"
  839. " :p02 AS PSET_NMBR, \r\n"
  840. " :p03 AS PSET_NM, \r\n"
  841. " :p04 AS PAN, \r\n"
  842. " :p05 AS TILT, \r\n"
  843. " :p06 AS ZOOM, \r\n"
  844. " :p07 AS FOCS, \r\n"
  845. " :p08 AS DFLT_YN \r\n"
  846. " FROM DUAL) M \r\n"
  847. " ON (L.CCTV_CTLR_NMBR = M.CCTV_CTLR_NMBR \r\n"
  848. " AND L.PSET_NMBR = M.PSET_NMBR ) \r\n"
  849. "WHEN MATCHED THEN \r\n"
  850. " UPDATE SET L.PSET_NM = M.PSET_NM, \r\n"
  851. " L.PAN = M.PAN, \r\n"
  852. " L.TILT = M.TILT, \r\n"
  853. " L.ZOOM = M.ZOOM, \r\n"
  854. " L.FOCS = M.FOCS, \r\n"
  855. " L.DFLT_YN = M.DFLT_YN \r\n"
  856. "WHEN NOT MATCHED THEN \r\n"
  857. " INSERT ( \r\n"
  858. " CCTV_CTLR_NMBR, \r\n"
  859. " PSET_NMBR, \r\n"
  860. " PSET_NM, \r\n"
  861. " PAN, \r\n"
  862. " TILT, \r\n"
  863. " ZOOM, \r\n"
  864. " FOCS, \r\n"
  865. " DFLT_YN ) \r\n"
  866. " VALUES ( \r\n"
  867. " M.CCTV_CTLR_NMBR, \r\n"
  868. " M.PSET_NMBR, \r\n"
  869. " M.PSET_NM, \r\n"
  870. " M.PAN, \r\n"
  871. " M.TILT, \r\n"
  872. " M.ZOOM, \r\n"
  873. " M.FOCS, \r\n"
  874. " M.DFLT_YN ) \r\n";
  875. pADO->SQL->Clear();
  876. pADO->SQL->Text = sQry;
  877. FOR_STL(TIncCctvPset *, pObj, AObj->FLists)
  878. {
  879. if (pObj->DEL_YN != "N") continue;
  880. pADO->Parameters->ParamByName("p01")->Value = APset->CCTV_CTLR_NMBR;
  881. pADO->Parameters->ParamByName("p02")->Value = APset->PSET_NMBR;
  882. pADO->Parameters->ParamByName("p03")->Value = APset->PSET_NM;
  883. pADO->Parameters->ParamByName("p04")->Value = APset->PAN;
  884. pADO->Parameters->ParamByName("p05")->Value = APset->TILT;
  885. pADO->Parameters->ParamByName("p06")->Value = APset->ZOOM;
  886. pADO->Parameters->ParamByName("p07")->Value = APset->FOCS;
  887. pADO->Parameters->ParamByName("p08")->Value = APset->DFLT_YN;
  888. pADO->ExecSQL();
  889. TIncCctvPset* pObj = AObj->FLists.Find(APset->PSET_NMBR);
  890. if (pObj)
  891. {
  892. pObj->CCTV_CTLR_NMBR = APset->CCTV_CTLR_NMBR;
  893. pObj->PSET_NMBR = APset->PSET_NMBR;
  894. pObj->PSET_NM = APset->PSET_NM;
  895. pObj->PAN = APset->PAN;
  896. pObj->TILT = APset->TILT;
  897. pObj->ZOOM = APset->ZOOM;
  898. pObj->FOCS = APset->FOCS;
  899. pObj->DFLT_YN = APset->DFLT_YN;
  900. }
  901. else
  902. {
  903. AObj->FLists.Push(APset->PSET_NMBR, APset);
  904. }
  905. }
  906. return true;
  907. }
  908. catch(EDatabaseError &E)
  909. {
  910. DBERRORLOG("TIncCctvCtlrManager::SavePreSet", String(E.ClassName()), E.Message, sQry);
  911. throw Exception(String(E.ClassName()) + E.Message);
  912. }
  913. catch(Exception &e)
  914. {
  915. DBERRORLOG("TIncCctvCtlrManager::SavePreSet", String(e.ClassName()), e.Message, sQry);
  916. throw Exception(String(e.ClassName()) + e.Message);
  917. }
  918. }
  919. __finally
  920. {
  921. if (pADO)
  922. {
  923. pADO->Close();
  924. delete pADO;
  925. }
  926. }
  927. return true;
  928. }
  929. //---------------------------------------------------------------------------
  930. bool TIncCctvCtlrManager::InsCctvControlHs(String ACtlDt, String ACctvNmbr, String ACtlType, String ACtlVal, String ACtlRes, String AUserId, TADOConnection *ADbConn/*=NULL*/)
  931. {
  932. String sQry;
  933. TADOQuery *pADO = NULL;
  934. sQry = "INSERT INTO TB_CCTV_CTRL_HS( \r\n"
  935. " CTRL_DT, \r\n"
  936. " CCTV_CTLR_NMBR, \r\n"
  937. " CTRL_TYPE, \r\n"
  938. " CTRL_VAL, \r\n"
  939. " CTRL_RESULT, \r\n"
  940. " USER_ID \r\n"
  941. " ) \r\n"
  942. " VALUES( \r\n"
  943. " :p01, \r\n"
  944. " :p02, \r\n"
  945. " :p03, \r\n"
  946. " :p04, \r\n"
  947. " :p05, \r\n"
  948. " :p06 \r\n"
  949. " ) \r\n";
  950. try
  951. {
  952. try
  953. {
  954. pADO = new TADOQuery(NULL);
  955. pADO->Close();
  956. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  957. pADO->SQL->Clear();
  958. pADO->SQL->Text = sQry;
  959. pADO->Parameters->ParamByName("p01")->Value = ACtlDt;
  960. pADO->Parameters->ParamByName("p02")->Value = ACctvNmbr;
  961. pADO->Parameters->ParamByName("p03")->Value = ACtlType;
  962. pADO->Parameters->ParamByName("p04")->Value = ACtlVal;
  963. pADO->Parameters->ParamByName("p05")->Value = ACtlRes;
  964. pADO->Parameters->ParamByName("p06")->Value = AUserId;
  965. pADO->ExecSQL();
  966. return true;
  967. }
  968. catch(EDatabaseError &E)
  969. {
  970. DBERRORLOG("TIncCctvCtlrManager::InsCctvControlHs", String(E.ClassName()), E.Message, sQry);
  971. throw Exception(String(E.ClassName()) + E.Message);
  972. }
  973. catch(Exception &e)
  974. {
  975. DBERRORLOG("TIncCctvCtlrManager::InsCctvControlHs", String(e.ClassName()), e.Message, sQry);
  976. throw Exception(String(e.ClassName()) + e.Message);
  977. }
  978. }
  979. __finally
  980. {
  981. if (pADO)
  982. {
  983. pADO->Close();
  984. delete pADO;
  985. }
  986. }
  987. return true;
  988. }
  989. //---------------------------------------------------------------------------