feat: migrate help utils to v3 api

This commit is contained in:
Cori Hudson 2022-10-05 18:19:44 -04:00
parent 50ce3a1772
commit db7a2a4ca0
2 changed files with 39 additions and 27 deletions

View file

@ -103,6 +103,35 @@ const txResources = async function (project) {
return slugs; return slugs;
}; };
/**
* @param {string} project - project slug (for example)
* @returns {object[]} - array of resource objects
*/
const txResourcesObjects = async function (project) {
const resources = await transifexApi.Resource.filter({
project: `o:${ORG_NAME}:p:${project}`
});
await resources.fetch();
return resources.data;
};
/**
* Gets available languages for a project
* @param {string} slug - project slug (for example, "scratch-editor")
* @returns {Promise<string[]>} - list of language codes
*/
const txAvailableLanguages = async function (slug) {
const project = await transifexApi.Project.get({
organization: `o:${ORG_NAME}`,
slug: slug
});
const languages = await project.fetch('languages');
return languages.data.map(l => l.code);
};
/** /**
* Uploads English source strings to a resource in transifex * Uploads English source strings to a resource in transifex
* @param {string} project - project slug (for example, "scratch-editor") * @param {string} project - project slug (for example, "scratch-editor")
@ -160,4 +189,4 @@ const txCreateResource = async function (project, {slug, name, i18nType, sourceS
} }
}; };
module.exports = {txPull, txPush, txResources, txCreateResource}; module.exports = {txPull, txPush, txResources, txResourcesObjects, txCreateResource, txAvailableLanguages};

View file

@ -5,19 +5,14 @@
* Helper functions for syncing Freshdesk knowledge base articles with Transifex * Helper functions for syncing Freshdesk knowledge base articles with Transifex
*/ */
const transifex = require('transifex');
const FreshdeskApi = require('./freshdesk-api.js'); const FreshdeskApi = require('./freshdesk-api.js');
const util = require('util');
const fs = require('fs'); const fs = require('fs');
const fsPromises = fs.promises; const fsPromises = fs.promises;
const mkdirp = require('mkdirp'); const mkdirp = require('mkdirp');
const {txPull, txResourcesObjects, txAvailableLanguages} = require('../lib/transifex.js');
const FD = new FreshdeskApi('https://mitscratch.freshdesk.com', process.env.FRESHDESK_TOKEN); const FD = new FreshdeskApi('https://mitscratch.freshdesk.com', process.env.FRESHDESK_TOKEN);
const TX_PROJECT = 'scratch-help'; const TX_PROJECT = 'scratch-help';
const TX = new transifex({
project_slug: TX_PROJECT,
credential: 'api:' + process.env.TX_TOKEN
});
const freshdeskLocale = locale => { const freshdeskLocale = locale => {
// map between Transifex locale and Freshdesk. Two letter codes are usually fine // map between Transifex locale and Freshdesk. Two letter codes are usually fine
@ -38,10 +33,6 @@ const freshdeskLocale = locale => {
return localeMap[locale] || locale; return localeMap[locale] || locale;
}; };
// Promisify Transifex async/callbacks to make them easier to use`
const getResources = util.promisify(TX.resourcesSetMethod.bind(TX));
const getResourceInfo = util.promisify(TX.resourcesInstanceMethods.bind(TX));
const getTranslation = util.promisify(TX.translationInstanceMethod.bind(TX));
/** /**
* Pull metadata from Transifex for the scratch-help project * Pull metadata from Transifex for the scratch-help project
@ -51,17 +42,13 @@ const getTranslation = util.promisify(TX.translationInstanceMethod.bind(TX));
* names: array of tx resources corresponding to the Freshdesk metadata * names: array of tx resources corresponding to the Freshdesk metadata
*/ */
exports.getInputs = async () => { exports.getInputs = async () => {
const resources = await getResources(TX_PROJECT); const resources = await txResourcesObjects(TX_PROJECT);
const languages = await txAvailableLanguages(TX_PROJECT);
// there are three types of resources differentiated by the file type // there are three types of resources differentiated by the file type
const folders = resources.filter(resource => resource.i18n_type === 'STRUCTURED_JSON'); const folders = resources.filter(resource => resource.i18n_type === 'STRUCTURED_JSON');
const names = resources.filter(resource => resource.i18n_type === 'KEYVALUEJSON'); const names = resources.filter(resource => resource.i18n_type === 'KEYVALUEJSON');
// ignore the yaml type because it's not possible to update via API // ignore the yaml type because it's not possible to update via API
// Lookup available languages by getting metadata for a resource, they all have the
// same set of languages, so it doesn't matter which one you get
const resourceInfo = await getResourceInfo(TX_PROJECT, resources[0].slug, true);
const languages = resourceInfo.available_languages.map(l => l.code);
return Promise.all([languages, folders, names]); // eslint-disable-line no-undef return Promise.all([languages, folders, names]); // eslint-disable-line no-undef
}; };
@ -139,11 +126,9 @@ const serializeFolderSave = async (json, locale) => {
* @return {Promise} [description] * @return {Promise} [description]
*/ */
exports.localizeFolder = async (folder, locale) => { exports.localizeFolder = async (folder, locale) => {
getTranslation(TX_PROJECT, folder.slug, locale, {mode: 'default'}) txPull(TX_PROJECT, folder.slug, locale, {mode: 'default'})
.then(data => { .then(data => {
const json = JSON.parse(data); serializeFolderSave(data, locale);
serializeFolderSave(json, locale);
}) })
.catch((e) => { .catch((e) => {
process.stdout.write(`Error processing ${folder.slug}, ${locale}: ${e.message}\n`); process.stdout.write(`Error processing ${folder.slug}, ${locale}: ${e.message}\n`);
@ -159,12 +144,11 @@ exports.localizeFolder = async (folder, locale) => {
*/ */
exports.debugFolder = async (folder, locale) => { exports.debugFolder = async (folder, locale) => {
mkdirp.sync('tmpDebug'); mkdirp.sync('tmpDebug');
getTranslation(TX_PROJECT, folder.slug, locale, {mode: 'default'}) txPull(TX_PROJECT, folder.slug, locale, {mode: 'default'})
.then(data => { .then(data => {
const json = JSON.parse(data);
fsPromises.writeFile( fsPromises.writeFile(
`tmpDebug/${folder.slug}_${locale}.json`, `tmpDebug/${folder.slug}_${locale}.json`,
JSON.stringify(json, null, 2) JSON.stringify(data, null, 2)
); );
}) })
.catch((e) => { .catch((e) => {
@ -181,10 +165,9 @@ exports.debugFolder = async (folder, locale) => {
* @return {Promise} [description] * @return {Promise} [description]
*/ */
exports.localizeNames = async (resource, locale) => { exports.localizeNames = async (resource, locale) => {
getTranslation(TX_PROJECT, resource.slug, locale, {mode: 'default'}) txPull(TX_PROJECT, resource.slug, locale, {mode: 'default'})
.then(data => { .then(data => {
const json = JSON.parse(data); serializeNameSave(data, resource, locale);
serializeNameSave(json, resource, locale);
}) })
.catch((e) => { .catch((e) => {
process.stdout.write(`Error saving ${resource.slug}, ${locale}: ${e.message}\n`); process.stdout.write(`Error saving ${resource.slug}, ${locale}: ${e.message}\n`);