PRODUCT_FACTORY.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374
  1. const CMD = {}
  2. const video_product_controllers = require('../src/data_manager/Controllers/video_product_controllers');
  3. const filter_data_controllers = require('../src/data_manager/Controllers/filter_data_controllers');
  4. const get_fq_book_tab_controllers = require('../src/data_manager/Controllers/get_fq_book_tab_controllers');
  5. const video_applet_product_controllers = require('../src/data_manager/Controllers/video_applet_product_controllers');
  6. const redis_help = require('../src/use_redis');
  7. const axios = require('axios');
  8. const config = require('../etc/config.json');
  9. const HttpClient = require('../src/HttpClient');
  10. const helper = require('../src/helper');
  11. const tools = require('../tools');
  12. const time_count = 2000;
  13. const task_queue = []
  14. async function processTask(){
  15. try{
  16. let isPauseTask = await redis_help.getKeyValue("isPauseTask")
  17. if(isPauseTask=="true"){
  18. return
  19. }
  20. let isInsertTask = false
  21. let FilterConfig = await redis_help.getKeyValue("FilterConfig")
  22. FilterConfig = JSON.parse(FilterConfig)
  23. let result = await filter_data_controllers.getFilterDataByStatus({ status: 0 });
  24. if(result.success){
  25. let tg_platform_id = result.data.tg_platform_id
  26. //判断是否存在这本书
  27. if(tg_platform_id==1){
  28. let hy_book_result = await video_product_controllers.getProductData({ book_id: result.data.book_id });
  29. if(hy_book_result.success){
  30. result.data.words = hy_book_result.data.words
  31. result.data.genre = hy_book_result.data.genre
  32. result.data.book_id = hy_book_result.data.product_id
  33. result.data.book_name = hy_book_result.data.product_name
  34. }else{
  35. isInsertTask = true
  36. }
  37. }else if(tg_platform_id==2){ //番茄
  38. //获取番茄书库的书
  39. let fq_book_result = await get_fq_book_tab_controllers.getData({ book_id: result.data.book_id });
  40. if(fq_book_result.success){//如果番茄书库里有这本书
  41. result.data.genre = fq_book_result.data.info.genre
  42. result.data.book_id = fq_book_result.data.book_id
  43. result.data.book_name = fq_book_result.data.info.book_name
  44. result.data.words = fq_book_result.data.info.word_number
  45. //获取商品库的商品
  46. let product_result = await video_product_controllers.getProductData({ book_id: fq_book_result.data.book_id });
  47. //如果商品库没有这个商品
  48. if(!product_result.success){ //如果只是 get_fq_book 有, 书库里没有
  49. fq_book_result.data.tg_platform_id = result.data.tg_platform_id
  50. //如果是长篇短篇符合
  51. if(CMD.isGenre(FilterConfig,result.data.genre)){
  52. await CMD.insert_product(result.data)
  53. }
  54. }
  55. }else{
  56. isInsertTask = true
  57. }
  58. }
  59. if(!isInsertTask){
  60. await CMD.update_filter_data(FilterConfig,result.data)
  61. }else{
  62. await filter_data_controllers.updateFilterData({id:result.data.id},{status:1})
  63. task_queue.push({result:result})
  64. }
  65. }
  66. }catch(e){
  67. await filter_data_controllers.updateFilterData({id:result.data.id},{status:2})
  68. } finally{
  69. setTimeout(processTask, 500);
  70. }
  71. }
  72. async function processCreateTask(){
  73. try{
  74. if(task_queue.length>0){
  75. let task_queue_item = task_queue.pop()
  76. let FilterConfig = await redis_help.getKeyValue("FilterConfig")
  77. FilterConfig = JSON.parse(FilterConfig)
  78. let result = task_queue_item.result
  79. let tg_platform_id = result.data.tg_platform_id
  80. if(tg_platform_id==1){
  81. let hy_book_data = await require('./collect_hy_book').runTask(result.data)
  82. if(CMD.isGenre(FilterConfig,hy_book_data.genre)){
  83. await CMD.insert_product(hy_book_data)
  84. }
  85. result.data.words = hy_book_data.words
  86. result.data.genre = hy_book_data.genre
  87. result.data.book_id = hy_book_data.book_id
  88. result.data.book_name = hy_book_data.book_name
  89. }else if(tg_platform_id==2){
  90. let client = new HttpClient()
  91. let sid_tt = await tools.getFqSidtt()
  92. let response = await client.proxyRequest( helper.getFqRequestOpt(result.data.book_id,sid_tt))
  93. let obj = response['data']
  94. let book_name = obj['novel_data'].book_name
  95. let book_id = obj['novel_data'].book_id
  96. let genre = CMD.getFqGenre(obj['novel_data'].genre)
  97. let words = obj['novel_data'].word_number
  98. let fq_book_data = {book_name:book_name,book_id:book_id,genre:genre,words:words,info:JSON.stringify(obj['novel_data'])}
  99. let fq_book = {}
  100. fq_book.key = result.data.book_id
  101. await CMD.add_fq_book(fq_book,fq_book_data)
  102. let product_result = await video_product_controllers.getProductData({ book_id: fq_book_data.book_id });
  103. if(!product_result.success){ //如果书库也没有
  104. fq_book.tg_platform_id = result.data.tg_platform_id
  105. if(CMD.isGenre(FilterConfig,fq_book_data.genre)){
  106. fq_book_data.tg_platform_id = result.data.tg_platform_id
  107. await CMD.insert_product(fq_book_data)
  108. }
  109. }
  110. result.data.words = words
  111. result.data.genre = fq_book_data.genre
  112. result.data.book_id = fq_book_data.book_id
  113. result.data.book_name = fq_book_data.book_name
  114. }
  115. await CMD.update_filter_data(FilterConfig,result.data)
  116. }
  117. }catch(e){
  118. console.log("processCreateTask:",e)
  119. } finally{
  120. setTimeout(processCreateTask, time_count);
  121. }
  122. }
  123. CMD.init = async function(){
  124. redis_help.connect((results)=>{
  125. if(results){
  126. }
  127. })
  128. processTask();
  129. processCreateTask();
  130. }
  131. CMD.getFqGenre = function(genre){
  132. if(genre=="0"){
  133. return 1;
  134. }
  135. if(genre=="8"){
  136. return 3;
  137. }
  138. if(genre=="202"){
  139. return 202;
  140. }
  141. return 999;
  142. }
  143. CMD.getAppInfoByPlatformId = function(AppConfig,tg_platform_id){
  144. for (let index = 0; index < AppConfig.length; index++) {
  145. const element = AppConfig[index];
  146. if(element.tg_platform_id==tg_platform_id){
  147. return element
  148. }
  149. }
  150. return null
  151. }
  152. CMD.isBlackBook = function(all_black_books,book_id){
  153. if(all_black_books==null){
  154. return false
  155. }
  156. for (let index = 0; index < all_black_books.length; index++) {
  157. const black_book = all_black_books[index];
  158. if(black_book.product_id==book_id){
  159. return true
  160. }
  161. }
  162. return false
  163. }
  164. CMD.getMainInfoByAppid = function(MainConfig,app_id){
  165. let list = []
  166. for (let index = 0; index < MainConfig.length; index++) {
  167. const element = MainConfig[index];
  168. if(element.app_id==app_id){
  169. list.push(element)
  170. }
  171. }
  172. return list
  173. }
  174. CMD.isGenre = function(FilterConfig,genre){
  175. let is_need = false
  176. //判断长篇短篇是否是要的数据
  177. for (let index = 0; index < FilterConfig.genre.length; index++) {
  178. const element = FilterConfig.genre[index];
  179. if(genre==element){
  180. is_need = true
  181. break
  182. }
  183. }
  184. return is_need
  185. }
  186. function deepCopy3(obj) {
  187. return JSON.parse(JSON.stringify(obj));
  188. }
  189. CMD.update_filter_data = async function(FilterConfig,data) {
  190. if(CMD.isGenre(FilterConfig,data.genre)){
  191. try{
  192. await CMD.video_product_material(data)
  193. }catch(e){
  194. console.log("video_product_material error:",e)
  195. }
  196. await filter_data_controllers.updateFilterData({id:data.id},{status:1,book_id:data.book_id,book_name:data.book_name,genre:data.genre,words:data.words})
  197. //创建一个小程序
  198. let AppConfig = await redis_help.getKeyValue("AppConfig")
  199. AppConfig = JSON.parse(AppConfig)
  200. let AppInfo = CMD.getAppInfoByPlatformId(AppConfig,data.tg_platform_id)
  201. data.app_id = AppInfo.app_id
  202. let PlatformInfo = await redis_help.getKeyValue("PlatformConfig")
  203. PlatformInfo = JSON.parse(PlatformInfo)
  204. if(PlatformInfo==null){
  205. return console.error("平台配置错误:",data)
  206. }
  207. let MainConfig = await redis_help.getKeyValue("MainConfig")
  208. MainConfig = JSON.parse(MainConfig)
  209. let list = CMD.getMainInfoByAppid(MainConfig,data.app_id)
  210. if(list.length<0){
  211. return console.error("获取主体错误:",data)
  212. }
  213. let black_books = await redis_help.getKeyValue("all_black_books")
  214. if(black_books!=null){
  215. black_books = JSON.parse(black_books)
  216. }
  217. for (let index = 0; index < list.length; index++) {
  218. const main_info = list[index];
  219. data.main_id = main_info.id
  220. data.main_name = main_info.main_name
  221. if(main_info.tg_link_config==undefined||main_info.tg_link_config==null){
  222. console.error("主体配置推广链接错误:",main_info)
  223. }else{
  224. if(!CMD.isBlackBook(black_books,data.book_id)){
  225. //符合标准进行创建表
  226. const result = await video_applet_product_controllers.getAppletProductData({book_id:data.book_id,main_id:data.main_id})
  227. if(!result.success){
  228. //没有找到 可以创建
  229. await video_applet_product_controllers.createAppletProductData({
  230. book_platform:data.tg_platform_id,
  231. product_name:data.book_name,
  232. product_id:data.book_id,
  233. dy_small_program_start:"",
  234. dy_small_program_start_data:"",
  235. dy_small_applet_app_id:data.app_id,
  236. status:0,
  237. main_id:data.main_id,
  238. promotion_id:"",
  239. wait_status:0,
  240. })
  241. }
  242. }
  243. }
  244. }
  245. }else{
  246. await filter_data_controllers.updateFilterData({id:data.id},{status:2,book_id:data.book_id,book_name:data.book_name,genre:data.genre})
  247. }
  248. }
  249. CMD.video_product_material = async function(data){
  250. let url = config.isDebug?config.debug_supdate_config.host:config.release_supdate_config.host
  251. url = url+'/sapi/video_product_material/supdate';
  252. const formData = new FormData();
  253. formData.append('data',JSON.stringify({
  254. dy_id:data.video_id,
  255. dy_url:data.video_link,
  256. product_id:data.book_id,
  257. product_name:data.book_name,
  258. d_z_number:data.like_num,
  259. collect_number:data.kepp_num,
  260. comment_number: data.comment_num,
  261. forward_number: data.shared_num,
  262. book_platform: data.tg_platform_id,
  263. title: data.title,
  264. yun_fabu_time:data.publish_time
  265. }))
  266. return await axios.post(url, formData, {
  267. headers: {
  268. 'Content-Type': 'multipart/form-data'
  269. }
  270. })
  271. .then(response => {
  272. if(response.data.code===10000){
  273. console.log("插入任务表成功:", response.data);
  274. }else{
  275. console.log("插入任务表失败:", formData);
  276. }
  277. })
  278. .catch(error => {
  279. console.error("插入任务表失败:", error,formData);
  280. });
  281. }
  282. CMD.insert_product = async function(data){
  283. return await video_product_controllers.createProductData({
  284. book_platform:data.tg_platform_id,
  285. product_name:data.book_name,
  286. genre:data.genre,
  287. product_id:data.book_id,
  288. words:data.words
  289. })
  290. }
  291. CMD.add_fq_book = async function(data,response){
  292. let book_name = response.book_name
  293. let book_id = response.book_id
  294. let genre = response.genre
  295. let words = response.word_number
  296. data.genre = 0
  297. if(genre=="0"){
  298. data.genre = 1;
  299. }
  300. if(genre=="8"){
  301. data.genre = 3;
  302. }
  303. if(genre=="202"){
  304. data.genre = 202;
  305. }
  306. data.words = words
  307. data.book_name = book_name
  308. data.book_id = book_id
  309. return await get_fq_book_tab_controllers.createData( {
  310. book_key:data.key,
  311. book_id:data.book_id,
  312. info:JSON.stringify(response)
  313. })
  314. }
  315. CMD.build_check_url = function(data){
  316. let url = 'https://clipvideoup.s6kuwan.com/sapi/check/get_check_url';
  317. const formData = new FormData();
  318. formData.append('platform_id', data.book_platform);
  319. formData.append('cp_spread_id', data.promotion_id);
  320. // console.log("formData:", formData);
  321. axios.post(url, formData, {
  322. headers: {
  323. 'Content-Type': 'multipart/form-data'
  324. }
  325. })
  326. .then(response => {
  327. if(response.data.code==10000){
  328. CMD.update_video_applet_product({promotion_id:data.promotion_id,
  329. product_id:data.product_id,check_url:response.data.content.check_url
  330. })
  331. }
  332. })
  333. .catch(error => {
  334. console.error('create_link was an error!', error);
  335. });
  336. }
  337. CMD.update_video_applet_product = function(data){
  338. sql_task_help.update('UPDATE video_applet_product SET status = ?, wait_status = ? , check_url = ? WHERE promotion_id = ? and product_id = ?',
  339. [1,1,data.check_url,data.promotion_id,data.product_id],
  340. ()=>{
  341. console.log("update_video_applet_product:更新成功!")
  342. })
  343. }
  344. CMD.init()