-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauthor-count-server.js
123 lines (110 loc) · 3.93 KB
/
author-count-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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
var Promise = require('bluebird');
var http = require('http');
var httpPromise = require('request-promise');
var _ = require('lodash');
var parameterStoreAccessor = require('./helpers/ParameterStoreAccessor');
var agent = new http.Agent({
keepAlive : true
});
var schemaConfig = require('./config/PratilipiAuthorCountSchema');
var dbUtility = require('./lib/DbUtility')({projectId: process.env.GCP_PROJ_ID, kind: 'PRATILIPI', schema: schemaConfig});
var failedAuthorIds = [];
function backfillAuthorCounts(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 prAuthorPratilipis = [];
var prAuthorHttpRequests = [];
pratilipis.newTimestamp = pratilipis.data[pratilipis.data.length - 1]._TIMESTAMP_;
pratilipis.data = pratilipis.data.filter((pratilipi) => {
return ['DRAFTED', 'PUBLISHED', 'DELETED'].includes(pratilipi.STATE) ;
});
var data = pratilipis.data;
console.log(`Before unique author ids ${data.length}`);
var authorIds = _.uniq(_.map(data, 'AUTHOR_ID'));
console.log(`After unique author ids ${authorIds.length}`);
for(var i = 0; i < authorIds.length; i++) {
var authorId = authorIds[i];
var filter = [
['AUTHOR_ID', '=', authorId]
];
prAuthorPratilipis.push(dbUtility.query(filter, null, null, null, null, false));
}
return Promise.all(prAuthorPratilipis).then((responses) => {
//return maybe only timestamp and moreResults;
for(var i = 0; i < responses.length; i++) {
var authorPratilipis = responses[i].data;
var pratilipisStateCounts = _.countBy(authorPratilipis, (pratilipi) => {
return pratilipi.STATE;
});
var draftedCount = pratilipisStateCounts.DRAFTED || 0;
var publishedCount = pratilipisStateCounts.PUBLISHED || 0;
prAuthorHttpRequests.push(updateAuthorCounts({
contentPublished: publishedCount,
contentDrafted: draftedCount
}, authorIds[i]));
}
return Promise.all(prAuthorHttpRequests)
.then(() => {
return pratilipis;
});
})
.then((pratilipis) => {
if(pratilipis.moreResults) {
console.log(`More results exist after timestamp ${pratilipis.newTimestamp}`);
setTimeout(function () {
backfillAuthorCounts(pratilipis.newTimestamp);
}, 5000);
} else {
console.log(`[FAILED AUTHOR IDS TOTAL AFTER SUCCESS] are ${failedAuthorIds}`);
process.exit();
}
})
.catch((err) => {
console.log(err);
console.log("[FAILED] Failed at this timestamp", timestamp);
return Promise.reject();
});
// return pratilipis;
})
.catch(err => {
console.log(err, 'Error occured. Bye bye.');
console.log(`[FAILED AUTHOR IDS TOTAL] are ${failedAuthorIds}`);
process.exit();
})
;
}
parameterStoreAccessor.getJarvisCredentials()
.then(config => {
Object.assign(process.env, config);
backfillAuthorCounts(process.env.LAST_TS);
})
;
function updateAuthorCounts(body, authorId) {
var authorFactsPatchOptions = {
method: 'PATCH',
uri: `${process.env.API_END_POINT}/authors/${authorId}`,
form: body,
agent: agent
};
if(process.env.STAGE != 'devo') {
authorFactsPatchOptions.headers = {
'Access-Token': process.env.JARVIS_ATOKEN,
'User-Id': process.env.JARVIS_USER_ID
};
}
console.log('Author patch request for ' + authorId + ' is ' + JSON.stringify(_.pick(authorFactsPatchOptions, ['form'])));
return httpPromise(authorFactsPatchOptions)
.catch((err) => {
console.log('[ERROR RETURNED FOR] ' + authorId + ' ' + err);
failedAuthorIds.push(authorId);
return;
})
;
}