Guest User

Untitled

a guest
Jul 9th, 2018
112
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.21 KB | None | 0 0
  1. #!/usr/bin/ruby
  2.  
  3. require 'rubygems'
  4. require 'fsr'
  5. require 'fsr/listener/outbound'
  6. require 'activerecord'
  7.  
  8. FSR.load_all_commands
  9.  
  10. class Card < ActiveRecord::Base
  11. ActiveRecord::Base.establish_connection(
  12. :adapter => "mysql",
  13. :host => "localhost",
  14. :username => "root",
  15. :password => "",
  16. :database => "callcard_development"
  17. )
  18. end
  19.  
  20. class Destination < ActiveRecord::Base
  21. ActiveRecord::Base.establish_connection(
  22. :adapter => "mysql",
  23. :host => "localhost",
  24. :username => "root",
  25. :password => "",
  26. :database => "callcard_development"
  27. )
  28. end
  29.  
  30. class CallCard < FSR::Listener::Outbound
  31. def session_initiated
  32. exten = @session.headers[:caller_caller_id_number]
  33. pin_wav = "/usr/local/freeswitch/sounds/en/us/callie/conference/8000/conf-pin.wav"
  34. bad_pin_wav = "/usr/local/freeswitch/sounds/en/us/callie/conference/8000/conf-bad-pin.wav"
  35. dial_tone = "tone_stream://%(10000,0,350,440)"
  36. FSR::Log.info "*** Answering incoming call from #{exten}"
  37. answer do
  38. fs_sleep(2000) do
  39. play_and_get_digits(pin_wav, bad_pin_wav, 2, 10, 3, 7000, ["#"], "pin_number", "\\d") do |pin_number|
  40. @card = Card.find_by_card_number(pin_number)
  41. if @card then
  42. FSR::Log.info "*** Success, grabbed #{pin_number} from #{exten}"
  43. play_and_get_digits(dial_tone, bad_pin_wav, 2, 11, 3, 7000, ["#"], "destination_number", "\\d") do |destination_number|
  44. prefix = destination_number[0,5]
  45. @destination = Destination.find_by_prefix(prefix)
  46. FSR::Log.info "*** Success, grabbed #{destination_number} from #{exten}"
  47. FSR::Log.info "*** Setting up the billing variables."
  48. uuid_setvar(@session.headers[:unique_id], 'nibble_rate', @destination.rate)
  49. uuid_setvar(@session.headers[:unique_id], 'nibble_account', @card.id)
  50. destination_status
  51. FSR::Log.info "*** Bridging."
  52. FSR::Log.info "*** You have #{duration} minutes to talk."
  53. speak("You have #{duration} minutes to talk.")
  54. #api("sched_api +#{(duration*60)-60} none uuid_displace #{@session.headers[:unique_id]} start tone_stream://%(500,0,500)")
  55. transfer("#{destination_number}", "XML", "default") { close_connection }
  56. #bridge("sofia/internal/#{destination_number}@0.0.0.0")
  57. end
  58. else
  59. FSR::Log.info "*** Failure, grabbed #{pin_number} from #{exten}"
  60. playback(bad_pin_wav)
  61. FSR::Log.info "*** Hanging up the call."
  62. hangup
  63. end
  64. end
  65. end
  66. end
  67. end
  68.  
  69. def duration
  70. @duration = @card.balance.to_i / @destination.rate.to_i
  71. return @duration
  72. end
  73.  
  74. def destination_status
  75. FSR::Log.info "=================================================="
  76. FSR::Log.info "*** Destination rate: #{@destination.rate}"
  77. FSR::Log.info "*** Card ID: #{@card.id}"
  78. FSR::Log.info "*** Destination: #{@destination.country}"
  79. FSR::Log.info "=================================================="
  80. end
  81. end
  82.  
  83. FSR.start_oes! CallCard, :port => 8084, :host => "127.0.0.1"
Add Comment
Please, Sign In to add comment