✨✨ 新增每日必做任务、更多庄园任务
This commit is contained in:
parent
db3855fd83
commit
968bd54fc8
234
hykb_tasks.py
234
hykb_tasks.py
@ -16,7 +16,6 @@ from bs4 import BeautifulSoup
|
|||||||
from fn_print import fn_print
|
from fn_print import fn_print
|
||||||
from sendNotify import send_notification_message_collection
|
from sendNotify import send_notification_message_collection
|
||||||
|
|
||||||
|
|
||||||
if 'Hykb_cookie' in os.environ:
|
if 'Hykb_cookie' in os.environ:
|
||||||
hykb_cookie = re.split("@", os.environ.get("Hykb_cookie"))
|
hykb_cookie = re.split("@", os.environ.get("Hykb_cookie"))
|
||||||
print(f"查找到{len(hykb_cookie)}个账号")
|
print(f"查找到{len(hykb_cookie)}个账号")
|
||||||
@ -40,6 +39,7 @@ class AsyncHykbTasks:
|
|||||||
self.temp_id = []
|
self.temp_id = []
|
||||||
self.bmh_tasks = []
|
self.bmh_tasks = []
|
||||||
self.items = []
|
self.items = []
|
||||||
|
self.moreManorToDo_tasks = []
|
||||||
|
|
||||||
async def get_task_ids(self):
|
async def get_task_ids(self):
|
||||||
response = await self.client.get("/n/hykb/qdjh/index.php")
|
response = await self.client.get("/n/hykb/qdjh/index.php")
|
||||||
@ -56,9 +56,9 @@ class AsyncHykbTasks:
|
|||||||
"id": re.search(r"hd_id=(.+)", parts[1]).group(1)
|
"id": re.search(r"hd_id=(.+)", parts[1]).group(1)
|
||||||
})
|
})
|
||||||
|
|
||||||
async def get_bmh_task_ids(self):
|
async def get_recommendToDoToday_task_ids(self):
|
||||||
"""
|
"""
|
||||||
获取爆米花相关任务的id
|
获取今日必做推荐任务的id
|
||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
response = await self.client.get("/n/hykb/cornfarm/index.php?imm=0")
|
response = await self.client.get("/n/hykb/cornfarm/index.php?imm=0")
|
||||||
@ -70,10 +70,34 @@ class AsyncHykbTasks:
|
|||||||
id_param = tasks_infos.select_one("dd")["class"][0]
|
id_param = tasks_infos.select_one("dd")["class"][0]
|
||||||
title_param = tasks_infos.select_one("dt").get_text()
|
title_param = tasks_infos.select_one("dt").get_text()
|
||||||
reward_param = tasks_infos.select_one("dd").get_text()
|
reward_param = tasks_infos.select_one("dd").get_text()
|
||||||
|
if "分享福利" in title_param or "分享资讯" in title_param:
|
||||||
self.bmh_tasks.append(
|
self.bmh_tasks.append(
|
||||||
{
|
{
|
||||||
"bmh_task_id": re.search(r"daily_dd_(.+)", id_param).group(1),
|
"bmh_task_id": re.search(r"daily_dd_(.+)", id_param).group(1),
|
||||||
"bmh_task_title": re.search(r"分享福利:(.*)", title_param).group(1),
|
"bmh_task_title": re.search(r"分享福利:(.*)", title_param).group(
|
||||||
|
1) if "分享福利" in title_param else re.search(r"分享资讯:(.*)", title_param).group(1),
|
||||||
|
"reward_num": re.search(r"可得+(.+)", reward_param).group(1)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
async def get_moreManorToDo_task_ids(self):
|
||||||
|
"""
|
||||||
|
获取更多庄园必做任务id
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
|
response = await self.client.get("https://huodong3.3839.com/n/hykb/cornfarm/index.php?imm=0")
|
||||||
|
html = response.text
|
||||||
|
soup = BeautifulSoup(html, 'html.parser')
|
||||||
|
task_list = soup.select(".taskYcxUl > li")
|
||||||
|
for task_item in task_list:
|
||||||
|
task_info = task_item.select_one("dl")
|
||||||
|
id_param = task_info["onclick"]
|
||||||
|
title_param = task_info.select_one("dt").get_text()
|
||||||
|
reward_param = task_info.select_one("dd").get_text()
|
||||||
|
self.moreManorToDo_tasks.append(
|
||||||
|
{
|
||||||
|
"bmh_task_id": re.search(r"ShowLue\((.+),'ycx'\); return false;", id_param).group(1),
|
||||||
|
"bmh_task_title": title_param,
|
||||||
"reward_num": re.search(r"可得+(.+)", reward_param).group(1)
|
"reward_num": re.search(r"可得+(.+)", reward_param).group(1)
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
@ -85,7 +109,7 @@ class AsyncHykbTasks:
|
|||||||
self.client.headers["Referer"] = f"https://huodong3.3839.com/n/hykb/newsign/index.php?imm=0&hd_id={hd_id_}"
|
self.client.headers["Referer"] = f"https://huodong3.3839.com/n/hykb/newsign/index.php?imm=0&hd_id={hd_id_}"
|
||||||
response = await self.client.post(
|
response = await self.client.post(
|
||||||
url=url,
|
url=url,
|
||||||
data=payload,
|
content=payload,
|
||||||
)
|
)
|
||||||
response_json = response.json()
|
response_json = response.json()
|
||||||
return response_json
|
return response_json
|
||||||
@ -93,7 +117,7 @@ class AsyncHykbTasks:
|
|||||||
print(e)
|
print(e)
|
||||||
return None
|
return None
|
||||||
|
|
||||||
async def process_item(self, item, bmh_itme):
|
"""async def process_item(self, item, bmh_itme):
|
||||||
id = item["id"]
|
id = item["id"]
|
||||||
await self.get_task("login", id)
|
await self.get_task("login", id)
|
||||||
data = await self.get_task("signToday", id)
|
data = await self.get_task("signToday", id)
|
||||||
@ -105,12 +129,6 @@ class AsyncHykbTasks:
|
|||||||
if key == "-1005":
|
if key == "-1005":
|
||||||
fn_print("体验游戏中,请一分钟后再刷新领取☑️")
|
fn_print("体验游戏中,请一分钟后再刷新领取☑️")
|
||||||
await self.get_task("tiyan", id)
|
await self.get_task("tiyan", id)
|
||||||
# self.temp_id.append(
|
|
||||||
# {
|
|
||||||
# "title": item["title"],
|
|
||||||
# "id": id
|
|
||||||
# }
|
|
||||||
# ) # 将正在体验的活动id加入列表中
|
|
||||||
elif key == "-1007":
|
elif key == "-1007":
|
||||||
await self.get_task("sharelimit", id)
|
await self.get_task("sharelimit", id)
|
||||||
fn_print(f"活动【{item['title']}】分享成功!✅")
|
fn_print(f"活动【{item['title']}】分享成功!✅")
|
||||||
@ -123,36 +141,77 @@ class AsyncHykbTasks:
|
|||||||
elif key == "no_login":
|
elif key == "no_login":
|
||||||
fn_print("⚠️⚠️scookie失效,请重新配置⚠️⚠️")
|
fn_print("⚠️⚠️scookie失效,请重新配置⚠️⚠️")
|
||||||
return False
|
return False
|
||||||
return True
|
return True"""
|
||||||
|
|
||||||
|
async def process_moreManorToDo_task(self, mmtodo_item):
|
||||||
|
if "预约" in mmtodo_item["bmh_task_title"]:
|
||||||
|
await self.appointment_moreManorToDo_task(mmtodo_item)
|
||||||
|
await self.get_moreManorToDo_task_reward(mmtodo_item, "YcxYuyueLing")
|
||||||
|
else:
|
||||||
|
if "微博" in mmtodo_item["bmh_task_title"]:
|
||||||
|
await self.get_moreManorToDo_task_reward(mmtodo_item, "YcxToWeiboRemindLing")
|
||||||
|
elif "微信" in mmtodo_item["bmh_task_title"]:
|
||||||
|
await self.get_moreManorToDo_task_reward(mmtodo_item, "YcxToWechatRemindLing")
|
||||||
|
elif "视频" in mmtodo_item["bmh_task_title"]:
|
||||||
|
await self.get_moreManorToDo_task_reward(mmtodo_item, "YcxToH5Url")
|
||||||
|
|
||||||
|
async def process_doItDaily_task(self, bmh_itme):
|
||||||
|
await self.do_tasks_every_day(bmh_itme)
|
||||||
|
await self.get_task_reward(bmh_itme)
|
||||||
|
|
||||||
async def do_tasks_every_day(self, task_items: dict):
|
async def do_tasks_every_day(self, task_items: dict):
|
||||||
"""
|
"""
|
||||||
调度每日必做任务
|
调度每日必做任务
|
||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
# 分享任务
|
url = "https://huodong3.3839.com/n/hykb/cornfarm/ajax_daily.php"
|
||||||
share_url = "https://huodong3.3839.com/n/hykb/cornfarm/ajax_daily.php"
|
daily_share_response = await self.client.post(
|
||||||
share_data = {
|
url=url,
|
||||||
"ac": "DailyShareCallback",
|
content=f"ac=DailyShare&id={task_items['bmh_task_id']}&onlyc=0&r=0.{random.randint(100000000000000, 8999999999999999)}&scookie={urllib.parse.quote(self.cookie)}&device=kbA25014349F11473F467DC6FF5C89E9D6"
|
||||||
"id": "{}".format(task_items["bmh_task_id"]),
|
)
|
||||||
"mode": "qq",
|
if daily_share_response.json()["key"] != "2002":
|
||||||
"source": "ds",
|
return False
|
||||||
"r": f"0.{random.randint(100000000000000, 8999999999999999)}",
|
# 回调任务
|
||||||
"scookie": self.cookie,
|
payload = (
|
||||||
"device": "kbA25014349F11473F467DC6FF5C89E9D6"
|
f"ac=DailyShareCallback&id={task_items['bmh_task_id']}&mode=qq&source=ds&r=0.{random.randint(100000000000000, 8999999999999999)}"
|
||||||
}
|
f"&scookie={urllib.parse.quote(self.cookie)}&device=kbA25014349F11473F467DC6FF5C89E9D6")
|
||||||
share_response = await self.client.post(url=share_url, json=share_data)
|
daily_share_callback_response = await self.client.post(url=url, content=payload)
|
||||||
try:
|
try:
|
||||||
share_response_json = share_response.json()
|
share_response_json = daily_share_callback_response.json()
|
||||||
if share_response_json["key"] == "ok" and share_response_json["info"] == "可以领奖":
|
if share_response_json["key"] == "ok" and share_response_json["info"] == "可以领奖":
|
||||||
fn_print("任务: {}, 可以领奖了.".format(task_items["bmh_task_title"]))
|
fn_print("任务: {}, 可以领奖了.".format(task_items["bmh_task_title"]))
|
||||||
return True
|
return True
|
||||||
|
elif share_response_json["key"] == "2002":
|
||||||
|
fn_print("任务: {}, 已经领过奖励了.")
|
||||||
|
return False
|
||||||
else:
|
else:
|
||||||
fn_print("任务: {}, 不可以领奖".format(task_items["bmh_task_title"]))
|
fn_print("任务: {}, 不可以领奖".format(task_items["bmh_task_title"]))
|
||||||
return False
|
return False
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
fn_print("调度任务异常:", e)
|
fn_print("调度任务异常:", e)
|
||||||
fn_print(share_response.text)
|
fn_print(daily_share_callback_response.text)
|
||||||
|
|
||||||
|
async def appointment_moreManorToDo_task(self, task_items):
|
||||||
|
"""
|
||||||
|
预约更多庄园必做任务
|
||||||
|
:param task_items:
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
|
url = "https://huodong3.3839.com/n/hykb/cornfarm/ajax_ycx.php"
|
||||||
|
payload = (
|
||||||
|
f"ac=YcxGameDetail&id={task_items['bmh_task_id']}&r=0.{random.randint(100000000000000, 8999999999999999)}"
|
||||||
|
f"&scookie={urllib.parse.quote(self.cookie)}"
|
||||||
|
"&device=kbA25014349F11473F467DC6FF5C89E9D6")
|
||||||
|
am_response = await self.client.post(url, content=payload)
|
||||||
|
try:
|
||||||
|
am_response_json = am_response.json()
|
||||||
|
if am_response_json["key"] == "ok":
|
||||||
|
fn_print(f"任务: 【{task_items['bmh_task_title']}】预约成功!")
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
fn_print(f"任务: 【{task_items['bmh_task_title']}】预约失败!")
|
||||||
|
except Exception as e:
|
||||||
|
print(f"任务{task_items['bmh_task_title']}预约操作错误:{e}")
|
||||||
|
|
||||||
async def get_task_reward(self, task_items: dict):
|
async def get_task_reward(self, task_items: dict):
|
||||||
"""
|
"""
|
||||||
@ -161,56 +220,98 @@ class AsyncHykbTasks:
|
|||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
url = "https://huodong3.3839.com/n/hykb/cornfarm/ajax_daily.php"
|
url = "https://huodong3.3839.com/n/hykb/cornfarm/ajax_daily.php"
|
||||||
data = {
|
payload = (
|
||||||
"ac": "DailyShareLing",
|
f"ac=DailyShareLing&smdeviceid=BTeK4FWZx3plsETCF1uY6S1h2uEajvI1AicKa4Lqz3U7Tt5wKKDZZqVmVr7WpkcEuSQKyiDA3d64bErE%2FsaJp3Q%3D%3D&verison=1.5.7.507&id={task_items['bmh_task_id']}&r=0.{random.randint(100000000000000, 8999999999999999)}&scookie={self.cookie}"
|
||||||
"smdeviceid": "BOMLz9iBlx4KwA+wayGk+H/+P91GAH9pC0q9dvBQcvwlVTppakJAfBnJr1K5lyBgzXtIcTgeBqAXtI7NWFaaz8A==",
|
f"&device=kbA25014349F11473F467DC6FF5C89E9D6")
|
||||||
|
response = await self.client.post(url=url, content=payload)
|
||||||
|
try:
|
||||||
|
response_json = response.json()
|
||||||
|
if response_json["key"] == "ok":
|
||||||
|
fn_print(
|
||||||
|
f"任务: {task_items['bmh_task_title']}- ✅奖励领取成功!\n成熟度+{response_json['reward_csd_num']}\n已完成任务数量:{response_json['daily_renwu_success_total']}\n今日获得成熟度{response_json['daily_day_all_chengshoudu']}")
|
||||||
|
elif response_json["key"] == "2001":
|
||||||
|
fn_print(f"任务:【{task_items['bmh_task_title']}】今天已经领取过了!")
|
||||||
|
else:
|
||||||
|
fn_print(f"奖励领取失败!{response_json.text}")
|
||||||
|
except Exception as e:
|
||||||
|
print("领取任务奖励异常: ", e)
|
||||||
|
|
||||||
|
async def get_moreManorToDo_task_reward(self, task_items, reward_type):
|
||||||
|
"""
|
||||||
|
领取更多庄园必做任务的奖励
|
||||||
|
:param task_items:
|
||||||
|
:param reward_type:
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
|
url = "https://huodong3.3839.com/n/hykb/cornfarm/ajax_ycx.php"
|
||||||
|
if reward_type == "YcxToWechatRemindLing":
|
||||||
|
payload = {
|
||||||
|
"ac": reward_type,
|
||||||
|
"id": f"{task_items['bmh_task_id']}",
|
||||||
|
"smdeviceid": "BTeK4FWZx3plsETCF1uY6S1h2uEajvI1AicKa4Lqz3U7Tt5wKKDZZqVmVr7WpkcEuSQKyiDA3d64bErE/saJp3Q==",
|
||||||
"verison": "1.5.7.507",
|
"verison": "1.5.7.507",
|
||||||
"id": "{}".format(task_items["bmh_task_id"]),
|
"VersionCode": "342",
|
||||||
"r": f"0.{random.randint(100000000000000, 8999999999999999)}",
|
"r": f"0.{random.randint(100000000000000, 8999999999999999)}",
|
||||||
"scookie": self.cookie,
|
"scookie": self.cookie,
|
||||||
"device": "kbA25014349F11473F467DC6FF5C89E9D6"
|
"device": "kbA25014349F11473F467DC6FF5C89E9D6"
|
||||||
}
|
}
|
||||||
response = await self.client.post(url=url, json=data)
|
elif reward_type == "YcxYuyueLing":
|
||||||
|
payload = {
|
||||||
|
"ac": reward_type,
|
||||||
|
"id": f"{task_items['bmh_task_id']}",
|
||||||
|
"smdeviceid": "BTeK4FWZx3plsETCF1uY6S1h2uEajvI1AicKa4Lqz3U7Tt5wKKDZZqVmVr7WpkcEuSQKyiDA3d64bErE/saJp3Q==",
|
||||||
|
"verison": "1.5.7.507",
|
||||||
|
"r": f"0.{random.randint(100000000000000, 8999999999999999)}",
|
||||||
|
"scookie": self.cookie,
|
||||||
|
"device": "kbA25014349F11473F467DC6FF5C89E9D6"
|
||||||
|
}
|
||||||
|
elif reward_type == "YcxToWeiboRemindLing":
|
||||||
|
payload = {
|
||||||
|
"ac": reward_type,
|
||||||
|
"id": f"{task_items['bmh_task_id']}",
|
||||||
|
"smdeviceid": "BTeK4FWZx3plsETCF1uY6S1h2uEajvI1AicKa4Lqz3U7Tt5wKKDZZqVmVr7WpkcEuSQKyiDA3d64bErE/saJp3Q==",
|
||||||
|
"verison": "1.5.7.507",
|
||||||
|
"VersionCode": "342",
|
||||||
|
"r": f"0.{random.randint(100000000000000, 8999999999999999)}",
|
||||||
|
"scookie": self.cookie,
|
||||||
|
"device": "kbA25014349F11473F467DC6FF5C89E9D6"
|
||||||
|
}
|
||||||
|
elif reward_type == "YcxToH5Url":
|
||||||
|
payload = {
|
||||||
|
"ac": reward_type,
|
||||||
|
"id": f"{task_items['bmh_task_id']}",
|
||||||
|
"r": f"0.{random.randint(100000000000000, 8999999999999999)}",
|
||||||
|
"scookie": self.cookie,
|
||||||
|
"device": "kbA25014349F11473F467DC6FF5C89E9D6"
|
||||||
|
}
|
||||||
|
response = await self.client.post(
|
||||||
|
url=url,
|
||||||
|
content=urllib.parse.urlencode(payload)
|
||||||
|
)
|
||||||
try:
|
try:
|
||||||
response_json = response.json()
|
m_response = response.json()
|
||||||
if response_json["key"] == "ok" and response_json["message"] == "成功":
|
if m_response["key"] == "ok":
|
||||||
fn_print(
|
fn_print(f"任务: 【{task_items['bmh_task_title']}】领取奖励成功!")
|
||||||
f"任务: {task_items['bmh_task_title']}- ✅奖励领取成功!\n成熟度+{response_json['reward_csd_num']}\n已完成任务数量:{response_json['daily_renwu_success_total']}\n今日获得成熟度{response_json['daily_day_all_chengshoudu']}")
|
elif m_response["key"] == "2001":
|
||||||
|
fn_print(f"任务: 【{task_items['bmh_task_title']}】已经领取过奖励啦")
|
||||||
else:
|
else:
|
||||||
fn_print("奖励领取失败!")
|
fn_print(f"奖励领取失败,{response.text}")
|
||||||
except Exception:
|
except Exception as e:
|
||||||
print(response.text)
|
print("领取任务奖励异常: ", e)
|
||||||
|
|
||||||
async def task(self):
|
async def task(self):
|
||||||
cookie = urllib.parse.quote(self.cookie) if "|" in self.cookie else self.cookie
|
|
||||||
await self.get_task_ids()
|
await self.get_task_ids()
|
||||||
await self.get_bmh_task_ids()
|
await self.get_recommendToDoToday_task_ids()
|
||||||
|
await self.get_moreManorToDo_task_ids()
|
||||||
|
|
||||||
|
for bmh_item in self.bmh_tasks:
|
||||||
|
if not await self.process_doItDaily_task(bmh_item):
|
||||||
|
continue
|
||||||
|
|
||||||
|
for mmtodo_item in self.moreManorToDo_tasks:
|
||||||
|
if not await self.process_moreManorToDo_task(mmtodo_item):
|
||||||
|
continue
|
||||||
|
|
||||||
for item, bmh_item in self.items, self.bmh_tasks:
|
|
||||||
if not await self.process_item(item, bmh_item):
|
|
||||||
break
|
|
||||||
# if self.temp_id:
|
|
||||||
# print("等待体验结束...")
|
|
||||||
# time.sleep(60)
|
|
||||||
# for ty_id in self.temp_id:
|
|
||||||
# await self.get_task("login", ty_id)
|
|
||||||
# data = await self.get_task("signToday", ty_id)
|
|
||||||
# key = str(data["key"])
|
|
||||||
# if key == "-1005":
|
|
||||||
# print("体验游戏中,请一分钟后再刷新领取☑️")
|
|
||||||
# await self.get_task("tiyan", id)
|
|
||||||
# self.temp_id.append(id) # 将正在体验的活动id加入列表中
|
|
||||||
# elif key == "-1007":
|
|
||||||
# await self.get_task("sharelimit", id)
|
|
||||||
# print(f"活动【{item['title']}】分享成功!✅")
|
|
||||||
# await self.get_task("login", id)
|
|
||||||
# await self.get_task("signToday", id)
|
|
||||||
# elif key == "-1002":
|
|
||||||
# print(f"活动【{item['title']}】奖励已领取过了!")
|
|
||||||
# elif key == "200":
|
|
||||||
# print(f"活动【{item['title']}】签到成功!✅已签到{data['signnum']}天")
|
|
||||||
# elif key == "no_login":
|
|
||||||
# print("⚠️⚠️scookie失效,请重新配置⚠️⚠️")
|
|
||||||
await self.client.aclose()
|
await self.client.aclose()
|
||||||
|
|
||||||
|
|
||||||
@ -225,7 +326,6 @@ async def run_all_tasks(cookies):
|
|||||||
|
|
||||||
|
|
||||||
async def main():
|
async def main():
|
||||||
hykb_cookie = []
|
|
||||||
await run_all_tasks(hykb_cookie)
|
await run_all_tasks(hykb_cookie)
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user