diff --git a/lib/settings.js b/lib/settings.js index 2dd9a4e9..39ed2d51 100644 --- a/lib/settings.js +++ b/lib/settings.js @@ -364,7 +364,7 @@ ${this.results.reduce((x, y) => { async updateAll() { // this.subOrgConfigs = this.subOrgConfigs || await this.getSubOrgConfigs(this.github, this.repo, this.log) // this.repoConfigs = this.repoConfigs || await this.getRepoConfigs(this.github, this.repo, this.log) - return this.eachRepositoryRepos(this.github, this.config.restrictedRepos, this.log).then(res => { + return this.eachRepositoryRepos(this.github, this.log).then(res => { this.appendToResults(res) }) } @@ -475,19 +475,49 @@ ${this.results.reduce((x, y) => { return restrictedRepos.filter((restrictedRepo) => { return RegExp(restrictedRepo).test(repoName) }).length > 0 } - async eachRepositoryRepos(github, restrictedRepos, log) { + async eachRepositoryRepos (github, log) { log.debug('Fetching repositories') - return github.paginate('GET /installation/repositories').then(repositories => { - return Promise.all(repositories.map(repository => { - if (this.isRestricted(repository.name)) { - return null - } - const { owner, name } = repository - return this.updateRepos({ owner: owner.login, repo: name }) + const processedRepos = new Set() + const results = [] + + // Process existing repositories + const existingRepoResults = await github.paginate('GET /installation/repositories') + .then(repositories => { + return Promise.all(repositories.map(repository => { + if (this.isRestricted(repository.name)) { + return null + } + const { owner, name } = repository + processedRepos.add(`${owner.login}/${name}`) + return this.updateRepos({ owner: owner.login, repo: name }) + })) }) - ) - }) + + // Process missing repositories + const repoInConfigs = Object.values(this.repoConfigs) + .filter(config => config.repository?.name) + .map(config => { + return { + name: config.repository.name, + owner: config.repository.organization || this.repo.owner + } + }) + const missingRepoResults = await Promise.all( + repoInConfigs + .filter(repo => !this.isRestricted(repo.name)) + .filter(repo => !processedRepos.has(`${repo.owner}/${repo.name}`)) + .map(repo => { + processedRepos.add(`${repo.owner}/${repo.name}`) + return this.updateRepos({ owner: repo.owner, repo: repo.name }) + }) + ) + + results + .concat(existingRepoResults || [], missingRepoResults || []) + .filter(result => result !== null) + + return results } /**