@crowdin/app-project-module
Version:
Module that generates for you all common endpoints for serving standalone Crowdin App
50 lines (49 loc) • 2.53 kB
JavaScript
;
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.CONTEXT_WINDOW_LIMIT = void 0;
const util_1 = require("../../../util");
const logger_1 = require("../../../util/logger");
const util_2 = require("../util");
exports.CONTEXT_WINDOW_LIMIT = 4096;
function handle(aiProvider) {
return (0, util_1.runAsyncWrapper)((req, res) => __awaiter(this, void 0, void 0, function* () {
try {
const modelList = yield aiProvider.getModelsList({
client: req.crowdinApiClient,
context: req.crowdinContext,
});
const data = modelList.map((model) => {
var _a, _b, _c, _d, _e, _f;
return ({
id: model.id,
supportsJsonMode: (_a = model.supportsJsonMode) !== null && _a !== void 0 ? _a : false,
supportsFunctionCalling: (_b = model.supportsFunctionCalling) !== null && _b !== void 0 ? _b : false,
supportsStreaming: (_c = model.supportsStreaming) !== null && _c !== void 0 ? _c : false,
supportsVision: (_d = model.supportsVision) !== null && _d !== void 0 ? _d : false,
contextWindowLimit: (_e = model.contextWindowLimit) !== null && _e !== void 0 ? _e : exports.CONTEXT_WINDOW_LIMIT,
outputLimit: (_f = model.outputLimit) !== null && _f !== void 0 ? _f : exports.CONTEXT_WINDOW_LIMIT,
});
});
res.send({ data });
}
catch (e) {
if (req.logError) {
req.logError(e);
}
if ((0, util_2.isRateLimitError)(e)) {
res.status(429);
}
res.send({ error: { message: (0, logger_1.getErrorMessage)(e) } });
}
}));
}
exports.default = handle;