UNPKG

gravitlauncher-remotecontrol-js

Version:
71 lines 13.6 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.isException = exports.getSuccess = exports.isError = exports.request = void 0; const node_https_1 = require("node:https"); const node_http_1 = require("node:http"); exports.default = request; function request(params, extractData) { return __awaiter(this, void 0, void 0, function* () { const url = new URL(params.rawUrl); if (url.pathname == '/') url.pathname = '/webapi/remotecontrol/command'; url.searchParams.append('token', params.token); url.searchParams.append('command', params.command); url.searchParams.append('log', `${!!params.log}`); const get = url.protocol === 'https:' ? node_https_1.get : url.protocol === 'http:' ? node_http_1.get : null; const req = new Promise((resolve, reject) => { get(url, response => { response.on('error', reject); response.setEncoding('utf-8'); response.on('data', dataChunk => resolve(Object.freeze(JSON.parse(dataChunk.toString())))); response.on('end', () => reject('No data!')); }) .on('error', reject); }); if (!extractData) return req; const lines = []; let data = ''; const extractedData = req.then(apiResponse => { var _a; if ((0, exports.isError)(apiResponse)) return extractData.onError(apiResponse.error); if ((0, exports.isException)(apiResponse)) return extractData.onException(apiResponse.data.exception, apiResponse.data.lines); apiResponse = (0, exports.getSuccess)(apiResponse); (_a = apiResponse.data.lines) === null || _a === void 0 ? void 0 : _a.forEach(line => { var _a; if ((_a = extractData.filter) === null || _a === void 0 ? void 0 : _a[line.level.toLowerCase()]) return; if (extractData.removeColors) line.message = line.message.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, ''); lines.push(line); data += `[${line.level}${' '.repeat(5 - line.level.length)}] ${line.message}\n`; }); return { lines, data }; }); if (!(yield extractedData)) throw 'Exception or error is resolved.'; return extractedData; }); } exports.request = request; const isError = (response) => 'error' in response; exports.isError = isError; const getSuccess = (response) => (!(0, exports.isError)(response) && !(0, exports.isException)(response)) ? response : null; exports.getSuccess = getSuccess; const isException = (response) => 'data' in response && 'success' in response.data && !response.data.success; exports.isException = isException; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.js","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":"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","sourcesContent":["import { get as httpsGet } from 'node:https';\nimport { get as httpGet } from 'node:http';\n\nexport interface RequestParams<LogEnabled extends boolean> {\n  rawUrl: string\n  token: string\n  command: string\n  log?: LogEnabled\n}\n\nexport interface ExtractDataOptions<LogEnabled extends boolean> {\n  onException: (exception: string, lines: Line<LogEnabled>[]) => void\n  onError: (error: ApiErrorResponse['error']) => void\n  removeColors?: true\n  filter?: {\n    dev?: true\n    debug?: true\n    info?: true\n    error?: true\n  }\n}\n\nexport type ExtractedData<LogEnabled extends boolean> = { lines: Line<LogEnabled>[], data: string }\n\nexport default request;\nexport async function request<L extends boolean = true >(params: RequestParams<L>, extractData: ExtractDataOptions<L>): Promise<ExtractedData<L>>\nexport async function request<L extends boolean = false>(params: RequestParams<L>, extractData: ExtractDataOptions<L>): Promise<ExtractedData<L>>\nexport async function request<L extends boolean = true >(params: RequestParams<L>, extractData?:             undefined): Promise<ApiResponse<L>>\nexport async function request<L extends boolean = false>(params: RequestParams<L>, extractData?:             undefined): Promise<ApiResponse<L>>\n\nexport async function request<L extends boolean>(params: RequestParams<L>, extractData?: ExtractDataOptions<L>) {\n  const url = new URL(params.rawUrl);\n  if (url.pathname == '/') url.pathname = '/webapi/remotecontrol/command';\n\n  url.searchParams.append('token', params.token);\n  url.searchParams.append('command', params.command);\n  url.searchParams.append('log', `${!!params.log}`);\n\n  const get: typeof httpGet =\n    url.protocol === 'https:'\n      ? httpsGet\n      : url.protocol === 'http:'\n        ? httpGet : null;\n\n  const req = new Promise<ApiResponse<L>>((resolve, reject) => {\n    get(url, response => {\n      response.on('error', reject);\n\n      response.setEncoding('utf-8');\n      response.on('data', dataChunk => resolve(Object.freeze(JSON.parse(dataChunk.toString())))); // That's will work perfect, just trust me\n\n      response.on('end', () => reject('No data!'));\n    })\n    .on('error', reject);\n  });\n\n  if (!extractData) return req;\n\n  const lines: Line<L>[] = [];\n  let data = '';\n\n  const extractedData = req.then(apiResponse => {\n    if (isError(apiResponse)) return extractData.onError(apiResponse.error);\n    if (isException(apiResponse)) return extractData.onException(apiResponse.data.exception, apiResponse.data.lines);\n\n    apiResponse = getSuccess(apiResponse);\n    apiResponse.data.lines?.forEach(line => {\n      if (extractData.filter?.[line.level.toLowerCase()]) return;\n      if (extractData.removeColors) line.message = line.message.replace(/[\\u001b\\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '');\n      lines.push(line);\n      data += `[${line.level}${' '.repeat(5 - line.level.length)}] ${line.message}\\n`;\n    });\n\n    return { lines, data } as ExtractedData<L>;\n  });\n\n  if (!await extractedData) throw 'Exception or error is resolved.';\n\n  return extractedData;\n}\n\nexport const isError = (response: ApiResponse<boolean>): response is ApiErrorResponse => 'error' in response;\nexport const getSuccess = <LogEnabled extends boolean>(response: ApiResponse<LogEnabled>): ApiSuccessResponse<LogEnabled> => (!isError(response) && !isException(response)) ? response as ApiSuccessResponse<LogEnabled> : null;\nexport const isException = <LogEnabled extends boolean>(response: ApiResponse<LogEnabled>): response is ApiExceptionResponse<LogEnabled> => 'data' in response && 'success' in response.data && !response.data.success;\n\nexport type ApiResponse<LogEnabled extends boolean> = Readonly<ApiSuccessResponse<LogEnabled> | ApiExceptionResponse<LogEnabled> | ApiErrorResponse>;\n\nexport type Line<LogEnabled extends boolean> = LogEnabled extends true ? { level: 'DEV' | 'DEBUG' | 'INFO' | 'ERROR', message: string } : undefined;\nexport interface ApiSuccessResponse<LogEnabled extends boolean> {\n  data: {\n    lines: Line<LogEnabled>[]\n    success: true\n  }\n}\nexport interface ApiExceptionResponse<LogEnabled extends boolean> {\n  data: {\n    lines: Line<LogEnabled>[]\n    exception: string\n    success: false\n  }\n}\nexport interface ApiErrorResponse {\n  error: 'RemoteControl disabled'             |\n    'You can used only GET and POST requests' |\n    'Missing required parameter: token'       |\n    'Token not valid'                         |\n    'Missing required parameter: command'     |\n    'You cannot execute this command'\n}\n"]}