watch_advise.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. """
  2. 完整刷视频广告
  3. """
  4. import base64
  5. import time
  6. import yaml
  7. from func.action_func import del_key_vague
  8. from scene.oprator.atom_data import single_click_by_control, click_pic, continual_swipe_screen, swipe_screen, stop_app, \
  9. start_app
  10. from task.task_job import callback_task
  11. from tools import loggerKit, redis_client
  12. """
  13. 头条极速版
  14. 刷广告
  15. """
  16. with open('config.yaml', 'r') as file:
  17. config = yaml.load(file, Loader=yaml.FullLoader)
  18. extern_domain = config['bmp-cp']['extern_domain']
  19. # 任务执行回调url
  20. task_callback_url = extern_domain + config['bmp-cp']['task_callback_url']
  21. def watch_advise(task_id, data):
  22. loggerKit.info("[头条极速版]请求信息:{0}'.format(data))")
  23. device_id = data.get("deviceID")
  24. perform_action_id = data.get("performActionId")
  25. result = data.get("result")
  26. if result is not None:
  27. """
  28. 非首个指令
  29. """
  30. perform_action_result = result.get("performActionResult")
  31. if perform_action_result is None:
  32. return_dict = {
  33. "data": "",
  34. "code": -2,
  35. "message": "fail, performActionResult is null"
  36. }
  37. # 回调任务中心
  38. del_key_vague(device_id)
  39. callback_task(500, '指令执行失败', task_id, device_id, 0, None)
  40. return return_dict
  41. # 指令执行失败
  42. if perform_action_result == "failure":
  43. # 回调任务中心
  44. return_dict = {
  45. "data": "",
  46. "code": -2,
  47. "message": "fail, performActionResult is null"
  48. }
  49. del_key_vague(device_id)
  50. callback_task(500, '指令执行失败', task_id, device_id, 0, None)
  51. return return_dict
  52. # 终止指令
  53. if perform_action_result == "stop":
  54. # 回调任务中心
  55. return_dict = {
  56. "data": "",
  57. "code": -2,
  58. "message": "指令被用户终止"
  59. }
  60. del_key_vague(device_id)
  61. callback_task(500, '指令被用户终止', task_id, device_id, 0, None)
  62. return return_dict
  63. """
  64. 每次操作完成后会将对应的操作唯一id存储到redis
  65. 并且返回给手机端 手机端下次带着上个操作id来执行下一个操作
  66. """
  67. last_action_id = redis_client.get(device_id + "operate")
  68. step0 = redis_client.get(f"{device_id}_step0")
  69. if step0 is not None and int(step0) == 1 and last_action_id is not None and int(perform_action_id) == int(
  70. last_action_id) and perform_action_result == "success":
  71. action1_id = int(round(time.time() * 1000))
  72. """
  73. 发送第1条指令
  74. 首页点击任务
  75. """
  76. action1_dict = single_click_by_control(action1_id, target_app="com.ss.android.article.lite",
  77. target_version="9.7.0.0",
  78. package_name="com.ss.android.article.lite",
  79. control_id="com.ss.android.article.lite:id/kp", timeout=30)
  80. redis_client.set(device_id + "operate", action1_id)
  81. redis_client.set(f"{device_id}_{action1_id}_step1", "1")
  82. redis_client.delete(f"{device_id}_step0")
  83. loggerKit.info("设备:{0}, action1_id:{1}", device_id, action1_id)
  84. return action1_dict
  85. step1 = redis_client.get(f"{device_id}_{perform_action_id}_step1")
  86. if step1 is not None and int(step1) == 1 and last_action_id is not None and int(perform_action_id) == int(
  87. last_action_id) and perform_action_result == "success":
  88. loggerKit.info("设备:{0}, action1_id_mem:{1}", device_id, int(last_action_id))
  89. action2_id = int(round(time.time() * 1000))
  90. """
  91. 发送第2条指令
  92. 看广告赚金币
  93. """
  94. with open("pic/advise.png", "rb") as image_file:
  95. encoded_string = base64.b64encode(image_file.read())
  96. action2_dict = click_pic(action2_id, target_app="com.ss.android.article.lite", target_version="9.7.0.0",
  97. package_name="com.ss.android.article.lite", pic_base64=encoded_string)
  98. redis_client.set(device_id + "operate", action2_id)
  99. redis_client.set(f"{device_id}_{action2_id}_step2", "1")
  100. redis_client.delete(f"{device_id}_{action2_id}_step1")
  101. loggerKit.info("设备:{0}, action2_id:{1}", device_id, action2_id)
  102. return action2_dict
  103. # 未找到图片
  104. if perform_action_result == "picNotFound":
  105. # 回调任务中心
  106. return_dict = {
  107. "data": "",
  108. "code": -2,
  109. "message": "picNotFound"
  110. }
  111. del_key_vague(device_id)
  112. callback_task(500, 'picNotFound', task_id, device_id, 0, None)
  113. return return_dict
  114. step2 = redis_client.get(f"{device_id}_{perform_action_id}_step2")
  115. if step2 is not None and int(step2) == 1 and last_action_id is not None and int(perform_action_id) == int(
  116. last_action_id) and perform_action_result == "success":
  117. loggerKit.info("设备:{0}, action2_id_mem:{1}", device_id, int(last_action_id))
  118. action3_id = int(round(time.time() * 1000))
  119. """
  120. 发送第3条指令
  121. 继续滑动屏幕以便查找图片
  122. """
  123. action3_dict = swipe_screen(action3_id, target_app="com.ss.android.article.lite",
  124. target_version="9.7.0.0",
  125. package_name="com.ss.android.article.lite")
  126. redis_client.set(device_id + "operate", action3_id)
  127. redis_client.set(f"{device_id}_{action3_id}_step3", "1")
  128. redis_client.delete(f"{device_id}_{action3_id}_step2")
  129. loggerKit.info("设备:{0}, action3_id:{1}", device_id, action3_id)
  130. return action3_dict
  131. step3 = redis_client.get(f"{device_id}_{perform_action_id}_step3")
  132. if step3 is not None and int(step3) == 1 and last_action_id is not None and int(perform_action_id) == int(
  133. last_action_id) and perform_action_result == "success":
  134. loggerKit.info("设备:{0}, action1_id_mem:{1}", device_id, int(last_action_id))
  135. action4_id = int(round(time.time() * 1000))
  136. """
  137. 发送第4条指令
  138. 看广告赚金币
  139. """
  140. with open("pic/advise.png", "rb") as image_file:
  141. encoded_string = base64.b64encode(image_file.read())
  142. action4_dict = click_pic(action4_id, target_app="com.ss.android.article.lite", target_version="9.7.0.0",
  143. package_name="com.ss.android.article.lite", pic_base64=encoded_string)
  144. redis_client.set(device_id + "operate", action4_id)
  145. redis_client.set(f"{device_id}_{action4_id}_step3", "1")
  146. redis_client.delete(f"{device_id}_{action4_id}_step3")
  147. loggerKit.info("设备:{0}, action4_id:{1}", device_id, action4_id)
  148. return action4_dict
  149. """
  150. 开始自动看广告
  151. """
  152. step4 = redis_client.get(f"{device_id}_{perform_action_id}_step4")
  153. if step4 is not None and int(step4) == 1 and last_action_id is not None and int(perform_action_id) == int(
  154. last_action_id) and perform_action_result == "success":
  155. loggerKit.info("设备:{0}, action1_id_mem:{1}", device_id, int(last_action_id))
  156. action5_id = int(round(time.time() * 1000))
  157. """
  158. 发送第5条指令
  159. 开始自动看广告
  160. """
  161. action5_dict = continual_swipe_screen(action5_id, target_app="com.ss.android.article.lite",
  162. target_version="9.7.0.0",
  163. package_name="com.ss.android.article.lite", continuous_time=180 * 5)
  164. redis_client.set(device_id + "operate", action5_id)
  165. redis_client.set(f"{device_id}_{action5_id}_step5", "1")
  166. redis_client.delete(f"{device_id}_{action5_id}_step4")
  167. loggerKit.info("设备:{0}, action5_id:{1}", device_id, action5_id)
  168. return action5_dict
  169. """
  170. 停止app
  171. """
  172. step5 = redis_client.get(f"{device_id}_step5")
  173. if step5 is not None and int(step5) == 1 and last_action_id is not None and int(perform_action_id) == int(
  174. last_action_id) and perform_action_result == "success":
  175. loggerKit.info("设备:{0}, action10_id_mem:{1}", device_id, int(last_action_id))
  176. action6_id = int(round(time.time() * 1000))
  177. """
  178. 停止指令
  179. 停止app
  180. """
  181. action6_dict = stop_app(action6_id, target_app="com.ss.android.article.lite",
  182. target_version="9.7.0.0",
  183. package_name="com.ss.android.article.lite")
  184. redis_client.delete(f"{device_id}_step5")
  185. del_key_vague(device_id)
  186. loggerKit.info("设备:{0}, action6_id:{1}", device_id, action6_dict)
  187. # 回调任务中心修改任务状态
  188. callback_task(None, None, task_id, device_id, 1, None)
  189. return action6_dict
  190. else:
  191. action0_id = int(round(time.time() * 1000))
  192. """
  193. 启动指令
  194. 启动app
  195. """
  196. action0_dict = start_app(action0_id, target_app="com.ss.android.article.lite",
  197. target_version="9.7.0.0",
  198. package_name="com.ss.android.article.lite")
  199. redis_client.set(device_id + "operate", action0_id)
  200. redis_client.set(f"{device_id}_step0", "1")
  201. redis_client.delete(f"{device_id}_step9")
  202. loggerKit.info("设备:{0}, action0_id:{1}", device_id, action0_id)
  203. return action0_dict