@yeci226/hoyoapi
Version:
HoYoAPI is an unofficial API Wrapper library developed to facilitate communication with the official HoYoLab API.
76 lines (75 loc) • 3.45 kB
JavaScript
;
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var auth_helper_exports = {};
__export(auth_helper_exports, {
buildAigisHeader: () => buildAigisHeader,
encryptCredentials: () => encryptCredentials,
generateAppLoginDS: () => generateAppLoginDS
});
module.exports = __toCommonJS(auth_helper_exports);
var crypto = __toESM(require("crypto"));
const LOGIN_KEY_TYPE_1 = "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4PMS2JVMwBsOIrYWRluY\nwEiFZL7Aphtm9z5Eu/anzJ09nB00uhW+ScrDWFECPwpQto/GlOJYCUwVM/raQpAj\n/xvcjK5tNVzzK94mhk+j9RiQ+aWHaTXmOgurhxSp3YbwlRDvOgcq5yPiTz0+kSeK\nZJcGeJ95bvJ+hJ/UMP0Zx2qB5PElZmiKvfiNqVUk8A8oxLJdBB5eCpqWV6CUqDKQ\nKSQP4sM0mZvQ1Sr4UcACVcYgYnCbTZMWhJTWkrNXqI8TMomekgny3y+d6NX/cFa6\n6jozFIF4HCX5aW8bp8C8vq2tFvFbleQ/Q3CU56EWWKMrOcpmFtRmC18s9biZBVR/\n8QIDAQAB\n-----END PUBLIC KEY-----";
function encryptCredentials(text) {
const buffer = Buffer.from(text, "utf8");
const encrypted = crypto.publicEncrypt(
{
key: LOGIN_KEY_TYPE_1,
padding: crypto.constants.RSA_PKCS1_PADDING
},
buffer
);
return encrypted.toString("base64");
}
function generateAppLoginDS(body) {
const salt = "IZPgfb0dRPtBeLuFkdDznSZ6f4wWt6y2";
const t = Math.floor(Date.now() / 1e3);
const chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
let r = "";
for (let i = 0; i < 6; i++) {
r += chars.charAt(Math.floor(Math.random() * chars.length));
}
const b = JSON.stringify(body);
const rawStr = "salt=".concat(salt, "&t=").concat(t, "&r=").concat(r, "&b=").concat(b, "&q=");
const hash = crypto.createHash("md5").update(rawStr).digest("hex");
return "".concat(t, ",").concat(r, ",").concat(hash);
}
function buildAigisHeader(sessionId, mmtData, geetestResult) {
const finalData = {
...mmtData,
...geetestResult
};
const b64Data = Buffer.from(JSON.stringify(finalData)).toString("base64");
return "".concat(sessionId, ";").concat(b64Data);
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
buildAigisHeader,
encryptCredentials,
generateAppLoginDS
});