lesson.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. var express = require('express');
  2. var url = require('url');
  3. var router = express.Router();
  4. var ljConst = require("../common/LjConst");
  5. var ljRetState = require("../common/LjRetState");
  6. var logHelper = require("../helper/LjLogHelper.js");
  7. var httpHelper = require("../helper/LjHttpHelper");
  8. var fileHelper = require("../helper/LjFileHelper");
  9. var apiHelper = require("../helper/LjApiHelper");
  10. var ljStringHelper = require("../helper/LjStringHelper");
  11. /**
  12. * 下载文件
  13. */
  14. router.get("/downloadFile",function(req,res,next)
  15. {
  16. var arg = url.parse(req.url, true).query;
  17. var courseId = arg.courseId;
  18. var eid = arg.eid;
  19. var uid = arg.uid;
  20. var token = arg.token;
  21. var lessonId = arg.lessonId;
  22. //获取参数
  23. logHelper.debug(arg);
  24. //校验参数
  25. if (ljStringHelper.isNull(courseId))
  26. {
  27. logHelper.info("null object of courseId");
  28. ljRetState.code = 2;
  29. ljRetState.msg ="null object of courseId"
  30. res.json(ljRetState);
  31. return;
  32. }
  33. if (ljStringHelper.isNull(lessonId))
  34. {
  35. logHelper.info("null object of lessonId");
  36. ljRetState.code = 2;
  37. ljRetState.msg ="null object of lessonId"
  38. res.json(ljRetState);
  39. return;
  40. }
  41. if (ljStringHelper.isNull(eid))
  42. {
  43. logHelper.info("null object of eid");
  44. ljRetState.code = 2;
  45. ljRetState.msg ="null object of eid"
  46. res.json(ljRetState);
  47. return;
  48. }
  49. if (ljStringHelper.isNull(uid))
  50. {
  51. logHelper.info("null object of uid");
  52. ljRetState.code = 2;
  53. ljRetState.msg ="null object of uid"
  54. res.json(ljRetState);
  55. return;
  56. }
  57. if (ljStringHelper.isNull(token))
  58. {
  59. logHelper.info("null object of token");
  60. ljRetState.code = 2;
  61. ljRetState.msg ="null object of token"
  62. res.json(ljRetState);
  63. return;
  64. }
  65. var opt = {};
  66. opt.eid = eid;
  67. opt.uid = uid;
  68. opt.token = token;
  69. opt.lessonId = lessonId;
  70. opt.courseId = courseId;
  71. opt.path = "/lesson/" + opt.lessonId;
  72. opt.url = apiHelper.getApiForQueryCourse(opt.lessonId, opt.courseId, opt.eid);
  73. opt.method = "get";
  74. httpHelper.request(opt, function (error, res, body)
  75. {
  76. //开始下载
  77. opt.downloadStatus = ljConst.FILE_DOWNLOADING
  78. addDownload(opt);
  79. logHelper.info("Begin to download file with lessonId【"+opt.lessonId+"】");
  80. let obj = JSON.parse(body);
  81. var lessonJsonObj = JSON.parse(body);
  82. if (lessonJsonObj.code == 200)
  83. {
  84. /*课件-Begin*/
  85. //课程集合
  86. var courseList = lessonJsonObj.data.list;
  87. //课程数
  88. var courseListSize = courseList.length;
  89. //遍历课件
  90. for (var i = 0; i < courseListSize; i++)
  91. {
  92. //资源集合
  93. var resourceList = courseList[i].list;
  94. //资源数
  95. var resourceSize = resourceList.length;
  96. for (var j = 0; j < resourceSize; j++)
  97. {
  98. logHelper.debug(resourceList[j].url);
  99. var url = resourceList[j].url;
  100. fileHelper.downloadFile(url);
  101. if(resourceSize - 1 == j)
  102. {
  103. //下载完成
  104. opt.downloadStatus = ljConst.FILE_DOWNLOADED
  105. addDownload(opt);
  106. logHelper.info("End to download file with lessonId【"+opt.lessonId+"】");
  107. }
  108. }
  109. }
  110. /*课件-End*/
  111. return "ok";
  112. }
  113. else
  114. {
  115. logHelper.error("failed to query lesson with lessonId[" + opt.lessonId + "],caused by error:" + lessonJsonObj);
  116. return "error";
  117. }
  118. })
  119. ljRetState.code = 2;
  120. ljRetState.msg ="null object of uid"
  121. ljRetState.success = true;
  122. res.setHeader("Access-Control-Allow-Origin","*");
  123. res.json(ljRetState);
  124. return;
  125. });
  126. /**
  127. * 读取文件
  128. */
  129. router.get("/readFile",function(req,res)
  130. {
  131. var arg = url.parse(req.url, true).query;
  132. var fileDirStr = arg.n;
  133. var fileDirNew = fileDirStr.replace(/\*/g,'\\');
  134. var fileDir = fileHelper.getFileDir(fileDirNew)
  135. var fileProp = fileHelper.getFileProperty(fileDir);
  136. logHelper.info(fileProp.fileType);
  137. if(fileProp.fileType == ljConst.VIDEO_TYPE_MP4)
  138. {
  139. logHelper.info(fileDir);
  140. fileHelper.readDecryptedStream(res,fileDir,"video/mp4")
  141. }
  142. else
  143. {
  144. fileHelper.readDecryptedStream(res,fileDir,"image/jpeg")
  145. }
  146. });
  147. function test()
  148. {
  149. console.log(11);
  150. }
  151. /**
  152. * 删除下载文件
  153. */
  154. router.get("/delFile",function(req,res)
  155. {
  156. var arg = url.parse(req.url, true).query;
  157. var courseId = arg.courseId;
  158. var eid = arg.eid;
  159. var uid = arg.uid;
  160. var token = arg.token;
  161. var lessonId = arg.lessonId;
  162. //获取参数
  163. logHelper.debug(arg);
  164. //校验参数
  165. if (ljStringHelper.isNull(courseId))
  166. {
  167. logHelper.info("null object of courseId");
  168. ljRetState.code = 2;
  169. ljRetState.msg ="null object of courseId"
  170. res.json(ljRetState);
  171. return;
  172. }
  173. if (ljStringHelper.isNull(lessonId))
  174. {
  175. logHelper.info("null object of lessonId");
  176. ljRetState.code = 2;
  177. ljRetState.msg ="null object of lessonId"
  178. res.json(ljRetState);
  179. return;
  180. }
  181. if (ljStringHelper.isNull(eid))
  182. {
  183. logHelper.info("null object of eid");
  184. ljRetState.code = 2;
  185. ljRetState.msg ="null object of eid"
  186. res.json(ljRetState);
  187. return;
  188. }
  189. if (ljStringHelper.isNull(uid))
  190. {
  191. logHelper.info("null object of uid");
  192. ljRetState.code = 2;
  193. ljRetState.msg ="null object of uid"
  194. res.json(ljRetState);
  195. return;
  196. }
  197. if (ljStringHelper.isNull(token))
  198. {
  199. logHelper.info("null object of token");
  200. ljRetState.code = 2;
  201. ljRetState.msg ="null object of token"
  202. res.json(ljRetState);
  203. return;
  204. }
  205. var opt = {};
  206. opt.eid = eid;
  207. opt.uid = uid;
  208. opt.token = token;
  209. opt.lessonId = lessonId;
  210. opt.courseId = courseId;
  211. opt.path = "/lesson/" + opt.lessonId;
  212. opt.url = apiHelper.getApiForQueryCourse(opt.lessonId, opt.courseId, opt.eid);
  213. opt.method = "get";
  214. httpHelper.request(opt, function (error, res, body)
  215. {
  216. let obj = JSON.parse(body);
  217. var lessonJsonObj = JSON.parse(body);
  218. if (lessonJsonObj.code == 200)
  219. {
  220. /*课件-Begin*/
  221. //课程集合
  222. var courseList = lessonJsonObj.data.list;
  223. //课程数
  224. var courseListSize = courseList.length;
  225. //遍历课件
  226. for (var i = 0; i < courseListSize; i++)
  227. {
  228. //资源集合
  229. var resourceList = courseList[i].list;
  230. //资源数
  231. var resourceSize = resourceList.length;
  232. for (var j = 0; j < resourceSize; j++)
  233. {
  234. logHelper.debug(resourceList[j].url);
  235. var url = resourceList[j].url;
  236. fileHelper.downloadFile(url)
  237. }
  238. }
  239. /*课件-End*/
  240. //删除记录
  241. delDownload(opt);
  242. return "ok";
  243. }
  244. else
  245. {
  246. logHelper.error("failed to query lesson with lessonId[" + opt.lessonId + "],caused by error:" + lessonJsonObj);
  247. return "error";
  248. }
  249. });
  250. ljRetState.code = 2;
  251. ljRetState.msg ="null object of uid"
  252. ljRetState.success = true;
  253. res.setHeader("Access-Control-Allow-Origin","*");
  254. res.json(ljRetState);
  255. return "";
  256. });
  257. var addDownload = function(opt)
  258. {
  259. opt.url = apiHelper.getApiForAddDownload(opt.lessonId,opt.courseId,opt.downloadStatus, null);
  260. opt.method = "post";
  261. opt.path = "/callback/download/add";
  262. httpHelper.request(opt, function (error, res, body)
  263. {
  264. var retObj = JSON.parse(body);
  265. logHelper.debug(retObj);
  266. if (retObj.code == 200)
  267. {
  268. logHelper.info("Succeed to call api[" + opt.path + "]");
  269. return true;
  270. }
  271. else
  272. {
  273. logHelper.error("Failed to call api[" + opt.path + "],caused by error[" + retObj + "]");
  274. return false;
  275. }
  276. });
  277. }
  278. var delDownload = function(opt)
  279. {
  280. opt.url = apiHelper.getApiForDelDownload(opt.lessonId, null);
  281. opt.method = "delete";
  282. opt.path = "/callback/download/delete";
  283. httpHelper.request(opt, function (error, res, body)
  284. {
  285. var retObj = JSON.parse(body);
  286. logHelper.debug(retObj);
  287. if (retObj.code == 200)
  288. {
  289. logHelper.info("Succeed to call api[" + opt.path + "]");
  290. return true;
  291. }
  292. else
  293. {
  294. logHelper.error("Failed to call api[" + opt.path + "],caused by error[" + retObj + "]");
  295. return false;
  296. }
  297. });
  298. }
  299. module.exports = router;