UNPKG

@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
"use strict"; 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 });