Pour faire suite à la discussion dans User API keys specification :
J’ai créé un petit script utilitaire pour tester les clés API utilisateur localement.
D’abord, installez les dépendances :
gem install addressable openssl base64 json
Ensuite, le script se trouve ici :
require 'addressable'
require 'openssl'
require 'base64'
require 'json'
PRIVATE_KEY = OpenSSL::PKey::RSA.new(2048)
PUBLIC_KEY = PRIVATE_KEY.public_key
puts 'Quel est le site cible ?'
site = STDIN.gets.chomp
template = Addressable::Template.new("#{site}/user-api-key/new{?query*}")
url = template.expand({
query: {
application_name: 'ruby',
client_id: `hostname`,
scopes: 'read',
public_key: PUBLIC_KEY,
nonce: 1
}
})
puts "naviguez vers #{url}."
puts
puts "copiez la clé générée ici"
puts
puts "appuyez sur ENTRÉE, tapez end et appuyez à nouveau sur ENTRÉE"
puts
$/ = "end"
encoded_key = STDIN.gets.chomp
user_api_key = JSON.parse(PRIVATE_KEY.private_decrypt(Base64.decode64(encoded_key)))
puts "Votre clé API utilisateur est #{user_api_key['key']}"