Greasy Fork is available in English.

Proven

Show Keybase Proofs on Twitter Profiles

// ==UserScript==
// @name         Proven
// @namespace    http://tampermonkey.net/
// @version      0.8
// @description  Show Keybase Proofs on Twitter Profiles
// @author       Daniel Schep
// @match        https://twitter.com/*
// @grant        GM_xmlhttpRequest
// ==/UserScript==

(function() {
  'use strict';

  const icons = {
    keybase: '',
    hackernews: '',
    reddit: '',
    twitter: '',
    github: '',
    generic_web_site: '',
    dns: '',
    facebook: '',
  };

  const users = new Map();
  const getUser = (username) => {
    if (!users.has(username)) {
      users.set(
        username,
        new Promise((resolve, reject) => GM_xmlhttpRequest({
          method: 'GET',
          url: `https://keybase.io/_/api/1.0/user/lookup.json?twitter=${username}`,
            onload: resolve,
          onerror: reject,
        }))
          .then(({response}) => JSON.parse(response))
          .then(({them: [{proofs_summary: {all}, basics: {username}}]}) => [{
            nametag: username,
            service_url: `https://keybase.io/${username}`,
              proof_type: 'keybase',
          }, ...all])
      );
    }
    return users.get(username);
  };

  const getProfileInfo = () => {
    const element = document.querySelector('.ProfileHeaderCard-screenname:not(.proven)');
    if (!element) return;
    const user = element.querySelector('b').innerText;
    element.classList.add('proven');
    getUser(user)
      .then((proofs) => proofs.map(({proof_type, nametag, service_url}) => {
        if (proof_type === 'twitter') return;
        element.innerHTML +=`
        <br/>
        <a href="${service_url}" class="ProfileHeaderCard-screennameLink u-linkComplex js-nav">
        <b><img src="${icons[proof_type]}"/> ${nametag}</b>
        </a>
        `;
      }));
  };
  window.setInterval(getProfileInfo, 1000);
  const getTweetInfo = () => {
    Array.from(document.querySelectorAll('.tweet .account-group:not(.proven)'))
      .map(parent => {
        parent.classList.add('proven');
        const user = parent.querySelector('.username b').innerText;
        const element = parent.querySelector('.UserBadges');
        getUser(user)
          .then((proofs) => proofs.map(({proof_type, nametag, service_url}) => {
            if (proof_type === 'twitter') return;
            element.innerHTML +=`
            <a href="${service_url}" title="${nametag}"><img src="${icons[proof_type]}"/></a>
            `;
          }));
      });
  };
  window.setInterval(getTweetInfo, 1000);
})();