Class: Pinnacle::Messages::Schedule::Client
- Inherits:
-
Object
- Object
- Pinnacle::Messages::Schedule::Client
- Defined in:
- lib/pinnacle/messages/schedule/client.rb
Instance Method Summary collapse
-
#cancel(request_options: {}, **params) ⇒ Pinnacle::Types::ScheduleCancelResult
Cancel a scheduled message or blast.
- #initialize(client:) ⇒ void constructor
Constructor Details
#initialize(client:) ⇒ void
10 11 12 |
# File 'lib/pinnacle/messages/schedule/client.rb', line 10 def initialize(client:) @client = client end |
Instance Method Details
#cancel(request_options: {}, **params) ⇒ Pinnacle::Types::ScheduleCancelResult
Cancel a scheduled message or blast.
Works for both individual scheduled messages and scheduled blasts. Use the ‘scheduleId` returned when the message or blast was scheduled.
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 |
# File 'lib/pinnacle/messages/schedule/client.rb', line 29 def cancel(request_options: {}, **params) params = Pinnacle::Internal::Types::Utils.normalize_keys(params) request = Pinnacle::Internal::JSON::Request.new( base_url: [:base_url], method: "DELETE", path: "messages/schedule/#{params[:id]}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Pinnacle::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Pinnacle::Types::ScheduleCancelResult.load(response.body) else error_class = Pinnacle::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |