diff options
| author | Brendan G. Lim | 2009-02-18 20:25:05 -0500 |
|---|---|---|
| committer | Brendan G. Lim | 2009-02-18 20:25:05 -0500 |
| commit | 8abc7168dd392b083fdfd3a9cb2ce1e7c1d068a0 (patch) | |
| tree | 0164494d431aec410a74d733914f520e98b74d15 /lib | |
| parent | 4e5aa349ac9d4c12da5d53de08d1fd3281bcfa0d (diff) | |
| download | sms-fu-8abc7168dd392b083fdfd3a9cb2ce1e7c1d068a0.tar.bz2 | |
Some structural changes to SMS Fu
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/sms_fu.rb | 30 |
1 files changed, 19 insertions, 11 deletions
diff --git a/lib/sms_fu.rb b/lib/sms_fu.rb index 6e22079..3ba2c21 100644 --- a/lib/sms_fu.rb +++ b/lib/sms_fu.rb @@ -22,45 +22,53 @@ require 'sms_notifier' # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. module SMSFu + def self.included(base) + base.class_eval do + def self.has_sms_fu + include SMSFu + end + end + end + RAILS_CONFIG_ROOT = defined?(RAILS_ROOT) ? "#{RAILS_ROOT}/config" : "#{File.dirname(__FILE__)}/../templates" unless defined?(RAILS_CONFIG_ROOT) @config ||= YAML::load(File.open("#{RAILS_CONFIG_ROOT}/sms_fu.yml")) @@carriers ||= @config['carriers'] @@from_address = @config['config']['from_address'] - + def self.carriers @@carriers.dup end - + def deliver_sms(number,carrier,message,options={}) raise SMSFuException.new("Cannot deliver an empty message to #{format_number(number)}") if message.nil? or message.empty? - + options[:limit] ||= message.length options[:from] ||= @@from_address message = message[0..options[:limit]-1] sms_email = determine_sms_email(format_number(number),carrier) - + SmsNotifier.deliver_sms_message(sms_email,message,options[:from]) rescue SMSFuException => exception raise exception end - + def get_sms_address(number,carrier) number = format_number(number) determine_sms_email(number,carrier) end - + private - + def format_number(number) pre_formatted = number.gsub("-","").strip formatted = (pre_formatted.length == 11 && pre_formatted[0,1] == "1") ? pre_formatted[1..pre_formatted.length] : pre_formatted return is_valid?(formatted) ? formatted : (raise SMSFuException.new("Phone number (#{number}) is not formatted correctly")) end - + def is_valid?(number) number.length >= 10 && number[/^.\d+$/] end - + def determine_sms_email(phone_number, carrier) if @@carriers.has_key?(carrier.downcase) "#{phone_number}#{@@carriers[carrier.downcase]}" @@ -68,6 +76,6 @@ module SMSFu raise SMSFuException.new("Specified carrier, #{carrier} is not supported.") end end - + class SMSFuException < StandardError; end -end
\ No newline at end of file +end |
