-
Notifications
You must be signed in to change notification settings - Fork 1
/
submitTranslation.js
60 lines (56 loc) · 2.21 KB
/
submitTranslation.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// Copyright 2022, University of Colorado Boulder
/**
* Provide functionality for submit translation API route.
*
* @author Liam Mulhall <liammulh@gmail.com>
*/
import deleteSavedTranslation from '../deleteSavedTranslation.js';
import logger from '../logger.js';
import prepareTranslationForLongTermStorage from '../prepareTranslationForLongTermStorage.js';
import requestBuild from '../requestBuild.js';
import storeTranslationLongTerm from '../storeTranslationLongTerm.js';
import { reportObjectCache } from '../translationApi.js';
/**
* API function. Prepare a user's translation for long-term storage and store the user's translation in long-term
* storage.
*
* @param {Object} req - Express request object
* @param {Object} res - Express response object
* @returns {Promise<String>} - success message
*/
const submitTranslation = async ( req, res ) => {
let submitted = false;
try {
logger.info( `sending ${req.body.locale}/${req.body.simName} translation to be prepared for long-term storage` );
const preparedTranslation = await prepareTranslationForLongTermStorage( req.body );
logger.info( `sending ${req.body.locale}/${req.body.simName} translation to be stored long-term` );
const longTermStorageRes = await storeTranslationLongTerm( preparedTranslation );
if ( longTermStorageRes ) {
reportObjectCache.setDirtyObject( req.body.locale, req.body.simName );
const wasDeleted = deleteSavedTranslation( {
userId: req.body.userId,
simName: req.body.simName,
locale: req.body.locale
} );
if ( wasDeleted ) {
logger.info( 'previously saved translation deleted' );
}
else {
logger.warn( 'either deletion of previously saved translation failed or there was no previously saved translation' );
}
const buildRequestRes = await requestBuild( req.body.simName, req.body.locale, req.body.userId );
if ( buildRequestRes ) {
logger.info( 'build request succeeded' );
}
submitted = buildRequestRes;
}
else {
logger.error( `long term storage of ${req.body.locale}/${req.body.simName} failed` );
}
}
catch( e ) {
logger.error( e );
}
res.send( submitted );
};
export default submitTranslation;