Class: Zavudev::Models::Message
- Inherits:
-
Internal::Type::BaseModel
- Object
- Internal::Type::BaseModel
- Zavudev::Models::Message
- Defined in:
- lib/zavudev/models/message.rb
Overview
Instance Attribute Summary collapse
-
#channel ⇒ Symbol, Zavudev::Models::Channel
Delivery channel.
-
#content ⇒ Zavudev::Models::MessageContent?
Content for non-text message types (WhatsApp and Telegram).
-
#cost ⇒ Float?
MAU cost in USD (charged for first contact of the month).
-
#cost_provider ⇒ Float?
Provider cost in USD (Telnyx, SES, etc.).
-
#cost_total ⇒ Float?
Total cost in USD (MAU + provider cost).
- #created_at ⇒ Time
- #error_code ⇒ String?
- #error_message ⇒ String?
- #from ⇒ String?
- #id ⇒ String
-
#message_type ⇒ Symbol, Zavudev::Models::MessageType
Type of message.
- #metadata ⇒ Hash{Symbol=>String}?
-
#provider_message_id ⇒ String?
Message ID from the delivery provider.
- #sender_id ⇒ String?
- #status ⇒ Symbol, Zavudev::Models::MessageStatus
-
#text ⇒ String?
Text content or caption.
- #to ⇒ String
- #updated_at ⇒ Time?
Instance Method Summary collapse
-
#initialize(id:, channel:, created_at:, message_type:, status:, to:, content: nil, cost: nil, cost_provider: nil, cost_total: nil, error_code: nil, error_message: nil, from: nil, metadata: nil, provider_message_id: nil, sender_id: nil, text: nil, updated_at: nil) ⇒ Object
constructor
Some parameter documentations has been truncated, see Message for more details.
Methods inherited from Internal::Type::BaseModel
==, #==, #[], coerce, #deconstruct_keys, #deep_to_h, dump, fields, hash, #hash, inherited, inspect, #inspect, known_fields, optional, recursively_to_h, required, #to_h, #to_json, #to_s, to_sorbet_type, #to_yaml
Methods included from Internal::Type::Converter
#coerce, coerce, #dump, dump, #inspect, inspect, meta_info, new_coerce_state, type_info
Methods included from Internal::Util::SorbetRuntimeSupport
#const_missing, #define_sorbet_constant!, #sorbet_constant_defined?, #to_sorbet_type, to_sorbet_type
Constructor Details
#initialize(id:, channel:, created_at:, message_type:, status:, to:, content: nil, cost: nil, cost_provider: nil, cost_total: nil, error_code: nil, error_message: nil, from: nil, metadata: nil, provider_message_id: nil, sender_id: nil, text: nil, updated_at: nil) ⇒ Object
Some parameter documentations has been truncated, see Zavudev::Models::Message for more details.
|
|
# File 'lib/zavudev/models/message.rb', line 106
|
Instance Attribute Details
#channel ⇒ Symbol, Zavudev::Models::Channel
Delivery channel. Use ‘auto’ for intelligent routing.
16 |
# File 'lib/zavudev/models/message.rb', line 16 required :channel, enum: -> { Zavudev::Channel } |
#content ⇒ Zavudev::Models::MessageContent?
Content for non-text message types (WhatsApp and Telegram).
44 |
# File 'lib/zavudev/models/message.rb', line 44 optional :content, -> { Zavudev::MessageContent } |
#cost ⇒ Float?
MAU cost in USD (charged for first contact of the month).
50 |
# File 'lib/zavudev/models/message.rb', line 50 optional :cost, Float, nil?: true |
#cost_provider ⇒ Float?
Provider cost in USD (Telnyx, SES, etc.).
56 |
# File 'lib/zavudev/models/message.rb', line 56 optional :cost_provider, Float, api_name: :costProvider, nil?: true |
#cost_total ⇒ Float?
Total cost in USD (MAU + provider cost).
62 |
# File 'lib/zavudev/models/message.rb', line 62 optional :cost_total, Float, api_name: :costTotal, nil?: true |
#created_at ⇒ Time
21 |
# File 'lib/zavudev/models/message.rb', line 21 required :created_at, Time, api_name: :createdAt |
#error_code ⇒ String?
67 |
# File 'lib/zavudev/models/message.rb', line 67 optional :error_code, String, api_name: :errorCode, nil?: true |
#error_message ⇒ String?
72 |
# File 'lib/zavudev/models/message.rb', line 72 optional :error_message, String, api_name: :errorMessage, nil?: true |
#from ⇒ String?
77 |
# File 'lib/zavudev/models/message.rb', line 77 optional :from, String |
#id ⇒ String
10 |
# File 'lib/zavudev/models/message.rb', line 10 required :id, String |
#message_type ⇒ Symbol, Zavudev::Models::MessageType
Type of message. Non-text types are supported by WhatsApp and Telegram (varies by type).
28 |
# File 'lib/zavudev/models/message.rb', line 28 required :message_type, enum: -> { Zavudev::MessageType }, api_name: :messageType |
#metadata ⇒ Hash{Symbol=>String}?
82 |
# File 'lib/zavudev/models/message.rb', line 82 optional :metadata, Zavudev::Internal::Type::HashOf[String] |
#provider_message_id ⇒ String?
Message ID from the delivery provider.
88 |
# File 'lib/zavudev/models/message.rb', line 88 optional :provider_message_id, String, api_name: :providerMessageId |
#sender_id ⇒ String?
93 |
# File 'lib/zavudev/models/message.rb', line 93 optional :sender_id, String, api_name: :senderId |
#status ⇒ Symbol, Zavudev::Models::MessageStatus
33 |
# File 'lib/zavudev/models/message.rb', line 33 required :status, enum: -> { Zavudev::MessageStatus } |
#text ⇒ String?
Text content or caption.
99 |
# File 'lib/zavudev/models/message.rb', line 99 optional :text, String |
#to ⇒ String
38 |
# File 'lib/zavudev/models/message.rb', line 38 required :to, String |
#updated_at ⇒ Time?
104 |
# File 'lib/zavudev/models/message.rb', line 104 optional :updated_at, Time, api_name: :updatedAt |