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