UNPKG

@crowdin/app-project-module

Version:

Module that generates for you all common endpoints for serving standalone Crowdin App

93 lines (92 loc) 4.33 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 }); const types_1 = require("../util/types"); const util_1 = require("../../../util"); const defaults_1 = require("../util/defaults"); const job_1 = require("../util/job"); const logger_1 = require("../../../util/logger"); const files_1 = require("../util/files"); function handle(config, integration) { return (0, util_1.runAsyncWrapper)((req, res) => __awaiter(this, void 0, void 0, function* () { var _a, _b, _c; req.logInfo('Updating integration data'); const client = req.crowdinApiClient; const projectId = req.crowdinContext.jwtPayload.context.project_id; const forcePushTranslations = ((_a = req.query) === null || _a === void 0 ? void 0 : _a.forcePushTranslations) === 'true' || !!((_b = req.body) === null || _b === void 0 ? void 0 : _b.forcePushTranslations); const rootFolder = yield (0, defaults_1.getRootFolder)(config, integration, req.crowdinApiClient, projectId); if (rootFolder) { req.logInfo(`Updating integration data for crowding root folder ${rootFolder.id}`); } if (req.isApiCall && !req.body.files) { return res.status(400).json({ error: { message: 'Missing required parameter: files', }, }); } // A request via API has a different structure if (((_c = config.api) === null || _c === void 0 ? void 0 : _c.default) && req.body.files) { req.body = req.body.files; } let payload = req.body; if (integration.excludedTargetLanguages) { let options = {}; if (rootFolder) { options = { directoryId: rootFolder.id, recursion: 'true', }; } const files = (yield client.sourceFilesApi.withFetchAll().listProjectFiles(projectId, options)).data.map((d) => d.data); payload = (0, files_1.filterLanguages)(payload, files); } yield (0, job_1.runAsJob)({ integrationId: req.crowdinContext.clientId, crowdinId: req.crowdinContext.crowdinId, type: types_1.JobType.UPDATE_TO_INTEGRATION, title: 'Sync files to ' + config.name, payload, res, projectId, client, jobType: types_1.JobClientType.MANUAL, jobStoreType: integration.jobStoreType, jobCallback: (job) => __awaiter(this, void 0, void 0, function* () { const result = yield integration.updateIntegration({ projectId, client, credentials: req.integrationCredentials, request: payload, rootFolder, appSettings: req.integrationSettings, job, }); let message; if ((0, files_1.isExtendedResultType)(result)) { message = result.message; } return { message }; }), onError: (e) => __awaiter(this, void 0, void 0, function* () { yield (0, logger_1.handleUserError)({ action: 'Sync files to External Service', error: e, crowdinId: req.crowdinContext.crowdinId, clientId: req.crowdinContext.clientId, }); throw e; }), forcePushTranslations, }); })); } exports.default = handle;