CDSVmsCtlrF.cpp 63 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSVmsCtlrF.h"
  4. #include "ITSUtilF.h"
  5. #include "VMSOprMainLibF.h"
  6. //---------------------------------------------------------------------------
  7. #pragma package(smart_init)
  8. //---------------------------------------------------------------------------
  9. TVmsIfscRltn::TVmsIfscRltn()
  10. {
  11. }
  12. //---------------------------------------------------------------------------
  13. TVmsIfscRltn::~TVmsIfscRltn()
  14. {
  15. }
  16. //---------------------------------------------------------------------------
  17. //---------------------------------------------------------------------------
  18. TVmsMsg::TVmsMsg()
  19. {
  20. for (int ii = 0; ii < INT_VMS_MAX_FORM; ii++)
  21. {
  22. PHASE[ii].pVmsBmp = NULL;
  23. }
  24. Init();
  25. };
  26. //---------------------------------------------------------------------------
  27. TVmsMsg::~TVmsMsg()
  28. {
  29. for (int ii = 0; ii < INT_VMS_MAX_FORM; ii++)
  30. {
  31. if (PHASE[ii].pVmsBmp)
  32. {
  33. PHASE[ii].pVmsBmp->FreeImage();
  34. PHASE[ii].pVmsBmp->Assign(NULL);
  35. delete PHASE[ii].pVmsBmp;
  36. PHASE[ii].pVmsBmp = NULL;
  37. }
  38. }
  39. };
  40. //---------------------------------------------------------------------------
  41. void TVmsMsg::Init()
  42. {
  43. Total = 0;
  44. Curr = 0;
  45. OFFER_DT = "19990101000000";
  46. OFFER_YN = false;
  47. IsLoading= true;
  48. for (int ii = 0; ii < INT_VMS_MAX_FORM; ii++)
  49. {
  50. PHASE[ii].DSPL_HH = 4; //표출시간
  51. PHASE[ii].DNLD_YN = "N"; //다운로드성공여부
  52. PHASE[ii].DSPL_CD = ""; //표출방법
  53. PHASE[ii].VMS_SCH_FORM_TYPE = 0;
  54. PHASE[ii].VMS_DSPL_MSG_TXT = "";
  55. }
  56. };
  57. //---------------------------------------------------------------------------
  58. void VmsInitStatus(INT_VMS_STATE *AState)
  59. {
  60. int ii;
  61. if (AState->Comm != vms_comm_normal && AState->Wcomm != vms_wcomm_normal)
  62. {
  63. AState->DoorStatus = vms_door_unknown; /* 도어상태정보코드, 0:열림 1:닫힘 2:알수없음 */
  64. AState->ModulePowerStatus = vms_module_power_unknown; /* 모듈전원상태정보코드, 0:켜짐 1:꺼짐 2:알수없음 */
  65. AState->BodyTemp = 0; /* 함체온도값(℃), 범위(-128~127) */
  66. AState->LuminanceStatus = 0; /* 화면의 밝기값 (최대 휘도값을 100으로 했을 때의 백분율 값), 범위(0~100) */
  67. AState->FanStatus = vms_fan_unknown; /* Fan 동작상태정보코드, 0:켜짐, 1:꺼짐 2:알수없음 */
  68. AState->HeaterStatus = vms_heater_unknown; /* Heater 동작상태정보코드, 0:켜짐, 1:꺼짐 2:알수없음 */
  69. AState->ExternalLightStatus = vms_unknown; /* 선택 외부조명 동작상태정보코드 0:켜짐, 1:꺼짐, 2:자동(공단은 미사용) */
  70. AState->AlarmLightStatus = vms_unknown; /* 선택 경광등 동작상태정보코드 0:켜짐, 1:꺼짐 */
  71. AState->SpeakerStatus = vms_unknown; /* 선택 스피커 동작상태정보코드 0:켜짐, 1:꺼짐 */
  72. //memset(&AState->ControllerCurrentTime, 0x00, sizeof(AState->ControllerCurrentTime)); /*선택 제어기 시간 (YYYYMMDDHHMMSS) */
  73. AState->Voltage = 0; /* 전압, 범위(0~255), 사용안함 */
  74. // AState->ModuleState = vms_unknown; /* 모듈 상태, 0:정상 1:장애 2:알수없음 */
  75. #if 0
  76. //AState->ModuleHorizontal = 0; /* 가로 모듈수 */
  77. //AState->ModuleVertical = 0; /* 세로 모듈수 */
  78. for (ii = 0; ii < INT_VMS_MAX_MODULE_BIT; ii++)
  79. AState->ModuleStatus[ii] = 0xFF;//vms_unknown; /* 모듈 개별 상태, 0:정상 1:장애 2:알수없음 */
  80. //AState->PowerCount = 0; /* 전원 갯수 */
  81. for (ii = 0; ii < INT_VMS_MAX_POWER_BIT; ii++)
  82. AState->PowerStatus[ii] = 0xFF;//vms_unknown; /* 전원 개별 상태, 0:켜짐 1:꺼짐 2:알수없음 */
  83. #endif
  84. #if 0
  85. AState->ScheduledMessageOperatingTime = 0; /* 필수 계획된 메시지의 동작시간(초) */
  86. AState->ModuleOperatingTemperature = 0; /* 필수 모듈 전원이 꺼지는 온도값(℃) */
  87. AState->FanOperatingTemperature = 0; /* 필수 Fan 동작 기준 온도값(℃) */
  88. AState->HeaterOperatingTemperature = 0; /* 필수 Heater 동작 기준 온도값(℃) */
  89. AState->ExternalLightOperatingLuminance = 0; /* 선택 외부전등 동작 기준 휘도값 */
  90. AState->ModuleBasicFailureRate = 0; /* 선택 모듈 장애율 (한 개의 모듈을 장애로 처리하기 위한 픽셀의 백분율값) */
  91. AState->MaximumRetry = 0; /* 선택 최대 재시도 횟수(회) */
  92. AState->ResponseTimeOut = 0; /* 선택 최대응답대기시간 (초) */
  93. AState->BlinkingCycleTime = 0; /* 선택 점멸시간 주기 ( 1/10초단위) */
  94. #endif
  95. }
  96. for (ii = 0; ii < INT_VMS_MAX_MODULE_BIT; ii++)
  97. AState->ModuleStatus[ii] = 0xFF;//vms_unknown; /* 모듈 개별 상태, 0:정상 1:장애 2:알수없음 */
  98. //AState->PowerCount = 0; /* 전원 갯수 */
  99. for (ii = 0; ii < INT_VMS_MAX_POWER_BIT; ii++)
  100. AState->PowerStatus[ii] = 0xFF;//vms_unknown; /* 전원 개별 상태, 0:켜짐 1:꺼짐 2:알수없음 */
  101. }
  102. //---------------------------------------------------------------------------
  103. //---------------------------------------------------------------------------
  104. TVmsCtlr::TVmsCtlr()
  105. {
  106. memset(&STATE, 0x00, sizeof(STATE));
  107. STATE.Comm = vms_comm_error;
  108. VmsInitStatus(&STATE);
  109. STATE.Comm = vms_comm_error;
  110. InitFormCount();
  111. VmsMsg = NULL;
  112. VmsMsg = new TVmsMsg();
  113. VmsMsg->Init();
  114. RunState = state_error;
  115. }
  116. //---------------------------------------------------------------------------
  117. TVmsCtlr::~TVmsCtlr()
  118. {
  119. FIfscRltn.RemoveAll();
  120. }
  121. //---------------------------------------------------------------------------
  122. void TVmsCtlr::CheckRunState()
  123. {
  124. RunState = STATE.Comm;
  125. if (STATE.Comm == vms_comm_normal && STATE.Wcomm != vms_wcomm_normal)
  126. {
  127. STATE.DoorStatus = vms_door_unknown;
  128. STATE.ModulePowerStatus = vms_module_power_unknown;
  129. STATE.PowerCtrlStatus = vms_module_power_unknown;
  130. STATE.BodyTemp = 0;
  131. STATE.LuminanceStatus = 0;
  132. STATE.FanStatus = vms_fan_unknown;
  133. STATE.HeaterStatus = vms_heater_unknown;
  134. }
  135. }
  136. //---------------------------------------------------------------------------
  137. TVmsSize::TVmsSize()
  138. {
  139. }
  140. //---------------------------------------------------------------------------
  141. //---------------------------------------------------------------------------
  142. TVmsCtlrManager *VmsCtlrManager = NULL;
  143. //---------------------------------------------------------------------------
  144. TVmsCtlrManager::TVmsCtlrManager()
  145. {
  146. FImgStream = NULL;
  147. }
  148. //---------------------------------------------------------------------------
  149. TVmsCtlrManager::~TVmsCtlrManager()
  150. {
  151. FVmsSize.RemoveAll();
  152. FLists.RemoveAll();
  153. if (FImgStream) delete FImgStream;
  154. FImgStream = NULL;
  155. }
  156. //---------------------------------------------------------------------------
  157. void TVmsCtlrManager::InitFormCount()
  158. {
  159. FLists.Lock();
  160. try
  161. {
  162. FOR_STL(TVmsCtlr*, pObj, FLists)
  163. {
  164. pObj->InitFormCount();
  165. }
  166. }
  167. __finally
  168. {
  169. FLists.UnLock();
  170. }
  171. };
  172. //---------------------------------------------------------------------------
  173. bool TVmsCtlrManager::LoadVmsSize(TADOConnection *ADbConn/*=NULL*/)
  174. {
  175. String sQry;
  176. TADOQuery *pADO = NULL;
  177. FVmsSize.Lock();
  178. try
  179. {
  180. FVmsSize.RemoveAll();
  181. }
  182. __finally
  183. {
  184. FVmsSize.UnLock();
  185. }
  186. sQry = "SELECT VMS_TYPE_CD, VMS_TYPE_NM, \r\n"
  187. " VMS_WDTH, VMS_HGHT, MODL_ROW_NUM, MODL_COL_NUM \r\n"
  188. " FROM TB_VMS_TYPE \r\n"
  189. " WHERE USE_YN = 'Y' \r\n";
  190. FVmsSize.Lock();
  191. try
  192. {
  193. try
  194. {
  195. pADO = new TADOQuery(NULL);
  196. pADO->Close();
  197. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  198. pADO->SQL->Clear();
  199. pADO->SQL->Text = sQry;
  200. pADO->Prepared = true;
  201. pADO->Open();
  202. for( ; !pADO->Eof; pADO->Next())
  203. {
  204. TVmsSize *pObj = new TVmsSize();
  205. pObj->TypeCd = pADO->FieldByName("VMS_TYPE_CD")->AsString;
  206. pObj->TypeNm = pADO->FieldByName("VMS_TYPE_NM")->AsString;
  207. pObj->Width = pADO->FieldByName("VMS_WDTH")->AsInteger;
  208. pObj->Height = pADO->FieldByName("VMS_HGHT")->AsInteger;
  209. FVmsSize.Push(pObj->TypeCd, pObj);
  210. }
  211. }
  212. catch(EDatabaseError &E)
  213. {
  214. DBERRORMSG("TVmsCtlrManager::LoadVmsSize", String(E.ClassName()), E.Message, sQry);
  215. throw Exception(String(E.ClassName()) + E.Message);
  216. }
  217. catch(Exception &e)
  218. {
  219. DBERRORMSG("TVmsCtlrManager::LoadVmsSize", String(e.ClassName()), e.Message, sQry);
  220. throw Exception(String(e.ClassName()) + e.Message);
  221. }
  222. }
  223. __finally
  224. {
  225. if (pADO)
  226. {
  227. pADO->Close();
  228. delete pADO;
  229. }
  230. FVmsSize.UnLock();
  231. }
  232. return true;
  233. }
  234. //---------------------------------------------------------------------------
  235. bool TVmsCtlrManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  236. {
  237. String sQry;
  238. TADOQuery *pADO = NULL;
  239. FMinWidth = 1000;
  240. FMinHeight= 1000;
  241. FMaxWidth = 0;
  242. FMaxHeight= 0;
  243. sQry = "SELECT A.*, \r\n"
  244. // " scp.dec_b64('DAMO','SCP','ARIA_256.SCPS',A.WEB_CMRA_PWD) AS PWD, \r\n"
  245. " A.WEB_CMRA_PWD AS PWD, \r\n"
  246. " B.VMS_TYPE_NM, \r\n"
  247. " B.VMS_WDTH, B.VMS_HGHT, \r\n"
  248. " B.ROW_NUM, B.COL_NUM, \r\n"
  249. " B.MODL_ROW_NUM, B.MODL_COL_NUM, \r\n"
  250. " B.POWR_ROW_NUM, B.POWR_COL_NUM \r\n"
  251. " FROM TB_VMS_CTLR A, \r\n"
  252. " TB_VMS_TYPE B \r\n"
  253. " WHERE A.VMS_TYPE_CD = B.VMS_TYPE_CD \r\n"
  254. " AND A.DEL_YN = 'N' \r\n";
  255. FLists.Lock();
  256. try
  257. {
  258. FLists.RemoveAll();
  259. try
  260. {
  261. pADO = new TADOQuery(NULL);
  262. pADO->Close();
  263. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  264. pADO->SQL->Clear();
  265. pADO->SQL->Text = sQry;
  266. pADO->Prepared = true;
  267. pADO->Open();
  268. for( ; !pADO->Eof; pADO->Next())
  269. {
  270. TVmsCtlr *pObj = new TVmsCtlr();
  271. pObj->VMS_CTLR_NMBR = pADO->FieldByName("VMS_CTLR_NMBR")->AsString; // N NUMBER(10) N VMS 제어기 번호
  272. pObj->VMS_CTLR_ID = pADO->FieldByName("VMS_CTLR_ID")->AsString.Trim(); // N VARCHAR2(10) Y VMS 제어기 ID
  273. pObj->VMS_NM = pADO->FieldByName("VMS_NM")->AsString.Trim(); // N VARCHAR2(40) Y VMS 명칭
  274. pObj->VMS_CTLR_IP = pADO->FieldByName("VMS_CTLR_IP")->AsString.Trim(); // N VARCHAR2(20) Y VMS 제어기 아이피
  275. pObj->VMS_CTLR_PORT = pADO->FieldByName("VMS_CMNC_PORT")->AsString.Trim().ToIntDef(0); // N NUMBER(5) Y 0 VMS 제어기 포트
  276. pObj->VMS_CTLR_LOCAL_NO = pADO->FieldByName("VMS_ID")->AsString.Trim().ToIntDef(0); // N NUMBER(5) Y 0 VMS 제어기 지역번호
  277. pObj->VMS_TYPE_CD = pADO->FieldByName("VMS_TYPE_CD")->AsString.Trim(); // N VARCHAR2(7) Y VMS 유형 코드
  278. pObj->ISTL_LCTN_NM = pADO->FieldByName("ISTL_LCTN_NM")->AsString.Trim(); // N VARCHAR2(40) Y 설치 위치 명
  279. pObj->X_CRDN = pADO->FieldByName("X_CRDN")->AsFloat; // N NUMBER(11,8) Y X 좌표
  280. pObj->Y_CRDN = pADO->FieldByName("Y_CRDN")->AsFloat; // N NUMBER(10,8) Y Y 좌표
  281. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString.Trim(); // N CHAR(1) Y 'N' 삭제 여부
  282. pObj->WEB_CMRA_IP = pADO->FieldByName("WEB_CMRA_IP")->AsString.Trim(); // N VARCHAR2(20) Y 웹 카메라 아이피
  283. pObj->WEB_CMRA_PORT = pADO->FieldByName("WEB_CMRA_PORT")->AsString.Trim(); // N NUMBER(5) Y 웹카메라 포트
  284. pObj->WEB_CMRA_ID = pADO->FieldByName("WEB_CMRA_ID")->AsString.Trim(); // N VARCHAR2(20) Y 웹카메라 ID
  285. //pObj->WEB_CMRA_PWD = pADO->FieldByName("WEB_CMRA_PWD")->AsString.Trim(); // N VARCHAR2(20) Y 웹카메라 비밀번호
  286. pObj->WEB_CMRA_PWD = pADO->FieldByName("PWD")->AsString.Trim(); // N VARCHAR2(20) Y 웹카메라 비밀번호
  287. pObj->STRM_SESN_NM = pADO->FieldByName("STRM_SESN_NM")->AsString.Trim(); // N VARCHAR2(200) Y 스트리밍 세션 명
  288. pObj->OPER_MODE = pADO->FieldByName("OPER_MODE")->AsString.Trim(); // N VARCHAR2(7) Y 'A' 운영 모드
  289. if (pObj->OPER_MODE != "A" && pObj->OPER_MODE != "F" && pObj->OPER_MODE != "B")
  290. {
  291. pObj->OPER_MODE = "A";
  292. }
  293. pObj->VMS_MAX_PHSE_NUM = pADO->FieldByName("VMS_MAX_PHSE_NUM")->AsInteger; // N NUMBER(2) Y 14 VMS 최대 표출면 개수
  294. pObj->DEF_PHSE_CHNG_CYCL = pADO->FieldByName("VMS_PHSE_CHNG_CYCL")->AsInteger; // N NUMBER(3) Y 5 기본메시지주기
  295. pObj->PANL_ON_TIME = pADO->FieldByName("PANL_ON_TIME")->AsString.Trim(); // N VARCHAR2(4) Y '0400' 전광판 ON TIME
  296. pObj->PANL_OFF_TIME = pADO->FieldByName("PANL_OFF_TIME")->AsString.Trim(); // N VARCHAR2(4) Y '0200' 전광판 OFF TIME
  297. pObj->PANL_PWER_MODE = pADO->FieldByName("PANL_PWER_MODE")->AsInteger; // N NUMBER(3) Y 2 전광판 전원 모드(0x00:꺼짐,0x01:켜짐,0x02:자동,0x09:알수없음)
  298. if (pObj->PANL_ON_TIME == "9999") pObj->PANL_ON_TIME = "0000";
  299. if (pObj->PANL_OFF_TIME == "9999") pObj->PANL_OFF_TIME = "0000";
  300. pObj->FAN_MODE = pADO->FieldByName("FAN_MODE")->AsInteger; // N NUMBER(3) Y 2 FAN 동작모드(0x00:꺼짐,0x01:켜짐,0x02:자동,0x09:알수없음)
  301. pObj->FAN_RUN_TMPR = pADO->FieldByName("FAN_MTNS_TMPR")->AsInteger; // N NUMBER(3) Y 30 팬 동작 온도
  302. pObj->HETR_MODE = pADO->FieldByName("HETR_MODE")->AsInteger; // N NUMBER(3) Y 2 히터 동작모드(0x00:꺼짐,0x01:켜짐,0x02:자동,0x09:알수없음)
  303. pObj->HETR_RUN_TMPR = pADO->FieldByName("HETR_MTNS_TMPR")->AsInteger; // N NUMBER(3) Y 0 히터 동작 온도
  304. pObj->BRGH_MODE = pADO->FieldByName("BRGH_MODE")->AsInteger; // N NUMBER(3) Y 2 휘도 모드(0x00:주간,0x01:야간,0x00:자동,0x09:알수없음)
  305. pObj->BRGH_CURR_STEP = pADO->FieldByName("BRGH_CURR_STEP")->AsInteger; // N NUMBER(3) Y 40 휘도 현재 단계(0~100)
  306. pObj->BRGH_WEEK_STEP = pADO->FieldByName("VMS_WEEK_BRGH_STEP")->AsString.Trim().ToIntDef(0); // N NUMBER(3) Y 64 휘도 주간 단계(0~100)
  307. pObj->BRGH_NGHT_STEP = pADO->FieldByName("VMS_NGHT_BRGH_STEP")->AsInteger; // N NUMBER(3) Y 48 휘도 야간 단계(0~100)
  308. pObj->MODL_ERR_RATE = pADO->FieldByName("VMS_MODL_ERR_RATE")->AsInteger; // N NUMBER(3) Y 10 VMS 모듈 오류 율
  309. pObj->CMNC_FAIL_RATE = pADO->FieldByName("VMS_CMNC_ERR_BASS_VAL")->AsString.Trim().ToIntDef(0); // N NUMBER(3) Y 60 VMS 통신 오류 기본 값
  310. pObj->WEB_CMRA_CMPY = pADO->FieldByName("WEB_CMRA_CMPY")->AsString.Trim(); // N VARCHAR2(50) Y 웹카메라제조사(삼성카메라'Samsung')
  311. pObj->WEB_CMRA_MDL = pADO->FieldByName("WEB_CMRA_MDL")->AsString.Trim(); // N VARCHAR2(126) Y 웹카메라모델
  312. pObj->ISTL_LCTN_ADDR = pADO->FieldByName("ISTL_LCTN_ADDR")->AsString.Trim(); // N VARCHAR2(200) Y 설치 위치 주소
  313. pObj->VMS_TYPE_NM = pADO->FieldByName("VMS_TYPE_NM")->AsString;
  314. pObj->FULL_STRM_SESN_NM = pADO->FieldByName("FULL_STRM_SESN_NM")->AsString.Trim();
  315. pObj->WEB_CMRA_PROTOCOL = pADO->FieldByName("WEB_CMRA_PROTOCOL")->AsString.Trim();
  316. if (pObj->WEB_CMRA_PROTOCOL == "1")
  317. {
  318. if (pObj->WEB_CMRA_MDL == "")
  319. {
  320. pObj->WEB_CMRA_MDL = "SNP-3120VH";
  321. }
  322. if (pObj->WEB_CMRA_CMPY == "")
  323. {
  324. pObj->WEB_CMRA_CMPY = "Samsung";
  325. }
  326. }
  327. pObj->WIDTH = pADO->FieldByName("VMS_WDTH")->AsString.Trim().ToIntDef(576);
  328. pObj->HEIGHT = pADO->FieldByName("VMS_HGHT")->AsString.Trim().ToIntDef(320);
  329. pObj->ROW_NUM = pADO->FieldByName("ROW_NUM")->AsInteger;
  330. pObj->COL_NUM = pADO->FieldByName("COL_NUM")->AsInteger;
  331. pObj->MODL_ROW_NUM = pADO->FieldByName("MODL_ROW_NUM")->AsInteger;
  332. pObj->MODL_COL_NUM = pADO->FieldByName("MODL_COL_NUM")->AsInteger;
  333. pObj->POWR_ROW_NUM = pADO->FieldByName("POWR_ROW_NUM")->AsInteger;
  334. pObj->POWR_COL_NUM = pADO->FieldByName("POWR_COL_NUM")->AsInteger;
  335. if (pObj->WIDTH > FMaxWidth) FMaxWidth = pObj->WIDTH;
  336. if (pObj->WIDTH < FMinWidth) FMinWidth = pObj->WIDTH;
  337. if (pObj->HEIGHT > FMaxHeight) FMaxHeight = pObj->HEIGHT;
  338. if (pObj->HEIGHT < FMinHeight) FMinHeight = pObj->HEIGHT;
  339. #if 0
  340. pObj->STATE.ScheduledMessageOperatingTime = pObj->VMS_PHSE_CHNG_CYCL; /* 필수 계획된 메시지의 동작시간(초) */
  341. pObj->STATE.ModuleOperatingTemperature = pObj->VMS_CMNC_ERR_BASS_VAL; /* 필수 모듈 전원이 꺼지는 온도값(℃) */
  342. pObj->STATE.FanOperatingTemperature = pObj->FAN_MTNS_TMPR; /* 필수 Fan 동작 기준 온도값(℃) */
  343. pObj->STATE.HeaterOperatingTemperature = pObj->HETR_MTNS_TMPR; /* 필수 Heater 동작 기준 온도값(℃) */
  344. pObj->STATE.ModuleBasicFailureRate = pObj->VMS_MODL_ERR_RATE; /* 선택 모듈 장애율 (한 개의 모듈을 장애로 처리하기 위한 픽셀의 백분율값) */
  345. #endif
  346. FLists.Push(pObj->VMS_CTLR_NMBR, pObj);
  347. pObj->Completed = true;
  348. }
  349. }
  350. catch(EDatabaseError &E)
  351. {
  352. DBERRORMSG("TVmsCtlrManager::LoadFromDb", String(E.ClassName()), E.Message, sQry);
  353. throw Exception(String(E.ClassName()) + E.Message);
  354. }
  355. catch(Exception &e)
  356. {
  357. DBERRORMSG("TVmsCtlrManager::LoadFromDb", String(e.ClassName()), e.Message, sQry);
  358. throw Exception(String(e.ClassName()) + e.Message);
  359. }
  360. }
  361. __finally
  362. {
  363. if (pADO)
  364. {
  365. pADO->Close();
  366. delete pADO;
  367. }
  368. FLists.UnLock();
  369. }
  370. return true;
  371. }
  372. //---------------------------------------------------------------------------
  373. bool TVmsCtlrManager::LoadStatusFromDb(TADOConnection *ADbConn/*=NULL*/)
  374. {
  375. String sQry;
  376. TADOQuery *pADO = NULL;
  377. #if 0
  378. //CMNC_STTS_CD
  379. 1 CMS0 CMS 정상 connected Y
  380. 2 CMS1 CMS 통신두절 Not connected Y
  381. 3 CMS2 CMS 정보없음 Y
  382. //COBXDOOR_OPEN_STTS_CD
  383. 1 CDS0 CDS 닫힘 a door closed Y
  384. 2 CDS1 CDS 열림 a door opened Y
  385. 3 CDS2 CDS 정보없음 Y
  386. 1 CRS0 CRS 가동 operated Y
  387. 2 CRS1 CRS 중지 stopped Y
  388. 1 CPS0 CPS ON Power On Y
  389. 2 CPS1 CPS OFF Power Off Y
  390. //HETR_STTS_CD
  391. 1 HTS0 HTS 가동 operated Y
  392. 2 HTS1 HTS 중지 stopped Y
  393. 3 HTS2 HTS 정보없음 Y
  394. //PWER_STTS_CD
  395. 1 PWS0 PWS 정상 normal Y
  396. 2 PWS1 PWS 오류 abnormal Y
  397. //FAN_STTS_CD
  398. 1 PAS0 PAS 가동 operated Y
  399. 2 PAS1 PAS 중지 stopped Y
  400. 3 PAS2 PAS 정보없음 Y
  401. //모듈
  402. 1 MOS0 MOS 정상 normal Y
  403. 2 MOS1 MOS 오류 abnormal Y
  404. #endif
  405. sQry = "SELECT * \r\n"
  406. " FROM TB_VMS_CTLR_STTS A, TB_VMS_CTLR B \r\n"
  407. " WHERE A.VMS_CTLR_NMBR = B.VMS_CTLR_NMBR \r\n"
  408. " AND A.UPDT_DT >= TO_CHAR(SYSDATE-5/1440, 'YYYYMMDDHH24MISS') \r\n";
  409. FLists.Lock();
  410. try
  411. {
  412. TVmsCtlr *pObj = NULL;
  413. #if 0
  414. FOR_STL(TVmsCtlr*, pTmp, FLists)
  415. {
  416. pTmp->STATE.Comm = vms_comm_error;
  417. VmsInitStatus(&pTmp->STATE);
  418. pTmp->RunState = state_error;
  419. }
  420. #endif
  421. try
  422. {
  423. int nORD;
  424. pADO = new TADOQuery(NULL);
  425. pADO->Close();
  426. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  427. pADO->SQL->Clear();
  428. pADO->SQL->Text = sQry;
  429. pADO->Prepared = true;
  430. pADO->Open();
  431. //int nRows = pADO->RecordCount;
  432. for( ; !pADO->Eof; pADO->Next())
  433. {
  434. String sVmsNmbr = pADO->FieldByName("VMS_CTLR_NMBR")->AsString;
  435. pObj = FLists.Find(sVmsNmbr);
  436. if (!pObj) continue;
  437. String UPDT_DT = pADO->FieldByName("UPDT_DT")->AsString;
  438. String CMNC_STTS_CD = pADO->FieldByName("CMNC_STTS_CD")->AsString;
  439. if (CMNC_STTS_CD != "CMS0")
  440. {
  441. //통신장애
  442. continue;
  443. }
  444. pObj->STATE.Comm = vms_comm_normal;
  445. String CBOXDOOR_OPEN_STTS_CD = pADO->FieldByName("CBOX_DOOR_STTS_CD")->AsString;
  446. if (CBOXDOOR_OPEN_STTS_CD == "CDS0") pObj->STATE.DoorStatus = vms_door_close;
  447. else if (CBOXDOOR_OPEN_STTS_CD == "CDS1") pObj->STATE.DoorStatus = vms_door_open;
  448. else pObj->STATE.DoorStatus = vms_door_unknown;
  449. String MODL_STTS_CD = pADO->FieldByName("MODL_STTS_CD")->AsString;
  450. if (MODL_STTS_CD == "MOS0") pObj->STATE.ModulePowerStatus = vms_module_power_on;
  451. else if (MODL_STTS_CD == "MOS1") pObj->STATE.ModulePowerStatus = vms_module_power_off;
  452. else pObj->STATE.ModulePowerStatus = vms_module_power_unknown;
  453. String CBOX_TMPR = pADO->FieldByName("CBOX_TMPR")->AsString;
  454. pObj->STATE.BodyTemp = CBOX_TMPR.ToIntDef(0);
  455. String CBOX_HMDT = pADO->FieldByName("BRGH_VAL")->AsString;
  456. pObj->STATE.LuminanceStatus = CBOX_HMDT.ToIntDef(0);
  457. String FAN_STTS_CD = pADO->FieldByName("FAN_STTS_CD")->AsString;
  458. if (FAN_STTS_CD == "PAS0") pObj->STATE.FanStatus = vms_fan_on;
  459. else if (FAN_STTS_CD == "PAS1") pObj->STATE.FanStatus = vms_fan_off;
  460. else pObj->STATE.FanStatus = vms_fan_unknown;
  461. String HETR_STTS_CD = pADO->FieldByName("HETR_STTS_CD")->AsString;
  462. if (HETR_STTS_CD == "HTS0") pObj->STATE.HeaterStatus = vms_heater_on;
  463. else if (HETR_STTS_CD == "HTS1") pObj->STATE.HeaterStatus = vms_heater_off;
  464. else pObj->STATE.HeaterStatus = vms_heater_unknown;
  465. String COMM_STTS_CD = pADO->FieldByName("COMM_STTS_CD")->AsString;
  466. if (COMM_STTS_CD == "CMS0") pObj->STATE.Wcomm = vms_wcomm_normal;
  467. //else if (COMM_STTS_CD == "CMS1") pObj->STATE.Wcomm = vms_wcomm_error;
  468. else pObj->STATE.Wcomm = vms_wcomm_error;
  469. pObj->MODL_STTS = pADO->FieldByName("MODL_STTS")->AsString;
  470. pObj->PWER_STTS = pADO->FieldByName("PWER_STTS")->AsString;
  471. pObj->CheckRunState();
  472. }
  473. }
  474. catch(EDatabaseError &E)
  475. {
  476. DBERRORMSG("TVmsCtlrManager::LoadStatusFromDb", String(E.ClassName()), E.Message, sQry);
  477. throw Exception(String(E.ClassName()) + E.Message);
  478. }
  479. catch(Exception &e)
  480. {
  481. DBERRORMSG("TVmsCtlrManager::LoadStatusFromDb", String(e.ClassName()), e.Message, sQry);
  482. throw Exception(String(e.ClassName()) + e.Message);
  483. }
  484. }
  485. __finally
  486. {
  487. if (pADO)
  488. {
  489. pADO->Close();
  490. delete pADO;
  491. }
  492. FLists.UnLock();
  493. }
  494. return true;
  495. }
  496. //---------------------------------------------------------------------------
  497. bool TVmsCtlrManager::DeleteVms(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  498. {
  499. String sQry;
  500. TADOQuery *pADO = NULL;
  501. sQry = "UPDATE TB_VMS_CTLR \r\n"
  502. " SET DEL_YN = 'Y' \r\n"
  503. " WHERE VMS_CTLR_NMBR = :p01 \r\n";
  504. try
  505. {
  506. try
  507. {
  508. pADO = new TADOQuery(NULL);
  509. pADO->Close();
  510. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  511. pADO->SQL->Clear();
  512. pADO->SQL->Text = sQry;
  513. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_NMBR;
  514. pADO->ExecSQL();
  515. sQry = "DELETE TB_FCLT_INFR \r\n"
  516. " WHERE FCLT_ID = :p01 \r\n";
  517. pADO->SQL->Clear();
  518. pADO->SQL->Text = sQry;
  519. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_ID;
  520. pADO->ExecSQL();
  521. return true;
  522. }
  523. catch(EDatabaseError &E)
  524. {
  525. DBERRORMSG("TVmsCtlrManager::DeleteVms", String(E.ClassName()), E.Message, sQry);
  526. throw Exception(String(E.ClassName()) + E.Message);
  527. }
  528. catch(Exception &e)
  529. {
  530. DBERRORMSG("TVmsCtlrManager::DeleteVms", String(e.ClassName()), e.Message, sQry);
  531. throw Exception(String(e.ClassName()) + e.Message);
  532. }
  533. }
  534. __finally
  535. {
  536. if (pADO)
  537. {
  538. pADO->Close();
  539. delete pADO;
  540. }
  541. }
  542. return true;
  543. }
  544. //---------------------------------------------------------------------------
  545. bool TVmsCtlrManager::InsertVms(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  546. {
  547. String sQry;
  548. TADOQuery *pADO = NULL;
  549. sQry = "INSERT INTO TB_VMS_CTLR \r\n"
  550. " ( \r\n"
  551. " VMS_CTLR_NMBR, \r\n"
  552. " VMS_CTLR_ID, \r\n"
  553. " VMS_NM, \r\n"
  554. " VMS_CTLR_IP, \r\n"
  555. " VMS_CMNC_PORT, \r\n"
  556. " VMS_ID, \r\n"
  557. " VMS_TYPE_CD, \r\n"
  558. " ISTL_LCTN_NM, \r\n"
  559. " X_CRDN, \r\n"
  560. " Y_CRDN, \r\n"
  561. " DEL_YN, \r\n"
  562. " WEB_CMRA_IP, \r\n"
  563. " WEB_CMRA_PORT, \r\n"
  564. " WEB_CMRA_ID, \r\n"
  565. " WEB_CMRA_PWD, \r\n"
  566. " STRM_SESN_NM, \r\n"
  567. " VMS_MAX_PHSE_NUM, \r\n"
  568. " PANL_ON_TIME, \r\n"
  569. " PANL_OFF_TIME, \r\n"
  570. " ISTL_LCTN_ADDR \r\n"
  571. " ) \r\n"
  572. " VALUES (:p01, \r\n"
  573. " :p02, \r\n"
  574. " :p03, \r\n"
  575. " :p04, \r\n"
  576. " :p05, \r\n"
  577. " :p06, \r\n"
  578. " :p07, \r\n"
  579. " :p08, \r\n"
  580. " :p09, \r\n"
  581. " :p10, \r\n"
  582. " :p11, \r\n"
  583. " :p12, \r\n"
  584. " :p13, \r\n"
  585. " :p14, \r\n"
  586. // " scp.enc_b64('DAMO','SCP','ARIA_256.SCPS',:p15), \r\n"
  587. " :p15, \r\n"
  588. " :p16, \r\n"
  589. " :p17, \r\n"
  590. " :p18, \r\n"
  591. " :p19, \r\n"
  592. " :p20) \r\n";
  593. try
  594. {
  595. try
  596. {
  597. pADO = new TADOQuery(NULL);
  598. pADO->Close();
  599. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  600. pADO->SQL->Clear();
  601. pADO->SQL->Text = sQry;
  602. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_NMBR;
  603. pADO->Parameters->ParamByName("p02")->Value = AObj->VMS_CTLR_ID;
  604. pADO->Parameters->ParamByName("p03")->Value = AObj->VMS_NM;
  605. pADO->Parameters->ParamByName("p04")->Value = AObj->VMS_CTLR_IP;
  606. pADO->Parameters->ParamByName("p05")->Value = AObj->VMS_CTLR_PORT;
  607. pADO->Parameters->ParamByName("p06")->Value = AObj->VMS_CTLR_LOCAL_NO;
  608. pADO->Parameters->ParamByName("p07")->Value = AObj->VMS_TYPE_CD;
  609. pADO->Parameters->ParamByName("p08")->Value = AObj->ISTL_LCTN_NM;
  610. pADO->Parameters->ParamByName("p09")->Value = AObj->X_CRDN;
  611. pADO->Parameters->ParamByName("p10")->Value = AObj->Y_CRDN;
  612. pADO->Parameters->ParamByName("p11")->Value = AObj->DEL_YN;
  613. pADO->Parameters->ParamByName("p12")->Value = AObj->WEB_CMRA_IP;
  614. pADO->Parameters->ParamByName("p13")->Value = AObj->WEB_CMRA_PORT;
  615. pADO->Parameters->ParamByName("p14")->Value = AObj->WEB_CMRA_ID;
  616. pADO->Parameters->ParamByName("p15")->Value = AObj->WEB_CMRA_PWD;
  617. pADO->Parameters->ParamByName("p16")->Value = AObj->STRM_SESN_NM;
  618. pADO->Parameters->ParamByName("p17")->Value = AObj->VMS_MAX_PHSE_NUM;
  619. pADO->Parameters->ParamByName("p18")->Value = AObj->PANL_ON_TIME;
  620. pADO->Parameters->ParamByName("p19")->Value = AObj->PANL_OFF_TIME;
  621. pADO->Parameters->ParamByName("p20")->Value = AObj->ISTL_LCTN_ADDR;
  622. pADO->ExecSQL();
  623. return MergeFcltInfo(AObj, ADbConn);
  624. }
  625. catch(EDatabaseError &E)
  626. {
  627. DBERRORMSG("TVmsCtlrManager::InsertVms", String(E.ClassName()), E.Message, sQry);
  628. throw Exception(String(E.ClassName()) + E.Message);
  629. }
  630. catch(Exception &e)
  631. {
  632. DBERRORMSG("TVmsCtlrManager::InsertVms", String(e.ClassName()), e.Message, sQry);
  633. throw Exception(String(e.ClassName()) + e.Message);
  634. }
  635. }
  636. __finally
  637. {
  638. if (pADO)
  639. {
  640. pADO->Close();
  641. delete pADO;
  642. }
  643. }
  644. return true;
  645. }
  646. //---------------------------------------------------------------------------
  647. bool TVmsCtlrManager::UpdateVms(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  648. {
  649. return MergeVms(AObj, ADbConn);
  650. }
  651. //---------------------------------------------------------------------------
  652. bool TVmsCtlrManager::MergeVms(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  653. {
  654. String sQry;
  655. TADOQuery *pADO = NULL;
  656. sQry = "MERGE INTO TB_VMS_CTLR L \r\n"
  657. "USING (SELECT :p01 AS VMS_CTLR_NMBR, \r\n"
  658. " :p02 AS VMS_CTLR_ID, \r\n"
  659. " :p03 AS VMS_NM, \r\n"
  660. " :p04 AS VMS_CTLR_IP, \r\n"
  661. " :p05 AS VMS_CMNC_PORT, \r\n"
  662. " :p06 AS VMS_ID, \r\n"
  663. " :p07 AS VMS_TYPE_CD, \r\n"
  664. " :p08 AS ISTL_LCTN_NM, \r\n"
  665. " :p09 AS X_CRDN, \r\n"
  666. " :p10 AS Y_CRDN, \r\n"
  667. " :p11 AS DEL_YN, \r\n"
  668. " :p12 AS WEB_CMRA_IP, \r\n"
  669. " :p13 AS WEB_CMRA_PORT, \r\n"
  670. " :p14 AS WEB_CMRA_ID, \r\n"
  671. // " scp.enc_b64('DAMO','SCP','ARIA_256.SCPS',:p15) AS WEB_CMRA_PWD, \r\n"
  672. " :p15 AS WEB_CMRA_PWD, \r\n"
  673. " :p16 AS STRM_SESN_NM, \r\n"
  674. " :p17 AS VMS_MAX_PHSE_NUM, \r\n"
  675. " :p18 AS PANL_ON_TIME, \r\n"
  676. " :p19 AS PANL_OFF_TIME, \r\n"
  677. " :p20 AS ISTL_LCTN_ADDR \r\n"
  678. " FROM DUAL) M \r\n"
  679. " ON (L.VMS_CTLR_NMBR = M.VMS_CTLR_NMBR) \r\n"
  680. "WHEN MATCHED THEN \r\n"
  681. " UPDATE SET L.VMS_CTLR_ID = M.VMS_CTLR_ID, \r\n"
  682. " L.VMS_NM = M.VMS_NM, \r\n"
  683. " L.VMS_CTLR_IP = M.VMS_CTLR_IP, \r\n"
  684. " L.VMS_CMNC_PORT = M.VMS_CMNC_PORT, \r\n"
  685. " L.VMS_ID = M.VMS_ID, \r\n"
  686. " L.VMS_TYPE_CD = M.VMS_TYPE_CD, \r\n"
  687. " L.ISTL_LCTN_NM = M.ISTL_LCTN_NM, \r\n"
  688. " L.X_CRDN = M.X_CRDN, \r\n"
  689. " L.Y_CRDN = M.Y_CRDN, \r\n"
  690. " L.DEL_YN = M.DEL_YN, \r\n"
  691. " L.WEB_CMRA_IP = M.WEB_CMRA_IP, \r\n"
  692. " L.WEB_CMRA_PORT = M.WEB_CMRA_PORT, \r\n"
  693. " L.WEB_CMRA_ID = M.WEB_CMRA_ID, \r\n"
  694. " L.WEB_CMRA_PWD = M.WEB_CMRA_PWD, \r\n"
  695. " L.STRM_SESN_NM = M.STRM_SESN_NM, \r\n"
  696. " L.VMS_MAX_PHSE_NUM = M.VMS_MAX_PHSE_NUM, \r\n"
  697. " L.PANL_ON_TIME = M.PANL_ON_TIME, \r\n"
  698. " L.PANL_OFF_TIME = M.PANL_OFF_TIME, \r\n"
  699. " L.ISTL_LCTN_ADDR = M.ISTL_LCTN_ADDR \r\n"
  700. "WHEN NOT MATCHED THEN \r\n"
  701. " INSERT ( \r\n"
  702. " VMS_CTLR_NMBR, \r\n"
  703. " VMS_CTLR_ID, \r\n"
  704. " VMS_NM, \r\n"
  705. " VMS_CTLR_IP, \r\n"
  706. " VMS_CMNC_PORT, \r\n"
  707. " VMS_ID, \r\n"
  708. " VMS_TYPE_CD, \r\n"
  709. " ISTL_LCTN_NM, \r\n"
  710. " X_CRDN, \r\n"
  711. " Y_CRDN, \r\n"
  712. " DEL_YN, \r\n"
  713. " WEB_CMRA_IP, \r\n"
  714. " WEB_CMRA_PORT, \r\n"
  715. " WEB_CMRA_ID, \r\n"
  716. " WEB_CMRA_PWD, \r\n"
  717. " STRM_SESN_NM, \r\n"
  718. " VMS_MAX_PHSE_NUM, \r\n"
  719. " PANL_ON_TIME, \r\n"
  720. " PANL_OFF_TIME, \r\n"
  721. " ISTL_LCTN_ADDR \r\n"
  722. " ) \r\n"
  723. " VALUES ( \r\n"
  724. " M.VMS_CTLR_NMBR, \r\n"
  725. " M.VMS_CTLR_ID, \r\n"
  726. " M.VMS_NM, \r\n"
  727. " M.VMS_CTLR_IP, \r\n"
  728. " M.VMS_CMNC_PORT, \r\n"
  729. " M.VMS_ID, \r\n"
  730. " M.VMS_TYPE_CD, \r\n"
  731. " M.ISTL_LCTN_NM, \r\n"
  732. " M.X_CRDN, \r\n"
  733. " M.Y_CRDN, \r\n"
  734. " M.DEL_YN, \r\n"
  735. " M.WEB_CMRA_IP, \r\n"
  736. " M.WEB_CMRA_PORT, \r\n"
  737. " M.WEB_CMRA_ID, \r\n"
  738. " M.WEB_CMRA_PWD, \r\n"
  739. " M.STRM_SESN_NM, \r\n"
  740. " M.VMS_MAX_PHSE_NUM, \r\n"
  741. " M.PANL_ON_TIME, \r\n"
  742. " M.PANL_OFF_TIME, \r\n"
  743. " M.ISTL_LCTN_ADDR \r\n"
  744. " ) \r\n";
  745. try
  746. {
  747. try
  748. {
  749. pADO = new TADOQuery(NULL);
  750. pADO->Close();
  751. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  752. pADO->SQL->Clear();
  753. pADO->SQL->Text = sQry;
  754. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_NMBR;
  755. pADO->Parameters->ParamByName("p02")->Value = AObj->VMS_CTLR_ID;
  756. pADO->Parameters->ParamByName("p03")->Value = AObj->VMS_NM;
  757. pADO->Parameters->ParamByName("p04")->Value = AObj->VMS_CTLR_IP;
  758. pADO->Parameters->ParamByName("p05")->Value = AObj->VMS_CTLR_PORT;
  759. pADO->Parameters->ParamByName("p06")->Value = AObj->VMS_CTLR_LOCAL_NO;
  760. pADO->Parameters->ParamByName("p07")->Value = AObj->VMS_TYPE_CD;
  761. pADO->Parameters->ParamByName("p08")->Value = AObj->ISTL_LCTN_NM;
  762. pADO->Parameters->ParamByName("p09")->Value = AObj->X_CRDN;
  763. pADO->Parameters->ParamByName("p10")->Value = AObj->Y_CRDN;
  764. pADO->Parameters->ParamByName("p11")->Value = AObj->DEL_YN;
  765. pADO->Parameters->ParamByName("p12")->Value = AObj->WEB_CMRA_IP;
  766. pADO->Parameters->ParamByName("p13")->Value = AObj->WEB_CMRA_PORT;
  767. pADO->Parameters->ParamByName("p14")->Value = AObj->WEB_CMRA_ID;
  768. pADO->Parameters->ParamByName("p15")->Value = AObj->WEB_CMRA_PWD;
  769. pADO->Parameters->ParamByName("p16")->Value = AObj->STRM_SESN_NM;
  770. pADO->Parameters->ParamByName("p17")->Value = AObj->VMS_MAX_PHSE_NUM;
  771. pADO->Parameters->ParamByName("p18")->Value = AObj->PANL_ON_TIME;
  772. pADO->Parameters->ParamByName("p19")->Value = AObj->PANL_OFF_TIME;
  773. pADO->Parameters->ParamByName("p20")->Value = AObj->ISTL_LCTN_ADDR;
  774. pADO->ExecSQL();
  775. return MergeFcltInfo(AObj, ADbConn);
  776. }
  777. catch(EDatabaseError &E)
  778. {
  779. DBERRORMSG("TVmsCtlrManager::MergeVms", String(E.ClassName()), E.Message, sQry);
  780. throw Exception(String(E.ClassName()) + E.Message);
  781. }
  782. catch(Exception &e)
  783. {
  784. DBERRORMSG("TVmsCtlrManager::MergeVms", String(e.ClassName()), e.Message, sQry);
  785. throw Exception(String(e.ClassName()) + e.Message);
  786. }
  787. }
  788. __finally
  789. {
  790. if (pADO)
  791. {
  792. pADO->Close();
  793. delete pADO;
  794. }
  795. }
  796. return true;
  797. }
  798. //---------------------------------------------------------------------------
  799. bool TVmsCtlrManager::MergeFcltInfo(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  800. {
  801. String sQry;
  802. TADOQuery *pADO = NULL;
  803. sQry = "MERGE INTO TB_FCLT_INFR L \r\n"
  804. "USING (SELECT :p01 AS FCLT_ID, \r\n"
  805. " :p02 AS FCLT_TYPE, \r\n"
  806. " :p03 AS FCLT_LCTN \r\n"
  807. " FROM DUAL) M \r\n"
  808. " ON (L.FCLT_ID = M.FCLT_ID AND L.FCLT_TYPE = M.FCLT_TYPE) \r\n"
  809. "WHEN MATCHED \r\n"
  810. "THEN \r\n"
  811. " UPDATE SET L.FCLT_LCTN = M.FCLT_LCTN, \r\n"
  812. " L.DEL_YN = 'N' \r\n"
  813. "WHEN NOT MATCHED \r\n"
  814. "THEN \r\n"
  815. " INSERT ( FCLT_ID, FCLT_TYPE, FCLT_LCTN) \r\n"
  816. " VALUES (M.FCLT_ID, M.FCLT_TYPE, M.FCLT_LCTN) \r\n";
  817. try
  818. {
  819. try
  820. {
  821. pADO = new TADOQuery(NULL);
  822. pADO->Close();
  823. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  824. pADO->SQL->Clear();
  825. pADO->SQL->Text = sQry;
  826. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_ID;
  827. pADO->Parameters->ParamByName("p02")->Value = "VMS";
  828. pADO->Parameters->ParamByName("p03")->Value = AObj->VMS_NM;
  829. pADO->ExecSQL();
  830. return true;
  831. }
  832. catch(EDatabaseError &E)
  833. {
  834. DBERRORMSG("TVmsCtlrManager::MergeFcltInfo", String(E.ClassName()), E.Message, sQry);
  835. throw Exception(String(E.ClassName()) + E.Message);
  836. }
  837. catch(Exception &e)
  838. {
  839. DBERRORMSG("TVmsCtlrManager::MergeFcltInfo", String(e.ClassName()), e.Message, sQry);
  840. throw Exception(String(e.ClassName()) + e.Message);
  841. }
  842. }
  843. __finally
  844. {
  845. if (pADO)
  846. {
  847. pADO->Close();
  848. delete pADO;
  849. }
  850. }
  851. return true;
  852. }
  853. //---------------------------------------------------------------------------
  854. bool TVmsCtlrManager::GetNextVmsId(int &ANmbr, int &AId, TADOConnection *ADbConn/*=NULL*/)
  855. {
  856. String sQry;
  857. TADOQuery *pADO = NULL;
  858. sQry = "SELECT NVL(MAX(VMS_CTLR_NMBR), 10000) + 1 AS NEWID FROM TB_VMS_CTLR \r\n";
  859. try
  860. {
  861. try
  862. {
  863. pADO = new TADOQuery(NULL);
  864. pADO->Close();
  865. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  866. pADO->SQL->Clear();
  867. pADO->SQL->Text = sQry;
  868. pADO->Prepared = true;
  869. pADO->Open();
  870. ANmbr = pADO->FieldByName("NEWID")->AsInteger;
  871. AId = ANmbr / 10000;
  872. return true;
  873. }
  874. catch(EDatabaseError &E)
  875. {
  876. DBERRORMSG("VmsCtlrManager::GetNextVmsId", String(E.ClassName()), E.Message, sQry);
  877. throw Exception(String(E.ClassName()) + E.Message);
  878. }
  879. catch(Exception &e)
  880. {
  881. DBERRORMSG("VmsCtlrManager::GetNextVmsId", String(e.ClassName()), e.Message, sQry);
  882. throw Exception(String(e.ClassName()) + e.Message);
  883. }
  884. }
  885. __finally
  886. {
  887. if (pADO)
  888. {
  889. pADO->Close();
  890. delete pADO;
  891. }
  892. }
  893. return false;
  894. }
  895. //---------------------------------------------------------------------------
  896. bool TVmsCtlrManager::UpdateCtlrInfo(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  897. {
  898. String sQry;
  899. TADOQuery *pADO = NULL;
  900. sQry = "UPDATE TB_VMS_CTLR \r\n"
  901. " SET PANL_ON_TIME = :p01, \r\n"
  902. " PANL_OFF_TIME = :p02 \r\n"
  903. " WHERE DEL_YN = 'N' \r\n";
  904. try
  905. {
  906. try
  907. {
  908. pADO = new TADOQuery(NULL);
  909. pADO->Close();
  910. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  911. pADO->SQL->Clear();
  912. pADO->SQL->Text = sQry;
  913. pADO->Parameters->ParamByName("p01")->Value = AObj->PANL_ON_TIME;
  914. pADO->Parameters->ParamByName("p02")->Value = AObj->PANL_OFF_TIME;
  915. pADO->ExecSQL();
  916. return true;
  917. }
  918. catch(EDatabaseError &E)
  919. {
  920. DBERRORMSG("TVmsCtlrManager::UpdateCtlrInfo", String(E.ClassName()), E.Message, sQry);
  921. throw Exception(String(E.ClassName()) + E.Message);
  922. }
  923. catch(Exception &e)
  924. {
  925. DBERRORMSG("TVmsCtlrManager::UpdateCtlrInfo", String(e.ClassName()), e.Message, sQry);
  926. throw Exception(String(e.ClassName()) + e.Message);
  927. }
  928. }
  929. __finally
  930. {
  931. if (pADO)
  932. {
  933. pADO->Close();
  934. delete pADO;
  935. }
  936. }
  937. return true;
  938. }
  939. //---------------------------------------------------------------------------
  940. bool TVmsCtlrManager::UpdateIfscCngsSpeedInfo(int ACngsSpd, TADOConnection *ADbConn/*=NULL*/)
  941. {
  942. String sQry;
  943. TADOQuery *pADO = NULL;
  944. sQry = "UPDATE TB_VMS_IFSC_RLTN \r\n"
  945. " SET CNGS_CNFM_SPED = :p01 \r\n";
  946. try
  947. {
  948. try
  949. {
  950. String sGradCd;
  951. pADO = new TADOQuery(NULL);
  952. pADO->Close();
  953. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  954. pADO->SQL->Clear();
  955. pADO->SQL->Text = sQry;
  956. pADO->Parameters->ParamByName("p01")->Value = ACngsSpd;
  957. pADO->ExecSQL();
  958. return true;
  959. }
  960. catch(EDatabaseError &E)
  961. {
  962. DBERRORLOG("TVmsCtlrManager::UpdateIfscCngsSpeedInfo", String(E.ClassName()), E.Message, sQry);
  963. throw Exception(String(E.ClassName()) + E.Message);
  964. }
  965. catch(Exception &e)
  966. {
  967. DBERRORLOG("TVmsCtlrManager::UpdateIfscCngsSpeedInfo", String(e.ClassName()), e.Message, sQry);
  968. throw Exception(String(e.ClassName()) + e.Message);
  969. }
  970. }
  971. __finally
  972. {
  973. if (pADO)
  974. {
  975. pADO->Close();
  976. delete pADO;
  977. }
  978. }
  979. return true;
  980. }
  981. //---------------------------------------------------------------------------
  982. bool TVmsCtlrManager::LoadIfscRltn(TADOConnection *ADbConn/*=NULL*/)
  983. {
  984. String sQry;
  985. TADOQuery *pADO = NULL;
  986. FLists.Lock();
  987. try
  988. {
  989. FOR_STL(TVmsCtlr*, pObj, FLists)
  990. {
  991. pObj->FIfscRltn.RemoveAll();
  992. }
  993. }
  994. __finally
  995. {
  996. FLists.UnLock();
  997. }
  998. sQry = "SELECT A.VMS_CTLR_NMBR, B.VMS_IFSC_ID, B.DSPL_PRRT, \r\n"
  999. " B.CNGS_CNFM_YN, B.CNGS_CNFM_SPED \r\n"
  1000. " FROM TB_VMS_CTLR A, \r\n"
  1001. " TB_VMS_IFSC_RLTN B, \r\n"
  1002. " TB_VMS_IFSC C \r\n"
  1003. " WHERE A.VMS_CTLR_NMBR = B.VMS_CTLR_NMBR \r\n"
  1004. " AND B.VMS_IFSC_ID = C.VMS_IFSC_ID \r\n"
  1005. " ORDER BY A.VMS_CTLR_NMBR, B.DSPL_PRRT \r\n";
  1006. FLists.Lock();
  1007. try
  1008. {
  1009. String VMS_CTLR_NMBR;
  1010. try
  1011. {
  1012. pADO = new TADOQuery(NULL);
  1013. pADO->Close();
  1014. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1015. pADO->SQL->Clear();
  1016. pADO->SQL->Text = sQry;
  1017. pADO->Prepared = true;
  1018. pADO->Open();
  1019. for( ; !pADO->Eof; pADO->Next())
  1020. {
  1021. VMS_CTLR_NMBR = pADO->FieldByName("VMS_CTLR_NMBR")->AsString;
  1022. TVmsCtlr *pVms = FLists.Find(String(VMS_CTLR_NMBR));
  1023. if (!pVms) continue;
  1024. TVmsIfscRltn *pObj = new TVmsIfscRltn();
  1025. if (pObj)
  1026. {
  1027. pObj->VMS_CTLR_NMBR = VMS_CTLR_NMBR;
  1028. pObj->VMS_IFSC_ID = pADO->FieldByName("VMS_IFSC_ID")->AsInteger;
  1029. pObj->DSPL_PRRT = pADO->FieldByName("DSPL_PRRT")->AsInteger;
  1030. pObj->CNGS_CNFM_YN = pADO->FieldByName("CNGS_CNFM_YN")->AsString;
  1031. pObj->CNGS_CNFM_SPED= pADO->FieldByName("CNGS_CNFM_SPED")->AsInteger;
  1032. pVms->FIfscRltn.Push(pObj->DSPL_PRRT, pObj);
  1033. }
  1034. }
  1035. }
  1036. catch(EDatabaseError &E)
  1037. {
  1038. DBERRORMSG("TVmsCtlrManager::LoadIfscRltn", String(E.ClassName()), E.Message, sQry);
  1039. throw Exception(String(E.ClassName()) + E.Message);
  1040. }
  1041. catch(Exception &e)
  1042. {
  1043. DBERRORMSG("TVmsCtlrManager::LoadIfscRltn", String(e.ClassName()), e.Message, sQry);
  1044. throw Exception(String(e.ClassName()) + e.Message);
  1045. }
  1046. }
  1047. __finally
  1048. {
  1049. if (pADO)
  1050. {
  1051. pADO->Close();
  1052. delete pADO;
  1053. }
  1054. FLists.UnLock();
  1055. }
  1056. return true;
  1057. }
  1058. //---------------------------------------------------------------------------
  1059. bool TVmsCtlrManager::SaveIfscRltn(TVmsCtlr *AObj, TADOConnection *ADbConn/*=NULL*/)
  1060. {
  1061. String sQry;
  1062. TADOQuery *pADO = NULL;
  1063. int ii;
  1064. try
  1065. {
  1066. try
  1067. {
  1068. pADO = new TADOQuery(NULL);
  1069. pADO->Close();
  1070. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1071. sQry = "DELETE FROM TB_VMS_IFSC_RLTN WHERE VMS_CTLR_NMBR = :p01";
  1072. pADO->SQL->Clear();
  1073. pADO->SQL->Text = sQry;
  1074. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_NMBR;
  1075. pADO->ExecSQL();
  1076. sQry = "INSERT INTO TB_VMS_IFSC_RLTN(VMS_CTLR_NMBR, VMS_IFSC_ID, DSPL_PRRT, CNGS_CNFM_YN, CNGS_CNFM_SPED) VALUES(:p01, :p02, :p03, :p04, :p05)";
  1077. ii = 0;
  1078. pADO->SQL->Clear();
  1079. pADO->SQL->Text = sQry;
  1080. FOR_STL(TVmsIfscRltn *, pLink, AObj->FIfscRltn)
  1081. {
  1082. pADO->Parameters->ParamByName("p01")->Value = AObj->VMS_CTLR_NMBR;
  1083. pADO->Parameters->ParamByName("p02")->Value = pLink->VMS_IFSC_ID;
  1084. pADO->Parameters->ParamByName("p03")->Value = String(ii+1);
  1085. pADO->Parameters->ParamByName("p04")->Value = pLink->CNGS_CNFM_YN;
  1086. pADO->Parameters->ParamByName("p05")->Value = pLink->CNGS_CNFM_SPED;
  1087. pADO->ExecSQL();
  1088. ii++;
  1089. }
  1090. return true;
  1091. }
  1092. catch(EDatabaseError &E)
  1093. {
  1094. DBERRORMSG("TVmsCtlrManager::SaveIfscRltn", String(E.ClassName()), E.Message, sQry);
  1095. throw Exception(String(E.ClassName()) + E.Message);
  1096. }
  1097. catch(Exception &e)
  1098. {
  1099. DBERRORMSG("TVmsCtlrManager::SaveIfscRltn", String(e.ClassName()), e.Message, sQry);
  1100. throw Exception(String(e.ClassName()) + e.Message);
  1101. }
  1102. }
  1103. __finally
  1104. {
  1105. if (pADO)
  1106. {
  1107. pADO->Close();
  1108. delete pADO;
  1109. }
  1110. }
  1111. return true;
  1112. }
  1113. //---------------------------------------------------------------------------
  1114. bool TVmsCtlrManager::LoadVmsMsg(TADOConnection *ADbConn/*=NULL*/)
  1115. {
  1116. String sQry;
  1117. TADOQuery *pADO = NULL;
  1118. sQry = "SELECT A.*, \r\n"
  1119. " TO_CHAR(SYSDATE - 8/1440, 'YYYYMMDDHH24MISS') AS SVC_DT \r\n"
  1120. " FROM TB_VMS_DSPL_PRST A, \r\n"
  1121. " (SELECT VMS_CTLR_NMBR, MAX(DSPL_DT) AS DSPL_DT \r\n"
  1122. " FROM TB_VMS_DSPL_PRST \r\n"
  1123. " GROUP BY VMS_CTLR_NMBR) B \r\n"
  1124. " WHERE A.VMS_CTLR_NMBR = B.VMS_CTLR_NMBR \r\n"
  1125. " AND A.DSPL_DT = B.DSPL_DT \r\n"
  1126. " ORDER BY A.VMS_CTLR_NMBR, A.PHASE \r\n";
  1127. FLists.Lock();
  1128. try
  1129. {
  1130. FOR_STL(TVmsCtlr*, pTmpObj, FLists)
  1131. {
  1132. pTmpObj->Lock();
  1133. pTmpObj->VmsMsg->Init();
  1134. pTmpObj->UnLock();
  1135. }
  1136. }
  1137. __finally
  1138. {
  1139. FLists.UnLock();
  1140. }
  1141. TVmsCtlr *pObj = NULL;
  1142. String sOldVmsNmbr = "";
  1143. int nPhase = 0;
  1144. try
  1145. {
  1146. try
  1147. {
  1148. pADO = new TADOQuery(NULL);
  1149. pADO->Close();
  1150. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1151. pADO->SQL->Clear();
  1152. pADO->SQL->Text = sQry;
  1153. pADO->Prepared = true;
  1154. pADO->Open();
  1155. for( ; !pADO->Eof; pADO->Next())
  1156. {
  1157. String sVmsNmbr = pADO->FieldByName("VMS_CTLR_NMBR")->AsString;
  1158. if (sVmsNmbr != sOldVmsNmbr)
  1159. {
  1160. if (pObj)
  1161. {
  1162. pObj->VmsMsg->Total = nPhase;
  1163. pObj->VmsMsg->Curr = 0;
  1164. pObj->VmsMsg->IsLoading = false;
  1165. pObj->UnLock();
  1166. }
  1167. pObj = FLists.Find(sVmsNmbr);
  1168. if (pObj)
  1169. {
  1170. pObj->Lock();
  1171. nPhase = 0;
  1172. sOldVmsNmbr = sVmsNmbr;
  1173. }
  1174. else continue;
  1175. }
  1176. if (!pObj) continue;
  1177. if (nPhase >= INT_VMS_MAX_FORM) continue;
  1178. SAFE_DELETE(FImgStream);
  1179. FImgStream = pADO->CreateBlobStream(pADO->FieldByName("VMS_DSPL_MSG_IMAG"), bmRead);
  1180. if (FImgStream && FImgStream->Size > 0)
  1181. {
  1182. try
  1183. {
  1184. if (!pObj->VmsMsg->PHASE[nPhase].pVmsBmp)
  1185. {
  1186. pObj->VmsMsg->PHASE[nPhase].pVmsBmp = new Graphics::TBitmap();
  1187. }
  1188. pObj->VmsMsg->PHASE[nPhase].pVmsBmp->FreeImage();
  1189. pObj->VmsMsg->PHASE[nPhase].pVmsBmp->LoadFromStream(FImgStream);
  1190. int PHASE = pADO->FieldByName("PHASE")->AsInteger;
  1191. pObj->VmsMsg->PHASE[nPhase].DSPL_HH = pADO->FieldByName("DSPL_HH")->AsInteger;
  1192. pObj->VmsMsg->PHASE[nPhase].DNLD_YN = pADO->FieldByName("DNLD_YN")->AsString;
  1193. pObj->VmsMsg->PHASE[nPhase].DSPL_CD = pADO->FieldByName("VMS_FORM_DSPL_MTHD_CD")->AsString;
  1194. pObj->VmsMsg->PHASE[nPhase].VMS_SCH_FORM_TYPE = pADO->FieldByName("VMS_SCH_FORM_TYPE")->AsInteger;
  1195. if (pObj->VmsMsg->PHASE[nPhase].DSPL_HH <= 0) pObj->VmsMsg->PHASE[nPhase].DSPL_HH = 3;
  1196. //if (pObj->VmsMsg->PHASE[nPhase].DSPL_HH >= 10) pObj->VmsMsg->PHASE[nPhase].DSPL_HH = 10;
  1197. if (pObj->VmsMsg->PHASE[nPhase].VMS_SCH_FORM_TYPE == eSchTp_video)
  1198. {
  1199. pObj->VmsMsg->PHASE[nPhase].VMS_DSPL_MSG_TXT = pADO->FieldByName("VMS_DSPL_MSG_INFO")->AsString.Trim();
  1200. pObj->VmsMsg->PHASE[nPhase].VMS_SCH_FORM_TYPE = eSchTp_hongbo; // TODO: 모두 이미지만 표출할 수 있도록 하자.
  1201. pObj->VmsMsg->PHASE[nPhase].DSPL_HH = 5;
  1202. }
  1203. if (pObj->VmsMsg->PHASE[nPhase].VMS_SCH_FORM_TYPE == eSchTp_stream)
  1204. {
  1205. pObj->VmsMsg->PHASE[nPhase].VMS_DSPL_MSG_TXT = pADO->FieldByName("VMS_DSPL_MSG_INFO")->AsString.Trim();
  1206. pObj->VmsMsg->PHASE[nPhase].VMS_SCH_FORM_TYPE = eSchTp_hongbo; // TODO: 모두 이미지만 표출할 수 있도록 하자.
  1207. pObj->VmsMsg->PHASE[nPhase].DSPL_HH = 5;
  1208. }
  1209. String DSPL_DT = pADO->FieldByName("DSPL_DT")->AsString;
  1210. String SVC_DT = pADO->FieldByName("SVC_DT")->AsString;
  1211. pObj->VmsMsg->OFFER_DT = DSPL_DT;
  1212. if (DSPL_DT >= SVC_DT)
  1213. {
  1214. pObj->VmsMsg->OFFER_YN = true;
  1215. }
  1216. else
  1217. {
  1218. pObj->VmsMsg->OFFER_YN = false;
  1219. }
  1220. if (pObj->VmsMsg->PHASE[nPhase].DNLD_YN == "N")
  1221. {
  1222. pObj->VmsMsg->OFFER_YN = false;
  1223. }
  1224. //TODO
  1225. if (pObj->STATE.Comm != vms_comm_normal)
  1226. {
  1227. pObj->VmsMsg->OFFER_YN = false;
  1228. }
  1229. nPhase++;
  1230. }
  1231. catch(Exception &e)
  1232. {
  1233. }
  1234. }
  1235. }
  1236. if (pObj)
  1237. {
  1238. pObj->VmsMsg->Total = nPhase;
  1239. pObj->VmsMsg->Curr = 0;
  1240. pObj->UnLock();
  1241. }
  1242. }
  1243. catch(EDatabaseError &E)
  1244. {
  1245. DBERRORMSG("TVmsCtlrManager::LoadVmsMsg", String(E.ClassName()), E.Message, sQry);
  1246. throw Exception(String(E.ClassName()) + E.Message);
  1247. }
  1248. catch(Exception &e)
  1249. {
  1250. DBERRORMSG("TVmsCtlrManager::LoadVmsMsg", String(e.ClassName()), e.Message, sQry);
  1251. throw Exception(String(e.ClassName()) + e.Message);
  1252. }
  1253. }
  1254. __finally
  1255. {
  1256. if (pADO)
  1257. {
  1258. pADO->Close();
  1259. delete pADO;
  1260. }
  1261. }
  1262. return true;
  1263. }
  1264. //---------------------------------------------------------------------------
  1265. bool TVmsCtlrManager::LoadVmsFormUsage(TADOConnection *ADbConn/*=NULL*/)
  1266. {
  1267. InitFormCount();
  1268. String sQry;
  1269. TADOQuery *pADO = NULL;
  1270. sQry = "SELECT A.VMS_CTLR_NMBR, \r\n"
  1271. " A.VMS_SCH_TYPE, \r\n"
  1272. " A.VMS_SCH_FORM_TYPE, \r\n"
  1273. " A.DSPL_STRT_HH, \r\n"
  1274. " A.DSPL_END_HH, \r\n"
  1275. " TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS') AS CURR_HH, \r\n"
  1276. " A.USE_YN \r\n"
  1277. " FROM TB_VMS_DSPL_SCH A, \r\n"
  1278. " TB_VMS_FORM B \r\n"
  1279. " WHERE 1=1 \r\n"
  1280. // " AND B.VALID_YN = 'Y' \r\n"
  1281. " AND A.VMS_FORM_ID = B.VMS_FORM_ID \r\n";
  1282. try
  1283. {
  1284. try
  1285. {
  1286. pADO = new TADOQuery(NULL);
  1287. pADO->Close();
  1288. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1289. ITSDb_SQLText(pADO, sQry);
  1290. ITSDb_SQLOpen(pADO);
  1291. TVmsCtlr *pObj;
  1292. int nSchType, nFormType;
  1293. for( ; !pADO->Eof; pADO->Next())
  1294. {
  1295. String sVmsNmbr = pADO->FieldByName("VMS_CTLR_NMBR")->AsString;
  1296. pObj = FLists.Find(sVmsNmbr);
  1297. if (!pObj) continue;
  1298. String sSchType = pADO->FieldByName("VMS_SCH_TYPE")->AsString.Trim();
  1299. if (sSchType == "A") nSchType = enScheduleAuto;
  1300. else if (sSchType == "F") nSchType = enScheduleFix;
  1301. else if (sSchType == "B") nSchType = enScheduleBase;
  1302. else continue;
  1303. nFormType = pADO->FieldByName("VMS_SCH_FORM_TYPE")->AsInteger;
  1304. if (nFormType < eSchTp_traffic && nFormType >= eSchTp_max) continue;
  1305. pObj->FormCnt[nSchType].Total[nFormType]++; //등록되어있는 전체 폼 숫자
  1306. if (pADO->FieldByName("USE_YN")->AsString != 'Y') continue;
  1307. //사용하는 것중에 현재시각이 제공시각안에 들어있는것은 카운트하지 않음.
  1308. String sStrHH = pADO->FieldByName("DSPL_STRT_HH")->AsString;
  1309. String sEndHH = pADO->FieldByName("DSPL_END_HH")->AsString;
  1310. String sCurHH = pADO->FieldByName("CURR_HH")->AsString;
  1311. if (sCurHH >= sStrHH && sCurHH <= sEndHH)
  1312. {
  1313. pObj->FormCnt[nSchType].Use[nFormType]++; //사용가능 폼 숫자
  1314. }
  1315. }
  1316. }
  1317. catch(EDatabaseError &E)
  1318. {
  1319. DBERRORMSG("TVmsCtlrManager::LoadVmsFormUsage", String(E.ClassName()), E.Message, sQry);
  1320. throw Exception(String(E.ClassName()) + E.Message);
  1321. }
  1322. catch(Exception &e)
  1323. {
  1324. DBERRORMSG("TVmsCtlrManager::LoadVmsFormUsage", String(e.ClassName()), e.Message, sQry);
  1325. throw Exception(String(e.ClassName()) + e.Message);
  1326. }
  1327. }
  1328. __finally
  1329. {
  1330. if (pADO)
  1331. {
  1332. pADO->Close();
  1333. delete pADO;
  1334. }
  1335. }
  1336. return true;
  1337. }
  1338. //---------------------------------------------------------------------------
  1339. bool TVmsCtlrManager::InsVmsControlHs(String ACtlDt, String AVmsNmbr, String ACtlType, String ACtlVal, String ACtlRes, String AUserId, TADOConnection *ADbConn/*=NULL*/)
  1340. {
  1341. String sQry;
  1342. TADOQuery *pADO = NULL;
  1343. sQry = "INSERT INTO TB_VMS_CTRL_HS( \r\n"
  1344. " CTRL_DT, \r\n"
  1345. " VMS_CTLR_NMBR, \r\n"
  1346. " CTRL_TYPE, \r\n"
  1347. " CTRL_VAL, \r\n"
  1348. " CTRL_RESULT, \r\n"
  1349. " USER_ID \r\n"
  1350. " ) \r\n"
  1351. " VALUES( \r\n"
  1352. " :p01, \r\n"
  1353. " :p02, \r\n"
  1354. " :p03, \r\n"
  1355. " :p04, \r\n"
  1356. " :p05, \r\n"
  1357. " :p06 \r\n"
  1358. " ) \r\n";
  1359. try
  1360. {
  1361. try
  1362. {
  1363. pADO = new TADOQuery(NULL);
  1364. pADO->Close();
  1365. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1366. pADO->SQL->Clear();
  1367. pADO->SQL->Text = sQry;
  1368. pADO->Parameters->ParamByName("p01")->Value = ACtlDt;
  1369. pADO->Parameters->ParamByName("p02")->Value = AVmsNmbr;
  1370. pADO->Parameters->ParamByName("p03")->Value = ACtlType;
  1371. pADO->Parameters->ParamByName("p04")->Value = ACtlVal;
  1372. pADO->Parameters->ParamByName("p05")->Value = ACtlRes;
  1373. pADO->Parameters->ParamByName("p06")->Value = AUserId;
  1374. pADO->ExecSQL();
  1375. return true;
  1376. }
  1377. catch(EDatabaseError &E)
  1378. {
  1379. DBERRORMSG("TVmsCtlrManager::InsVmsControlHs", String(E.ClassName()), E.Message, sQry);
  1380. throw Exception(String(E.ClassName()) + E.Message);
  1381. }
  1382. catch(Exception &e)
  1383. {
  1384. DBERRORMSG("TVmsCtlrManager::InsVmsControlHs", String(e.ClassName()), e.Message, sQry);
  1385. throw Exception(String(e.ClassName()) + e.Message);
  1386. }
  1387. }
  1388. __finally
  1389. {
  1390. if (pADO)
  1391. {
  1392. pADO->Close();
  1393. delete pADO;
  1394. }
  1395. }
  1396. return true;
  1397. }
  1398. //---------------------------------------------------------------------------
  1399. int VmsGetFormTypeIdx(int AFormType)
  1400. {
  1401. int nFormTypeIdx = -1;
  1402. switch(AFormType)
  1403. {
  1404. case eFormTp_traf_1: // 소통상황(1단)
  1405. case eFormTp_traf_2: // 소통상황(2단)
  1406. case eFormTp_traf_3: // 소통상황(3단)
  1407. case eFormTp_traf_4: // 소통상황(4단)
  1408. case eFormtp_figure: // 소통상황(도형식배경소통정보)
  1409. nFormTypeIdx = eSchTp_traffic;
  1410. break;
  1411. case eFormTp_congest: // 정체소통상황
  1412. nFormTypeIdx = eSchTp_congest;
  1413. break;
  1414. case eFormTp_incident: // 돌발문안
  1415. nFormTypeIdx = eSchTp_incident;
  1416. break;
  1417. case eFormTp_gongsa: // 공사/행사문안
  1418. nFormTypeIdx = eSchTp_gongsa;
  1419. break;
  1420. case eFormTp_hongbo: // 홍보문안
  1421. nFormTypeIdx = eSchTp_hongbo;
  1422. break;
  1423. case eFormTp_deture: // 우회도로
  1424. nFormTypeIdx = eSchTp_deture;
  1425. break;
  1426. case eFormTp_safe: // 재난안전
  1427. nFormTypeIdx = eSchTp_safe;
  1428. break;
  1429. case eFormTp_video: // 동영상
  1430. nFormTypeIdx = eSchTp_video;
  1431. break;
  1432. case eFormTp_stream: // 스트리밍영상
  1433. nFormTypeIdx = eSchTp_stream;
  1434. break;
  1435. case eFormTp_atmp: // 대기환경
  1436. nFormTypeIdx = eSchTp_atmp;
  1437. break;
  1438. case eFormTp_park: // 주차정보
  1439. nFormTypeIdx = eSchTp_park;
  1440. break;
  1441. default: break;
  1442. }
  1443. return nFormTypeIdx;
  1444. }