CHERWIN_SCRIPTS/KFHS.py

354 lines
13 KiB
Python
Raw Normal View History

2024-05-15 06:18:39 +08:00
# !/usr/bin/python3
# -- coding: utf-8 --
# -------------------------------
# cron "30 1 * * *" script-path=xxx.py,tag=匹配cron用
# const $ = new Env('微信公众号:卡夫亨氏新厨艺')
import os
import random
import time
from datetime import date, datetime
import requests
from requests.packages.urllib3.exceptions import InsecureRequestWarning
# import CHERWIN_TOOLS
# 禁用安全请求警告
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
if os.path.isfile('DEV_ENV.py'):
import DEV_ENV
if os.path.isfile('notify.py'):
from notify import send
print("加载通知服务成功!")
else:
print("加载通知服务失败!")
send_msg = ''
one_msg=''
def Log(cont=''):
global send_msg,one_msg
print(cont)
if cont:
one_msg += f'{cont}\n'
send_msg += f'{cont}\n'
class RUN:
def __init__(self,info,index):
global one_msg
one_msg = ''
split_info = info.split('@')
self.token = split_info[0]
len_split_info = len(split_info)
last_info = split_info[len_split_info - 1]
self.send_UID = None
if len_split_info > 0 and "UID_" in last_info:
self.send_UID = last_info
self.index = index + 1
Log(f"\n---------开始执行第{self.index}个账号>>>>>")
self.s = requests.session()
self.s.verify = False
self.headers = {
'Host': 'fscrm.kraftheinz.net.cn',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x63090719) XWEB/8447 Flue',
'token': self.token,
'Accept': '*/*',
'Origin': 'https://fscrm.kraftheinz.net.cn',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://fscrm.kraftheinz.net.cn/?code=031NdLkl2SD8ac4BUKll2x4iqC2NdLkO&state=fid%3DN8d3E4AyKCBiu7DuBRNPlw&appid=wx65da983ae179e97b',
'Accept-Language': 'zh-CN,zh;q=0.9',
'Content-Type': 'application/x-www-form-urlencoded',
}
self.baseUrl = 'https://fscrm.kraftheinz.net.cn/crm/public/index.php/api/v1/'
def getUserInfo(self,End=False):
global userid_list, username_list
response = self.s.get(
f'{self.baseUrl}getUserInfo',
headers=self.headers
)
if response.status_code == 200:
try:
resp = response.json()
data = resp.get('data',{})
nickname = data.get('nickname','')
openId = data.get('openId','')
signTimes = data.get('signTimes',0)
memberInfo = data.get('memberInfo', {})
phone = memberInfo.get('phone', '')
score = memberInfo.get('score', '')
if End :
Log(f'执行后积分:【{score}')
return True
self.member_id = data.get('member_id','')
# add = {"nickname":nickname,"member_id":member_id}
userid_list.append(self.member_id)
username_list.append(nickname)
Log(f'>>>当前用户:【{nickname}\nID{self.member_id}\nOpenID:【{openId}\n已连续签到【{signTimes}】天')
serialSign = data.get('serialSign', [{}])
if serialSign :
current_date = date.today()
date_string = serialSign[0].get('createdAt',current_date)
memberBalance = serialSign[0].get('memberBalance', 0)
parsed_date = datetime.strptime(date_string, '%Y-%m-%d %H:%M:%S').date()
if parsed_date == current_date:
print(f"今日已签到,当前积分:【{memberBalance}")
else:
print("今日未签到")
wait_time = random.randint(1000, 10000) / 1000.0 # 转换为秒
time.sleep(wait_time)
print('随机延时1-10秒执行签到')
self.dailySign()
return True
except:
print(response.text)
return False
else:
print("API访问失败")
return False
def dailySign(self):
print('执行签到')
response = self.s.post(
f'{self.baseUrl}dailySign',
headers=self.headers
)
if response.status_code == 200:
try:
resp = response.json()
msg = resp['msg']
Log(f'>{msg}')
except:
print(response.text)
else:
print("API访问失败")
def getCookbookIndex(self):
global Cookid_list
data = {
'page': '1',
'pagesize': '30'
}
response = self.s.post(
f'{self.baseUrl}getCookbookIndex',
headers=self.headers, data=data
)
if response.status_code == 200:
try:
resp = response.json()
id_list = resp['data']['chineseCookbook']['data']
for i in id_list:
Cookid_list.append(i['id'])
print(f'>获取到菜谱ID:【{Cookid_list}')
except:
print(response.text)
else:
print("API访问失败")
def recordScoreShare(self, cookbook_id, now_id):
# print('')
# self.getUserInfo()
Log('开始互助')
for id in userid_list:
if now_id == id: continue
# Log(f'>>>开始为【{id}】分享的菜谱【{cookbook_id}】助力')
data = {
'cookbook_id': cookbook_id,
'invite_id': id,
}
response = self.s.post(
f'{self.baseUrl}recordScoreShare',
headers=self.headers, data=data
)
if response.status_code == 200:
try:
resp = response.json()
msg = resp['msg']
Log(f'>为【{id}】助力结果:【{msg}')
except:
print(response.text)
else:
print("API访问失败")
def helpAuthor(self, authorid, cookbook_id, now_id):
Log('开始助力作者')
if now_id != authorid:
data = {
'cookbook_id': cookbook_id,
'invite_id': authorid,
}
response = self.s.post(
f'{self.baseUrl}recordScoreShare',
headers=self.headers, data=data
)
if response.status_code == 200:
try:
resp = response.json()
msg = resp['msg']
Log(f'>为【作者】助力结果:【{msg}')
except:
print(response.text)
else:
print("API访问失败")
else:
Log('助力对象为自身,跳过')
# 预留兑换函数
def exchangeIntegralNew(self):
data = {
'value': '爱奇艺月卡',
'phone': '',
'type': '视频卡'
}
# data = {
# 'value': '全网10元话费',
# 'phone': '',
# 'type': '话费',
# 'memberId': '',
# }
response = self.s.post(
f'{self.baseUrl}exchangeIntegralNew',
headers=self.headers,
data=data
)
if response.status_code == 200:
try:
resp = response.json()
msg = resp['msg']
Log(f'>{msg}')
except:
print(response.text)
else:
print("API访问失败")
def main(self):
# self.getUserInfo()
# self.getCookbookIndex()
if self.getUserInfo():
if self.index == 1:
self.getCookbookIndex()
self.getUserInfo(True)
self.sendMsg()
return True
else:
return False
def help(self):
# print(Cookid_list)
# print(username_list)
# print(userid_list)
if Cookid_list and username_list and userid_list:
cookbook_id = random.choice(Cookid_list)
username = username_list[self.index-1]
now_id = userid_list[self.index-1]
Log(f'\n当前用于助力用户:【{username}】 ID:【{now_id}')
self.helpAuthor(662056, cookbook_id, now_id)
self.recordScoreShare(cookbook_id, now_id)
self.sendMsg(True)
return True
else:
return False
def sendMsg(self,help=False):
if self.send_UID:
push_res = CHERWIN_TOOLS.wxpusher(self.send_UID, one_msg, APP_NAME,help)
print(push_res)
def down_file(filename, file_url):
print(f'开始下载:{filename},下载地址:{file_url}')
try:
response = requests.get(file_url, verify=False, timeout=10)
response.raise_for_status()
with open(filename + '.tmp', 'wb') as f:
f.write(response.content)
print(f'{filename}】下载完成!')
# 检查临时文件是否存在
temp_filename = filename + '.tmp'
if os.path.exists(temp_filename):
# 删除原有文件
if os.path.exists(filename):
os.remove(filename)
# 重命名临时文件
os.rename(temp_filename, filename)
print(f'{filename}】重命名成功!')
return True
else:
print(f'{filename}】临时文件不存在!')
return False
except Exception as e:
print(f'{filename}】下载失败:{str(e)}')
return False
def import_Tools():
global CHERWIN_TOOLS,ENV, APP_INFO, TIPS, TIPS_HTML, AuthorCode
import CHERWIN_TOOLS
# print(APP_NAME, local_script_name, ENV_NAME,local_version)
ENV, APP_INFO, TIPS, TIPS_HTML, AuthorCode = CHERWIN_TOOLS.main(APP_NAME, local_script_name, ENV_NAME,local_version)
if __name__ == '__main__':
APP_NAME = '卡夫亨氏新厨艺'
ENV_NAME = 'KFHS'
CK_NAME = 'token'
print(f'''
{APP_NAME}签到
功能
积分签到
抓包步骤
打开{APP_NAME}
授权登陆
打开抓包工具
找请求头带{CK_NAME}的URl
复制里面的{CK_NAME}参数值
注册链接复制微信打开https://fscrm.kraftheinz.net.cn/?from=N8d3E4AyKCBiu7DuBRNPlw==#/
wxpusher一对一推送功能
需要定义变量export WXPUSHER=wxpusher的app_token不设置则不启用wxpusher一对一推送
需要在{ENV_NAME}变量最后添加@wxpusher的UID
参数示例Fks8FqmiTksnmZSj2fDvxxxxxxxxx@UID_xxxxx
设置青龙变量
export {ENV_NAME}='{CK_NAME}参数值'多账号#或&分割
export SCRIPT_UPDATE = 'False' 关闭脚本自动更新默认开启
注意token有效期7天7天后重新抓
推荐cron5 8 * * *
@Author CHERWIN
''')
local_script_name = os.path.basename(__file__)
local_version = '2024.04.06'
if os.path.isfile('CHERWIN_TOOLS.py'):
import_Tools()
else:
if down_file('CHERWIN_TOOLS.py', 'https://py.cherwin.cn/CHERWIN_TOOLS.py'):
print('脚本依赖下载完成请重新运行脚本')
import_Tools()
else:
print('脚本依赖下载失败请到https://py.cherwin.cn/CHERWIN_TOOLS.py下载最新版本依赖')
exit()
print(TIPS)
token = ''
token = ENV if ENV else token
print(token)
if not token:
print(f"未填写{ENV_NAME}变量\n青龙可在环境变量设置 {ENV_NAME} 或者在本脚本文件上方将{CK_NAME}填入token =''")
exit()
tokens = CHERWIN_TOOLS.ENV_SPLIT(token)
print(tokens)
Cookid_list = []
userid_list = []
username_list = []
if len(tokens) > 0:
print(f"\n>>>>>>>>>>共获取到{len(tokens)}个账号<<<<<<<<<<")
for index, infos in enumerate(tokens):
run_result = RUN(infos, index).main()
if not run_result: continue
print(f"\n>>>>>>>>>>开始互助<<<<<<<<<<")
for index, infos in enumerate(tokens):
run_result = RUN(infos, index).help()
if not run_result: continue
2024-04-08 02:14:22 +08:00
if send: send(f'{APP_NAME}挂机通知', send_msg + TIPS_HTML)