all files / src/ pools.js

100% Statements 21/21
50% Branches 2/4
100% Functions 0/0
100% Lines 19/19
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                                                        40×                    
"use strict";
 
const hl = require("highland");
const utils = require("./utils");
const BeneLogger = require('bene-logger');
 
const getBySectionPoolId = (db, tableName) => hl.wrapCallback((item, cb) => {
    db.query({
        "TableName": tableName,
        "KeyConditionExpression": 'Id = :hkey and Area = :rkey',
        "ExpressionAttributeValues": {
            ':hkey': item.id,
            ':rkey': item.area
        }
    }, cb);
});
 
module.exports = (config, db) => (req, res, next) => {
 
    const source = req.params.source;
    const publicationId = req.params.publicationId;
    const escenicId = req.params.escenicId;
    const area = req.params.area;
 
    const logger = new BeneLogger({logging: config.logging.enabled});
 
    logger.setDefaults({
        body: JSON.stringify(req.params),
        service_name: 'apps-list-api'
    });
 
    logger.info('Pools GET request');
 
    const stream = getBySectionPoolId(db, config.dynamodb.tableNamePools)({
        "id": `${source}.${escenicId}`,
        "area": area
    })
        .pluck("Items")
        .pluck(0)
        .pluck("ArticleIds")
        .sequence()
        .take(40)
        .map(id => `${source}.${id}`);
 
    const articlesEndpoint = !req.query.cache || req.query.cache !== "false" ? config.cacheEndpoint : config.articleEndpoint;
 
    const GetArticle = utils.makeArticleRequest(logger, articlesEndpoint, source, publicationId);
    const NotFound = utils.notFound(`No pools found for /${source}/${publicationId}/pool/${escenicId}/`);
 
    utils.getArticlesInParallel(logger, GetArticle, NotFound, stream)
        .sequence()
        .reject(utils.shouldBeExcluded)
        .collect()
        .map(utils.addMeta)
        .toCallback(utils.sendResponse(logger, res, next));
};