接续自 用户 API 密钥规范 的讨论:
我创建了一个小的实用脚本来在本地测试用户 API 密钥。
首先安装依赖项:
然后脚本在这里:
require 'addressable'
require 'openssl'
require 'base64'
require 'json'
PRIVATE_KEY = OpenSSL::PKey::RSA.new(2048)
PUBLIC_KEY = PRIVATE_KEY.public_key
puts '目标站点是什么?'
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 "导航到 #{url}。"
puts
puts "将生成的密钥复制到此处"
puts
puts "按 ENTER,然后输入 end 再按 ENTER"
puts
$/ = "end"
encoded_key = STDIN.gets.chomp
user_api_key = JSON.parse(PRIVATE_KEY.private_decrypt(Base64.decode64(encoded_key)))
puts "您的用户 API 密钥是 #{user_api_key['key']}"