-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
91 lines (86 loc) · 3.6 KB
/
server.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
var Promise = require('bluebird');
var schemaConfig = require('./config/PratilipiSchema');
var CategoryService;
var dbUtility = require('./lib/DbUtility')({projectId: process.env.GCP_PROJ_ID, kind: 'PRATILIPI', schema: schemaConfig});
var parameterStoreAccessor = require('./helpers/ParameterStoreAccessor');
function fetchAndSyncCategoriesData(timestamp) {
var filter = null;
var orderBy = ['_TIMESTAMP_'];
if(timestamp) {
var filter = [
['_TIMESTAMP_', '>=', new Date(timestamp)]
];
}
dbUtility.query(filter, null, null, 50, orderBy, false)
.then(pratilipis => {
var addPratilipis = [];
console.log(pratilipis.data.length, 'before filtering');
pratilipis.newTimestamp = pratilipis.data[pratilipis.data.length - 1]._TIMESTAMP_;
pratilipis.data = pratilipis.data.filter((pratilipi) => {
if(['MAGAZINE', 'BOOK'].includes(pratilipi.PRATILIPI_TYPE) && (pratilipi.SUGGESTED_TAGS || pratilipi.TAG_IDS)) {
console.log(`[WRONG CONTENT_TYPE PRESENT] for pratilipi id ${pratilipi.PRATILIPI_ID}`);
}
return ['ARTICLE', 'POEM', 'STORY'].includes(pratilipi.PRATILIPI_TYPE) && ['DRAFTED', 'PUBLISHED'].includes(pratilipi.STATE) ;
});
console.log(pratilipis.data.length, 'after filtering');
var data = pratilipis.data;
for(var i = 0; i < data.length; i++) {
var pratilipi = data[i];
// console.log(pratilipi.PRATILIPI_ID, pratilipi.LANGUAGE, pratilipi.PRATILIPI_TYPE, pratilipi.TAG_IDS, pratilipi.SUGGESTED_TAGS);
console.log(`[PRATILIPI_ID]: ${pratilipi.PRATILIPI_ID}`);
addPratilipis.push(CategoryService.insertCategoriesInPratilipi(pratilipi.PRATILIPI_ID, pratilipi.LANGUAGE, pratilipi.PRATILIPI_TYPE, pratilipi.TAG_IDS, pratilipi.SUGGESTED_TAGS, pratilipi._TIMESTAMP_));
}
return Promise.all(addPratilipis).then(() => {
//return maybe only timestamp and moreResults;
return pratilipis;
})
.catch((err) => {
console.log(err);
console.log("[FAILED] Failed at this timestamp", timestamp);
return Promise.reject();
});
// return pratilipis;
})
.then(pratilipis => {
console.log(`${pratilipis.data.length} successfully inserted.`);
if(pratilipis.moreResults) {
console.log(`More results exist after timestamp ${timestamp}`);
setTimeout(function () {
fetchAndSyncCategoriesData(pratilipis.newTimestamp);
}, 1000);
} else {
console.log(`[FK FAILED PRATILIPI IDS TOTAL AFTER SUCCESS] are ${CategoryService.fkFailedPratilipiIds}`);
console.log(`[LENGTH FAILED PRATILIPI IDS TOTAL AFTER SUCCESS] are ${CategoryService.lengthFailedPratilipiIds}`);
process.exit();
}
})
.catch(err => {
console.log(err, 'Error occured. Bye bye.');
console.log(`[FK FAILED PRATILIPI IDS TOTAL] are ${CategoryService.fkFailedPratilipiIds}`);
console.log(`[LENGTH FAILED PRATILIPI IDS TOTAL] are ${CategoryService.lengthFailedPratilipiIds}`);
process.exit();
})
;
}
parameterStoreAccessor.getMySqlDbCredentials()
.then(config => {
Object.assign(process.env, config);
var models = require('./sequelize-models');
CategoryService = require('./Category');
return models.sequelize.authenticate();
})
.then(() => {
fetchAndSyncCategoriesData(process.env.LAST_UPDATED_TIMESTAMP);
})
;
// .then(() => {
// // console.log('authenticated');
// // CategoryService.getSystemCategories('HINDI')
// // .then(results => {
// // console.log(results);
// // return;
// // });
// db.sequelize.sync();
//
// })
//