Skip to content

Instantly share code, notes, and snippets.

@abloom
Created December 30, 2010 17:54
Show Gist options
  • Save abloom/760052 to your computer and use it in GitHub Desktop.
Save abloom/760052 to your computer and use it in GitHub Desktop.
#!/usr/bin/env ruby
require 'logger'
$stdout.sync = true
$stdin.sync = true
path = "/usr/local/var/log/ejabberd/auth.log"
file = File.open(path, File::WRONLY | File::APPEND | File::CREAT)
file.sync = true
logger = Logger.new(file)
logger.level = Logger::DEBUG
logger.info "Starting ejabberd authentication service"
loop do
begin
$stdin.eof? # wait for input
start = Time.now
msg = $stdin.read(2)
length = msg.unpack('n').first
msg = $stdin.read(length)
cmd, *data = msg.split(":")
logger.info "Incoming Request: '#{cmd}'"
success = case cmd
when "auth"
logger.info "Authenticating #{data[0]}@#{data[1]}"
data[2] == "password"
else
false
end
bool = success ? 1 : 0
$stdout.write [2, bool].pack("nn")
logger.info "Response: #{success ? "success" : "failure"}"
rescue => e
logger.error "#{e.class.name}: #{e.message}"
logger.error e.backtrace.join("\n\t")
end
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment