From 04621913a7339339f29a1f845abfd4296abffc5c Mon Sep 17 00:00:00 2001 From: Martin Migasiewicz <616250+martinm82@users.noreply.github.com> Date: Wed, 15 Feb 2023 14:06:14 +0100 Subject: [PATCH] chore(logs): improve log messages --- index.js | 156 ++++++++++++++++++++++---------------- lib/configManager.js | 12 +-- lib/mergeDeep.js | 2 +- lib/plugins/branches.js | 10 +-- lib/plugins/diffable.js | 2 +- lib/plugins/repository.js | 36 ++++----- lib/plugins/validator.js | 8 +- lib/settings.js | 20 ++--- lib/validator.js | 8 +- 9 files changed, 138 insertions(+), 116 deletions(-) diff --git a/index.js b/index.js index dc1f82bc..1abc86a0 100644 --- a/index.js +++ b/index.js @@ -10,13 +10,14 @@ const env = require('./lib/env') let deploymentConfig module.exports = (robot, _, Settings = require('./lib/settings')) => { async function syncAllSettings (nop, context, repo = context.repo(), ref) { + const log = robot.log.child({ context: 'index', repository: repo.repo }) try { deploymentConfig = await loadYamlFileSystem() - robot.log.debug(`deploymentConfig is ${JSON.stringify(deploymentConfig)}`) + log.debug(`deploymentConfig is ${JSON.stringify(deploymentConfig)}`) const configManager = new ConfigManager(context, ref) const runtimeConfig = await configManager.loadGlobalSettingsYaml() const config = Object.assign({}, deploymentConfig, runtimeConfig) - robot.log.debug(`config for ref ${ref} is ${JSON.stringify(config)}`) + log.debug(`config for ref ${ref} is ${JSON.stringify(config)}`) if (ref) { return Settings.syncAll(nop, context, repo, config, ref) } else { @@ -30,7 +31,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { deploymentConfig = {} } const nopcommand = new NopCommand(filename, repo, null, e, 'ERROR') - robot.log.error(`NOPCOMMAND ${JSON.stringify(nopcommand)}`) + log.error(`NOPCOMMAND ${JSON.stringify(nopcommand)}`) Settings.handleError(nop, context, repo, deploymentConfig, ref, nopcommand) } else { throw e @@ -39,13 +40,14 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { } async function syncSubOrgSettings (nop, context, suborg, repo = context.repo(), ref) { + const log = robot.log.child({ context: 'index', suborg, repository: repo.repo }) try { deploymentConfig = await loadYamlFileSystem() - robot.log.debug(`deploymentConfig is ${JSON.stringify(deploymentConfig)}`) + log.debug(`deploymentConfig is ${JSON.stringify(deploymentConfig)}`) const configManager = new ConfigManager(context, ref) const runtimeConfig = await configManager.loadGlobalSettingsYaml() const config = Object.assign({}, deploymentConfig, runtimeConfig) - robot.log.debug(`config for ref ${ref} is ${JSON.stringify(config)}`) + log.debug(`config for ref ${ref} is ${JSON.stringify(config)}`) return Settings.syncSubOrgs(nop, context, suborg, repo, config, ref) } catch (e) { if (nop) { @@ -55,7 +57,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { deploymentConfig = {} } const nopcommand = new NopCommand(filename, repo, null, e, 'ERROR') - robot.log.error(`NOPCOMMAND ${JSON.stringify(nopcommand)}`) + log.error(`NOPCOMMAND ${JSON.stringify(nopcommand)}`) Settings.handleError(nop, context, repo, deploymentConfig, ref, nopcommand) } else { throw e @@ -64,13 +66,14 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { } async function syncSettings (nop, context, repo = context.repo(), ref) { + const log = robot.log.child({ context: 'index', repository: repo.repo }) try { deploymentConfig = await loadYamlFileSystem() - robot.log.debug(`deploymentConfig is ${JSON.stringify(deploymentConfig)}`) + log.debug(`deploymentConfig is ${JSON.stringify(deploymentConfig)}`) const configManager = new ConfigManager(context, ref) const runtimeConfig = await configManager.loadGlobalSettingsYaml() const config = Object.assign({}, deploymentConfig, runtimeConfig) - robot.log.debug(`config for ref ${ref} is ${JSON.stringify(config)}`) + log.debug(`config for ref ${ref} is ${JSON.stringify(config)}`) return Settings.sync(nop, context, repo, config, ref) } catch (e) { if (nop) { @@ -80,7 +83,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { deploymentConfig = {} } const nopcommand = new NopCommand(filename, repo, null, e, 'ERROR') - robot.log.error(`NOPCOMMAND ${JSON.stringify(nopcommand)}`) + log.error(`NOPCOMMAND ${JSON.stringify(nopcommand)}`) Settings.handleError(nop, context, repo, deploymentConfig, ref, nopcommand) } else { throw e @@ -108,23 +111,25 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { function getAllChangedSubOrgConfigs (payload) { const settingPattern = new Glob('.github/suborgs/*.yml') + const log = robot.log.child({ context: 'index' }) + // Changes will be an array of files that were added const added = payload.commits.map(c => { return (c.added.filter(s => { - robot.log.debug(JSON.stringify(s)) + log.debug(JSON.stringify(s)) return (s.search(settingPattern) >= 0) })) }).flat(2) const modified = payload.commits.map(c => { return (c.modified.filter(s => { - robot.log.debug(JSON.stringify(s)) + log.debug(JSON.stringify(s)) return (s.search(settingPattern) >= 0) })) }).flat(2) const changes = added.concat(modified) const configs = changes.map(file => { const matches = file.match(settingPattern) - robot.log.debug(`${JSON.stringify(file)} \n ${matches[1]}`) + log.debug(`${JSON.stringify(file)} \n ${matches[1]}`) return { name: matches[1] + '.yml', path: file } }) return configs @@ -132,30 +137,33 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { function getAllChangedRepoConfigs (payload, owner) { const settingPattern = new Glob('.github/repos/*.yml') + const log = robot.log.child({ context: 'index' }) + // Changes will be an array of files that were added const added = payload.commits.map(c => { return (c.added.filter(s => { - robot.log.debug(JSON.stringify(s)) + log.debug(JSON.stringify(s)) return (s.search(settingPattern) >= 0) })) }).flat(2) const modified = payload.commits.map(c => { return (c.modified.filter(s => { - robot.log.debug(JSON.stringify(s)) + log.debug(JSON.stringify(s)) return (s.search(settingPattern) >= 0) })) }).flat(2) const changes = added.concat(modified) const configs = changes.map(file => { - robot.log.debug(`${JSON.stringify(file)}`) + log.debug(`${JSON.stringify(file)}`) return { repo: file.match(settingPattern)[1], owner } }) return configs } function getChangedRepoConfigName (glob, files, owner) { + const log = robot.log.child({ context: 'index' }) const modifiedFiles = files.filter(s => { - robot.log.debug(JSON.stringify(s)) + log.debug(JSON.stringify(s)) return (s.search(glob) >= 0) }) @@ -165,31 +173,34 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { } function getChangedSubOrgConfigName (glob, files) { + const log = robot.log.child({ context: 'index' }) const modifiedFiles = files.filter(s => { - robot.log.debug(JSON.stringify(s)) + log.debug(JSON.stringify(s)) return (s.search(glob) >= 0) }) return modifiedFiles.map(modifiedFile => { - robot.log.debug(`${JSON.stringify(modifiedFile)}`) + log.debug(`${JSON.stringify(modifiedFile)}`) return { name: modifiedFile.match(glob)[1] + '.yml', path: modifiedFile } }) } async function createCheckRun (context, pull_request, head_sha, head_branch) { const { payload } = context - robot.log.debug(`Check suite was requested! for ${context.repo()} ${pull_request.number} ${head_sha} ${head_branch}`) + const log = robot.log.child({ context: 'index' }) + log.debug(`Check suite was requested! for ${context.repo()} ${pull_request.number} ${head_sha} ${head_branch}`) const res = await context.octokit.checks.create({ owner: payload.repository.owner.login, repo: payload.repository.name, name: 'Safe-setting validator', head_sha }) - robot.log.debug(JSON.stringify(res, null)) + log.debug(JSON.stringify(res, null)) } async function syncInstallation () { - robot.log.trace('Fetching installations') + const log = robot.log.child({ context: 'index' }) + log.trace('Fetching installations') const github = await robot.auth() const installations = await github.paginate( @@ -198,7 +209,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { if (installations.length > 0) { const installation = installations[0] - robot.log.trace(`${JSON.stringify(installation)}`) + log.trace(`${JSON.stringify(installation)}`) const github = await robot.auth(installation.id) const context = { payload: { @@ -216,6 +227,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { robot.on('push', async context => { const { payload } = context const { repository } = payload + const log = robot.log.child({ context: 'index', event: 'push', repository: repository.name }) const adminRepo = repository.name === env.ADMIN_REPO if (!adminRepo) { @@ -224,7 +236,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { const defaultBranch = payload.ref === 'refs/heads/' + repository.default_branch if (!defaultBranch) { - robot.log.debug('Not working on the default branch, returning...') + log.debug('Not working on the default branch, returning...') return } @@ -233,7 +245,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { commit.modified.includes(Settings.FILE_NAME) }) if (settingsModified) { - robot.log.debug(`Changes in '${Settings.FILE_NAME}' detected, doing a full synch...`) + log.debug(`Changes in '${Settings.FILE_NAME}' detected, doing a full synch...`) return syncAllSettings(false, context) } @@ -251,18 +263,19 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { })) } - robot.log.debug(`No changes in '${Settings.FILE_NAME}' detected, returning...`) + log.debug(`No changes in '${Settings.FILE_NAME}' detected, returning...`) }) robot.on('branch_protection_rule', async context => { const { payload } = context - const { sender } = payload - robot.log.debug('Branch Protection edited by ', JSON.stringify(sender)) + const { sender, repository } = payload + const log = robot.log.child({ context: 'index', event: 'branch_protection_rule', repository: repository.name }) + if (sender.type === 'Bot') { - robot.log.debug('Branch Protection edited by Bot') + log.debug(`Branch Protection edited by a Bot (${sender.login}), returning...`) return } - robot.log.debug('Branch Protection edited by a Human') + log.debug(`Branch Protection edited by a Human (${sender.login})`) return syncSettings(false, context) }) @@ -274,30 +287,31 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { ] robot.on(member_change_events, async context => { const { payload } = context - const { sender } = payload - robot.log.debug('Repository member edited by ', JSON.stringify(sender)) + const { sender, repository } = payload + const log = robot.log.child({ context: 'index', event: 'member_change_events', repository: repository.name }) if (sender.type === 'Bot') { - robot.log.debug('Repository member edited by Bot') + log.debug(`Repository member edited by a Bot (${sender.login}), returning...`) return } - robot.log.debug('Repository member edited by a Human') + log.debug(`Repository member edited by a Human (${sender.login})`) return syncSettings(false, context) }) robot.on('repository.edited', async context => { const { payload } = context const { changes, repository, sender } = payload - robot.log.debug('repository.edited payload from ', JSON.stringify(sender)) + const log = robot.log.child({ context: 'index', event: 'repository.edited', repository: repository.name }) + if (sender.type === 'Bot') { - robot.log.debug('Repository Edited by a Bot') + log.debug(`Repository edited by a Bot (${sender.login}), returning...`) return } - robot.log.debug('Repository Edited by a Human') + log.debug(`Repository edited by a Human (${sender.login}`) if (!Object.prototype.hasOwnProperty.call(changes, 'default_branch')) { - robot.log.debug('Repository configuration was edited but the default branch was not affected, returning...') + log.debug('Repository configuration was edited but the default branch was not affected, returning...') return } - robot.log.debug(`Default branch changed from '${changes.default_branch.from}' to '${repository.default_branch}'`) + log.debug(`Default branch changed from '${changes.default_branch.from}' to '${repository.default_branch}'`) return syncSettings(false, context) }) @@ -305,18 +319,20 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { const { payload } = context const { repository } = payload const adminRepo = repository.name === env.ADMIN_REPO - robot.log.debug(`Is Admin repo event ${adminRepo}`) + const log = robot.log.child({ context: 'index', event: 'check_suite.requested', repository: repository.name }) + + log.debug(`Is Admin repo event ${adminRepo}`) if (!adminRepo) { - robot.log.debug('Not working on the Admin repo, returning...') + log.debug('Not working on the Admin repo, returning...') return } const defaultBranch = payload.check_suite.head_branch === repository.default_branch if (defaultBranch) { - robot.log.debug(' Working on the default branch, returning...') + log.debug(' Working on the default branch, returning...') return } if (!payload.check_suite.pull_requests[0]) { - robot.log.debug('Not working on a PR, returning...') + log.debug('Not working on a PR, returning...') return } const pull_request = payload.check_suite.pull_requests[0] @@ -324,18 +340,20 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { }) robot.on('pull_request.opened', async context => { - robot.log.debug('Pull_request opened !') const { payload } = context const { repository } = payload const adminRepo = repository.name === env.ADMIN_REPO - robot.log.debug(`Is Admin repo event ${adminRepo}`) + const log = robot.log.child({ context: 'index', event: 'pull_request.opened', repository: repository.name }) + + log.debug('Pull_request opened!') + log.debug(`Is Admin repo event ${adminRepo}`) if (!adminRepo) { - robot.log.debug('Not working on the Admin repo, returning...') + log.debug('Not working on the Admin repo, returning...') return } const defaultBranch = payload.pull_request.head_branch === repository.default_branch if (defaultBranch) { - robot.log.debug(' Working on the default branch, returning...') + log.debug('Working on the default branch, returning...') return } const pull_request = payload.pull_request @@ -343,58 +361,59 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { }) robot.on('pull_request.reopened', async context => { - robot.log.debug('Pull_request REopened !') const { payload } = context const { repository } = payload const pull_request = payload.pull_request const adminRepo = repository.name === env.ADMIN_REPO + const log = robot.log.child({ context: 'index', event: 'pull_request.reopened', repository: repository.name }) - robot.log.debug(`Is Admin repo event ${adminRepo}`) + log.debug('Pull request reopened!') + log.debug(`Is Admin repo event ${adminRepo}`) if (!adminRepo) { - robot.log.debug('Not working on the Admin repo, returning...') + log.debug('Not working on the Admin repo, returning...') return } const defaultBranch = payload.pull_request.head_branch === repository.default_branch if (defaultBranch) { - robot.log.debug(' Working on the default branch, returning...') + log.debug(' Working on the default branch, returning...') return } return createCheckRun(context, pull_request, payload.pull_request.head.sha, payload.pull_request.head.ref) }) robot.on(['check_suite.rerequested'], async context => { - robot.log.debug('Check suite was rerequested!') - return createCheckRun(context) - }) - - robot.on(['check_suite.rerequested'], async context => { - robot.log.debug('Check suite was rerequested!') + const { payload } = context + const { repository } = payload + const log = robot.log.child({ context: 'index', event: 'check_suite.rerequested', repository: repository.name }) + log.debug('Check suite was rerequested!') return createCheckRun(context) }) robot.on(['check_run.created'], async context => { - robot.log.debug('Check run was created!') const { payload } = context const { repository } = payload const { check_run } = payload const { check_suite } = check_run const pull_request = check_suite.pull_requests[0] const source = payload.check_run.name === 'Safe-setting validator' + const log = robot.log.child({ context: 'index', event: 'check_run.created', repository: repository.name }) + + log.debug('Check run was created!') if (!source) { - robot.log.debug(' Not triggered by Safe-settings...') + log.debug('Not triggered by Safe-settings...') return } const adminRepo = repository.name === env.ADMIN_REPO - robot.log.debug(`Is Admin repo event ${adminRepo}`) + log.debug(`Is Admin repo event ${adminRepo}`) if (!adminRepo) { - robot.log.debug('Not working on the Admin repo, returning...') + log.debug('Not working on the Admin repo, returning...') return } if (!pull_request) { - robot.log.debug('Not working on a PR, returning...') + log.debug('Not working on a PR, returning...') return } @@ -406,7 +425,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { started_at: new Date().toISOString(), output: { title: 'Starting NOP', summary: 'initiating...' } } - robot.log.debug(`Updating check run ${JSON.stringify(params)}`) + log.debug(`Updating check run ${JSON.stringify(params)}`) await context.octokit.checks.update(params) // guarding against null value from upstream libary that is @@ -422,7 +441,7 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { const settingsModified = files.includes(Settings.FILE_NAME) if (settingsModified) { - robot.log.debug(`Changes in '${Settings.FILE_NAME}' detected, doing a full synch...`) + log.debug(`Changes in '${Settings.FILE_NAME}' detected, doing a full synch...`) return syncAllSettings(true, context, context.repo(), pull_request.head.ref) } @@ -450,14 +469,16 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { conclusion: 'success', output: { title: 'No Safe-settings changes detected', summary: 'No changes detected' } } - robot.log.debug(`Completing check run ${JSON.stringify(params)}`) + log.debug(`Completing check run ${JSON.stringify(params)}`) await context.octokit.checks.update(params) }) robot.on('repository.created', async context => { const { payload } = context - const { sender } = payload - robot.log.debug('repository.created payload from ', JSON.stringify(sender)) + const { sender, repository } = payload + const log = robot.log.child({ context: 'index', event: 'repository.created', repository: repository.name }) + + log.debug('repository.created payload from ', JSON.stringify(sender)) return syncSettings(false, context) }) @@ -474,7 +495,8 @@ module.exports = (robot, _, Settings = require('./lib/settings')) => { # * * * * * * */ cron.schedule(process.env.CRON, () => { - robot.log.debug('running a task every minute') + const log = robot.log.child({ event: 'cron' }) + log.debug(`running a scheduled task (${process.env.CRON})`) syncInstallation() }) } diff --git a/lib/configManager.js b/lib/configManager.js index 58f5bb43..985bdd48 100644 --- a/lib/configManager.js +++ b/lib/configManager.js @@ -6,15 +6,15 @@ module.exports = class ConfigManager { constructor (context, ref) { this.context = context this.ref = ref - this.log = context.log + this.log = context.log.child({ context: 'ConfigManager' }) } /** -* Loads a file from GitHub -* -* @param params Params to fetch the file with -* @return The parsed YAML file -*/ + * Loads a file from GitHub + * + * @param params Params to fetch the file with + * @return The parsed YAML file + */ async loadYaml (filePath) { try { const repo = { owner: this.context.repo().owner, repo: env.ADMIN_REPO } diff --git a/lib/mergeDeep.js b/lib/mergeDeep.js index b942f5f1..f5e760be 100644 --- a/lib/mergeDeep.js +++ b/lib/mergeDeep.js @@ -2,7 +2,7 @@ const mergeBy = require('./mergeArrayBy') const NAME_FIELDS = ['name', 'username'] class MergeDeep { constructor (log, ignorableFields, configvalidators = {}, overridevalidators = {}) { - this.log = log + this.log = log.child({ context: 'MergeDeep' }) this.ignorableFields = ignorableFields this.configvalidators = configvalidators this.overridevalidators = overridevalidators diff --git a/lib/plugins/branches.js b/lib/plugins/branches.js index 2b98ac90..e524f82b 100644 --- a/lib/plugins/branches.js +++ b/lib/plugins/branches.js @@ -8,7 +8,7 @@ module.exports = class Branches { this.github = github this.repo = repo this.branches = settings - this.log = log + this.log = log.child({ context: 'Branches', repository: this.repo.repo }) this.nop = nop } @@ -24,7 +24,7 @@ module.exports = class Branches { let p = Object.assign(this.repo, { branch: branch.name }) if (branch.name === 'default') { p = Object.assign(this.repo, { branch: currentRepo.data.default_branch }) - this.log(`Deleting default branch protection for branch ${currentRepo.data.default_branch}`) + this.log.debug(`Deleting default branch protection for branch ${currentRepo.data.default_branch}`) } // Hack to handle closures and keep params from changing const params = Object.assign({}, p) @@ -41,7 +41,7 @@ module.exports = class Branches { let p = Object.assign(this.repo, { branch: branch.name }) if (branch.name === 'default') { p = Object.assign(this.repo, { branch: currentRepo.data.default_branch }) - // this.log(`Setting default branch protection for branch ${currentRepo.data.default_branch}`) + // this.log.debug(`Setting default branch protection for branch ${currentRepo.data.default_branch}`) } // Hack to handle closures and keep params from changing const params = Object.assign({}, p) @@ -72,7 +72,7 @@ module.exports = class Branches { return Promise.resolve(resArray) } this.log.debug(`Adding branch protection ${JSON.stringify(params)}`) - return this.github.repos.updateBranchProtection(params).then(res => this.log(`Branch protection applied successfully ${JSON.stringify(res.url)}`)).catch(e => { this.log.error(`Error applying branch protection ${JSON.stringify(e)}`); return [] }) + return this.github.repos.updateBranchProtection(params).then(res => this.log.debug(`Branch protection applied successfully ${JSON.stringify(res.url)}`)).catch(e => { this.log.error(`Error applying branch protection ${JSON.stringify(e)}`); return [] }) }).catch((e) => { if (e.status === 404) { Object.assign(params, branch.protection, { headers: previewHeaders }) @@ -81,7 +81,7 @@ module.exports = class Branches { return Promise.resolve(resArray) } this.log.debug(`Adding branch protection ${JSON.stringify(params)}`) - return this.github.repos.updateBranchProtection(params).then(res => this.log(`Branch protection applied successfully ${JSON.stringify(res.url)}`)).catch(e => { this.log.error(`Error applying branch protection ${JSON.stringify(e)}`); return [] }) + return this.github.repos.updateBranchProtection(params).then(res => this.log.debug(`Branch protection applied successfully ${JSON.stringify(res.url)}`)).catch(e => { this.log.error(`Error applying branch protection ${JSON.stringify(e)}`); return [] }) } else { this.log.error(e) // return diff --git a/lib/plugins/diffable.js b/lib/plugins/diffable.js index 4d7f6549..9535e23f 100644 --- a/lib/plugins/diffable.js +++ b/lib/plugins/diffable.js @@ -27,7 +27,7 @@ module.exports = class Diffable { this.github = github this.repo = repo this.entries = entries - this.log = log + this.log = log.child({ context: this.constructor.name, repository: this.repo.repo }) this.nop = nop } diff --git a/lib/plugins/repository.js b/lib/plugins/repository.js index 9883b490..e9d5dd44 100644 --- a/lib/plugins/repository.js +++ b/lib/plugins/repository.js @@ -50,7 +50,7 @@ module.exports = class Repository { this.topics = this.settings.topics this.security = this.settings.security this.repo = repo - this.log = log + this.log = log.child({ context: 'Repository', repository: this.repo.repo }) this.nop = nop this.force_create = this.settings.force_create this.template = this.settings.template @@ -82,10 +82,10 @@ module.exports = class Repository { this.log.debug(`Result of comparing topics for changes source ${JSON.stringify(resp.data.topics)} target ${JSON.stringify(this.topics)} = ${topicResults}`) if (this.nop && changes.hasChanges) { - resArray.push(new NopCommand('Repository', this.repo, null, `Repo settings changes: ${results}`)) + resArray.push(new NopCommand('Repository', this.repo, null, `[${this.settings.name}] Repo settings changes: ${results}`)) } if (this.nop && topicChanges.hasChanges) { - resArray.push(new NopCommand('Repository', this.repo, null, `Repo topics changes ${topicResults}`)) + resArray.push(new NopCommand('Repository', this.repo, null, `[${this.settings.name}] Repo topics changes ${topicResults}`)) } const promises = [] if (changes.hasChanges) { @@ -93,7 +93,7 @@ module.exports = class Repository { if (this.settings.default_branch && (resp.data.default_branch !== this.settings.default_branch)) { this.log.debug('There is a rename of the default branch') if (this.nop) { - resArray.push(new NopCommand('Repository', this.repo, this.github.repos.renameBranch.endpoint(resp.data.default_branch, this.settings.default_branch), `Repo rename default branch to ${this.settings.default_branch}`)) + resArray.push(new NopCommand('Repository', this.repo, this.github.repos.renameBranch.endpoint(resp.data.default_branch, this.settings.default_branch), `[${this.settings.name}] Repo rename default branch to ${this.settings.default_branch}`)) } else { promises.push(this.renameBranch(resp.data.default_branch, this.settings.default_branch)) } @@ -114,7 +114,7 @@ module.exports = class Repository { } else { this.log.debug(`There are no changes for repo ${JSON.stringify(this.repo)}.`) if (this.nop) { - resArray.push(new NopCommand('Repository', this.repo, null, `There are no changes for repo ${JSON.stringify(this.repo)}.`)) + resArray.push(new NopCommand('Repository', this.repo, null, `[${this.settings.name}] There are no changes for repo ${JSON.stringify(this.repo)}.`)) } } if (this.nop) { @@ -126,7 +126,7 @@ module.exports = class Repository { if (e.status === 404) { if (this.force_create) { if (this.template) { - this.log(`Creating repo using template ${this.template}`) + this.log.debug(`Creating repo using template ${this.template}`) const options = { template_owner: this.repo.owner, template_repo: this.template, owner: this.repo.owner, name: this.repo.repo, private: (this.settings.private ? this.settings.private : true), description: this.settings.description ? this.settings.description : '' } if (this.nop) { @@ -139,7 +139,7 @@ module.exports = class Repository { // https://docs.github.com/en/rest/repos/repos#create-an-organization-repository uses org instead of owner like // the API to create a repo with a template this.settings.org = this.settings.owner - this.log('Creating repo with settings ', this.settings) + this.log.debug('Creating repo with settings ', this.settings) if (this.nop) { this.log.debug(`Creating Repo ${JSON.stringify(this.github.repos.createInOrg.endpoint(this.settings))} `) return Promise.resolve([ @@ -162,19 +162,19 @@ module.exports = class Repository { } renameBranch (oldname, newname) { - const parms = { + const params = { owner: this.settings.owner, repo: this.settings.repo, branch: oldname, new_name: newname } - this.log.debug(`Rename default branch repo with settings ${JSON.stringify(parms)}`) + this.log.debug(`Rename default branch repo with settings ${JSON.stringify(params)}`) if (this.nop) { return Promise.resolve([ - new NopCommand(this.constructor.name, this.repo, this.github.repos.renameBranch.endpoint(parms), 'Rename Branch') + new NopCommand(this.constructor.name, this.repo, this.github.repos.renameBranch.endpoint(params), 'Rename Branch') ]) } - return this.github.repos.renameBranch(parms) + return this.github.repos.renameBranch(params) } updaterepo (resArray) { @@ -199,14 +199,14 @@ module.exports = class Repository { if (this.topics) { if (repoData.data?.topics.length !== this.topics.length || !repoData.data?.topics.every(t => this.topics.includes(t))) { - this.log(`Updating repo with topics ${this.topics.join(',')}`) + this.log.debug(`Updating repo with topics ${this.topics.join(',')}`) if (this.nop) { resArray.push((new NopCommand(this.constructor.name, this.repo, this.github.repos.replaceAllTopics.endpoint(parms), 'Update Topics'))) return Promise.resolve(resArray) } return this.github.repos.replaceAllTopics(parms) } else { - this.log(`no need to update topics for ${repoData.data.name}`) + this.log.debug(`no need to update topics for ${repoData.data.name}`) if (this.nop) { resArray.push((new NopCommand(this.constructor.name, this.repo, null, `no need to update topics for ${repoData.data.name}`))) return Promise.resolve(resArray) @@ -218,9 +218,9 @@ module.exports = class Repository { // Added support for Code Security and Analysis updateSecurity (repoData, resArray) { if (this.security?.enableVulnerabilityAlerts === true || this.security?.enableVulnerabilityAlerts === false) { - this.log(`Found repo with security settings ${JSON.stringify(this.security)}`) + this.log.debug(`Found repo with security settings ${JSON.stringify(this.security)}`) if (this.security.enableVulnerabilityAlerts === true) { - this.log(`Enabling Dependabot alerts for owner: ${repoData.owner.login} and repo ${repoData.name}`) + this.log.debug(`Enabling Dependabot alerts for owner: ${repoData.owner.login} and repo ${repoData.name}`) if (this.nop) { resArray.push((new NopCommand(this.constructor.name, this.repo, this.github.repos.enableVulnerabilityAlerts.endpoint({ owner: repoData.owner.login, @@ -234,7 +234,7 @@ module.exports = class Repository { }) } else { - this.log(`Disabling Dependabot alerts for for owner: ${repoData.owner.login} and repo ${repoData.name}`) + this.log.debug(`Disabling Dependabot alerts for for owner: ${repoData.owner.login} and repo ${repoData.name}`) if (this.nop) { resArray.push((new NopCommand(this.constructor.name, this.github.repos.disableVulnerabilityAlerts.endpoint({ owner: repoData.owner.login, @@ -249,7 +249,7 @@ module.exports = class Repository { } } else { - this.log(`no need to update security for ${repoData.name}`) + this.log.debug(`no need to update security for ${repoData.name}`) if (this.nop) { resArray.push((new NopCommand(this.constructor.name, this.repo, null, `no need to update security for ${repoData.name}`))) return Promise.resolve(resArray) @@ -289,4 +289,4 @@ module.exports = class Repository { } } } -} \ No newline at end of file +} diff --git a/lib/plugins/validator.js b/lib/plugins/validator.js index ee16c281..e97896c2 100644 --- a/lib/plugins/validator.js +++ b/lib/plugins/validator.js @@ -6,7 +6,7 @@ module.exports = class Validator { // this.regex = /[a-zA-Z0-9_-]+_\w[a-zA-Z0-9_-]+.*/gm this.regex = new RegExp(this.pattern, 'gm') this.repo = repo - this.log = log + this.log = log.child({ context: 'Validator', repository: this.repo.repo }) this.nop = nop } @@ -20,7 +20,7 @@ module.exports = class Validator { } }).then(res => { if (this.repo.repo.search(this.regex) >= 0) { - this.log(`Repo ${this.repo.repo} Passed Validation for pattern ${this.pattern}`) + this.log.debug(`Repo ${this.repo.repo} Passed Validation for pattern ${this.pattern}`) if (this.nop) { return Promise.resolve([ new NopCommand(this.constructor.name, this.repo, null, `Passed Validation for pattern ${this.pattern}`) @@ -38,7 +38,7 @@ module.exports = class Validator { }) } } else { - this.log(`Repo ${this.repo.repo} Failed Validation for pattern ${this.pattern}`) + this.log.warn(`Repo ${this.repo.repo} Failed Validation for pattern ${this.pattern}`) if (this.nop) { return Promise.resolve([ new NopCommand(this.constructor.name, this.repo, null, `Failed Validation for pattern ${this.pattern}`) @@ -59,7 +59,7 @@ module.exports = class Validator { }) .catch(() => {}) } catch (error) { - this.log(`Error in Validation checking ${error}`) + this.log.error(`Error in Validation checking ${error}`) } } } diff --git a/lib/settings.js b/lib/settings.js index 86b5e1dd..1c28e5ab 100644 --- a/lib/settings.js +++ b/lib/settings.js @@ -51,7 +51,7 @@ class Settings { if (suborg) { this.subOrgConfigMap = [suborg] } - this.log = context.log + this.log = context.log.child({ context: 'Settings', repository: this.repo.repo }) this.results = [] this.configvalidators = {} this.overridevalidators = {} @@ -198,7 +198,7 @@ ${this.results.reduce((x, y) => { // If suborg config has been updated then only restrict to the repos for that suborg if (this.subOrgConfigMap && !subOrgConfig) { - this.log.debug(`Skipping... SubOrg config changed but this repo is not part of it. ${JSON.stringify(repo)} suborg config ${JSON.stringify(this.subOrgConfigMap)}`) + this.log.info(`Skipping... SubOrg config changed but this repo is not part of it. ${JSON.stringify(repo)} suborg config ${JSON.stringify(this.subOrgConfigMap)}`) return } @@ -286,10 +286,10 @@ ${this.results.reduce((x, y) => { if (Array.isArray(baseConfig) && Array.isArray(config)) { for (const baseEntry of baseConfig) { const newEntry = config.find(e => e.name === baseEntry.name) - this.validate(section, baseEntry, newEntry) + this.validate(repoName, section, baseEntry, newEntry) } } else { - this.validate(section, baseConfig, config) + this.validate(repoName, section, baseConfig, config) } if (section !== 'repositories' && section !== 'repository') { // Ignore any config that is not a plugin @@ -303,7 +303,7 @@ ${this.results.reduce((x, y) => { return childPlugins } - validate (section, baseConfig, overrideConfig) { + validate (repoName, section, baseConfig, overrideConfig) { const configValidator = this.configvalidators[section] if (configValidator) { this.log.debug(`Calling configvalidator for key ${section} `) @@ -328,7 +328,7 @@ ${this.results.reduce((x, y) => { if (Array.isArray(restrictedRepos)) { // For backward compatibility support the old format if (restrictedRepos.includes(repoName)) { - this.log.debug(`Skipping retricted repo ${repoName}`) + this.log.info(`Skipping retricted repo ${repoName}`) return true } else { this.log.debug(`${repoName} not in restricted repos ${restrictedRepos}`) @@ -339,12 +339,12 @@ ${this.results.reduce((x, y) => { this.log.debug(`Allowing ${repoName} in restrictedRepos.include [${restrictedRepos.include}]`) return false } else { - this.log.debug(`Skipping repo ${repoName} not in restrictedRepos.include`) + this.log.info(`Skipping repo ${repoName} not in restrictedRepos.include`) return true } } else if (Array.isArray(restrictedRepos.exclude)) { if (this.includesRepo(repoName, restrictedRepos.exclude)) { - this.log.debug(`Skipping excluded repo ${repoName} in restrictedRepos.exclude`) + this.log.info(`Skipping excluded repo ${repoName} in restrictedRepos.exclude`) return true } else { this.log.debug(`Allowing ${repoName} not in restrictedRepos.exclude [${restrictedRepos.exclude}]`) @@ -453,8 +453,8 @@ ${this.results.reduce((x, y) => { // read the repo contents using tree this.log.debug(`repos directory info ${JSON.stringify(repoDirInfo)}`) - //const endpoint = `/repos/${this.repo.owner}/${repo.repo}/git/trees/${repoDirInfo.sha}` - //this.log.debug(`endpoint: ${endpoint}`) + // const endpoint = `/repos/${this.repo.owner}/${repo.repo}/git/trees/${repoDirInfo.sha}` + // this.log.debug(`endpoint: ${endpoint}`) const treeParams = Object.assign(repo, { tree_sha: repoDirInfo.sha, recursive: 0 }) const response = await this.github.git.getTree(treeParams).catch(e => { this.log.debug(`Error getting settings ${JSON.stringify(this.github.git.getTree.endpoint(treeParams))} ${e}`) diff --git a/lib/validator.js b/lib/validator.js index 6d61e040..d675a7ff 100644 --- a/lib/validator.js +++ b/lib/validator.js @@ -5,7 +5,7 @@ module.exports = class Validator { // this.regex = /[a-zA-Z0-9_-]+_\w[a-zA-Z0-9_-]+.*/gm this.regex = new RegExp(this.pattern, 'gm') this.repo = repo - this.log = log + this.log = log.child({ context: 'Validator', repository: this.repo.repo }) } sync () { @@ -18,7 +18,7 @@ module.exports = class Validator { } }).then(res => { if (this.repo.repo.search(this.regex) >= 0) { - this.log(`Repo ${this.repo.repo} Passed Validation for pattern ${this.pattern}`) + this.log.debug(`Repo ${this.repo.repo} Passed Validation for pattern ${this.pattern}`) if (res.data.names.find(x => x === 'validation-error')) { res.data.names = res.data.names.filter(x => x !== 'validation-error') return this.github.repos.replaceAllTopics({ @@ -31,7 +31,7 @@ module.exports = class Validator { }) } } else { - this.log(`Repo ${this.repo.repo} Failed Validation for pattern ${this.pattern}`) + this.log.error(`Repo ${this.repo.repo} Failed Validation for pattern ${this.pattern}`) if (!res.data.names.find(x => x === 'validation-error')) { res.data.names.push('validation-error') return this.github.repos.replaceAllTopics({ @@ -46,7 +46,7 @@ module.exports = class Validator { } }) } catch (error) { - this.log(`Error in Validation checking ${error}`) + this.log.error(`Error in Validation checking ${error}`) } } }