all files / src/ topStories.js

100% Statements 19/19
100% Branches 4/4
100% Functions 0/0
100% Lines 17/17
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                                                                   
"use strict";
 
let R = require("ramda");
let hl = require("highland");
let utils = require("./utils");
const BeneLogger = require('bene-logger');
 
const getByPubId = (tableName, db) => hl.wrapCallback((id, cb) => {
    db.query({
        "TableName": tableName,
        "KeyConditionExpression": 'Id = :hkey',
        "ExpressionAttributeValues": {
            ':hkey': id
        },
        "Limit": 40
    }, cb);
});
 
module.exports = (config, db) => (req, res, next) => {
 
    const source = req.params.source;
 
    const publicationId = req.params.publicationId;
    const logger = new BeneLogger({logging: config.logging.enabled});
 
    logger.setDefaults({
        body: JSON.stringify(req.params),
        service_name: 'appsTopStoriesAPI'
    });
 
    logger.info('Pools GET request');
 
    const articlesEndpoint = !req.query.cache || req.query.cache !== "false" ? config.cacheEndpoint : config.articleEndpoint;
 
    const stream = getByPubId(config.dynamodb.tableName, db)(`${source}.${publicationId}`)
        .pluck("Items")
        .reject(R.isEmpty)
        .sequence()
        .pluck("ArticleId");
    
    const GetArticle = utils.makeArticleRequest(logger, articlesEndpoint, source, publicationId);
    const NotFound = utils.notFound(`No pools found for publication /${source}/${publicationId}`);
 
    utils.getArticlesInParallel(logger, GetArticle, NotFound, stream)
        .sequence()
        .reject(utils.shouldBeExcluded)
        .collect()
        .map(utils.addMeta)
        .toCallback(utils.sendResponse(logger, res, next));
};