Add files via upload

This commit is contained in:
3288588344
2024-06-17 13:51:29 +08:00
committed by GitHub
parent 13c3574732
commit a31ea56631
13 changed files with 1440 additions and 8 deletions

516
zippo会员签到.js Normal file

File diff suppressed because one or more lines are too long

43
临期批发_.py Normal file

File diff suppressed because one or more lines are too long

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.10 21:00 @Date: 2024.06.10 21:00
@Description: 每日一句 小程序 一天大概2毛 满3提 @Description: 每日一句 小程序 一天大概2毛 满3提
------------------------------------------ ------------------------------------------

5
代挂布局.js Normal file
View File

@@ -0,0 +1,5 @@
https://star.kaiershuzi.com/#/pages/login/register?code=LQKD1EM6
https://nyshare.igmdns.com/index.html?inviteCode=23108
注册好加QQ1151268390带挂0鲁

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.11 16:43 @Date: 2024.06.11 16:43
@Description: 华硕商城APP 基础任务 浏览[好像有BUG]5分 + 签到5分 = 抽奖9分 @Description: 华硕商城APP 基础任务 浏览[好像有BUG]5分 + 签到5分 = 抽奖9分
------------------------------------------ ------------------------------------------

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.11 18:52 @Date: 2024.06.11 18:52
@Description: 卡池权益会员店 小程序 一周签到大概50积分 500换5花费 @Description: 卡池权益会员店 小程序 一周签到大概50积分 500换5花费
------------------------------------------ ------------------------------------------

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.09 12.40 @Date: 2024.06.09 12.40
@Description: 古井贡酒会员中心小程序 @Description: 古井贡酒会员中心小程序
------------------------------------------ ------------------------------------------

View File

@@ -0,0 +1,216 @@
/*
------------------------------------------
@Author: smallfawn
@Date: 2024.06.11 19:19
@Description: 富士instax玩拍由我俱乐部 小程序 每日签到+抽奖
------------------------------------------
变量名instax
变量值 https://instax.app.xcxd.net.cn/ 域名Headers请求头的Authorization 去掉Bearer 多账号&或换行或新增同名变量
[Script]
http-response
[MITM]
hostname =
⚠️【免责声明】
------------------------------------------
1、此脚本仅用于学习研究不保证其合法性、准确性、有效性请根据情况自行判断本人对此不承担任何保证责任。
2、由于此脚本仅用于学习研究您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。
3、请勿将此脚本用于任何商业或非法目的若违反规定请自行对此负责。
4、此脚本涉及应用与本人无关本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。
5、本人对任何脚本引发的问题概不负责包括但不限于由脚本错误引起的任何损失和损害。
6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利应及时通知并提供身份证明所有权证明我们将在收到认证文件确认后删除此脚本。
7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本即视为您已接受此免责声明。
*/
const $ = new Env("富士instax玩拍由我俱乐部");
let ckName = `instax`;
let userCookie = checkEnv(
($.isNode() ? process.env[ckName] : $.getdata(ckName)) || ""
);
const notify = $.isNode() ? require("./sendNotify") : "";
!(async () => {
console.log(
`==================================================\n 脚本执行 - 北京时间(UTC+8): ${new Date(
new Date().getTime() +
new Date().getTimezoneOffset() * 60 * 1000 +
8 * 60 * 60 * 1000
).toLocaleString()} \n==================================================`
);
//console.log(userCookie)
if (!userCookie?.length) return console.log(`没有找到CK哦`);
let index = 1;
let strSplitor = "#";
for (let user of userCookie) {
$.log(`\n🚀 user:【${index}】 start work\n`);
index++
$.token = user
$.ckStatus = true;
$.userId = null
await me()
await $.wait(3000)
if ($.userId) {
await signIn()
await $.wait(3000)
await chance()
}
}
await $.sendMsg($.logs.join("\n"));
})()
.catch((e) => console.log(e))
.finally(() => $.done());
async function me() {
let config = {
url: `https://instax.app.xcxd.net.cn/api/me`,
method: `GET`,
headers: {
"Accept": "*/*",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9",
"Authorization": "Bearer " + $.token,
"Connection": "keep-alive",
"Content-Type": "application/json",
"Host": "instax.app.xcxd.net.cn",
"Referer": "https://servicewechat.com/wx3cb572fbf3aa30c8/134/page-frame.html",
"Sec-Fetch-Dest": "empty",
"Sec-Fetch-Mode": "cors",
"Sec-Fetch-Site": "cross-site",
"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 MicroMessenger/7.0.20.1781(0x6700143B) NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF WindowsWechat(0x6309092b) XWEB/8555",
"xweb_xhr": "1"
},
}
let { data: result } = await Request(config);
if (result?.error == false) {
$.userId = result.data.user.id
$.log(`[${result.data.user.nickname}] 当前积分[${result.data.user.credit}] 等级[${result.data.user.user_level_id}]`);
} else {
$.log(`获取信息 失败[${result.message}]`);
}
}
async function signIn() {
let config = {
url: `https://instax.app.xcxd.net.cn/api/user/${$.userId}/sign-activity/23/sign`,
method: `POST`,
headers: {
"Accept": "*/*",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9",
"Authorization": "Bearer " + $.token,
"Connection": "keep-alive",
"Content-Type": "application/json",
"Host": "instax.app.xcxd.net.cn",
"Referer": "https://servicewechat.com/wx3cb572fbf3aa30c8/134/page-frame.html",
"Sec-Fetch-Dest": "empty",
"Sec-Fetch-Mode": "cors",
"Sec-Fetch-Site": "cross-site",
"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 MicroMessenger/7.0.20.1781(0x6700143B) NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF WindowsWechat(0x6309092b) XWEB/8555",
"xweb_xhr": "1"
},
data: JSON.stringify({})
}
let { data: response } = await Request(config);
if (response?.error == false) {
$.log(`签到成功`);
} else {
$.log(`签到失败[${response}]`);
}
}
async function chance() {
let config = {
url: `https://instax.app.xcxd.net.cn/api/user/${$.userId}/draw-activities/41/chance`,
method: `GET`,
headers: {
"Accept": "*/*",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9",
"Authorization": "Bearer " + $.token,
"Connection": "keep-alive",
"Content-Type": "application/json",
"Host": "instax.app.xcxd.net.cn",
"Referer": "https://servicewechat.com/wx3cb572fbf3aa30c8/134/page-frame.html",
"Sec-Fetch-Dest": "empty",
"Sec-Fetch-Mode": "cors",
"Sec-Fetch-Site": "cross-site",
"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 MicroMessenger/7.0.20.1781(0x6700143B) NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF WindowsWechat(0x6309092b) XWEB/8555",
"xweb_xhr": "1"
}
}
let { data: result } = await Request(config);
if (result?.error == false) {
$.log(`查询抽奖次数 [${result.data}]`);
for (let i = 0; i < result.data; i++) {
await $.wait(3000)
await draw()
}
} else {
$.log(`查询抽奖次数 失败[${result.message}]`);
}
}
async function draw() {
let config = {
url: `https://instax.app.xcxd.net.cn/api/user/${$.userId}/draw-activities/41/draw`,
method: `POST`,
headers: {
"Accept": "*/*",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9",
"Authorization": "Bearer " + $.token,
"Connection": "keep-alive",
"Content-Type": "application/json",
"Host": "instax.app.xcxd.net.cn",
"Referer": "https://servicewechat.com/wx3cb572fbf3aa30c8/134/page-frame.html",
"Sec-Fetch-Dest": "empty",
"Sec-Fetch-Mode": "cors",
"Sec-Fetch-Site": "cross-site",
"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 MicroMessenger/7.0.20.1781(0x6700143B) NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF WindowsWechat(0x6309092b) XWEB/8555",
"xweb_xhr": "1"
},
data: JSON.stringify({})
}
let { data: result } = await Request(config);
if (result?.error == false) {
$.log(`抽奖成功 [${result.data.record.desc}]`);
} else {
$.log(`抽奖失败[${result.message}]`);
}
}
function checkEnv(userCookie) {
const envSplitor = ["&", "\n"];
//console.log(userCookie);
let userList = userCookie
.split(envSplitor.find((o) => userCookie.includes(o)) || "&")
.filter((n) => n);
console.log(`共找到${userList.length}个账号`);
return userList;
}
// prettier-ignore
function Env(t, s) { return new (class { constructor(t, s) { this.name = t; this.logs = []; this.logSeparator = "\n"; this.startTime = new Date().getTime(); Object.assign(this, s); this.log("", `\ud83d\udd14${this.name},\u5f00\u59cb!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } queryStr(options) { return Object.entries(options).map(([key, value]) => `${key}=${typeof value === "object" ? JSON.stringify(value) : value}`).join("&") } getURLParams(url) { const params = {}; const queryString = url.split("?")[1]; if (queryString) { const paramPairs = queryString.split("&"); paramPairs.forEach((pair) => { const [key, value] = pair.split("="); params[key] = value }) } return params } isJSONString(str) { try { return JSON.parse(str) && typeof JSON.parse(str) === "object" } catch (e) { return false } } isJson(obj) { var isjson = typeof obj == "object" && Object.prototype.toString.call(obj).toLowerCase() == "[object object]" && !obj.length; return isjson } async sendMsg(message) { if (!message) return; if (this.isNode()) { await notify.sendNotify(this.name, message) } else { this.msg(this.name, "", message) } } randomNumber(length) { const characters = "0123456789"; return Array.from({ length }, () => characters[Math.floor(Math.random() * characters.length)]).join("") } randomString(length) { const characters = "abcdefghijklmnopqrstuvwxyz0123456789"; return Array.from({ length }, () => characters[Math.floor(Math.random() * characters.length)]).join("") } uuid() { return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c) { var r = (Math.random() * 16) | 0, v = c == "x" ? r : (r & 0x3) | 0x8; return v.toString(16) }) } time(t) { let s = { "M+": new Date().getMonth() + 1, "d+": new Date().getDate(), "H+": new Date().getHours(), "m+": new Date().getMinutes(), "s+": new Date().getSeconds(), "q+": Math.floor((new Date().getMonth() + 3) / 3), S: new Date().getMilliseconds(), }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (new Date().getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in s) { new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? s[e] : ("00" + s[e]).substr(("" + s[e]).length))) } return t } msg(title = t, subtitle = "", body = "", options) { const formatOptions = (options) => { if (!options) { return options } else if (typeof options === "string") { if (this.isQuanX()) { return { "open-url": options } } else { return undefined } } else if (typeof options === "object" && (options["open-url"] || options["media-url"])) { if (this.isQuanX()) { return options } else { return undefined } } else { return undefined } }; if (!this.isMute) { if (this.isQuanX()) { $notify(title, subtitle, body, formatOptions(options)) } } let logs = ["", "==============📣系统通知📣=============="]; logs.push(title); subtitle ? logs.push(subtitle) : ""; body ? logs.push(body) : ""; console.log(logs.join("\n")); this.logs = this.logs.concat(logs) } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, s) { const e = !this.isQuanX(); e ? this.log("", `\u2757\ufe0f${this.name},\u9519\u8bef!`, t.stack) : this.log("", `\u2757\ufe0f${this.name},\u9519\u8bef!`, t) } wait(t) { return new Promise((s) => setTimeout(s, t)) } done(t = {}) { const s = new Date().getTime(), e = (s - this.startTime) / 1e3; this.log("", `\ud83d\udd14${this.name},\u7ed3\u675f!\ud83d\udd5b ${e}\u79d2`); this.log(); if (this.isNode()) { process.exit(1) } if (this.isQuanX()) { $done(t) } } })(t, s) }
async function Request(options) {
if ($.isNode()) {
const axios = require("axios");
Request = async (options) => {
try {
return await axios.request(options);
} catch (error) {
//console.log(error.response.data)
return error && error.response ? error.response.data : "请求失败";
}
};
}
if ($.isQuanX()) {
Request = async (options) => {
try {
return await $task.fetch(options);
} catch (error) {
return error && error.error ? error.error : "请求失败";
}
};
}
return await Request(options);
}

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.08 13.21 @Date: 2024.06.08 13.21
@Description: 小猴工具小程序 @Description: 小猴工具小程序
------------------------------------------ ------------------------------------------

652
心喜小程序.js Normal file
View File

@@ -0,0 +1,652 @@
/**
* cron 9 9 * * * xx.js
* 变量名: xinxi
* 每天运行一次就行
* 报错是正常情况
* 变量值:api.xinc818.com 请求头中sso的值 多账户&或者换行
* scriptVersionNow = "0.0.1";
*/
const $ = new Env("心喜");
const notify = $.isNode() ? require('./sendNotify') : '';
let ckName = "xinxi";
let envSplitor = ["&", "\n"]; //多账号分隔符
let strSplitor = "#"; //多变量分隔符
let userIdx = 0;
let userList = [];
class Task {
constructor(str) {
this.index = ++userIdx;
this.ck = str.split(strSplitor)[0]; //单账号多变量分隔符
this.ckStatus = true;
this.userId = null
this.artList = []
this.goodsList = []
}
async main() {
await this.user_info();
if (this.ckStatus == true) {
await this.task_signin();
await this.task_lottery()
await this.task_share()
await this.task_goods()
await this.art_list()
if (this.artList.length > 0) {
await this.task_follow(this.artList[0])
}
await this.goods_list()
if (this.goodsList.length > 0) {
await this.task_like(this.goodsList[0])
}
}
}
async task_signin() {
try {
let result = await this.taskRequest("get", `https://api.xinc818.com/mini/sign/in?dailyTaskId=`)
//console.log(result);
if (result.code == 0) {
$.log(`✅账号[${this.index}] 签到状态【${result.data.flag}】获得积分【${result.data.integral}】🎉`)
} else {
console.log(`❌账号[${this.index}] 签到状态【false】`);
console.log(result);
}
} catch (e) {
console.log(e);
}
}
async user_info() {
try {
let result = await this.taskRequest("get", `https://api.xinc818.com/mini/user`)
//console.log(options);
console.log(result);
if (result.code == 0) {
$.log(`✅账号[${this.index}] 【${result.data.nickname}】积分【${result.data.integral}】🎉`)
this.userId = result.data.id
} else {
console.log(`❌账号[${this.index}] 用户查询【false】`);
console.log(result);
}
} catch (e) {
console.log(e);
}
}
//浏览30sAPI
async task_goods() {
try {
let result = await this.taskRequest("get", `https://api.xinc818.com/mini/dailyTask/browseGoods/22`)
//console.log(options);
console.log(result);
if (result.code == 0) {
if (result.data !== null) {
$.log(`✅账号[${this.index}] 完成浏览30s成功 获得【${result.data.singleReward}`)
} else {
console.log(`❌账号[${this.index}] 完成浏览30s任务失败`);
}
} else {
console.log(`❌账号[${this.index}] 完成浏览30s任务失败`);
console.log(result);
}
} catch (e) {
console.log(e);
}
}
//想要任务API
async task_like(id) {
console.log(`https://api.xinc818.com/mini/integralGoods/${id}?type=`)
try {
let goodsResult = await this.taskRequest("get", `https://api.xinc818.com/mini/integralGoods/${id}?type=`)
if (goodsResult.data) {
let likeResult = await this.taskRequest("post", `https://api.xinc818.com/mini/live/likeLiveItem`, { "isLike": true, "dailyTaskId": 20, "productId": Number(goodsResult.data.outerId) })
//console.log(options);
console.log(likeResult);
if (likeResult.code == 0) {
if (likeResult.data !== null) {
$.log(`✅账号[${this.index}] 完成点击想要任务成功 获得【${likeResult.data.singleReward}`)
} else {
console.log(`❌账号[${this.index}] 完成点击想要任务失败`);
}
} else {
console.log(`❌账号[${this.index}] 完成点击想要任务失败`);
console.log(likeResult);
}
}
} catch (e) {
console.log(e);
}
}
//关注用户API
async task_follow(pusherId) {
console.log(pusherId)
try {
let result = await this.taskRequest("post", `https://api.xinc818.com/mini/user/follow`, { "decision": true, "followUserId": pusherId })
//console.log(options);
console.log(result);
if (result.code == 0) {
if (result.data !== null) {
$.log(`✅账号[${this.index}] 完成关注用户任务成功 获得【${result.data.singleReward}`)
} else {
console.log(`❌账号[${this.index}] 完成关注用户任务失败`);
}
} else {
console.log(`❌账号[${this.index}] 完成关注用户任务失败`);
console.log(result);
}
} catch (e) {
console.log(e);
}
}
//抽奖API
async task_lottery() {
try {
let result = await this.taskRequest("post", `https://api.xinc818.com/mini/lottery/draw`, { "activity": 61, "batch": false, "isIntegral": false, "userId": Number(this.userId), "dailyTaskId": 9 })
//console.log(options);
console.log(result);
if (result.code == 0) {
if (result.data !== null) {
$.log(`✅账号[${this.index}] 完成抽奖成功 获得【${result.data.taskResult.singleReward}】积分 奖品【${result.data.lotteryResult.integral}`)
} else {
console.log(`❌账号[${this.index}] 完成抽奖失败`);
}
} else {
console.log(`❌账号[${this.index}] 完成抽奖失败`);
console.log(result);
}
} catch (e) {
console.log(e);
}
}
//分享API
async task_share() {
try {
let result = await this.taskRequest("get", `https://api.xinc818.com/mini/dailyTask/share`)
//console.log(options);
console.log(result);
if (result.code == 0) {
if (result.data !== null) {
$.log(`✅账号[${this.index}] 完成分享成功 获得【${result.data.singleReward}`)
} else {
console.log(`❌账号[${this.index}] 完成分享失败`);
}
} else {
console.log(`❌账号[${this.index}] 完成分享失败`);
console.log(result);
}
} catch (e) {
console.log(e);
}
}
//获取帖子列表API(包含用户和帖子)
async art_list() {
try {
let result = await this.taskRequest("get", `https://cdn-api.xinc818.com/mini/posts/sorts?sortType=COMMENT&pageNum=1&pageSize=10&groupClassId=0`)
//console.log(options);
console.log(result);
if (result.code == 0) {
if (result.data.list.length > 0) {
for (let i = 0; i < 2; i++)
this.artList.push(result.data.list[i].publisherId)
}
} else {
console.log(result);
}
} catch (e) {
console.log(e);
}
}
//获取商品API
async goods_list() {
try {
let result = await this.taskRequest("get", `https://cdn-api.xinc818.com/mini/integralGoods?orderField=sort&orderScheme=DESC&pageSize=10&pageNum=1`)
//console.log(options);
console.log(result);
if (result.code == 0) {
if (result.data.list.length > 0) {
for (let i = 0; i < 2; i++)
this.goodsList.push(result.data.list[i].id)
}
} else {
console.log(result);
}
} catch (e) {
console.log(e);
}
}
async taskRequest(method, url, body = "") {
//
let headers = {
//"Host": "api.xinc818.com",
"Connection": "keep-alive",
"charset": "utf-8",
"User-Agent": "Mozilla/5.0 (Linux; Android 10; MI 8 Lite Build/QKQ1.190910.002; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/116.0.0.0 Mobile Safari/537.36 XWEB/1160027 MMWEBSDK/20231002 MMWEBID/2585 MicroMessenger/8.0.43.2480(0x28002B51) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 MiniProgramEnv/android",
"content-type": "application/json",
"Accept-Encoding": "gzip,compress,br,deflate",
"sso": this.ck,
"Referer": "https://servicewechat.com/wx673f827a4c2c94fa/253/page-frame.html"
}
const reqeuestOptions = {
url: url,
method: method,
headers: headers
}
if (method !== "get") {
if (headers["Content-Type"] == "application/json") {
reqeuestOptions["body"] = JSON.stringify(body);
} else {
reqeuestOptions["body"] = body
}
}
let { body: result } = await $.httpRequest(reqeuestOptions)
return result
}
}
!(async () => {
if (!(await checkEnv())) return;
if (userList.length > 0) {
let taskall = [];
for (let user of userList) {
if (user.ckStatus) {
taskall.push(user.main());
}
}
await Promise.all(taskall);
}
await $.sendMsg($.logs.join("\n"))
})()
.catch((e) => console.log(e))
.finally(() => $.done());
//********************************************************
/**
* 变量检查与处理
* @returns
*/
async function checkEnv() {
let userCookie = ($.isNode() ? process.env[ckName] : $.getdata(ckName)) || "";
if (userCookie) {
let e = envSplitor[0];
for (let o of envSplitor)
if (userCookie.indexOf(o) > -1) {
e = o;
break;
}
for (let n of userCookie.split(e)) n && userList.push(new Task(n));
} else {
console.log(`未找到CK【${ckName}`);
return;
}
return console.log(`共找到${userList.length}个账号`), true; //true == !0
}
function Env(t, s) {
return new (class {
constructor(t, s) {
this.name = t;
this.data = null;
this.dataFile = "box.dat";
this.logs = [];
this.logSeparator = "\n";
this.startTime = new Date().getTime();
Object.assign(this, s);
this.log("", `\ud83d\udd14${this.name}, \u5f00\u59cb!`);
}
isNode() {
return "undefined" != typeof module && !!module.exports;
}
isQuanX() {
return "undefined" != typeof $task;
}
isSurge() {
return "undefined" != typeof $httpClient && "undefined" == typeof $loon;
}
isLoon() {
return "undefined" != typeof $loon;
}
loaddata() {
if (!this.isNode()) return {};
{
this.fs = this.fs ? this.fs : require("fs");
this.path = this.path ? this.path : require("path");
const t = this.path.resolve(this.dataFile),
s = this.path.resolve(process.cwd(), this.dataFile),
e = this.fs.existsSync(t),
i = !e && this.fs.existsSync(s);
if (!e && !i) return {};
{
const i = e ? t : s;
try {
return JSON.parse(this.fs.readFileSync(i));
} catch (t) {
return {};
}
}
}
}
writedata() {
if (this.isNode()) {
this.fs = this.fs ? this.fs : require("fs");
this.path = this.path ? this.path : require("path");
const t = this.path.resolve(this.dataFile),
s = this.path.resolve(process.cwd(), this.dataFile),
e = this.fs.existsSync(t),
i = !e && this.fs.existsSync(s),
o = JSON.stringify(this.data);
e ? this.writeFileSync(t, o) : i ? this.fs.writeFileSync(s, o) : this.fs.writeFileSync(t, o);
}
}
lodash_get(t, s, e) {
const i = s.replace(/\[(\d+)\]/g, ".$1").split(".");
let o = t;
for (const t of i) if (((o = Object(o)[t]), void 0 === o)) return e;
return o;
}
lodash_set(t, s, e) {
return Object(t) !== t
? t
: (Array.isArray(s) || (s = s.toString().match(/[^.[\]]+/g) || []),
(s
.slice(0, -1)
.reduce(
(t, e, i) =>
Object(t[e]) === t[e]
? t[e]
: (t[e] = Math.abs(s[i + 1]) >> 0 == +s[i + 1] ? [] : {}),
t
)[s[s.length - 1]] = e),
t);
}
getdata(t) {
let s = this.getval(t);
if (/^@/.test(t)) {
const [, e, i] = /^@(.*?)\.(.*?)$/.exec(t),
o = e ? this.getval(e) : "";
if (o)
try {
const t = JSON.parse(o);
s = t ? this.lodash_get(t, i, "") : s;
} catch (t) {
s = "";
}
}
return s;
}
setdata(t, s) {
let e = !1;
if (/^@/.test(s)) {
const [, i, o] = /^@(.*?)\.(.*?)$/.exec(s),
h = this.getval(i),
a = i ? ("null" === h ? null : h || "{}") : "{}";
try {
const s = JSON.parse(a);
this.lodash_set(s, o, t), (e = this.setval(JSON.stringify(s), i));
} catch (s) {
const h = {};
this.lodash_set(h, o, t), (e = this.setval(JSON.stringify(h), i));
}
} else e = this.setval(t, s);
return e;
}
getval(t) {
if (this.isSurge() || this.isLoon()) {
return $persistentStore.read(t);
} else if (this.isQuanX()) {
return $prefs.valueForKey(t);
} else if (this.isNode()) {
this.data = this.loaddata();
return this.data[t];
} else {
return this.data && this.data[t] || null;
}
}
setval(t, s) {
if (this.isSurge() || this.isLoon()) {
return $persistentStore.write(t, s);
} else if (this.isQuanX()) {
return $prefs.setValueForKey(t, s);
} else if (this.isNode()) {
this.data = this.loaddata();
this.data[s] = t;
this.writedata();
return true;
} else {
return this.data && this.data[s] || null;
}
}
initGotEnv(t) {
this.got = this.got ? this.got : require("got");
this.cktough = this.cktough ? this.cktough : require("tough-cookie");
this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar();
if (t) {
t.headers = t.headers ? t.headers : {};
if (typeof t.headers.Cookie === "undefined" && typeof t.cookieJar === "undefined") {
t.cookieJar = this.ckjar;
}
}
}
/**
* @param {Object} options
* @returns {String} 将 Object 对象 转换成 queryStr: key=val&name=senku
*/
queryStr(options) {
return Object.entries(options)
.map(([key, value]) => `${key}=${typeof value === 'object' ? JSON.stringify(value) : value}`)
.join('&');
}
//从url获取参数组成json
getURLParams(url) {
const params = {};
const queryString = url.split('?')[1];
if (queryString) {
const paramPairs = queryString.split('&');
paramPairs.forEach(pair => {
const [key, value] = pair.split('=');
params[key] = value;
});
}
return params;
}
isJSONString(str) {
try {
var obj = JSON.parse(str);
if (typeof obj == 'object' && obj) {
return true;
} else {
return false;
}
} catch (e) {
return false;
}
}
isJson(obj) {
var isjson = typeof (obj) == "object" && Object.prototype.toString.call(obj).toLowerCase() == "[object object]" && !obj.length;
return isjson;
}
async sendMsg(message) {
if (!message) return;
if ($.isNode()) {
await notify.sendNotify($.name, message)
} else {
$.msg($.name, '', message)
}
}
async httpRequest(options) {
let t = {
...options
};
if (!t.headers) {
t.headers = {}
}
if (t.params) {
t.url += '?' + this.queryStr(t.params);
}
t.method = t.method.toLowerCase();
if (t.method === 'get') {
delete t.headers['Content-Type'];
delete t.headers['Content-Length'];
delete t.headers['content-type'];
delete t.headers['content-length'];
delete t["body"]
}
if (t.method === 'post') {
let ContentType;
if (!t.body) {
t.body = ""
} else {
if (typeof t.body == "string") {
if (this.isJSONString(t.body)) {
ContentType = 'application/json'
} else {
ContentType = 'application/x-www-form-urlencoded'
}
} else if (this.isJson(t.body)) {
t.body = JSON.stringify(t.body);
ContentType = 'application/json';
}
}
if (!t.headers['Content-Type'] || !t.headers['content-type']) {
t.headers['Content-Type'] = ContentType;
}
delete t.headers['Content-Length'];
}
if (this.isNode()) {
this.initGotEnv(t);
let httpResult = await this.got(t);
if (this.isJSONString(httpResult.body)) {
httpResult.body = JSON.parse(httpResult.body)
}
return httpResult;
}
if (this.isQuanX()) {
t.method = t.method.toUpperCase()
return new Promise((resolve, reject) => {
$task.fetch(t).then(response => {
if (this.isJSONString(response.body)) {
response.body = JSON.parse(response.body)
}
resolve(response)
})
})
}
}
randomNumber(length) {
const characters = '0123456789';
return Array.from({ length }, () => characters[Math.floor(Math.random() * characters.length)]).join('');
}
randomString(length) {
const characters = 'abcdefghijklmnopqrstuvwxyz0123456789';
return Array.from({ length }, () => characters[Math.floor(Math.random() * characters.length)]).join('');
}
timeStamp() {
return new Date().getTime()
}
uuid() {
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
var r = Math.random() * 16 | 0,
v = c == 'x' ? r : (r & 0x3 | 0x8);
return v.toString(16);
});
}
time(t) {
let s = {
"M+": new Date().getMonth() + 1,
"d+": new Date().getDate(),
"H+": new Date().getHours(),
"m+": new Date().getMinutes(),
"s+": new Date().getSeconds(),
"q+": Math.floor((new Date().getMonth() + 3) / 3),
S: new Date().getMilliseconds(),
};
/(y+)/.test(t) &&
(t = t.replace(
RegExp.$1,
(new Date().getFullYear() + "").substr(4 - RegExp.$1.length)
));
for (let e in s)
new RegExp("(" + e + ")").test(t) &&
(t = t.replace(
RegExp.$1,
1 == RegExp.$1.length
? s[e]
: ("00" + s[e]).substr(("" + s[e]).length)
));
return t;
}
msg(s = t, e = "", i = "", o) {
const h = (t) =>
!t || (!this.isLoon() && this.isSurge())
? t
: "string" == typeof t
? this.isLoon()
? t
: this.isQuanX()
? { "open-url": t }
: void 0
: "object" == typeof t && (t["open-url"] || t["media-url"])
? this.isLoon()
? t["open-url"]
: this.isQuanX()
? t
: void 0
: void 0;
this.isMute ||
(this.isSurge() || this.isLoon()
? $notification.post(s, e, i, h(o))
: this.isQuanX() && $notify(s, e, i, h(o)));
let logs = ['', '==============📣系统通知📣=============='];
logs.push(t);
e ? logs.push(e) : '';
i ? logs.push(i) : '';
console.log(logs.join('\n'));
this.logs = this.logs.concat(logs);
}
log(...t) {
t.length > 0 && (this.logs = [...this.logs, ...t]),
console.log(t.join(this.logSeparator));
}
logErr(t, s) {
const e = !this.isSurge() && !this.isQuanX() && !this.isLoon();
e
? this.log("", `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t.stack)
: this.log("", `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t);
}
wait(t) {
return new Promise((s) => setTimeout(s, t));
}
done(t = {}) {
const s = new Date().getTime(),
e = (s - this.startTime) / 1e3;
this.log(
"",
`\ud83d\udd14${this.name}, \u7ed3\u675f! \ud83d\udd5b ${e} \u79d2`
)
this.log()
if (this.isNode()) {
process.exit(1)
}
if (this.isQuanX()) {
$done(t)
}
}
})(t, s);
}

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.09 10.04 @Date: 2024.06.09 10.04
@Description: 波司登小程序 每日签到 @Description: 波司登小程序 每日签到
------------------------------------------ ------------------------------------------

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.08 10.25 @Date: 2024.06.08 10.25
@Description: 爱玛会员俱乐部 小程序 @Description: 爱玛会员俱乐部 小程序
------------------------------------------ ------------------------------------------

View File

@@ -1,6 +1,6 @@
/* /*
------------------------------------------ ------------------------------------------
@Author: smallfawn 860562056 @Author: smallfawn
@Date: 2024.06.11 12:44 @Date: 2024.06.11 12:44
@Description: 瑷尔博士官方云商城小程序 @Description: 瑷尔博士官方云商城小程序
------------------------------------------ ------------------------------------------