aboutsummaryrefslogtreecommitdiff
path: root/3.2/mail.rb
blob: e8f9cdd73419a9eed9703ee4686bf99929cb5d4a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#!/usr/bin/env ruby

require 'openssl'
require 'securerandom'
require 'sinatra'

set :port, 4568

Service = "Mail"
ServicePassword = "{FvM<kgG}VpHxKJO;6Zo"

def decrypt(ticket)
  ticket = [ticket].pack("H*").unpack("C*").pack("c*")
  cipher = OpenSSL::Cipher::AES.new(256, :CBC).decrypt
  cipher.key = Digest::SHA2.digest(ServicePassword)
  cipher.update(ticket) + cipher.final
end

post '/login' do
  request.body.rewind
  data = JSON.parse(request.body.read)
  next "Invalid request\n" unless data.keys.sort == %w(ticket username)
  un, ws, sn, ls, ts = decrypt(data["ticket"]).split(?\0)
  ls = ls.to_i
  ts = ts.to_i
  next "Invalid ticket\n" unless sn == Service
  next "Invalid ticket\n" unless un == data["username"]
  next "Invalid ticket\n" unless ws == request.ip
  next "Invalid ticket\n" unless Time.now.to_i >= ts
  next "Ticket expired\n" unless Time.now.to_i < (ts + ls)
  "Login okay! You have no mail.\n"
end