Files
shields/services/keybase/keybase-pgp.service.js
chris48s c73072deed Remove requestOptions2GotOptions compatibility layer (#7270)
* 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>
2021-11-15 19:56:08 +00:00

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 })
}
}