mirror of https://github.com/renovatebot/renovate
69 lines
1.9 KiB
JavaScript
69 lines
1.9 KiB
JavaScript
const logger = require('./logger');
|
|
const config = require('./config');
|
|
const github = require('./api/github');
|
|
|
|
// Require main source
|
|
const worker = require('./worker');
|
|
|
|
module.exports = {
|
|
start,
|
|
};
|
|
|
|
function start() {
|
|
// Parse config
|
|
config.parseConfigs();
|
|
|
|
// Initialize our promise chain
|
|
let p = Promise.resolve();
|
|
|
|
// Get global config
|
|
const globalConfig = config.getGlobalConfig();
|
|
|
|
// Queue repositories in sequence
|
|
globalConfig.repositories.forEach((repo) => {
|
|
p = p.then(() => processRepo(repo));
|
|
});
|
|
|
|
// Queue package files in sequence within a repo
|
|
function processRepo(repo) {
|
|
logger.debug(`Processing repository: ${JSON.stringify(repo)}`);
|
|
// Set GitHub token for this repo
|
|
process.env.GITHUB_TOKEN = repo.token || globalConfig.token;
|
|
// Initialize repo
|
|
return github.initRepo(repo.repository)
|
|
.then(() => ensurePackageFiles(repo))
|
|
.then(getWorkers);
|
|
}
|
|
|
|
// Ensure repo contains packageFiles
|
|
function ensurePackageFiles(repo) {
|
|
// Check for manually configured package files
|
|
if (repo.packageFiles.length) {
|
|
return Promise.resolve(repo);
|
|
}
|
|
// Otherwise, autodiscover filenames
|
|
return github.findFilePaths('package.json')
|
|
.then((fileNames) => {
|
|
const packageFiles =
|
|
fileNames.map(fileName => ({ fileName }));
|
|
return Object.assign(repo, { packageFiles });
|
|
});
|
|
}
|
|
|
|
// Return a promise queue of package file workers
|
|
function getWorkers(repo) {
|
|
return repo.packageFiles.reduce((promise, packageFile) => {
|
|
const cascadedConfig = config.getCascadedConfig(repo, packageFile);
|
|
return promise.then(() => worker(repo.repository, packageFile.fileName, cascadedConfig));
|
|
}, Promise.resolve());
|
|
}
|
|
|
|
// Process all promises
|
|
p.then(() => { // eslint-disable-line promise/always-return
|
|
logger.info('Renovate finished');
|
|
})
|
|
.catch((error) => {
|
|
logger.error(`Unexpected error: ${error}`);
|
|
});
|
|
}
|