Files
grecia/lib/sms_api.rb
Javi Martín d0d681a44b Add and apply EmptyLineAfterGuardClause rule
We were inconsistent on this one. I consider it particularly useful when
a method starts with a `return` statement.

In other cases, we probably shouldn't have a guard rule in the middle of
a method in any case, but that's a different refactoring.
2019-10-24 17:56:03 +02:00

58 lines
1.4 KiB
Ruby

require "open-uri"
class SMSApi
attr_accessor :client
def initialize
@client = Savon.client(wsdl: url)
end
def url
return "" unless end_point_available?
open(Rails.application.secrets.sms_end_point).base_uri.to_s
end
def authorization
Base64.encode64("#{Rails.application.secrets.sms_username}:#{Rails.application.secrets.sms_password}")
end
def sms_deliver(phone, code)
return stubbed_response unless end_point_available?
response = client.call(:enviar_sms_simples, message: request(phone, code))
success?(response)
end
def request(phone, code)
{ autorizacion: authorization,
destinatarios: { destinatario: phone },
texto_mensaje: "Clave para verificarte: #{code}. Gobierno Abierto",
solicita_notificacion: "All" }
end
def success?(response)
response.body[:respuesta_sms][:respuesta_servicio_externo][:texto_respuesta] == "Success"
end
def end_point_available?
Rails.env.staging? || Rails.env.preproduction? || Rails.env.production?
end
def stubbed_response
{
respuesta_sms: {
identificador_mensaje: "1234567",
fecha_respuesta: "Thu, 20 Aug 2015 16:28:05 +0200",
respuesta_pasarela: {
codigo_pasarela: "0000",
descripcion_pasarela: "Operación ejecutada correctamente."
},
respuesta_servicio_externo: {
codigo_respuesta: "1000",
texto_respuesta: "Success"
}
}
}
end
end