mirror of
https://github.com/smallfawn/QLScriptPublic.git
synced 2025-12-17 15:25:10 +08:00
Create ppmt.js
This commit is contained in:
376
ppmt.js
Normal file
376
ppmt.js
Normal file
@@ -0,0 +1,376 @@
|
|||||||
|
/*
|
||||||
|
------------------------------------------
|
||||||
|
@Author: sm
|
||||||
|
@Date: 2024.06.07 19:15
|
||||||
|
@Description: 微信小程序泡泡玛特
|
||||||
|
------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
[Script]
|
||||||
|
http-response ^https:\/\/mxsa\.mxbc\.net\/api\/v1\/customer\/info script-path=https://gist.githubusercontent.com/Sliverkiss/865c82e42a5730bb696f6700ebb94cee/raw/mxbc.js, requires-body=true, timeout=60, tag=蜜雪冰城获取token
|
||||||
|
|
||||||
|
[MITM]
|
||||||
|
hostname = mxsa.mxbc.net
|
||||||
|
|
||||||
|
⚠️【免责声明】
|
||||||
|
------------------------------------------
|
||||||
|
1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。
|
||||||
|
2、由于此脚本仅用于学习研究,您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。
|
||||||
|
3、请勿将此脚本用于任何商业或非法目的,若违反规定请自行对此负责。
|
||||||
|
4、此脚本涉及应用与本人无关,本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。
|
||||||
|
5、本人对任何脚本引发的问题概不负责,包括但不限于由脚本错误引起的任何损失和损害。
|
||||||
|
6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利,应及时通知并提供身份证明,所有权证明,我们将在收到认证文件确认后删除此脚本。
|
||||||
|
7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本,即视为您已接受此免责声明。
|
||||||
|
*/
|
||||||
|
|
||||||
|
const $ = new Env("微信小程序泡泡玛特");
|
||||||
|
let ckName = `paopaomate`
|
||||||
|
process.env[ckName] = `88528490#oZdQ349xzm92VdabAtMekA5vPPTw`
|
||||||
|
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) throw new Error(`没有找到【${ckName}】`);
|
||||||
|
let index = 0;
|
||||||
|
let strSplitor = "#";
|
||||||
|
|
||||||
|
for (let user of userCookie) {
|
||||||
|
$.log(`\n🚀 user:${index || ++index} start work\n`)
|
||||||
|
let id = user.split(strSplitor)[0]
|
||||||
|
let openid = user.split(strSplitor)[1]
|
||||||
|
let ckStatus = true
|
||||||
|
ckStatus = await UserInfo(id, openid)
|
||||||
|
if (ckStatus) {
|
||||||
|
await SignIn(openid)
|
||||||
|
|
||||||
|
}
|
||||||
|
X
|
||||||
|
}
|
||||||
|
|
||||||
|
await $.sendMsg($.logs.join("\n"));
|
||||||
|
})().catch((e) => console.log(e)).finally(() => $.done());
|
||||||
|
function getSign(t, e, n) {
|
||||||
|
function md5(data) {
|
||||||
|
const crypto = require('crypto');
|
||||||
|
return crypto.createHash('md5').update(data).digest('hex');
|
||||||
|
}
|
||||||
|
function d(t, e, n) {
|
||||||
|
var o = {};
|
||||||
|
Object.keys(t).sort().forEach((function (n) {
|
||||||
|
o[n] = "POST" === e ? t[n] : t[n].toString()
|
||||||
|
}
|
||||||
|
)),
|
||||||
|
o.version = "5.0.34";
|
||||||
|
var s = (new Date).getTime().toString()
|
||||||
|
, c = JSON.stringify(o) + "PopMartminiApp1117" + s
|
||||||
|
, u = md5(c);
|
||||||
|
return t.sign = n ? md5(i.Base64.encode(u + "PopMartminiApp0314")) : u,
|
||||||
|
t.time = s,
|
||||||
|
t.version = "5.0.34",
|
||||||
|
t
|
||||||
|
}
|
||||||
|
|
||||||
|
return d(t, e, n)
|
||||||
|
}
|
||||||
|
|
||||||
|
async function SignIn(openid) {
|
||||||
|
let { sign: sign, time: time, version: version } = getSign({
|
||||||
|
openid: openid
|
||||||
|
}, 'GET', true)
|
||||||
|
let { data: result } = await Request({
|
||||||
|
method: 'GET',
|
||||||
|
url: 'https://popvip.paquapp.com/miniapp/v2/sign_in/everySignDay/?openid=' + openid + '&sign=' + sign + '&time=' + time + '&version=' + version,
|
||||||
|
headers: {
|
||||||
|
'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/122.0.6261.120 Mobile Safari/537.36 XWEB/1220067 MMWEBSDK/20240404 MMWEBID/8150 MicroMessenger/8.0.49.2600(0x28003156) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 MiniProgramEnv/android',
|
||||||
|
'Accept-Encoding': 'gzip,compress,br,deflate',
|
||||||
|
'identity_code': openid,
|
||||||
|
'charset': 'utf-8',
|
||||||
|
'content-type': 'application/x-www-form-urlencoded;charset=utf-8',
|
||||||
|
'Referer': 'https://servicewechat.com/wx9627eb7f4b1c69d5/638/page-frame.html'
|
||||||
|
}
|
||||||
|
})
|
||||||
|
$.log(result)
|
||||||
|
}
|
||||||
|
async function UserInfo(id, openid) {
|
||||||
|
let { data: result } = await Request({
|
||||||
|
method: 'GET',
|
||||||
|
url: 'https://popvip.paquapp.com/miniapp/v2/wechat/getUserInfo/?user_id=' + id + '&sign=bd11fa3de1584216a19e810746315059&time=1717760159176&version=5.0.34',
|
||||||
|
headers: {
|
||||||
|
'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/122.0.6261.120 Mobile Safari/537.36 XWEB/1220067 MMWEBSDK/20240404 MMWEBID/8150 MicroMessenger/8.0.49.2600(0x28003156) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 MiniProgramEnv/android',
|
||||||
|
'Accept-Encoding': 'gzip,compress,br,deflate',
|
||||||
|
'identity_code': openid,
|
||||||
|
'charset': 'utf-8',
|
||||||
|
'content-type': 'application/x-www-form-urlencoded;charset=utf-8',
|
||||||
|
'Referer': 'https://servicewechat.com/wx9627eb7f4b1c69d5/638/page-frame.html'
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return code == 1 ? $.log(`${result.data.nickname} 积分【${result.data.points}】`) : false
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkEnv(userCookie) {
|
||||||
|
if (!userCookie) {
|
||||||
|
console.log(`未找到CK【${ckName}】`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const envSplitor = ["&", "\n"];
|
||||||
|
let userList = userCookie.split(envSplitor.find(o => userCookie.includes(o)) || "&").filter(n => n);
|
||||||
|
console.log(`共找到${userList.length}个账号`);
|
||||||
|
return userList;
|
||||||
|
}
|
||||||
|
//Env Api =============================
|
||||||
|
/*
|
||||||
|
* @modifyAuthor @smallfawn
|
||||||
|
* @modifyTime 2024-05-01
|
||||||
|
* @modifyInfo 抽离操作文件的函数
|
||||||
|
*/
|
||||||
|
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) {
|
||||||
|
throw error && error.error ? error.error : "请求失败";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
if ($.isQuanX()) {
|
||||||
|
Request = async (options) => {
|
||||||
|
try {
|
||||||
|
return await $task.fetch(options);
|
||||||
|
} catch (error) {
|
||||||
|
throw error && error.error ? error.error : "请求失败";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return await Request(options)
|
||||||
|
}
|
||||||
|
|
||||||
|
function Bucket() {
|
||||||
|
return new (class {
|
||||||
|
constructor(fileName) {
|
||||||
|
this.fileName = fileName;
|
||||||
|
this.ensureFileExists();
|
||||||
|
this.data = this.readFile();
|
||||||
|
}
|
||||||
|
ensureFileExists() {
|
||||||
|
this.fs ? this.fs : (this.fs = require("fs"));
|
||||||
|
this.path ? this.path : (this.path = require("path"));
|
||||||
|
this.filePath = this.path.join(__dirname, this.fileName);
|
||||||
|
if (!this.fs.existsSync(this.filePath)) {
|
||||||
|
this.fs.writeFileSync(this.filePath, "{}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
readFile() {
|
||||||
|
try {
|
||||||
|
const data = this.fs.readFileSync(this.filePath, "utf-8");
|
||||||
|
return JSON.parse(data);
|
||||||
|
} catch (error) {
|
||||||
|
console.error(`Error reading file:${error}`);
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
writeFile() {
|
||||||
|
try {
|
||||||
|
this.fs.writeFileSync(
|
||||||
|
this.filePath,
|
||||||
|
JSON.stringify(this.data, null, 2)
|
||||||
|
);
|
||||||
|
} catch (error) { }
|
||||||
|
}
|
||||||
|
set(key, value) {
|
||||||
|
this.data[key] = value;
|
||||||
|
this.writeFile();
|
||||||
|
}
|
||||||
|
get(key) {
|
||||||
|
return this.data[key];
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user