UNPKG

osu-api-extended

Version:

Advanced osu! api wrapper for v1 and v2, with extra stuff

100 lines (99 loc) 4.25 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.scores_list = void 0; const request_1 = require("../../utility/request"); const handleErrors_1 = require("../../utility/handleErrors"); const scores_list = (params, addons) => __awaiter(void 0, void 0, void 0, function* () { const object = {}; let url = 'https://osu.ppy.sh/api/v2'; let method = 'GET'; switch (params.type) { case 'leaderboard': if (params.beatmap_id == null) { return (0, handleErrors_1.handleErrors)(`Specify beatmap id`); } ; url += `/beatmaps/${params.beatmap_id}/scores`; object['type'] = params.leaderboard_type; object['mode'] = params.mode; object['mods[]'] = params.mods; break; case 'beatmap_best': if (params.beatmap_id == null) { return (0, handleErrors_1.handleErrors)(`Specify beatmap id`); } ; if (params.user_id == null) { return (0, handleErrors_1.handleErrors)(`Specify user id`); } ; url += `/beatmaps/${params.beatmap_id}/scores/users/${params.user_id}`; object['mode'] = params.mode; object['mods[]'] = params.mods; break; case 'beatmap_all': if (params.beatmap_id == null) { return (0, handleErrors_1.handleErrors)(`Specify beatmap id`); } ; if (params.user_id == null) { return (0, handleErrors_1.handleErrors)(`Specify user id`); } ; url += `/beatmaps/${params.beatmap_id}/scores/users/${params.user_id}/all`; object['mode'] = params.mode; break; case 'user_best': case 'user_firsts': case 'user_recent': case 'user_pinned': if (params.user_id == null) { return (0, handleErrors_1.handleErrors)(`Specify user id`); } ; url += `/users/${params.user_id}/scores/${params.type.replace('user_', '')}`; object['mode'] = params.mode; object['limit'] = params.limit; object['offset'] = params.offset; object['include_fails'] = params.include_fails == true ? 1 : params.include_fails == false ? 0 : undefined; break; case 'solo_scores': if (params.beatmap_id == null) { return (0, handleErrors_1.handleErrors)(`Specify beatmap id`); } ; url += `/beatmaps/${params.beatmap_id}/solo-scores`; object['type'] = params.leaderboard_type; object['mode'] = params.mode; object['mods[]'] = params.mods; break; default: return (0, handleErrors_1.handleErrors)(`Unsupported type: ${params.type}`); } ; const data = yield (0, request_1.request)(url, { method: method, params: object, addons, }); if (data.error) return (0, handleErrors_1.handleErrors)(data.error); if (['leaderboard', 'beatmap_all'].includes(params.type)) { data.scores.forEach((r, index) => r.index = index); return data.scores; } ; if (params.type != 'beatmap_best') data.forEach((r, index) => r.index = index); return data; }); exports.scores_list = scores_list;