* gzip --> decompress * strictSSL --> https.rejectUnauthorized * auth --> username/password * qs --> searchParams * fix base service auth docs * completely remove requestOptions2GotOptions layer * update the docs Co-authored-by: repo-ranger[bot] <39074581+repo-ranger[bot]@users.noreply.github.com>
78 lines
1.6 KiB
JavaScript
78 lines
1.6 KiB
JavaScript
import Joi from 'joi'
|
|
import { nonNegativeInteger } from '../validators.js'
|
|
import KeybaseProfile from './keybase-profile.js'
|
|
|
|
const keyFingerprintSchema = Joi.object({
|
|
status: Joi.object({
|
|
code: nonNegativeInteger.required(),
|
|
}).required(),
|
|
them: Joi.array()
|
|
.items(
|
|
Joi.object({
|
|
public_keys: {
|
|
primary: {
|
|
key_fingerprint: Joi.string().hex().required(),
|
|
},
|
|
},
|
|
})
|
|
.required()
|
|
.allow(null)
|
|
)
|
|
.min(0)
|
|
.max(1),
|
|
}).required()
|
|
|
|
export default class KeybasePGP extends KeybaseProfile {
|
|
static route = {
|
|
base: 'keybase/pgp',
|
|
pattern: ':username',
|
|
}
|
|
|
|
static examples = [
|
|
{
|
|
title: 'Keybase PGP',
|
|
namedParams: { username: 'skyplabs' },
|
|
staticPreview: this.render({ fingerprint: '1863145FD39EE07E' }),
|
|
},
|
|
]
|
|
|
|
static defaultBadgeData = {
|
|
label: 'pgp',
|
|
color: 'informational',
|
|
}
|
|
|
|
static render({ fingerprint }) {
|
|
return {
|
|
message: fingerprint.slice(-16).toUpperCase(),
|
|
}
|
|
}
|
|
|
|
static apiVersion = '1.0'
|
|
|
|
async handle({ username }) {
|
|
const options = {
|
|
searchParams: {
|
|
usernames: username,
|
|
fields: 'public_keys',
|
|
},
|
|
}
|
|
|
|
const data = await this.fetch({
|
|
schema: keyFingerprintSchema,
|
|
options,
|
|
})
|
|
|
|
const { user } = this.transform({ data })
|
|
const primaryKey = user.public_keys.primary
|
|
|
|
if (primaryKey == null) {
|
|
return {
|
|
message: 'no key fingerprint found',
|
|
color: 'inactive',
|
|
}
|
|
}
|
|
|
|
return this.constructor.render({ fingerprint: primaryKey.key_fingerprint })
|
|
}
|
|
}
|