Files
shields/services/sonar/sonar-base.js
dependabot-preview[bot] 294aa1e1df Build(deps-dev): bump eslint-plugin-import from 2.17.3 to 2.18.0; autofixes (#3671)
* Build(deps-dev): bump eslint-plugin-import from 2.17.3 to 2.18.0

Bumps [eslint-plugin-import](https://github.com/benmosher/eslint-plugin-import) from 2.17.3 to 2.18.0.
- [Release notes](https://github.com/benmosher/eslint-plugin-import/releases)
- [Changelog](https://github.com/benmosher/eslint-plugin-import/blob/master/CHANGELOG.md)
- [Commits](https://github.com/benmosher/eslint-plugin-import/compare/v2.17.3...v2.18.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>

* Autofixes
2019-07-08 12:13:46 -04:00

100 lines
2.4 KiB
JavaScript

'use strict'
const Joi = require('@hapi/joi')
const serverSecrets = require('../../lib/server-secrets')
const { isLegacyVersion } = require('./sonar-helpers')
const { BaseJsonService } = require('..')
const schema = Joi.object({
component: Joi.object({
measures: Joi.array()
.items(
Joi.object({
metric: Joi.string().required(),
value: Joi.alternatives(
Joi.number().min(0),
Joi.allow('OK', 'ERROR')
).required(),
}).required()
)
.required(),
}).required(),
}).required()
const legacyApiSchema = Joi.array()
.items(
Joi.object({
msr: Joi.array()
.items(
Joi.object({
key: Joi.string().required(),
val: Joi.alternatives(
Joi.number().min(0),
Joi.allow('OK', 'ERROR')
).required(),
}).required()
)
.required(),
}).required()
)
.required()
module.exports = class SonarBase extends BaseJsonService {
async fetch({ sonarVersion, protocol, host, component, metricName }) {
let qs, url
const useLegacyApi = isLegacyVersion({ sonarVersion })
if (useLegacyApi) {
url = `${protocol}://${host}/api/resources`
qs = {
resource: component,
depth: 0,
metrics: metricName,
includeTrends: true,
}
} else {
url = `${protocol}://${host}/api/measures/component`
qs = {
componentKey: component,
metricKeys: metricName,
}
}
const options = { qs }
if (serverSecrets.sonarqube_token) {
options.auth = {
user: serverSecrets.sonarqube_token,
}
}
return this._requestJson({
schema: useLegacyApi ? legacyApiSchema : schema,
url,
options,
errorMessages: {
404: 'component or metric not found, or legacy API not supported',
},
})
}
transform({ json, sonarVersion }) {
const useLegacyApi = isLegacyVersion({ sonarVersion })
const metrics = {}
if (useLegacyApi) {
json[0].msr.forEach(measure => {
// Most values are numeric, but not all of them.
metrics[measure.key] = parseInt(measure.val) || measure.val
})
} else {
json.component.measures.forEach(measure => {
// Most values are numeric, but not all of them.
metrics[measure.metric] = parseInt(measure.value) || measure.value
})
}
return metrics
}
}