Ruby GpgmeでのPassPhraseコールバックを使用します
質問
Ruby Gpgme Gem(1.0.8)を使用しています。私のパスフレーズコールバックは呼び出されません:
def passfunc(*args)
fd = args.last
io = IO.for_fd(fd, 'w')
io.puts "mypassphrase"
io.flush
end
opts = {
:passphrase_callback => method(:passfunc)
}
GPGME.decrypt(input,output, opts)
誰かがパスフレーズコールバックの実用的な例を持っていますか?
解決
コールバックのサンプルは、次の作業例で見つけることができます。デタッチされたモードでファイルに署名します。つまり、署名ファイルは元のファイルから分離されています。 〜/.gnupgまたはそのようなものでデフォルトのキーリングを使用します。キーリングに別のディレクトリを使用するには、環境変数env ["gnupghome"] = ""を呼び出す前にgpgme :: sign()を設定します。
#!/usr/bin/ruby
require 'rubygems'
require 'gpgme'
puts "Signing #{ARGV[0]}"
input = File.open(ARGV[0],'r')
PASSWD = "abc"
def passfunc(hook, uid_hint, passphrase_info, prev_was_bad, fd)
puts("Passphrase for #{uid_hint}: ")
io = IO.for_fd(fd, 'w')
io.write(PASSWD+"\n")
io.flush
end
output = File.open(ARGV[0]+'.asc','w')
sign = GPGME::sign(input, {
:passphrase_callback => method(:passfunc),
:mode => GPGME::SIG_MODE_DETACH
})
output.write(sign)
output.close
input.close
他のヒント
これは、分離された署名を使用しない別の作業例です。これをテストするには、「user@host.name」をキーの識別子に変更して、これを行います。GPG.DECRYPT(gpg.encrypt( 'some text'、:armor => true))
require 'gpgme'
require 'highline/import'
module GPG
ENCRYPT_KEY = 'user@host.com'
@gpg = GPGME::Crypto.new
class << self
def decrypt(encrypted_data, options = {})
options = { :passphrase_callback => self.method(:passfunc) }.merge(options)
@gpg.decrypt(encrypted_data, options).read
end
def encrypt(data_to_encrypt, options = {})
options = { :passphrase_callback => self.method(:passfunc), :armor => true }.merge(options)
@gpg.encrypt(data_to_encrypt, options).read
end
private
def get_passphrase
ask("Enter passphrase for #{ENCRYPT_KEY}: ") { |q| q.echo = '*' }
end
def passfunc(hook, uid_hint, passphrase_info, prev_was_bad, fd)
begin
system('stty -echo')
io = IO.for_fd(fd, 'w')
io.puts(get_passphrase)
io.flush
ensure
(0 ... $_.length).each do |i| $_[i] = ?0 end if $_
system('stty echo')
end
$stderr.puts
end
end
end
乾杯!、
- カール
所属していません StackOverflow