Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

cci-pingu

Package Overview
Dependencies
Maintainers
1
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cci-pingu - npm Package Compare versions

Comparing version 2.7.15 to 2.8.0

57

dist/lib/task.js

@@ -7,5 +7,5 @@ 'use strict';

var _superagent = require('superagent');
var _request = require('request');
var _superagent2 = _interopRequireDefault(_superagent);
var _request2 = _interopRequireDefault(_request);

@@ -127,3 +127,7 @@ var _fs = require('fs');

downloadError = false;
_superagent2.default.get(url).query({ 'circle-token': config.token }).timeout(config.timeout * 1000).on('error', function (err) {
(0, _request2.default)({
method: 'GET',
url: url + '?circle-token=' + config.token,
timeout: config.timeout * 1000
}).on('error', function (err) {
console.error('Download failed: ' + JSON.stringify(err) + '.');

@@ -195,4 +199,4 @@ console.warn('CCI task finished with failure.');

updateResponse(res, []);
if (!res.ok) {
console.error('Status: ' + res.status + ', ' + res.text);
if (res.statusCode !== 200) {
console.error('Status: ' + res.statusCode + ', ' + res.statusMessage);
console.warn('CCI task finished with failure.');

@@ -202,3 +206,12 @@ scheduleNext();

// res.ok
console.log('Response from CCI server:\n' + JSON.stringify(res.body, null, 4));
var body = void 0;
try {
body = JSON.parse(res.body);
} catch (e) {
console.error('Cannot parse response form the server!');
console.warn('CCI task finished with failure.');
scheduleNext();
return;
}
console.log('Response from CCI server:\n' + JSON.stringify(body, null, 4));
var prefixes = config.artifacts.map(function (item) {

@@ -208,3 +221,3 @@ return { name: item, found: false };

var urls = [];
res.body.forEach(function (item) {
body.forEach(function (item) {
prefixes.forEach(function (prefix) {

@@ -248,4 +261,4 @@ if (item.path.indexOf(prefix.name) !== -1) {

updateResponse(res);
if (!res.ok) {
console.error('Status: ' + res.status + ', ' + res.text);
if (res.statusCode !== 200) {
console.error('Status: ' + res.statusCode + ', ' + res.statusMessage);
console.warn('CCI task finished with failure.');

@@ -259,3 +272,11 @@ scheduleNext();

// res.ok
var builds = res.body;
var builds = void 0;
try {
builds = JSON.parse(res.body);
} catch (e) {
console.error('Cannot parse response form the server!');
console.warn('CCI task finished with failure.');
scheduleNext();
return;
}
if (!options.install) {

@@ -292,3 +313,8 @@ console.log('Response from CCI server:\n' + JSON.stringify(builds, null, 4));

console.log('Getting info about build ' + config._last + ' artifacts.');
_superagent2.default.get(config.cci_url + apiPath).query({ 'circle-token': config.token }).set('Accept', 'application/json').timeout(config.timeout * 1000).end(cciArtifactsInfoHandler);
(0, _request2.default)({
method: 'GET',
url: config.cci_url + apiPath + '?circle-token=' + config.token,
headers: { Accept: 'application/json' },
timeout: config.timeout * 1000
}, cciArtifactsInfoHandler);
}

@@ -320,6 +346,11 @@ }

console.log('Getting info about last successful build of ' + config._name + '.');
_superagent2.default.get(config.cci_url + apiPath).query({ 'circle-token': config.token, filter: 'successful', limit: 100 }).set('Accept', 'application/json').timeout(config.timeout * 1000).end(cciBuildInfoHandler);
(0, _request2.default)({
method: 'GET',
url: config.cci_url + apiPath + '?circle-token=' + config.token + '&filter=successful&limit=100',
headers: { Accept: 'application/json' },
timeout: config.timeout * 1000
}, cciBuildInfoHandler);
};
exports.default = _module;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/task.js"],"names":["module","options","config","downloadError","EXIT_CODE","updateResponse","res","defaultBody","text","body","JSON","parse","e","scheduleNext","_save","last","_last","cfgFile","write","console","info","process","exit","setTimeout","run","interval","logPrefixed","prefix","logFn","data","toString","split","slice","map","s","join","startScript","scriptFile","path","resolve","script","_target","cwd","dirname","stdout","on","stderr","warn","err","error","stringify","code","message","cciDownloadOne","_urls","length","url","pop","filename","streamName","decodeURIComponent","stream","fs","createWriteStream","start","Date","getTime","request","get","query","token","timeout","dur","splice","nextTick","pipe","cciDownload","statSync","directory","basename","i","log","mkdirSync","cciArtifactsInfoHandler","ok","status","prefixes","artifacts","name","item","found","urls","forEach","indexOf","push","allFound","cciBuildInfoHandler","builds","install","order_by","workflows_job_name","build","workflows","job_name","build_num","_name","apiPath","hosting","organisation","project","cci_url","set","end","_options","read","ignore_branch","branch","filter","limit"],"mappings":"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","file":"task.js","sourcesContent":["// Module for talking to CCI, getting the artifacts, downloading them,\n// starting the action script, saving the updated config file, ...\n//\n// The task.run() schedules next run as needed.\n// All disk operations are synchronous.\n\nimport request from 'superagent';\nimport fs from 'fs';\nimport path from 'path';\nimport { spawn } from 'child_process';\nimport orderBy from 'lodash.orderby';\nimport filter from 'lodash.filter';\n\nconst module = {};\nlet options; // set once at first run()\nlet config;  // re-read in each iteration\nlet downloadError; // stop the process in case download failed\n\nlet EXIT_CODE; // return code for '--run-once' mode\n\nconst updateResponse = (res, defaultBody = null) => {\n  if (res.text) {\n    try {\n      res.body = JSON.parse(res.text);\n    } catch (e) {\n      res.body = defaultBody;\n    }\n  }\n};\n\nconst scheduleNext = () => {\n  if (config._save) {\n    config.last = config._last;\n    if (options.cfgFile.write(config)) {\n      console.info('New configuration file revision successfully saved.');\n    }\n  }\n  if (options['run-once']) {\n    console.info('CCI-PINGU about to exit. Thanks for flying with us!');\n    process.exit(EXIT_CODE);\n  } else {\n    setTimeout(module.run, config.interval * 1000);\n    console.info('Next CCI task scheduled in ' + config.interval + ' seconds.');\n  }\n};\n\nconst logPrefixed = (prefix, logFn) => (data) => {\n  logFn(data.toString().split('\\n').slice(0, -1).map((s) => `${prefix} ${s}`).join('\\n'));\n};\n\nconst startScript = () => {\n  const scriptFile = path.resolve(config.script);\n  console.info('Executing \"' + scriptFile + '\".');\n  try {\n    const script = spawn(scriptFile, [ config._target, config._last ], { cwd: path.dirname(scriptFile) });\n    script.stdout.on('data', logPrefixed('*', console.info));\n    script.stderr.on('data', logPrefixed('!', console.warn));\n    script.on('error', (err) => {\n      console.error('Failed to start script \"' + scriptFile + '\".');\n      console.error(JSON.stringify(err));\n      console.warn('CCI task finished with failure.');\n      scheduleNext();\n    });\n    script.on('close', (code) => {\n      if (!code) { // success\n        console.info('CCI task successfully finished.');\n        config._save = true;\n      } else { // fail\n        console.error('Installation script failed with exit code (' + code + ').');\n      }\n      EXIT_CODE = code;\n      scheduleNext();\n    });\n  } catch (e) { // spawn can throw exceptions on its own\n    console.error('Failed to start script \"' + scriptFile + '\".');\n    console.error(e.message);\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  }\n};\n\nconst cciDownloadOne = () => {\n  if (!config._urls.length) {\n    startScript();\n  } else {\n    const url = config._urls.pop();\n    let filename = url.split('/');\n    filename = filename[filename.length - 1];\n    const streamName = path.join(config._target, decodeURIComponent(filename));\n    const stream = fs.createWriteStream(streamName);\n    console.info('Downloading \"' + decodeURIComponent(url) + '\".');\n    const start = (new Date()).getTime();\n    downloadError = false;\n    request\n      .get(url)\n      .query({ 'circle-token': config.token })\n      .timeout(config.timeout * 1000)\n      .on('error', (err) => {\n        console.error('Download failed: ' + JSON.stringify(err) + '.');\n        console.warn('CCI task finished with failure.');\n        downloadError = true;\n        scheduleNext();\n      })\n      .on('end', () => {\n        if (downloadError) { return; }\n        let dur = (new Date()).getTime() - start;\n        if (dur > 999) {\n          dur = ('' + dur).split('');\n          dur.splice(dur.length - 3, 0, '.');\n          dur = dur.join('');\n        }\n        console.info('Saved as \"' + streamName + '\" in ' + dur + ' ms.');\n        process.nextTick(cciDownloadOne);\n      })\n      .pipe(stream);\n  }\n};\nconst cciDownload = () => {\n  // create target directory\n  try {\n    fs.statSync(config.directory);\n  } catch (e) {\n    console.error('Directory \"' + config.directory + '\" does not exist, cannot write there.');\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n  const basename = 'build-' + config._last;\n  let dirname;\n  try {\n    let i = 1;\n    while (true) {  // eslint-disable-line no-constant-condition\n      dirname = basename + (i > 1 ? '.' + i : '');\n      fs.statSync(path.join(config.directory, dirname));\n      i++;\n    }\n  } catch (e) {\n    // exception is fine\n  }\n  // create new dir\n  config._target = path.resolve(path.join(config.directory, dirname));\n  console.log('Creating artifact directory \"' + config._target + '\".');\n  try {\n    fs.mkdirSync(config._target);\n  } catch (e) {\n    console.error('Target directory \"' + config._target + '\" cannot be created.');\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n\n  // start the downloads\n  cciDownloadOne();\n};\n\nconst cciArtifactsInfoHandler = (err, res) => {\n  if (err) {\n    console.error(JSON.stringify(err));\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n  updateResponse(res, []);\n  if (!res.ok) {\n    console.error('Status: ' + res.status + ', ' + res.text);\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  } else { // res.ok\n    console.log('Response from CCI server:\\n' + JSON.stringify(res.body, null, 4));\n    const prefixes = config.artifacts.map(item => {\n      return { name: item, found: false };\n    });\n    const urls = [];\n    res.body.forEach(item => {\n      prefixes.forEach(prefix => {\n        if (item.path.indexOf(prefix.name) !== -1) {\n          urls.push(item.url);\n          prefix.found = true;\n        }\n      });\n    });\n    console.log('Collected artifact URLs (to download):\\n' + JSON.stringify(urls, null, 4));\n    let allFound = true;\n    prefixes.forEach(prefix => { if (!prefix.found) { allFound = false; } });\n    if (!allFound) {\n      console.error('Not all artifacts found! Missing:');\n      prefixes.forEach(prefix => { if (!prefix.found) { console.error('+ ' + prefix.name); } });\n      console.warn('CCI task finished with failure.');\n      scheduleNext();\n    } else {\n      config._urls = urls;\n      cciDownload();\n    }\n  }\n};\n\nconst cciBuildInfoHandler = (err, res) => {\n  if (err) {\n    console.error(JSON.stringify(err));\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n  updateResponse(res);\n  if (!res.ok) {\n    console.error('Status: ' + res.status + ', ' + res.text);\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  } else if (!res.body || !res.body.length) {\n    console.error('No successful build found!');\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  } else { // res.ok\n    let builds = res.body;\n    if (!options.install) {\n      console.log('Response from CCI server:\\n' + JSON.stringify(builds, null, 4));\n      builds = orderBy(builds, [ config.order_by ], [ 'desc' ]);\n      if (config.workflows_job_name) {\n        console.log('Filtering the available successful builds on workflows job name = ' + config.workflows_job_name + '.');\n        builds = filter(builds, (build) => (build.workflows && (build.workflows.job_name === config.workflows_job_name)));\n        if (!builds.length) {\n          console.error('No successful build with specified workflows job name found!');\n          console.warn('CCI task finished with failure.');\n          scheduleNext();\n          return;\n        }\n      }\n    }\n    config._last = builds[0].build_num;\n    !options.install && console.info('Last successful ' + config._name + ' build number: ' + config._last + '.');\n    if (!options.install && (config.last === config._last)) {\n      console.info('Build ' + config._last + ' already installed.');\n      console.info('CCI task successfully finished.');\n      EXIT_CODE = 0;\n      scheduleNext();\n    } else {\n      if (options.install && (config.last === config._last)) {\n        console.info('Build ' + config._last + ' already installed, about to install it again...');\n      } else {\n        console.info('Build ' + config._last + ' is not installed yet.');\n      }\n      const apiPath = ['/api/v1.1/project', config.hosting, config.organisation,\n        config.project, config._last, 'artifacts'].join('/');\n      console.log('Getting info about build ' + config._last + ' artifacts.');\n      request\n        .get(config.cci_url + apiPath)\n        .query({ 'circle-token': config.token })\n        .set('Accept', 'application/json')\n        .timeout(config.timeout * 1000)\n        .end(cciArtifactsInfoHandler);\n    }\n  }\n};\n\nmodule.run = (_options = null) => {\n  EXIT_CODE = 1;   // update to 0 on final success\n  if (_options) { options = _options; }\n  config = options.cfgFile.read();\n  if (config.ignore_branch) {\n    config.branch = '<ANY>';\n  }\n  config._name = [config.hosting, config.organisation, config.project, config.branch].join('/');\n  console.info('CCI task started.');\n  if (options.install) {\n    cciBuildInfoHandler(null, {\n      ok: true,\n      body: [ { build_num: options.install } ]\n    });\n    return;\n  }\n  const apiPath =\n    config.ignore_branch\n      ? ['/api/v1.1/project', config.hosting, config.organisation, config.project].join('/')\n      : ['/api/v1.1/project', config.hosting, config.organisation, config.project, 'tree', config.branch].join('/');\n  console.log('Getting info about last successful build of ' + config._name + '.');\n  request\n    .get(config.cci_url + apiPath)\n    .query({ 'circle-token': config.token, filter: 'successful', limit: 100 })\n    .set('Accept', 'application/json')\n    .timeout(config.timeout * 1000)\n    .end(cciBuildInfoHandler);\n};\n\nexport default module;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/task.js"],"names":["module","options","config","downloadError","EXIT_CODE","updateResponse","res","defaultBody","text","body","JSON","parse","e","scheduleNext","_save","last","_last","cfgFile","write","console","info","process","exit","setTimeout","run","interval","logPrefixed","prefix","logFn","data","toString","split","slice","map","s","join","startScript","scriptFile","path","resolve","script","_target","cwd","dirname","stdout","on","stderr","warn","err","error","stringify","code","message","cciDownloadOne","_urls","length","url","pop","filename","streamName","decodeURIComponent","stream","fs","createWriteStream","start","Date","getTime","method","token","timeout","dur","splice","nextTick","pipe","cciDownload","statSync","directory","basename","i","log","mkdirSync","cciArtifactsInfoHandler","statusCode","statusMessage","prefixes","artifacts","name","item","found","urls","forEach","indexOf","push","allFound","cciBuildInfoHandler","builds","install","order_by","workflows_job_name","build","workflows","job_name","build_num","_name","apiPath","hosting","organisation","project","cci_url","headers","Accept","_options","read","ignore_branch","branch","ok"],"mappings":"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","file":"task.js","sourcesContent":["// Module for talking to CCI, getting the artifacts, downloading them,\n// starting the action script, saving the updated config file, ...\n//\n// The task.run() schedules next run as needed.\n// All disk operations are synchronous.\n\nimport request from 'request';\nimport fs from 'fs';\nimport path from 'path';\nimport { spawn } from 'child_process';\nimport orderBy from 'lodash.orderby';\nimport filter from 'lodash.filter';\n\nconst module = {};\nlet options; // set once at first run()\nlet config;  // re-read in each iteration\nlet downloadError; // stop the process in case download failed\n\nlet EXIT_CODE; // return code for '--run-once' mode\n\nconst updateResponse = (res, defaultBody = null) => {\n  if (res.text) {\n    try {\n      res.body = JSON.parse(res.text);\n    } catch (e) {\n      res.body = defaultBody;\n    }\n  }\n};\n\nconst scheduleNext = () => {\n  if (config._save) {\n    config.last = config._last;\n    if (options.cfgFile.write(config)) {\n      console.info('New configuration file revision successfully saved.');\n    }\n  }\n  if (options['run-once']) {\n    console.info('CCI-PINGU about to exit. Thanks for flying with us!');\n    process.exit(EXIT_CODE);\n  } else {\n    setTimeout(module.run, config.interval * 1000);\n    console.info('Next CCI task scheduled in ' + config.interval + ' seconds.');\n  }\n};\n\nconst logPrefixed = (prefix, logFn) => (data) => {\n  logFn(data.toString().split('\\n').slice(0, -1).map((s) => `${prefix} ${s}`).join('\\n'));\n};\n\nconst startScript = () => {\n  const scriptFile = path.resolve(config.script);\n  console.info('Executing \"' + scriptFile + '\".');\n  try {\n    const script = spawn(scriptFile, [ config._target, config._last ], { cwd: path.dirname(scriptFile) });\n    script.stdout.on('data', logPrefixed('*', console.info));\n    script.stderr.on('data', logPrefixed('!', console.warn));\n    script.on('error', (err) => {\n      console.error('Failed to start script \"' + scriptFile + '\".');\n      console.error(JSON.stringify(err));\n      console.warn('CCI task finished with failure.');\n      scheduleNext();\n    });\n    script.on('close', (code) => {\n      if (!code) { // success\n        console.info('CCI task successfully finished.');\n        config._save = true;\n      } else { // fail\n        console.error('Installation script failed with exit code (' + code + ').');\n      }\n      EXIT_CODE = code;\n      scheduleNext();\n    });\n  } catch (e) { // spawn can throw exceptions on its own\n    console.error('Failed to start script \"' + scriptFile + '\".');\n    console.error(e.message);\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  }\n};\n\nconst cciDownloadOne = () => {\n  if (!config._urls.length) {\n    startScript();\n  } else {\n    const url = config._urls.pop();\n    let filename = url.split('/');\n    filename = filename[filename.length - 1];\n    const streamName = path.join(config._target, decodeURIComponent(filename));\n    const stream = fs.createWriteStream(streamName);\n    console.info('Downloading \"' + decodeURIComponent(url) + '\".');\n    const start = (new Date()).getTime();\n    downloadError = false;\n    request({\n      method: 'GET',\n      url: `${url}?circle-token=${config.token}`,\n      timeout: config.timeout * 1000\n    })\n      .on('error', (err) => {\n        console.error('Download failed: ' + JSON.stringify(err) + '.');\n        console.warn('CCI task finished with failure.');\n        downloadError = true;\n        scheduleNext();\n      })\n      .on('end', () => {\n        if (downloadError) { return; }\n        let dur = (new Date()).getTime() - start;\n        if (dur > 999) {\n          dur = ('' + dur).split('');\n          dur.splice(dur.length - 3, 0, '.');\n          dur = dur.join('');\n        }\n        console.info('Saved as \"' + streamName + '\" in ' + dur + ' ms.');\n        process.nextTick(cciDownloadOne);\n      })\n      .pipe(stream);\n  }\n};\nconst cciDownload = () => {\n  // create target directory\n  try {\n    fs.statSync(config.directory);\n  } catch (e) {\n    console.error('Directory \"' + config.directory + '\" does not exist, cannot write there.');\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n  const basename = 'build-' + config._last;\n  let dirname;\n  try {\n    let i = 1;\n    while (true) {  // eslint-disable-line no-constant-condition\n      dirname = basename + (i > 1 ? '.' + i : '');\n      fs.statSync(path.join(config.directory, dirname));\n      i++;\n    }\n  } catch (e) {\n    // exception is fine\n  }\n  // create new dir\n  config._target = path.resolve(path.join(config.directory, dirname));\n  console.log('Creating artifact directory \"' + config._target + '\".');\n  try {\n    fs.mkdirSync(config._target);\n  } catch (e) {\n    console.error('Target directory \"' + config._target + '\" cannot be created.');\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n\n  // start the downloads\n  cciDownloadOne();\n};\n\nconst cciArtifactsInfoHandler = (err, res) => {\n  if (err) {\n    console.error(JSON.stringify(err));\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n  updateResponse(res, []);\n  if (res.statusCode !== 200) {\n    console.error('Status: ' + res.statusCode + ', ' + res.statusMessage);\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  } else { // res.ok\n    let body;\n    try {\n      body = JSON.parse(res.body);\n    } catch (e) {\n      console.error('Cannot parse response form the server!');\n      console.warn('CCI task finished with failure.');\n      scheduleNext();\n      return;\n    }\n    console.log('Response from CCI server:\\n' + JSON.stringify(body, null, 4));\n    const prefixes = config.artifacts.map(item => {\n      return { name: item, found: false };\n    });\n    const urls = [];\n    body.forEach(item => {\n      prefixes.forEach(prefix => {\n        if (item.path.indexOf(prefix.name) !== -1) {\n          urls.push(item.url);\n          prefix.found = true;\n        }\n      });\n    });\n    console.log('Collected artifact URLs (to download):\\n' + JSON.stringify(urls, null, 4));\n    let allFound = true;\n    prefixes.forEach(prefix => { if (!prefix.found) { allFound = false; } });\n    if (!allFound) {\n      console.error('Not all artifacts found! Missing:');\n      prefixes.forEach(prefix => { if (!prefix.found) { console.error('+ ' + prefix.name); } });\n      console.warn('CCI task finished with failure.');\n      scheduleNext();\n    } else {\n      config._urls = urls;\n      cciDownload();\n    }\n  }\n};\n\nconst cciBuildInfoHandler = (err, res) => {\n  if (err) {\n    console.error(JSON.stringify(err));\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n    return;\n  }\n  updateResponse(res);\n  if (res.statusCode !== 200) {\n    console.error('Status: ' + res.statusCode + ', ' + res.statusMessage);\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  } else if (!res.body || !res.body.length) {\n    console.error('No successful build found!');\n    console.warn('CCI task finished with failure.');\n    scheduleNext();\n  } else { // res.ok\n    let builds;\n    try {\n      builds = JSON.parse(res.body);\n    } catch (e) {\n      console.error('Cannot parse response form the server!');\n      console.warn('CCI task finished with failure.');\n      scheduleNext();\n      return;\n    }\n    if (!options.install) {\n      console.log('Response from CCI server:\\n' + JSON.stringify(builds, null, 4));\n      builds = orderBy(builds, [ config.order_by ], [ 'desc' ]);\n      if (config.workflows_job_name) {\n        console.log('Filtering the available successful builds on workflows job name = ' + config.workflows_job_name + '.');\n        builds = filter(builds, (build) => (build.workflows && (build.workflows.job_name === config.workflows_job_name)));\n        if (!builds.length) {\n          console.error('No successful build with specified workflows job name found!');\n          console.warn('CCI task finished with failure.');\n          scheduleNext();\n          return;\n        }\n      }\n    }\n    config._last = builds[0].build_num;\n    !options.install && console.info('Last successful ' + config._name + ' build number: ' + config._last + '.');\n    if (!options.install && (config.last === config._last)) {\n      console.info('Build ' + config._last + ' already installed.');\n      console.info('CCI task successfully finished.');\n      EXIT_CODE = 0;\n      scheduleNext();\n    } else {\n      if (options.install && (config.last === config._last)) {\n        console.info('Build ' + config._last + ' already installed, about to install it again...');\n      } else {\n        console.info('Build ' + config._last + ' is not installed yet.');\n      }\n      const apiPath = ['/api/v1.1/project', config.hosting, config.organisation,\n        config.project, config._last, 'artifacts'].join('/');\n      console.log('Getting info about build ' + config._last + ' artifacts.');\n      request({\n        method: 'GET',\n        url: `${config.cci_url + apiPath}?circle-token=${config.token}`,\n        headers: { Accept: 'application/json' },\n        timeout: config.timeout * 1000\n      }, cciArtifactsInfoHandler);\n    }\n  }\n};\n\nmodule.run = (_options = null) => {\n  EXIT_CODE = 1;   // update to 0 on final success\n  if (_options) { options = _options; }\n  config = options.cfgFile.read();\n  if (config.ignore_branch) {\n    config.branch = '<ANY>';\n  }\n  config._name = [config.hosting, config.organisation, config.project, config.branch].join('/');\n  console.info('CCI task started.');\n  if (options.install) {\n    cciBuildInfoHandler(null, {\n      ok: true,\n      body: [ { build_num: options.install } ]\n    });\n    return;\n  }\n  const apiPath =\n    config.ignore_branch\n      ? ['/api/v1.1/project', config.hosting, config.organisation, config.project].join('/')\n      : ['/api/v1.1/project', config.hosting, config.organisation, config.project, 'tree', config.branch].join('/');\n  console.log('Getting info about last successful build of ' + config._name + '.');\n  request({\n    method: 'GET',\n    url: `${config.cci_url + apiPath}?circle-token=${config.token}&filter=successful&limit=100`,\n    headers: { Accept: 'application/json' },\n    timeout: config.timeout * 1000\n  }, cciBuildInfoHandler);\n};\n\nexport default module;\n"]}

@@ -7,3 +7,3 @@ 'use strict';

// generated code, please see package.json
exports.default = '2.7.15';
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi92ZXJzaW9uLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7a0JBQ2UsUSIsImZpbGUiOiJ2ZXJzaW9uLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gZ2VuZXJhdGVkIGNvZGUsIHBsZWFzZSBzZWUgcGFja2FnZS5qc29uXG5leHBvcnQgZGVmYXVsdCAnMi43LjE1JztcbiJdfQ==
exports.default = '2.8.0';
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi92ZXJzaW9uLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7a0JBQ2UsTyIsImZpbGUiOiJ2ZXJzaW9uLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gZ2VuZXJhdGVkIGNvZGUsIHBsZWFzZSBzZWUgcGFja2FnZS5qc29uXG5leHBvcnQgZGVmYXVsdCAnMi44LjAnO1xuIl19
{
"name": "cci-pingu",
"version": "2.7.15",
"version": "2.8.0",
"description": "Periodically check for new builds (artifacts) on CircleCI and install them in turn",

@@ -38,7 +38,7 @@ "license": "MIT",

"babel-preset-stage-0": "6.24.1",
"eslint": "5.16.0",
"eslint-config-standard": "12.0.0",
"eslint-plugin-import": "2.17.2",
"eslint-plugin-node": "9.0.1",
"eslint-plugin-promise": "4.1.1",
"eslint": "6.0.1",
"eslint-config-standard": "13.0.1",
"eslint-plugin-import": "2.18.0",
"eslint-plugin-node": "9.1.0",
"eslint-plugin-promise": "4.2.1",
"eslint-plugin-standard": "4.0.0",

@@ -51,6 +51,8 @@ "mocha": "6.1.4"

"lodash.orderby": "4.6.0",
"superagent": "5.0.5"
"request": "2.88.0"
},
"renovate": {
"extends": ["config:base"],
"extends": [
"config:base"
],
"bumpVersion": "patch",

@@ -57,0 +59,0 @@ "automerge": true,

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc