Skip to content

Commit

Permalink
Add homebrew downloads badge
Browse files Browse the repository at this point in the history
  • Loading branch information
kdheepak committed Feb 21, 2021
1 parent 1adfbe4 commit 79c607f
Show file tree
Hide file tree
Showing 5 changed files with 114 additions and 4 deletions.
82 changes: 82 additions & 0 deletions services/homebrew/homebrew-downloads.service.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
'use strict'

const Joi = require('joi')
const { downloadCount } = require('../color-formatters')
const { metric } = require('../text-formatters')
const { BaseJsonService } = require('..')
const { nonNegativeInteger } = require('../validators')

function getSchema({ formula }) {
return Joi.object({
analytics: Joi.object({
install: Joi.object({
'30d': Joi.object({ [formula]: nonNegativeInteger }).required(),
'90d': Joi.object({ [formula]: nonNegativeInteger }).required(),
'365d': Joi.object({ [formula]: nonNegativeInteger }).required(),
}).required(),
install_on_request: Joi.object({
'30d': Joi.object({ [formula]: nonNegativeInteger }).required(),
'90d': Joi.object({ [formula]: nonNegativeInteger }).required(),
'365d': Joi.object({ [formula]: nonNegativeInteger }).required(),
}).required(),
}).required(),
}).required()
}

const periodMap = {
dm: {
api_field: '30d',
suffix: '/month',
},
dq: {
api_field: '90d',
suffix: '/quarter',
},
dy: {
api_field: '365d',
suffix: '/year',
},
}

module.exports = class HomebrewDownloads extends BaseJsonService {
static category = 'downloads'

static route = {
base: 'homebrew',
pattern: 'installs/:interval(dm|dq|dy)/:formula',
}

static examples = [
{
title: 'homebrew downloads',
namedParams: { interval: 'dm', formula: 'cake' },
staticPreview: this.render({ interval: 'dm', downloads: 93 }),
},
]

static defaultBadgeData = { label: 'downloads' }

static render({ interval, downloads }) {
return {
message: `${metric(downloads)}${periodMap[interval].suffix}`,
color: downloadCount(downloads),
}
}

async fetch({ formula }) {
const schema = getSchema({ formula })
return this._requestJson({
schema,
url: `https://formulae.brew.sh/api/formula/${formula}.json`,
errorMessages: { 404: 'formula not found' },
})
}

async handle({ interval, formula }) {
const data = await this.fetch({ formula })
return this.constructor.render({
interval,
downloads: data.analytics.install[periodMap[interval].api_field][formula],
})
}
}
28 changes: 28 additions & 0 deletions services/homebrew/homebrew-downloads.tester.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
'use strict'

const t = (module.exports = require('../tester').createServiceTester())
const { isMetricOverTimePeriod } = require('../test-validators')

t.create('daily downloads (valid)')
.get('/installs/dm/cake.json')
.expectBadge({ label: 'downloads', message: isMetricOverTimePeriod })

t.create('yearly downloads (valid)')
.get('/installs/dq/cake.json')
.expectBadge({ label: 'downloads', message: isMetricOverTimePeriod })

t.create('yearly downloads (valid)')
.get('/installs/dy/cake.json')
.expectBadge({ label: 'downloads', message: isMetricOverTimePeriod })

t.create('daily downloads (not found)')
.get('/installs/dm/not-a-package.json')
.expectBadge({ label: 'downloads', message: 'formula not found' })

t.create('yearly downloads (not found)')
.get('/installs/dq/not-a-package.json')
.expectBadge({ label: 'downloads', message: 'formula not found' })

t.create('yearly downloads (not found)')
.get('/installs/dy/not-a-package.json')
.expectBadge({ label: 'downloads', message: 'formula not found' })
Original file line number Diff line number Diff line change
Expand Up @@ -10,14 +10,14 @@ const schema = Joi.object({
}).required(),
}).required()

module.exports = class Homebrew extends BaseJsonService {
module.exports = class HomebrewVersion extends BaseJsonService {
static category = 'version'

static route = { base: 'homebrew/v', pattern: ':formula' }

static examples = [
{
title: 'homebrew',
title: 'homebrew version',
namedParams: { formula: 'cake' },
staticPreview: renderVersionBadge({ version: 'v0.32.0' }),
},
Expand Down
File renamed without changes.
4 changes: 2 additions & 2 deletions services/test-validators.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,10 @@ const isMetricOverMetric = withRegex(
)

const isMetricOverTimePeriod = withRegex(
/^([1-9][0-9]*[kMGTPEZY]?|[1-9]\.[1-9][kMGTPEZY])\/(year|month|four weeks|week|day)$/
/^([1-9][0-9]*[kMGTPEZY]?|[1-9]\.[1-9][kMGTPEZY])\/(year|month|four weeks|quarter|week|day)$/
)

const isZeroOverTimePeriod = withRegex(/^0\/(year|month|four weeks|week|day)$/)
const isZeroOverTimePeriod = withRegex(/^0\/(year|month|four weeks|quarter|week|day)$/)

const isIntegerPercentage = withRegex(/^[1-9][0-9]?%|^100%|^0%$/)
const isDecimalPercentage = withRegex(/^[0-9]+\.[0-9]*%$/)
Expand Down

0 comments on commit 79c607f

Please sign in to comment.