systemApi.cs 92 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Net.Http;
  6. using ResfullApi.Models;
  7. using ResfullApi.Models.balance;
  8. using Newtonsoft.Json;
  9. using System.Data;
  10. using System.IO;
  11. using System.Xml;
  12. using Microsoft.AspNetCore.Mvc;
  13. using Newtonsoft.Json.Linq;
  14. using Microsoft.Extensions.Caching.Memory;
  15. using CommonObj.common;
  16. using CommonObj.model;
  17. using StackExchange.Redis;
  18. namespace ApiProcess.Controllers
  19. {
  20. [ApiController]
  21. [Route("api/[controller]/[action]/data")]
  22. public class systemApi : ControllerBase
  23. {
  24. static readonly log4net.ILog logger = log4net.LogManager.GetLogger(typeof(systemApi));
  25. private IMemoryCache memoryCache;
  26. public systemApi(IMemoryCache memoryCache)
  27. {
  28. this.memoryCache = memoryCache;
  29. }
  30. // {"msisdn":"50940227941","serviceId":"23","money":"2000"}
  31. [HttpPost]
  32. public IActionResult systemCharge([FromBody] dynamic sendData)
  33. {
  34. ////log4net.ILog logger = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
  35. ////log4net.Config.XmlConfigurator.Configure();
  36. responseObjUtil response = new responseObjUtil();
  37. response.status = "-1";
  38. response.message = "Err unknow";
  39. try
  40. {
  41. systemObjChargeRequest data = JsonConvert.DeserializeObject<systemObjChargeRequest>(sendData.ToString());
  42. logger.Info("New request income systemCharge :" + data.ToString());
  43. //lay ve thong tin cua CGW ung voi service
  44. DataSet ds_sv = systemDataAccess.SYS_GET_SERVICE_BY_ID(data.serviceId);
  45. logger.Info("Call database SYS_GET_SERVICE_BY_ID success:");
  46. if (ds_sv != null & ds_sv.Tables[0].Rows.Count > 0)
  47. {
  48. DataRow dr = ds_sv.Tables[0].Rows[0];
  49. string SV_CODE = dr["sv_code"].ToString();
  50. string sv_charg_shortcode = dr["sv_charg_shortcode"].ToString();
  51. string sv_command = dr["sv_command"].ToString();
  52. string sv_charg_url = dr["sv_charg_url"].ToString();
  53. string sv_charg_user = dr["sv_charg_user"].ToString();
  54. string sv_charg_pass = dr["sv_charg_pass"].ToString();
  55. string sv_char_timeout = dr["sv_char_timeout"].ToString();
  56. string sv_char_wscode = dr["sv_char_wscode"].ToString();
  57. string sv_charg_rawdata = dr["sv_charg_rawdata"].ToString();
  58. string sv_charg_gworder = dr["sv_charg_gworder"].ToString();
  59. string msisdn_temp = data.msisdn;
  60. string money = data.money;
  61. string reqid = SV_CODE + "_" + msisdn_temp+"_" + System.DateTime.Now.ToString("ddMMyyyyHHmmsss");
  62. string request = createdRequest(reqid, msisdn_temp, money, sv_charg_shortcode, sv_command, sv_charg_user, sv_charg_pass,
  63. sv_char_wscode, sv_charg_rawdata, sv_charg_gworder);
  64. logger.Info("Request :" + request);
  65. string resultPost = getContent(sv_charg_url, sv_char_timeout, request);
  66. logger.Info("Response :" + resultPost);
  67. string err_code_cmd = "-2000";
  68. string err_msg_cmd = "cmd err unknow";
  69. string ketqua = "-1000|unknow";
  70. string err_code = "-1000";
  71. string err_msg = "unknow";
  72. if (!string.IsNullOrEmpty(resultPost))
  73. {
  74. XmlDocument xmlDoc = new XmlDocument();
  75. xmlDoc.LoadXml(resultPost);
  76. err_code_cmd = xmlDoc.GetElementsByTagName("error").Item(0).InnerText;
  77. err_msg_cmd = xmlDoc.GetElementsByTagName("description").Item(0).InnerText;
  78. if (err_code_cmd == "0")
  79. {
  80. ketqua = xmlDoc.GetElementsByTagName("return").Item(0).InnerText;
  81. err_code = ketqua.Split('|')[0];
  82. err_msg = ketqua.Split('|')[1];
  83. logger.Info("send request id :" + reqid + " err_code: " + err_code + " err_msg: " + err_msg);
  84. }
  85. //update log charge
  86. DataSet ds_updateLog = systemDataAccess.SYS_UPDATE_LOG_CHARGE(data.msisdn, data.serviceId, data.money, err_code_cmd, err_msg_cmd, err_code, err_msg, data.isRenew);
  87. if (ds_updateLog != null & ds_updateLog.Tables[0].Rows.Count > 0)
  88. {
  89. response.status = ds_updateLog.Tables[0].Rows[0]["status"].ToString();
  90. response.message = ds_updateLog.Tables[0].Rows[0]["message"].ToString();
  91. }
  92. }
  93. }
  94. }
  95. catch (Exception ex)
  96. {
  97. logger.Info("Err:" + ex.ToString());
  98. }
  99. logger.Info("Responase to web: " + response.ToString());
  100. return Ok(response);
  101. }
  102. private string createdRequest(string requestid, string msisdn, string money, string shortcode, string command,
  103. string user, string pass, string sv_char_wscode, string sv_charg_rawdata, string sv_charg_gworder)
  104. {
  105. //log4net.ILog logger = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
  106. //log4net.Config.XmlConfigurator.Configure();
  107. string request = "";
  108. try
  109. {
  110. string input = msisdn + "|" + shortcode + "|" + command + "|1|" + money + "|" + requestid;
  111. request = request + @"<soapenv:Envelope xmlns:soapenv=""http://schemas.xmlsoap.org/soap/envelope/"" xmlns:web=""http://webservice.bccsgw.viettel.com/"">";
  112. request = request + @"<soapenv:Header/>";
  113. request = request + @"<soapenv:Body>";
  114. request = request + @"<web:gwOperation>";
  115. request = request + @"<Input>";
  116. request = request + @"<username>" + user + @"</username>";
  117. request = request + @"<password>" + pass + @"</password>";
  118. request = request + @"<wscode>" + sv_char_wscode + @"</wscode>";
  119. request = request + @"<param name=""GWORDER"" value=""" + sv_charg_gworder + @"""/>";
  120. request = request + @"<param name=""input"" value=""" + input + @"""/>";
  121. request = request + @"<rawData></rawData>";
  122. request = request + @"</Input>";
  123. request = request + @"</web:gwOperation>";
  124. request = request + @"</soapenv:Body>";
  125. request = request + @"</soapenv:Envelope>";
  126. }
  127. catch (Exception ex)
  128. {
  129. logger.Info("Err when create request: " + ex.ToString());
  130. }
  131. return request;
  132. }
  133. private string getContent(string api_path, string timeout, string xml)
  134. {
  135. //log4net.ILog logger = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
  136. //log4net.Config.XmlConfigurator.Configure();
  137. string rp = "";
  138. try
  139. {
  140. HttpWebRequest request = (HttpWebRequest)WebRequest.Create(api_path);
  141. byte[] bytes;
  142. bytes = System.Text.Encoding.UTF8.GetBytes(xml);
  143. request.ContentType = "text/xml; encoding='utf-8'";
  144. request.ContentLength = bytes.Length;
  145. request.Method = "POST";
  146. request.Timeout = Convert.ToInt32(timeout);
  147. Stream requestStream = request.GetRequestStream();
  148. requestStream.Write(bytes, 0, bytes.Length);
  149. requestStream.Close();
  150. HttpWebResponse response;
  151. response = (HttpWebResponse)request.GetResponse();
  152. Stream responseStream = response.GetResponseStream();
  153. rp = new StreamReader(responseStream).ReadToEnd();
  154. }
  155. catch (Exception ex)
  156. {
  157. logger.Info("Err when post: " + ex.ToString());
  158. }
  159. return rp;
  160. }
  161. // USER WEB CMS MANAGEMENT APIs
  162. [HttpPost]
  163. public IActionResult sysUserWebCmsGetList([FromBody] dynamic sendData)
  164. {
  165. logger.Info("New request income sysUserWebCmsGetList :" + sendData.ToString());
  166. userWebCmsObjList response = new userWebCmsObjList();
  167. response.responseCode = "-1";
  168. response.responseMessage = "Err unknow";
  169. try
  170. {
  171. var userObj = JObject.Parse(sendData.ToString());
  172. string users = Convert.ToString(userObj["users"]);
  173. string id = Convert.ToString(userObj["id"]);
  174. string username = Convert.ToString(userObj["username"]);
  175. string role = Convert.ToString(userObj["role"]);
  176. string isLock = Convert.ToString(userObj["isLock"]);
  177. string order = Convert.ToString(userObj["order"]);
  178. string rowsOnPage = Convert.ToString(userObj["rowsOnPage"]);
  179. string seqPage = Convert.ToString(userObj["seqPage"]);
  180. if (string.IsNullOrEmpty(users)) users = "-1";
  181. if (string.IsNullOrEmpty(id)) id = "-1";
  182. if (string.IsNullOrEmpty(username)) username = "-1";
  183. if (string.IsNullOrEmpty(role)) role = "-1";
  184. if (string.IsNullOrEmpty(isLock)) isLock = "-1";
  185. if (string.IsNullOrEmpty(order)) order = "asc";
  186. if (string.IsNullOrEmpty(rowsOnPage)) rowsOnPage = "1000000000000";
  187. if (string.IsNullOrEmpty(seqPage)) seqPage = "1";
  188. string token = Convert.ToString(userObj["token"]);
  189. string channel = Convert.ToString(userObj["channel"]);
  190. string language = Convert.ToString(userObj["language"]);
  191. if (string.IsNullOrEmpty(language)) language = "-1";
  192. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  193. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  194. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  195. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  196. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  197. redisConnection _redis;
  198. memoryCache.TryGetValue("redis", out _redis);
  199. if (_redis == null)
  200. {
  201. var cacheExpiryOptions = new MemoryCacheEntryOptions
  202. {
  203. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  204. Priority = CacheItemPriority.High,
  205. SlidingExpiration = TimeSpan.FromMinutes(2),
  206. Size = 1024,
  207. };
  208. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  209. _redis.connet();
  210. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  211. }
  212. if (!_redis.isConnet())
  213. {
  214. if (!_redis.connet())
  215. {
  216. logger.Info("Connect to redis false");
  217. response.responseCode = "-2";
  218. response.responseMessage = "System Update";
  219. logger.Info("confirmTicket response : " + response.ToString());
  220. return Ok(response);
  221. }
  222. else
  223. {
  224. var cacheExpiryOptions = new MemoryCacheEntryOptions
  225. {
  226. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  227. Priority = CacheItemPriority.High,
  228. SlidingExpiration = TimeSpan.FromMinutes(2),
  229. Size = 1024,
  230. };
  231. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  232. }
  233. }
  234. //----------------------Ket thuc lay redis tu cache -------------------------------------
  235. tokenObj _tokenObj = null;
  236. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  237. {
  238. logger.Info("Authen token false");
  239. response.responseCode = "35";
  240. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  241. logger.Info("confirmTicket response : " + response.ToString());
  242. return Ok(response);
  243. }
  244. DataSet ds_regist = systemUserDataAccess.SYS_USER_WEB_CMS_GET_LIST(users, id, username, role, isLock, order, rowsOnPage, seqPage);
  245. logger.Info("Call database SYS_USER_WEB_CMS_GET_LIST success:");
  246. response.responseCode = "0";
  247. response.responseMessage = "Success";
  248. if (ds_regist != null && ds_regist.Tables.Count > 0 && ds_regist.Tables[0].Rows.Count > 0)
  249. {
  250. response.rowsOnPage = ds_regist.Tables[0].Rows[0]["ROW_ON_PAGE"].ToString();
  251. response.seqPage = ds_regist.Tables[0].Rows[0]["SEQ_PAGE"].ToString();
  252. response.totalPage = ds_regist.Tables[0].Rows[0]["TOTAL_PAGE"].ToString();
  253. response.list = new userWebCmsObj[ds_regist.Tables[0].Rows.Count];
  254. for (int j = 0; j < ds_regist.Tables[0].Rows.Count; j++)
  255. {
  256. userWebCmsObj _obj = new userWebCmsObj();
  257. _obj.id = ds_regist.Tables[0].Rows[j]["ID"].ToString();
  258. _obj.username = ds_regist.Tables[0].Rows[j]["USERNAME"].ToString();
  259. _obj.password = ds_regist.Tables[0].Rows[j]["PASSWORD"].ToString();
  260. _obj.role = ds_regist.Tables[0].Rows[j]["ROLE"].ToString();
  261. _obj.countryCode = ds_regist.Tables[0].Rows[j]["COUNTRY_CODE"].ToString();
  262. _obj.isLock = ds_regist.Tables[0].Rows[j]["IS_LOCK"].ToString();
  263. _obj.totalFalse = ds_regist.Tables[0].Rows[j]["TOTAL_FALSE"].ToString();
  264. _obj.timeLock = ds_regist.Tables[0].Rows[j]["TIME_LOCK"].ToString();
  265. _obj.note = ds_regist.Tables[0].Rows[j]["NOTE"].ToString();
  266. response.list[j] = _obj;
  267. }
  268. }
  269. }
  270. catch (Exception ex)
  271. {
  272. logger.Info("exception: " + ex.ToString());
  273. response.responseCode = "-2";
  274. response.responseMessage = "System upgrade";
  275. }
  276. logger.Info("Response to web: " + response.ToString());
  277. return Ok(response);
  278. }
  279. [HttpPost]
  280. public IActionResult sysUserWebCmsInsert([FromBody] dynamic sendData)
  281. {
  282. logger.Info("New request income sysUserWebCmsInsert :" + sendData.ToString());
  283. Response response = new Response();
  284. response.responseCode = "-1";
  285. response.responseMessage = "Err unknow";
  286. try
  287. {
  288. var userObj = JObject.Parse(sendData.ToString());
  289. string username = Convert.ToString(userObj["username"]);
  290. string password = Convert.ToString(userObj["password"]);
  291. string role = Convert.ToString(userObj["role"]);
  292. string countryCode = Convert.ToString(userObj["countryCode"]);
  293. string note = Convert.ToString(userObj["note"]);
  294. string users = Convert.ToString(userObj["users"]);
  295. if (string.IsNullOrEmpty(username)) username = "-1";
  296. if (string.IsNullOrEmpty(password)) password = "-1";
  297. if (string.IsNullOrEmpty(role)) role = "-1";
  298. if (string.IsNullOrEmpty(countryCode)) countryCode = "-1";
  299. if (string.IsNullOrEmpty(note)) note = "-1";
  300. if (string.IsNullOrEmpty(users)) users = "-1";
  301. string token = Convert.ToString(userObj["token"]);
  302. string channel = Convert.ToString(userObj["channel"]);
  303. string language = Convert.ToString(userObj["language"]);
  304. if (string.IsNullOrEmpty(language)) language = "-1";
  305. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  306. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  307. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  308. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  309. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  310. redisConnection _redis;
  311. memoryCache.TryGetValue("redis", out _redis);
  312. if (_redis == null)
  313. {
  314. var cacheExpiryOptions = new MemoryCacheEntryOptions
  315. {
  316. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  317. Priority = CacheItemPriority.High,
  318. SlidingExpiration = TimeSpan.FromMinutes(2),
  319. Size = 1024,
  320. };
  321. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  322. _redis.connet();
  323. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  324. }
  325. if (!_redis.isConnet())
  326. {
  327. if (!_redis.connet())
  328. {
  329. logger.Info("Connect to redis false");
  330. response.responseCode = "-2";
  331. response.responseMessage = "System Update";
  332. logger.Info("confirmTicket response : " + response.ToString());
  333. return Ok(response);
  334. }
  335. else
  336. {
  337. var cacheExpiryOptions = new MemoryCacheEntryOptions
  338. {
  339. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  340. Priority = CacheItemPriority.High,
  341. SlidingExpiration = TimeSpan.FromMinutes(2),
  342. Size = 1024,
  343. };
  344. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  345. }
  346. }
  347. //----------------------Ket thuc lay redis tu cache -------------------------------------
  348. tokenObj _tokenObj = null;
  349. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  350. {
  351. logger.Info("Authen token false");
  352. response.responseCode = "35";
  353. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  354. logger.Info("confirmTicket response : " + response.ToString());
  355. return Ok(response);
  356. }
  357. DataSet ds_regist = systemUserDataAccess.SYS_USER_WEB_CMS_INSERT(username, password, role, countryCode, note, users);
  358. logger.Info("Call database SYS_USER_WEB_CMS_INSERT success:");
  359. if (ds_regist != null && ds_regist.Tables[0].Rows.Count > 0)
  360. {
  361. response.responseCode = ds_regist.Tables[0].Rows[0]["status"].ToString();
  362. response.responseMessage = ds_regist.Tables[0].Rows[0]["msg"].ToString();
  363. }
  364. else
  365. {
  366. response.responseCode = "-1";
  367. response.responseMessage = "Err unknow";
  368. }
  369. }
  370. catch (Exception ex)
  371. {
  372. logger.Info("exception: " + ex.ToString());
  373. response.responseCode = "-2";
  374. response.responseMessage = "System upgrade";
  375. }
  376. logger.Info("Response to web: " + response.ToString());
  377. return Ok(response);
  378. }
  379. [HttpPost]
  380. public IActionResult sysUserWebCmsUpdate([FromBody] dynamic sendData)
  381. {
  382. logger.Info("New request income sysUserWebCmsUpdate :" + sendData.ToString());
  383. Response response = new Response();
  384. response.responseCode = "-1";
  385. response.responseMessage = "Err unknow";
  386. try
  387. {
  388. var userObj = JObject.Parse(sendData.ToString());
  389. string id = Convert.ToString(userObj["id"]);
  390. string username = Convert.ToString(userObj["username"]);
  391. string password = Convert.ToString(userObj["password"]);
  392. string role = Convert.ToString(userObj["role"]);
  393. string countryCode = Convert.ToString(userObj["countryCode"]);
  394. string isLock = Convert.ToString(userObj["isLock"]);
  395. string timeLock = Convert.ToString(userObj["timeLock"]);
  396. string totalFalse = Convert.ToString(userObj["totalFalse"]);
  397. string note = Convert.ToString(userObj["note"]);
  398. string users = Convert.ToString(userObj["users"]);
  399. if (string.IsNullOrEmpty(id)) id = "-1";
  400. if (string.IsNullOrEmpty(username)) username = "-1";
  401. if (string.IsNullOrEmpty(password)) password = "-1";
  402. if (string.IsNullOrEmpty(role)) role = "-1";
  403. if (string.IsNullOrEmpty(countryCode)) countryCode = "-1";
  404. if (string.IsNullOrEmpty(isLock)) isLock = "-1";
  405. if (string.IsNullOrEmpty(timeLock)) timeLock = "-1";
  406. if (string.IsNullOrEmpty(totalFalse)) totalFalse = "-1";
  407. if (string.IsNullOrEmpty(note)) note = "-1";
  408. if (string.IsNullOrEmpty(users)) users = "-1";
  409. string token = Convert.ToString(userObj["token"]);
  410. string channel = Convert.ToString(userObj["channel"]);
  411. string language = Convert.ToString(userObj["language"]);
  412. if (string.IsNullOrEmpty(language)) language = "-1";
  413. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  414. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  415. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  416. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  417. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  418. redisConnection _redis;
  419. memoryCache.TryGetValue("redis", out _redis);
  420. if (_redis == null)
  421. {
  422. var cacheExpiryOptions = new MemoryCacheEntryOptions
  423. {
  424. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  425. Priority = CacheItemPriority.High,
  426. SlidingExpiration = TimeSpan.FromMinutes(2),
  427. Size = 1024,
  428. };
  429. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  430. _redis.connet();
  431. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  432. }
  433. if (!_redis.isConnet())
  434. {
  435. if (!_redis.connet())
  436. {
  437. logger.Info("Connect to redis false");
  438. response.responseCode = "-2";
  439. response.responseMessage = "System Update";
  440. logger.Info("confirmTicket response : " + response.ToString());
  441. return Ok(response);
  442. }
  443. else
  444. {
  445. var cacheExpiryOptions = new MemoryCacheEntryOptions
  446. {
  447. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  448. Priority = CacheItemPriority.High,
  449. SlidingExpiration = TimeSpan.FromMinutes(2),
  450. Size = 1024,
  451. };
  452. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  453. }
  454. }
  455. //----------------------Ket thuc lay redis tu cache -------------------------------------
  456. tokenObj _tokenObj = null;
  457. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  458. {
  459. logger.Info("Authen token false");
  460. response.responseCode = "35";
  461. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  462. logger.Info("confirmTicket response : " + response.ToString());
  463. return Ok(response);
  464. }
  465. DataSet ds_regist = systemUserDataAccess.SYS_USER_WEB_CMS_UPDATE(id, username, password, role, countryCode, isLock, timeLock, totalFalse, note, users);
  466. logger.Info("Call database SYS_USER_WEB_CMS_UPDATE success:");
  467. if (ds_regist != null && ds_regist.Tables[0].Rows.Count > 0)
  468. {
  469. response.responseCode = ds_regist.Tables[0].Rows[0]["status"].ToString();
  470. response.responseMessage = ds_regist.Tables[0].Rows[0]["msg"].ToString();
  471. }
  472. else
  473. {
  474. response.responseCode = "-1";
  475. response.responseMessage = "Err unknow";
  476. }
  477. }
  478. catch (Exception ex)
  479. {
  480. logger.Info("exception: " + ex.ToString());
  481. response.responseCode = "-2";
  482. response.responseMessage = "System upgrade";
  483. }
  484. logger.Info("Response to web: " + response.ToString());
  485. return Ok(response);
  486. }
  487. // FUNCTION WEB CMS MANAGEMENT APIs
  488. [HttpPost]
  489. public IActionResult sysFunctionWebCmsGetList([FromBody] dynamic sendData)
  490. {
  491. logger.Info("New request income sysFunctionWebCmsGetList :" + sendData.ToString());
  492. functionWebCmsObjList response = new functionWebCmsObjList();
  493. response.responseCode = "-1";
  494. response.responseMessage = "Err unknow";
  495. try
  496. {
  497. var userObj = JObject.Parse(sendData.ToString());
  498. string users = Convert.ToString(userObj["users"]);
  499. string id = Convert.ToString(userObj["id"]);
  500. string role = Convert.ToString(userObj["role"]);
  501. string name = Convert.ToString(userObj["name"]);
  502. string link = Convert.ToString(userObj["link"]);
  503. string order = Convert.ToString(userObj["order"]);
  504. string rowsOnPage = Convert.ToString(userObj["rowsOnPage"]);
  505. string seqPage = Convert.ToString(userObj["seqPage"]);
  506. if (string.IsNullOrEmpty(users)) users = "-1";
  507. if (string.IsNullOrEmpty(id)) id = "-1";
  508. if (string.IsNullOrEmpty(role)) role = "-1";
  509. if (string.IsNullOrEmpty(name)) name = "-1";
  510. if (string.IsNullOrEmpty(link)) link = "-1";
  511. if (string.IsNullOrEmpty(order)) order = "asc";
  512. if (string.IsNullOrEmpty(rowsOnPage)) rowsOnPage = "1000000000000";
  513. if (string.IsNullOrEmpty(seqPage)) seqPage = "1";
  514. string token = Convert.ToString(userObj["token"]);
  515. string channel = Convert.ToString(userObj["channel"]);
  516. string language = Convert.ToString(userObj["language"]);
  517. if (string.IsNullOrEmpty(language)) language = "-1";
  518. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  519. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  520. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  521. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  522. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  523. redisConnection _redis;
  524. memoryCache.TryGetValue("redis", out _redis);
  525. if (_redis == null)
  526. {
  527. var cacheExpiryOptions = new MemoryCacheEntryOptions
  528. {
  529. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  530. Priority = CacheItemPriority.High,
  531. SlidingExpiration = TimeSpan.FromMinutes(2),
  532. Size = 1024,
  533. };
  534. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  535. _redis.connet();
  536. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  537. }
  538. if (!_redis.isConnet())
  539. {
  540. if (!_redis.connet())
  541. {
  542. logger.Info("Connect to redis false");
  543. response.responseCode = "-2";
  544. response.responseMessage = "System Update";
  545. logger.Info("confirmTicket response : " + response.ToString());
  546. return Ok(response);
  547. }
  548. else
  549. {
  550. var cacheExpiryOptions = new MemoryCacheEntryOptions
  551. {
  552. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  553. Priority = CacheItemPriority.High,
  554. SlidingExpiration = TimeSpan.FromMinutes(2),
  555. Size = 1024,
  556. };
  557. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  558. }
  559. }
  560. //----------------------Ket thuc lay redis tu cache -------------------------------------
  561. tokenObj _tokenObj = null;
  562. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  563. {
  564. logger.Info("Authen token false");
  565. response.responseCode = "35";
  566. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  567. logger.Info("confirmTicket response : " + response.ToString());
  568. return Ok(response);
  569. }
  570. DataSet ds_regist = systemUserDataAccess.SYS_FUNCTION_WEB_CMS_GET_LIST(users, id, role, name, link, order, rowsOnPage, seqPage);
  571. logger.Info("Call database SYS_FUNCTION_WEB_CMS_GET_LIST success:");
  572. response.responseCode = "0";
  573. response.responseMessage = "Success";
  574. if (ds_regist != null && ds_regist.Tables.Count > 0 && ds_regist.Tables[0].Rows.Count > 0)
  575. {
  576. response.rowsOnPage = ds_regist.Tables[0].Rows[0]["ROW_ON_PAGE"].ToString();
  577. response.seqPage = ds_regist.Tables[0].Rows[0]["SEQ_PAGE"].ToString();
  578. response.totalPage = ds_regist.Tables[0].Rows[0]["TOTAL_PAGE"].ToString();
  579. response.list = new functionWebCmsObj[ds_regist.Tables[0].Rows.Count];
  580. for (int j = 0; j < ds_regist.Tables[0].Rows.Count; j++)
  581. {
  582. functionWebCmsObj _obj = new functionWebCmsObj();
  583. _obj.id = ds_regist.Tables[0].Rows[j]["ID"].ToString();
  584. _obj.role = ds_regist.Tables[0].Rows[j]["ROLE"].ToString();
  585. _obj.name = ds_regist.Tables[0].Rows[j]["NAME"].ToString();
  586. _obj.link = ds_regist.Tables[0].Rows[j]["LINK"].ToString();
  587. _obj.note = ds_regist.Tables[0].Rows[j]["NOTE"].ToString();
  588. response.list[j] = _obj;
  589. }
  590. }
  591. }
  592. catch (Exception ex)
  593. {
  594. logger.Info("exception: " + ex.ToString());
  595. response.responseCode = "-2";
  596. response.responseMessage = "System upgrade";
  597. }
  598. logger.Info("Response to web: " + response.ToString());
  599. return Ok(response);
  600. }
  601. [HttpPost]
  602. public IActionResult sysFunctionWebCmsInsert([FromBody] dynamic sendData)
  603. {
  604. logger.Info("New request income sysFunctionWebCmsInsert :" + sendData.ToString());
  605. Response response = new Response();
  606. response.responseCode = "-1";
  607. response.responseMessage = "Err unknow";
  608. try
  609. {
  610. var userObj = JObject.Parse(sendData.ToString());
  611. string role = Convert.ToString(userObj["role"]);
  612. string name = Convert.ToString(userObj["name"]);
  613. string link = Convert.ToString(userObj["link"]);
  614. string note = Convert.ToString(userObj["note"]);
  615. string users = Convert.ToString(userObj["users"]);
  616. if (string.IsNullOrEmpty(role)) role = "-1";
  617. if (string.IsNullOrEmpty(name)) name = "-1";
  618. if (string.IsNullOrEmpty(link)) link = "-1";
  619. if (string.IsNullOrEmpty(note)) note = "-1";
  620. if (string.IsNullOrEmpty(users)) users = "-1";
  621. string token = Convert.ToString(userObj["token"]);
  622. string channel = Convert.ToString(userObj["channel"]);
  623. string language = Convert.ToString(userObj["language"]);
  624. if (string.IsNullOrEmpty(language)) language = "-1";
  625. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  626. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  627. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  628. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  629. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  630. redisConnection _redis;
  631. memoryCache.TryGetValue("redis", out _redis);
  632. if (_redis == null)
  633. {
  634. var cacheExpiryOptions = new MemoryCacheEntryOptions
  635. {
  636. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  637. Priority = CacheItemPriority.High,
  638. SlidingExpiration = TimeSpan.FromMinutes(2),
  639. Size = 1024,
  640. };
  641. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  642. _redis.connet();
  643. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  644. }
  645. if (!_redis.isConnet())
  646. {
  647. if (!_redis.connet())
  648. {
  649. logger.Info("Connect to redis false");
  650. response.responseCode = "-2";
  651. response.responseMessage = "System Update";
  652. logger.Info("confirmTicket response : " + response.ToString());
  653. return Ok(response);
  654. }
  655. else
  656. {
  657. var cacheExpiryOptions = new MemoryCacheEntryOptions
  658. {
  659. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  660. Priority = CacheItemPriority.High,
  661. SlidingExpiration = TimeSpan.FromMinutes(2),
  662. Size = 1024,
  663. };
  664. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  665. }
  666. }
  667. //----------------------Ket thuc lay redis tu cache -------------------------------------
  668. tokenObj _tokenObj = null;
  669. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  670. {
  671. logger.Info("Authen token false");
  672. response.responseCode = "35";
  673. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  674. logger.Info("confirmTicket response : " + response.ToString());
  675. return Ok(response);
  676. }
  677. DataSet ds_regist = systemUserDataAccess.SYS_FUNCTION_WEB_CMS_INSERT(role, name, link, note, users);
  678. logger.Info("Call database SYS_FUNCTION_WEB_CMS_INSERT success:");
  679. if (ds_regist != null && ds_regist.Tables[0].Rows.Count > 0)
  680. {
  681. response.responseCode = ds_regist.Tables[0].Rows[0]["status"].ToString();
  682. response.responseMessage = ds_regist.Tables[0].Rows[0]["msg"].ToString();
  683. }
  684. else
  685. {
  686. response.responseCode = "-1";
  687. response.responseMessage = "Err unknow";
  688. }
  689. }
  690. catch (Exception ex)
  691. {
  692. logger.Info("exception: " + ex.ToString());
  693. response.responseCode = "-2";
  694. response.responseMessage = "System upgrade";
  695. }
  696. logger.Info("Response to web: " + response.ToString());
  697. return Ok(response);
  698. }
  699. [HttpPost]
  700. public IActionResult sysFunctionWebCmsUpdate([FromBody] dynamic sendData)
  701. {
  702. logger.Info("New request income sysFunctionWebCmsUpdate :" + sendData.ToString());
  703. Response response = new Response();
  704. response.responseCode = "-1";
  705. response.responseMessage = "Err unknow";
  706. try
  707. {
  708. var userObj = JObject.Parse(sendData.ToString());
  709. string id = Convert.ToString(userObj["id"]);
  710. string role = Convert.ToString(userObj["role"]);
  711. string name = Convert.ToString(userObj["name"]);
  712. string link = Convert.ToString(userObj["link"]);
  713. string note = Convert.ToString(userObj["note"]);
  714. string users = Convert.ToString(userObj["users"]);
  715. if (string.IsNullOrEmpty(id)) id = "-1";
  716. if (string.IsNullOrEmpty(role)) role = "-1";
  717. if (string.IsNullOrEmpty(name)) name = "-1";
  718. if (string.IsNullOrEmpty(link)) link = "-1";
  719. if (string.IsNullOrEmpty(note)) note = "-1";
  720. if (string.IsNullOrEmpty(users)) users = "-1";
  721. string token = Convert.ToString(userObj["token"]);
  722. string channel = Convert.ToString(userObj["channel"]);
  723. string language = Convert.ToString(userObj["language"]);
  724. if (string.IsNullOrEmpty(language)) language = "-1";
  725. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  726. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  727. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  728. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  729. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  730. redisConnection _redis;
  731. memoryCache.TryGetValue("redis", out _redis);
  732. if (_redis == null)
  733. {
  734. var cacheExpiryOptions = new MemoryCacheEntryOptions
  735. {
  736. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  737. Priority = CacheItemPriority.High,
  738. SlidingExpiration = TimeSpan.FromMinutes(2),
  739. Size = 1024,
  740. };
  741. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  742. _redis.connet();
  743. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  744. }
  745. if (!_redis.isConnet())
  746. {
  747. if (!_redis.connet())
  748. {
  749. logger.Info("Connect to redis false");
  750. response.responseCode = "-2";
  751. response.responseMessage = "System Update";
  752. logger.Info("confirmTicket response : " + response.ToString());
  753. return Ok(response);
  754. }
  755. else
  756. {
  757. var cacheExpiryOptions = new MemoryCacheEntryOptions
  758. {
  759. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  760. Priority = CacheItemPriority.High,
  761. SlidingExpiration = TimeSpan.FromMinutes(2),
  762. Size = 1024,
  763. };
  764. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  765. }
  766. }
  767. //----------------------Ket thuc lay redis tu cache -------------------------------------
  768. tokenObj _tokenObj = null;
  769. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  770. {
  771. logger.Info("Authen token false");
  772. response.responseCode = "35";
  773. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  774. logger.Info("confirmTicket response : " + response.ToString());
  775. return Ok(response);
  776. }
  777. DataSet ds_regist = systemUserDataAccess.SYS_FUNCTION_WEB_CMS_UPDATE(id, role, name, link, note, users);
  778. logger.Info("Call database SYS_FUNCTION_WEB_CMS_UPDATE success:");
  779. if (ds_regist != null && ds_regist.Tables[0].Rows.Count > 0)
  780. {
  781. response.responseCode = ds_regist.Tables[0].Rows[0]["status"].ToString();
  782. response.responseMessage = ds_regist.Tables[0].Rows[0]["msg"].ToString();
  783. }
  784. else
  785. {
  786. response.responseCode = "-1";
  787. response.responseMessage = "Err unknow";
  788. }
  789. }
  790. catch (Exception ex)
  791. {
  792. logger.Info("exception: " + ex.ToString());
  793. response.responseCode = "-2";
  794. response.responseMessage = "System upgrade";
  795. }
  796. logger.Info("Response to web: " + response.ToString());
  797. return Ok(response);
  798. }
  799. // REPORT COUNT DAILY MANAGEMENT APIs
  800. [HttpPost]
  801. public IActionResult sysReportCountDailyGetList([FromBody] dynamic sendData)
  802. {
  803. logger.Info("New request income sysReportCountDailyGetList :" + sendData.ToString());
  804. reportCountDailyObjList response = new reportCountDailyObjList();
  805. response.responseCode = "-1";
  806. response.responseMessage = "Err unknow";
  807. try
  808. {
  809. var userObj = JObject.Parse(sendData.ToString());
  810. string users = Convert.ToString(userObj["users"]);
  811. string id = Convert.ToString(userObj["id"]);
  812. string reportDate = Convert.ToString(userObj["reportDate"]);
  813. string campaignId = Convert.ToString(userObj["campaignId"]);
  814. string serviceId = Convert.ToString(userObj["serviceId"]);
  815. string fromDate = Convert.ToString(userObj["fromDate"]);
  816. string toDate = Convert.ToString(userObj["toDate"]);
  817. string order = Convert.ToString(userObj["order"]);
  818. string rowsOnPage = Convert.ToString(userObj["rowsOnPage"]);
  819. string seqPage = Convert.ToString(userObj["seqPage"]);
  820. if (string.IsNullOrEmpty(users)) users = "-1";
  821. if (string.IsNullOrEmpty(id)) id = "-1";
  822. if (string.IsNullOrEmpty(reportDate)) reportDate = "-1";
  823. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  824. if (string.IsNullOrEmpty(serviceId)) serviceId = "-1";
  825. if (string.IsNullOrEmpty(fromDate)) fromDate = "-1";
  826. if (string.IsNullOrEmpty(toDate)) toDate = "-1";
  827. if (string.IsNullOrEmpty(order)) order = "desc";
  828. if (string.IsNullOrEmpty(rowsOnPage)) rowsOnPage = "1000000000000";
  829. if (string.IsNullOrEmpty(seqPage)) seqPage = "1";
  830. string token = Convert.ToString(userObj["token"]);
  831. string channel = Convert.ToString(userObj["channel"]);
  832. string language = Convert.ToString(userObj["language"]);
  833. if (string.IsNullOrEmpty(language)) language = "-1";
  834. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  835. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  836. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  837. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  838. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  839. redisConnection _redis;
  840. memoryCache.TryGetValue("redis", out _redis);
  841. if (_redis == null)
  842. {
  843. var cacheExpiryOptions = new MemoryCacheEntryOptions
  844. {
  845. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  846. Priority = CacheItemPriority.High,
  847. SlidingExpiration = TimeSpan.FromMinutes(2),
  848. Size = 1024,
  849. };
  850. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  851. _redis.connet();
  852. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  853. }
  854. if (!_redis.isConnet())
  855. {
  856. if (!_redis.connet())
  857. {
  858. logger.Info("Connect to redis false");
  859. response.responseCode = "-2";
  860. response.responseMessage = "System Update";
  861. logger.Info("confirmTicket response : " + response.ToString());
  862. return Ok(response);
  863. }
  864. else
  865. {
  866. var cacheExpiryOptions = new MemoryCacheEntryOptions
  867. {
  868. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  869. Priority = CacheItemPriority.High,
  870. SlidingExpiration = TimeSpan.FromMinutes(2),
  871. Size = 1024,
  872. };
  873. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  874. }
  875. }
  876. //----------------------Ket thuc lay redis tu cache -------------------------------------
  877. tokenObj _tokenObj = null;
  878. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  879. {
  880. logger.Info("Authen token false");
  881. response.responseCode = "35";
  882. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  883. logger.Info("confirmTicket response : " + response.ToString());
  884. return Ok(response);
  885. }
  886. DataSet ds_regist = systemDataAccess.SYS_REPORT_COUNT_DAILY_GET_LIST(users, id, reportDate, campaignId, serviceId, fromDate, toDate, order, rowsOnPage, seqPage);
  887. logger.Info("Call database SYS_REPORT_COUNT_DAILY_GET_LIST success:");
  888. response.responseCode = "0";
  889. response.responseMessage = "Success";
  890. if (ds_regist != null && ds_regist.Tables.Count > 0 && ds_regist.Tables[0].Rows.Count > 0)
  891. {
  892. response.rowsOnPage = ds_regist.Tables[0].Rows[0]["ROW_ON_PAGE"].ToString();
  893. response.seqPage = ds_regist.Tables[0].Rows[0]["SEQ_PAGE"].ToString();
  894. response.totalPage = ds_regist.Tables[0].Rows[0]["TOTAL_PAGE"].ToString();
  895. response.list = new reportCountDailyObj[ds_regist.Tables[0].Rows.Count];
  896. for (int j = 0; j < ds_regist.Tables[0].Rows.Count; j++)
  897. {
  898. reportCountDailyObj _obj = new reportCountDailyObj();
  899. _obj.id = ds_regist.Tables[0].Rows[j]["ID"].ToString();
  900. _obj.reportDate = ds_regist.Tables[0].Rows[j]["REPORT_DATE"] != DBNull.Value ? Convert.ToDateTime(ds_regist.Tables[0].Rows[j]["REPORT_DATE"]).ToString("dd/MM/yyyy") : "";
  901. _obj.campaignId = ds_regist.Tables[0].Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["CAMPAIGN_ID"].ToString() : "";
  902. _obj.campaignName = ds_regist.Tables[0].Rows[j]["CAMPAIGN_NAME"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["CAMPAIGN_NAME"].ToString() : "";
  903. _obj.priority = ds_regist.Tables[0].Rows[j]["PRIORITY"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["PRIORITY"].ToString() : "";
  904. _obj.isDefault = ds_regist.Tables[0].Rows[j]["IS_DEFAULT"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["IS_DEFAULT"].ToString() : "";
  905. _obj.isMyService = ds_regist.Tables[0].Rows[j]["IS_MYSERVICE"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["IS_MYSERVICE"].ToString() : "";
  906. _obj.addType = ds_regist.Tables[0].Rows[j]["ADD_TYPE"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["ADD_TYPE"].ToString() : "";
  907. _obj.serviceId = ds_regist.Tables[0].Rows[j]["SERVICE_ID"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["SERVICE_ID"].ToString() : "";
  908. _obj.serviceName = ds_regist.Tables[0].Rows[j]["SERVICE_NAME"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["SERVICE_NAME"].ToString() : "";
  909. _obj.countSend1 = ds_regist.Tables[0].Rows[j]["COUNT_SEND_1"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_SEND_1"].ToString() : "0";
  910. _obj.countSuccess1 = ds_regist.Tables[0].Rows[j]["COUNT_SUCCESS_1"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_SUCCESS_1"].ToString() : "0";
  911. _obj.countFail1 = ds_regist.Tables[0].Rows[j]["COUNT_FAIL_1"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_FAIL_1"].ToString() : "0";
  912. _obj.countPress1 = ds_regist.Tables[0].Rows[j]["COUNT_PRESS_1"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_PRESS_1"].ToString() : "0";
  913. _obj.countSend2 = ds_regist.Tables[0].Rows[j]["COUNT_SEND_2"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_SEND_2"].ToString() : "0";
  914. _obj.countPress2 = ds_regist.Tables[0].Rows[j]["COUNT_PRESS_2"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_PRESS_2"].ToString() : "0";
  915. _obj.countRegSuccess = ds_regist.Tables[0].Rows[j]["COUNT_REG_SUCCESS"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_REG_SUCCESS"].ToString() : "0";
  916. _obj.countRegFail = ds_regist.Tables[0].Rows[j]["COUNT_REG_FAIL"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_REG_FAIL"].ToString() : "0";
  917. _obj.insertTime = ds_regist.Tables[0].Rows[j]["INSERT_TIME"] != DBNull.Value ? Convert.ToDateTime(ds_regist.Tables[0].Rows[j]["INSERT_TIME"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  918. response.list[j] = _obj;
  919. }
  920. }
  921. }
  922. catch (Exception ex)
  923. {
  924. logger.Info("exception: " + ex.ToString());
  925. response.responseCode = "-2";
  926. response.responseMessage = "System upgrade";
  927. }
  928. logger.Info("Response to web: " + response.ToString());
  929. return Ok(response);
  930. }
  931. // REPORT ERROR DAILY MANAGEMENT APIs
  932. [HttpPost]
  933. public IActionResult sysReportErrorDailyGetList([FromBody] dynamic sendData)
  934. {
  935. logger.Info("New request income sysReportErrorDailyGetList :" + sendData.ToString());
  936. reportErrorDailyObjList response = new reportErrorDailyObjList();
  937. response.responseCode = "-1";
  938. response.responseMessage = "Err unknow";
  939. try
  940. {
  941. var userObj = JObject.Parse(sendData.ToString());
  942. string users = Convert.ToString(userObj["users"]);
  943. string reportDate = Convert.ToString(userObj["reportDate"]);
  944. string campaignId = Convert.ToString(userObj["campaignId"]);
  945. string serviceId = Convert.ToString(userObj["serviceId"]);
  946. if (string.IsNullOrEmpty(users)) users = "-1";
  947. if (string.IsNullOrEmpty(reportDate)) reportDate = "-1";
  948. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  949. if (string.IsNullOrEmpty(serviceId)) serviceId = "-1";
  950. string token = Convert.ToString(userObj["token"]);
  951. string channel = Convert.ToString(userObj["channel"]);
  952. string language = Convert.ToString(userObj["language"]);
  953. if (string.IsNullOrEmpty(language)) language = "-1";
  954. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  955. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  956. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  957. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  958. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  959. redisConnection _redis;
  960. memoryCache.TryGetValue("redis", out _redis);
  961. if (_redis == null)
  962. {
  963. var cacheExpiryOptions = new MemoryCacheEntryOptions
  964. {
  965. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  966. Priority = CacheItemPriority.High,
  967. SlidingExpiration = TimeSpan.FromMinutes(2),
  968. Size = 1024,
  969. };
  970. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  971. _redis.connet();
  972. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  973. }
  974. if (!_redis.isConnet())
  975. {
  976. if (!_redis.connet())
  977. {
  978. logger.Info("Connect to redis false");
  979. response.responseCode = "-2";
  980. response.responseMessage = "System Update";
  981. logger.Info("confirmTicket response : " + response.ToString());
  982. return Ok(response);
  983. }
  984. else
  985. {
  986. var cacheExpiryOptions = new MemoryCacheEntryOptions
  987. {
  988. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  989. Priority = CacheItemPriority.High,
  990. SlidingExpiration = TimeSpan.FromMinutes(2),
  991. Size = 1024,
  992. };
  993. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  994. }
  995. }
  996. //----------------------Ket thuc lay redis tu cache -------------------------------------
  997. tokenObj _tokenObj = null;
  998. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  999. {
  1000. logger.Info("Authen token false");
  1001. response.responseCode = "35";
  1002. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  1003. logger.Info("confirmTicket response : " + response.ToString());
  1004. return Ok(response);
  1005. }
  1006. DataSet ds_regist = systemDataAccess.SYS_REPORT_ERROR_DAILY_GET_LIST(users, reportDate, campaignId, serviceId);
  1007. logger.Info("Call database SYS_REPORT_ERROR_DAILY_GET_LIST success:");
  1008. response.responseCode = "0";
  1009. response.responseMessage = "Success";
  1010. if (ds_regist != null && ds_regist.Tables.Count > 0 && ds_regist.Tables[0].Rows.Count > 0)
  1011. {
  1012. response.list = new reportErrorDailyObj[ds_regist.Tables[0].Rows.Count];
  1013. for (int j = 0; j < ds_regist.Tables[0].Rows.Count; j++)
  1014. {
  1015. reportErrorDailyObj _obj = new reportErrorDailyObj();
  1016. _obj.id = ds_regist.Tables[0].Rows[j]["ID"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["ID"].ToString() : "";
  1017. _obj.reportDate = ds_regist.Tables[0].Rows[j]["REPORT_DATE"] != DBNull.Value ? Convert.ToDateTime(ds_regist.Tables[0].Rows[j]["REPORT_DATE"]).ToString("dd/MM/yyyy") : "";
  1018. _obj.campaignId = ds_regist.Tables[0].Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["CAMPAIGN_ID"].ToString() : "";
  1019. _obj.serviceId = ds_regist.Tables[0].Rows[j]["SERVICE_ID"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["SERVICE_ID"].ToString() : "";
  1020. _obj.errorCode = ds_regist.Tables[0].Rows[j]["ERROR_CODE"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["ERROR_CODE"].ToString() : "";
  1021. _obj.countNum = ds_regist.Tables[0].Rows[j]["COUNT_NUM"] != DBNull.Value ? ds_regist.Tables[0].Rows[j]["COUNT_NUM"].ToString() : "0";
  1022. _obj.insertTime = ds_regist.Tables[0].Rows[j]["INSERT_TIME"] != DBNull.Value ? Convert.ToDateTime(ds_regist.Tables[0].Rows[j]["INSERT_TIME"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  1023. response.list[j] = _obj;
  1024. }
  1025. }
  1026. else
  1027. {
  1028. response.list = new reportErrorDailyObj[0];
  1029. }
  1030. }
  1031. catch (Exception ex)
  1032. {
  1033. logger.Info("exception: " + ex.ToString());
  1034. response.responseCode = "-2";
  1035. response.responseMessage = "System upgrade";
  1036. }
  1037. logger.Info("Response to web: " + response.ToString());
  1038. return Ok(response);
  1039. }
  1040. // HOURLY IMPRESSIONS API
  1041. [HttpPost]
  1042. public IActionResult sysHourlyImpressionsGetList([FromBody] dynamic sendData)
  1043. {
  1044. logger.Info("New request income sysHourlyImpressionsGetList :" + sendData.ToString());
  1045. hourlyImpressionsObjList response = new hourlyImpressionsObjList();
  1046. response.responseCode = "-1";
  1047. response.responseMessage = "Err unknow";
  1048. try
  1049. {
  1050. var userObj = JObject.Parse(sendData.ToString());
  1051. string campaignId = Convert.ToString(userObj["campaignId"]);
  1052. string serviceId = Convert.ToString(userObj["serviceId"]);
  1053. string hours = Convert.ToString(userObj["hours"]);
  1054. string quickJump = Convert.ToString(userObj["quickJump"]);
  1055. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  1056. if (string.IsNullOrEmpty(serviceId)) serviceId = "-1";
  1057. if (string.IsNullOrEmpty(hours)) hours = "72h";
  1058. if (string.IsNullOrEmpty(quickJump)) quickJump = "-1";
  1059. string token = Convert.ToString(userObj["token"]);
  1060. string channel = Convert.ToString(userObj["channel"]);
  1061. string language = Convert.ToString(userObj["language"]);
  1062. if (string.IsNullOrEmpty(language)) language = "-1";
  1063. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  1064. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  1065. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  1066. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  1067. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  1068. redisConnection _redis;
  1069. memoryCache.TryGetValue("redis", out _redis);
  1070. if (_redis == null)
  1071. {
  1072. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1073. {
  1074. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1075. Priority = CacheItemPriority.High,
  1076. SlidingExpiration = TimeSpan.FromMinutes(2),
  1077. Size = 1024,
  1078. };
  1079. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  1080. _redis.connet();
  1081. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1082. }
  1083. if (!_redis.isConnet())
  1084. {
  1085. if (!_redis.connet())
  1086. {
  1087. logger.Info("Connect to redis false");
  1088. response.responseCode = "-2";
  1089. response.responseMessage = "System Update";
  1090. logger.Info("sysHourlyImpressionsGetList response : " + response.ToString());
  1091. return Ok(response);
  1092. }
  1093. else
  1094. {
  1095. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1096. {
  1097. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1098. Priority = CacheItemPriority.High,
  1099. SlidingExpiration = TimeSpan.FromMinutes(2),
  1100. Size = 1024,
  1101. };
  1102. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1103. }
  1104. }
  1105. //----------------------Ket thuc lay redis tu cache -------------------------------------
  1106. tokenObj _tokenObj = null;
  1107. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  1108. {
  1109. logger.Info("Authen token false");
  1110. response.responseCode = "35";
  1111. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  1112. logger.Info("sysHourlyImpressionsGetList response : " + response.ToString());
  1113. return Ok(response);
  1114. }
  1115. DataSet ds = balanceDataAccess.GET_HOURLY_IMPRESSIONS(campaignId, serviceId, hours, quickJump);
  1116. logger.Info("Call database GET_HOURLY_IMPRESSIONS success:");
  1117. response.responseCode = "0";
  1118. response.responseMessage = "Success";
  1119. if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  1120. {
  1121. response.list = new hourlyImpressionsObj[ds.Tables[0].Rows.Count];
  1122. for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
  1123. {
  1124. hourlyImpressionsObj _obj = new hourlyImpressionsObj();
  1125. _obj.hourLabel = ds.Tables[0].Rows[j]["HOUR_LABEL"] != DBNull.Value ? ds.Tables[0].Rows[j]["HOUR_LABEL"].ToString() : "";
  1126. _obj.hourValue = ds.Tables[0].Rows[j]["HOUR_VALUE"] != DBNull.Value ? ds.Tables[0].Rows[j]["HOUR_VALUE"].ToString() : "";
  1127. _obj.campaignId = ds.Tables[0].Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_ID"].ToString() : "";
  1128. _obj.campaignName = ds.Tables[0].Rows[j]["CAMPAIGN_NAME"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_NAME"].ToString() : "";
  1129. _obj.serviceId = ""; // No longer using service
  1130. _obj.serviceName = ""; // No longer using service
  1131. _obj.countImpressions = ds.Tables[0].Rows[j]["COUNT_IMPRESSED"] != DBNull.Value ? ds.Tables[0].Rows[j]["COUNT_IMPRESSED"].ToString() : "0";
  1132. response.list[j] = _obj;
  1133. }
  1134. }
  1135. }
  1136. catch (Exception ex)
  1137. {
  1138. logger.Info("exception: " + ex.ToString());
  1139. response.responseCode = "-2";
  1140. response.responseMessage = "System upgrade";
  1141. }
  1142. logger.Info("Response to web: " + response.ToString());
  1143. return Ok(response);
  1144. }
  1145. // DAILY IMPRESSIONS API
  1146. [HttpPost]
  1147. public IActionResult sysDailyImpressionsGetList([FromBody] dynamic sendData)
  1148. {
  1149. logger.Info("New request income sysDailyImpressionsGetList :" + sendData.ToString());
  1150. hourlyImpressionsObjList response = new hourlyImpressionsObjList();
  1151. response.responseCode = "-1";
  1152. response.responseMessage = "Err unknow";
  1153. try
  1154. {
  1155. var userObj = JObject.Parse(sendData.ToString());
  1156. string campaignId = Convert.ToString(userObj["campaignId"]);
  1157. string fromDate = Convert.ToString(userObj["fromDate"]);
  1158. string toDate = Convert.ToString(userObj["toDate"]);
  1159. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  1160. if (string.IsNullOrEmpty(fromDate)) fromDate = "-1";
  1161. if (string.IsNullOrEmpty(toDate)) toDate = "-1";
  1162. string token = Convert.ToString(userObj["token"]);
  1163. string channel = Convert.ToString(userObj["channel"]);
  1164. string language = Convert.ToString(userObj["language"]);
  1165. if (string.IsNullOrEmpty(language)) language = "-1";
  1166. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  1167. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  1168. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  1169. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  1170. //---------------------Lay ra va luu mot redis tu cache-----------------------------
  1171. redisConnection _redis;
  1172. memoryCache.TryGetValue("redis", out _redis);
  1173. if (_redis == null)
  1174. {
  1175. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1176. {
  1177. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1178. Priority = CacheItemPriority.High,
  1179. SlidingExpiration = TimeSpan.FromMinutes(2),
  1180. Size = 1024,
  1181. };
  1182. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  1183. _redis.connet();
  1184. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1185. }
  1186. if (!_redis.isConnet())
  1187. {
  1188. if (!_redis.connet())
  1189. {
  1190. logger.Info("Connect to redis false");
  1191. response.responseCode = "-2";
  1192. response.responseMessage = "System Update";
  1193. logger.Info("sysDailyImpressionsGetList response : " + response.ToString());
  1194. return Ok(response);
  1195. }
  1196. else
  1197. {
  1198. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1199. {
  1200. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1201. Priority = CacheItemPriority.High,
  1202. SlidingExpiration = TimeSpan.FromMinutes(2),
  1203. Size = 1024,
  1204. };
  1205. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1206. }
  1207. }
  1208. //----------------------Ket thuc lay redis tu cache -------------------------------------
  1209. tokenObj _tokenObj = null;
  1210. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  1211. {
  1212. logger.Info("Authen token false");
  1213. response.responseCode = "35";
  1214. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  1215. logger.Info("sysDailyImpressionsGetList response : " + response.ToString());
  1216. return Ok(response);
  1217. }
  1218. DataSet ds = balanceDataAccess.GET_DAILY_IMPRESSIONS(campaignId, fromDate, toDate);
  1219. logger.Info("Call database GET_DAILY_IMPRESSIONS success:");
  1220. response.responseCode = "0";
  1221. response.responseMessage = "Success";
  1222. if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  1223. {
  1224. response.list = new hourlyImpressionsObj[ds.Tables[0].Rows.Count];
  1225. for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
  1226. {
  1227. hourlyImpressionsObj _obj = new hourlyImpressionsObj();
  1228. _obj.hourLabel = ds.Tables[0].Rows[j]["DAY_LABEL"] != DBNull.Value ? ds.Tables[0].Rows[j]["DAY_LABEL"].ToString() : "";
  1229. _obj.hourValue = ds.Tables[0].Rows[j]["DAY_VALUE"] != DBNull.Value ? Convert.ToDateTime(ds.Tables[0].Rows[j]["DAY_VALUE"]).ToString("yyyy-MM-dd") : "";
  1230. _obj.campaignId = ds.Tables[0].Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_ID"].ToString() : "";
  1231. _obj.campaignName = ds.Tables[0].Rows[j]["CAMPAIGN_NAME"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_NAME"].ToString() : "";
  1232. _obj.serviceId = ""; // No longer using service
  1233. _obj.serviceName = ""; // No longer using service
  1234. _obj.countImpressions = ds.Tables[0].Rows[j]["COUNT_IMPRESSED"] != DBNull.Value ? ds.Tables[0].Rows[j]["COUNT_IMPRESSED"].ToString() : "0";
  1235. response.list[j] = _obj;
  1236. }
  1237. }
  1238. }
  1239. catch (Exception ex)
  1240. {
  1241. logger.Info("exception: " + ex.ToString());
  1242. response.responseCode = "-2";
  1243. response.responseMessage = "System upgrade";
  1244. }
  1245. logger.Info("Response to web: " + response.ToString());
  1246. return Ok(response);
  1247. }
  1248. [HttpPost]
  1249. public IActionResult sysDailyUniqueImpressionsGetList([FromBody] dynamic sendData)
  1250. {
  1251. logger.Info("New request income sysDailyUniqueImpressionsGetList :" + sendData.ToString());
  1252. hourlyImpressionsObjList response = new hourlyImpressionsObjList();
  1253. response.responseCode = "-1";
  1254. response.responseMessage = "Err unknow";
  1255. try
  1256. {
  1257. var userObj = JObject.Parse(sendData.ToString());
  1258. string campaignId = Convert.ToString(userObj["campaignId"]);
  1259. string serviceId = Convert.ToString(userObj["serviceId"]);
  1260. string fromDate = Convert.ToString(userObj["fromDate"]);
  1261. string toDate = Convert.ToString(userObj["toDate"]);
  1262. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  1263. if (string.IsNullOrEmpty(serviceId)) serviceId = "-1";
  1264. if (string.IsNullOrEmpty(fromDate)) fromDate = "-1";
  1265. if (string.IsNullOrEmpty(toDate)) toDate = "-1";
  1266. string token = Convert.ToString(userObj["token"]);
  1267. string channel = Convert.ToString(userObj["channel"]);
  1268. string language = Convert.ToString(userObj["language"]);
  1269. if (string.IsNullOrEmpty(language)) language = "-1";
  1270. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  1271. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  1272. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  1273. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  1274. redisConnection _redis;
  1275. memoryCache.TryGetValue("redis", out _redis);
  1276. if (_redis == null)
  1277. {
  1278. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1279. {
  1280. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1281. Priority = CacheItemPriority.High,
  1282. SlidingExpiration = TimeSpan.FromMinutes(2),
  1283. Size = 1024,
  1284. };
  1285. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  1286. _redis.connet();
  1287. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1288. }
  1289. if (!_redis.isConnet())
  1290. {
  1291. if (!_redis.connet())
  1292. {
  1293. logger.Info("Connect to redis false");
  1294. response.responseCode = "-2";
  1295. response.responseMessage = "System Update";
  1296. logger.Info("sysDailyUniqueImpressionsGetList response : " + response.ToString());
  1297. return Ok(response);
  1298. }
  1299. else
  1300. {
  1301. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1302. {
  1303. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1304. Priority = CacheItemPriority.High,
  1305. SlidingExpiration = TimeSpan.FromMinutes(2),
  1306. Size = 1024,
  1307. };
  1308. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1309. }
  1310. }
  1311. tokenObj _tokenObj = null;
  1312. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  1313. {
  1314. logger.Info("Authen token false");
  1315. response.responseCode = "35";
  1316. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  1317. logger.Info("sysDailyUniqueImpressionsGetList response : " + response.ToString());
  1318. return Ok(response);
  1319. }
  1320. DataSet ds = balanceDataAccess.GET_DAILY_UNIQUE_IMPRESSIONS(campaignId, serviceId, fromDate, toDate);
  1321. logger.Info("Call database GET_DAILY_UNIQUE_IMPRESSIONS success:");
  1322. response.responseCode = "0";
  1323. response.responseMessage = "Success";
  1324. if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  1325. {
  1326. response.list = new hourlyImpressionsObj[ds.Tables[0].Rows.Count];
  1327. for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
  1328. {
  1329. hourlyImpressionsObj _obj = new hourlyImpressionsObj();
  1330. _obj.hourLabel = ds.Tables[0].Rows[j]["DAY_LABEL"] != DBNull.Value ? ds.Tables[0].Rows[j]["DAY_LABEL"].ToString() : "";
  1331. _obj.hourValue = ds.Tables[0].Rows[j]["DAY_VALUE"] != DBNull.Value ? Convert.ToDateTime(ds.Tables[0].Rows[j]["DAY_VALUE"]).ToString("yyyy-MM-dd") : "";
  1332. _obj.campaignId = ds.Tables[0].Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_ID"].ToString() : "";
  1333. _obj.campaignName = ds.Tables[0].Rows[j]["CAMPAIGN_NAME"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_NAME"].ToString() : "";
  1334. _obj.serviceId = "";
  1335. _obj.serviceName = "";
  1336. _obj.countImpressions = ds.Tables[0].Rows[j]["COUNT_IMPRESSED"] != DBNull.Value ? ds.Tables[0].Rows[j]["COUNT_IMPRESSED"].ToString() : "0";
  1337. response.list[j] = _obj;
  1338. }
  1339. }
  1340. }
  1341. catch (Exception ex)
  1342. {
  1343. logger.Info("exception: " + ex.ToString());
  1344. response.responseCode = "-2";
  1345. response.responseMessage = "System upgrade";
  1346. }
  1347. logger.Info("sysDailyUniqueImpressionsGetList response : " + response.ToString());
  1348. return Ok(response);
  1349. }
  1350. [HttpPost]
  1351. public IActionResult sysDailyEngagedGetList([FromBody] dynamic sendData)
  1352. {
  1353. logger.Info("New request income sysDailyEngagedGetList :" + sendData.ToString());
  1354. hourlyImpressionsObjList response = new hourlyImpressionsObjList();
  1355. response.responseCode = "-1";
  1356. response.responseMessage = "Err unknow";
  1357. try
  1358. {
  1359. var userObj = JObject.Parse(sendData.ToString());
  1360. string campaignId = Convert.ToString(userObj["campaignId"]);
  1361. string serviceId = Convert.ToString(userObj["serviceId"]);
  1362. string fromDate = Convert.ToString(userObj["fromDate"]);
  1363. string toDate = Convert.ToString(userObj["toDate"]);
  1364. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  1365. if (string.IsNullOrEmpty(serviceId)) serviceId = "-1";
  1366. if (string.IsNullOrEmpty(fromDate)) fromDate = "-1";
  1367. if (string.IsNullOrEmpty(toDate)) toDate = "-1";
  1368. string token = Convert.ToString(userObj["token"]);
  1369. string channel = Convert.ToString(userObj["channel"]);
  1370. string language = Convert.ToString(userObj["language"]);
  1371. if (string.IsNullOrEmpty(language)) language = "-1";
  1372. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  1373. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  1374. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  1375. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  1376. redisConnection _redis;
  1377. memoryCache.TryGetValue("redis", out _redis);
  1378. if (_redis == null)
  1379. {
  1380. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1381. {
  1382. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1383. Priority = CacheItemPriority.High,
  1384. SlidingExpiration = TimeSpan.FromMinutes(2),
  1385. Size = 1024,
  1386. };
  1387. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  1388. _redis.connet();
  1389. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1390. }
  1391. if (!_redis.isConnet())
  1392. {
  1393. if (!_redis.connet())
  1394. {
  1395. logger.Info("Connect to redis false");
  1396. response.responseCode = "-2";
  1397. response.responseMessage = "System Update";
  1398. logger.Info("sysDailyEngagedGetList response : " + response.ToString());
  1399. return Ok(response);
  1400. }
  1401. else
  1402. {
  1403. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1404. {
  1405. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1406. Priority = CacheItemPriority.High,
  1407. SlidingExpiration = TimeSpan.FromMinutes(2),
  1408. Size = 1024,
  1409. };
  1410. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1411. }
  1412. }
  1413. tokenObj _tokenObj = null;
  1414. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  1415. {
  1416. logger.Info("Authen token false");
  1417. response.responseCode = "35";
  1418. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  1419. logger.Info("sysDailyEngagedGetList response : " + response.ToString());
  1420. return Ok(response);
  1421. }
  1422. DataSet ds = balanceDataAccess.GET_DAILY_ENGAGED_USERS(campaignId, serviceId, fromDate, toDate);
  1423. logger.Info("Call database GET_DAILY_ENGAGED_USERS success:");
  1424. response.responseCode = "0";
  1425. response.responseMessage = "Success";
  1426. if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  1427. {
  1428. response.list = new hourlyImpressionsObj[ds.Tables[0].Rows.Count];
  1429. for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
  1430. {
  1431. hourlyImpressionsObj _obj = new hourlyImpressionsObj();
  1432. _obj.hourLabel = ds.Tables[0].Rows[j]["DAY_LABEL"] != DBNull.Value ? ds.Tables[0].Rows[j]["DAY_LABEL"].ToString() : "";
  1433. _obj.hourValue = ds.Tables[0].Rows[j]["DAY_VALUE"] != DBNull.Value ? Convert.ToDateTime(ds.Tables[0].Rows[j]["DAY_VALUE"]).ToString("yyyy-MM-dd") : "";
  1434. _obj.campaignId = ds.Tables[0].Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_ID"].ToString() : "";
  1435. _obj.campaignName = ds.Tables[0].Rows[j]["CAMPAIGN_NAME"] != DBNull.Value ? ds.Tables[0].Rows[j]["CAMPAIGN_NAME"].ToString() : "";
  1436. _obj.serviceId = "";
  1437. _obj.serviceName = "";
  1438. _obj.countImpressions = ds.Tables[0].Rows[j]["COUNT_ENGAGED"] != DBNull.Value ? ds.Tables[0].Rows[j]["COUNT_ENGAGED"].ToString() : "0";
  1439. response.list[j] = _obj;
  1440. }
  1441. }
  1442. }
  1443. catch (Exception ex)
  1444. {
  1445. logger.Info("exception: " + ex.ToString());
  1446. response.responseCode = "-2";
  1447. response.responseMessage = "System upgrade";
  1448. }
  1449. logger.Info("sysDailyEngagedGetList response : " + response.ToString());
  1450. return Ok(response);
  1451. }
  1452. // PUSH USSD DETAIL REPORT
  1453. [HttpPost]
  1454. public IActionResult sysPushUssdDetailGetList([FromBody] dynamic sendData)
  1455. {
  1456. logger.Info("New request income sysPushUssdDetailGetList :" + sendData.ToString());
  1457. pushUssdDetailObjList response = new pushUssdDetailObjList();
  1458. response.responseCode = "-1";
  1459. response.responseMessage = "Err unknow";
  1460. try
  1461. {
  1462. var userObj = JObject.Parse(sendData.ToString());
  1463. string users = Convert.ToString(userObj["users"]);
  1464. string campaignId = Convert.ToString(userObj["campaignId"]);
  1465. string serviceId = Convert.ToString(userObj["serviceId"]);
  1466. string msisdn = Convert.ToString(userObj["msisdn"]);
  1467. string sendStatus = Convert.ToString(userObj["sendStatus"]);
  1468. string isSuccess = Convert.ToString(userObj["isSuccess"]);
  1469. string fromDate = Convert.ToString(userObj["fromDate"]);
  1470. string toDate = Convert.ToString(userObj["toDate"]);
  1471. string order = Convert.ToString(userObj["order"]);
  1472. string rowsOnPage = Convert.ToString(userObj["rowsOnPage"]);
  1473. string seqPage = Convert.ToString(userObj["seqPage"]);
  1474. if (string.IsNullOrEmpty(users)) users = "-1";
  1475. if (string.IsNullOrEmpty(campaignId)) campaignId = "-1";
  1476. if (string.IsNullOrEmpty(serviceId)) serviceId = "-1";
  1477. if (string.IsNullOrEmpty(msisdn)) msisdn = "-1";
  1478. if (string.IsNullOrEmpty(sendStatus)) sendStatus = "-1";
  1479. if (string.IsNullOrEmpty(isSuccess)) isSuccess = "-1";
  1480. if (string.IsNullOrEmpty(fromDate)) fromDate = "-1";
  1481. if (string.IsNullOrEmpty(toDate)) toDate = "-1";
  1482. if (string.IsNullOrEmpty(order)) order = "desc";
  1483. if (string.IsNullOrEmpty(rowsOnPage)) rowsOnPage = "100";
  1484. if (string.IsNullOrEmpty(seqPage)) seqPage = "1";
  1485. string token = Convert.ToString(userObj["token"]);
  1486. string channel = Convert.ToString(userObj["channel"]);
  1487. string language = Convert.ToString(userObj["language"]);
  1488. if (string.IsNullOrEmpty(language)) language = "-1";
  1489. string RedisIp = Common.GetValuesAppSetting("webConfig", "RedisIp");
  1490. string RedisPort = Common.GetValuesAppSetting("webConfig", "RedisPort");
  1491. string RedisPass = Common.GetValuesAppSetting("webConfig", "RedisPass");
  1492. var clientIp = HttpContext.Connection.RemoteIpAddress.ToString();
  1493. redisConnection _redis;
  1494. memoryCache.TryGetValue("redis", out _redis);
  1495. if (_redis == null)
  1496. {
  1497. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1498. {
  1499. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1500. Priority = CacheItemPriority.High,
  1501. SlidingExpiration = TimeSpan.FromMinutes(2),
  1502. Size = 1024,
  1503. };
  1504. _redis = new redisConnection(RedisIp, RedisPort, RedisPass);
  1505. _redis.connet();
  1506. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1507. }
  1508. if (!_redis.isConnet())
  1509. {
  1510. if (!_redis.connet())
  1511. {
  1512. logger.Info("Connect to redis false");
  1513. response.responseCode = "-2";
  1514. response.responseMessage = "System Update";
  1515. logger.Info("sysPushUssdDetailGetList response : " + response.ToString());
  1516. return Ok(response);
  1517. }
  1518. else
  1519. {
  1520. var cacheExpiryOptions = new MemoryCacheEntryOptions
  1521. {
  1522. AbsoluteExpiration = DateTime.Now.AddMonths(12),
  1523. Priority = CacheItemPriority.High,
  1524. SlidingExpiration = TimeSpan.FromMinutes(2),
  1525. Size = 1024,
  1526. };
  1527. memoryCache.Set("redis", _redis, cacheExpiryOptions);
  1528. }
  1529. }
  1530. tokenObj _tokenObj = null;
  1531. if (!CommonFunction.checkToken(clientIp, token, channel, _redis, logger, out _tokenObj))
  1532. {
  1533. logger.Info("Authen token false");
  1534. response.responseCode = "35";
  1535. response.responseMessage = CommonObj.common.CommonFunction.getErrCodeObjFromRedis(_redis, channel, response.responseCode, language);
  1536. logger.Info("sysPushUssdDetailGetList response : " + response.ToString());
  1537. return Ok(response);
  1538. }
  1539. DataSet ds = systemDataAccess.SYS_PUSH_USSD_DETAIL_GET_LIST(users, campaignId, serviceId, msisdn, sendStatus, isSuccess, fromDate, toDate, order, rowsOnPage, seqPage);
  1540. logger.Info("Call database SYS_PUSH_USSD_DETAIL_GET_LIST success:");
  1541. response.responseCode = "0";
  1542. response.responseMessage = "Success";
  1543. if (ds != null && ds.Tables.Count > 0)
  1544. {
  1545. var dataTable = ds.Tables[0];
  1546. response.list = new pushUssdDetailObj[dataTable.Rows.Count];
  1547. for (int j = 0; j < dataTable.Rows.Count; j++)
  1548. {
  1549. var _obj = new pushUssdDetailObj();
  1550. _obj.id = dataTable.Rows[j]["ID"].ToString();
  1551. _obj.requestId = dataTable.Rows[j]["REQUEST_ID"].ToString();
  1552. _obj.campaignId = dataTable.Rows[j]["CAMPAIGN_ID"] != DBNull.Value ? dataTable.Rows[j]["CAMPAIGN_ID"].ToString() : "";
  1553. _obj.campaignName = dataTable.Rows[j].Table.Columns.Contains("CAMPAIGN_NAME") && dataTable.Rows[j]["CAMPAIGN_NAME"] != DBNull.Value ? dataTable.Rows[j]["CAMPAIGN_NAME"].ToString() : "";
  1554. _obj.serviceId = dataTable.Rows[j]["SERVICE_ID"] != DBNull.Value ? dataTable.Rows[j]["SERVICE_ID"].ToString() : "";
  1555. _obj.msisdn = dataTable.Rows[j]["MSISDN"].ToString();
  1556. _obj.sendTime = dataTable.Rows[j]["SEND_TIME"] != DBNull.Value ? Convert.ToDateTime(dataTable.Rows[j]["SEND_TIME"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  1557. _obj.sendStatus = dataTable.Rows[j]["SEND_STATUS"] != DBNull.Value ? dataTable.Rows[j]["SEND_STATUS"].ToString() : "";
  1558. _obj.totalStep = dataTable.Rows[j]["TOTAL_STEP"] != DBNull.Value ? dataTable.Rows[j]["TOTAL_STEP"].ToString() : "";
  1559. _obj.isStep1 = dataTable.Rows[j]["IS_STEP_1"] != DBNull.Value ? dataTable.Rows[j]["IS_STEP_1"].ToString() : "";
  1560. _obj.step1Time = dataTable.Rows[j]["STEP_1_TIME"] != DBNull.Value ? Convert.ToDateTime(dataTable.Rows[j]["STEP_1_TIME"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  1561. _obj.isStep2 = dataTable.Rows[j]["IS_STEP_2"] != DBNull.Value ? dataTable.Rows[j]["IS_STEP_2"].ToString() : "";
  1562. _obj.step2Time = dataTable.Rows[j]["STEP_2_TIME"] != DBNull.Value ? Convert.ToDateTime(dataTable.Rows[j]["STEP_2_TIME"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  1563. _obj.errorCode = dataTable.Rows[j]["ERROR_CODE"] != DBNull.Value ? dataTable.Rows[j]["ERROR_CODE"].ToString() : "";
  1564. _obj.isSuccess = dataTable.Rows[j]["IS_SUCCESS"] != DBNull.Value ? dataTable.Rows[j]["IS_SUCCESS"].ToString() : "";
  1565. _obj.insertTime = dataTable.Rows[j]["INSERT_TIME"] != DBNull.Value ? Convert.ToDateTime(dataTable.Rows[j]["INSERT_TIME"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  1566. _obj.lastUpdate = dataTable.Rows[j]["LAST_UPDATE"] != DBNull.Value ? Convert.ToDateTime(dataTable.Rows[j]["LAST_UPDATE"]).ToString("dd/MM/yyyy HH:mm:ss") : "";
  1567. response.list[j] = _obj;
  1568. }
  1569. }
  1570. }
  1571. catch (Exception ex)
  1572. {
  1573. logger.Info("exception: " + ex.ToString());
  1574. response.responseCode = "-2";
  1575. response.responseMessage = "System upgrade";
  1576. }
  1577. logger.Info("sysPushUssdDetailGetList response : " + response.ToString());
  1578. return Ok(response);
  1579. }
  1580. }
  1581. }