Class: Telerivet::ScheduledMessage

Inherits:
Entity
  • Object
show all
Defined in:
lib/telerivet/scheduledmessage.rb

Overview

Represents a scheduled message within Telerivet.

Fields:

- id (string, max 34 characters)
    * ID of the scheduled message
    * Read-only

- content
    * Text content of the scheduled message
    * Updatable via API

- rrule
    * Recurrence rule for recurring scheduled messages, e.g. 'FREQ=MONTHLY' or
        'FREQ=WEEKLY;INTERVAL=2'; see
        [RFC2445](https://tools.ietf.org/html/rfc2445#section-4.3.10).
    * Updatable via API

- timezone_id
    * Timezone ID used to compute times for recurring messages; see [List of tz database
        time zones Wikipedia
        article](http://en.wikipedia.org/wiki/List_of_tz_database_time_zones).
    * Updatable via API

- recipients (array of objects)
    * List of recipients. Each recipient is an object with a string `type` property, which
        may be `"phone_number"`, `"group"`, or `"filter"`.

        If the type is `"phone_number"`, the `phone_number` property will
        be set to the recipient's phone number.

        If the type is `"group"`, the `group_id` property will be set to
        the ID of the group, and the `group_name` property will be set to the name of the
        group.

        If the type is `"filter"`, the `filter_type` property (string) and
        `filter_params` property (object) describe the filter used to send the broadcast. (API
        clients should not rely on a particular value or format of the `filter_type` or
        `filter_params` properties, as they may change without notice.)
    * Read-only

- recipients_str
    * A string with a human readable description of the first few recipients (possibly
        truncated)
    * Read-only

- group_id
    * ID of the group to send the message to (null if the recipient is an individual
        contact, or if there are multiple recipients)
    * Updatable via API

- contact_id
    * ID of the contact to send the message to (null if the recipient is a group, or if
        there are multiple recipients)
    * Updatable via API

- to_number
    * Phone number to send the message to (null if the recipient is a group, or if there
        are multiple recipients)
    * Updatable via API

- route_id
    * ID of the phone or route the message will be sent from
    * Updatable via API

- service_id (string, max 34 characters)
    * The service associated with this message (for voice calls, the service defines the
        call flow)
    * Updatable via API

- audio_url
    * For voice calls, the URL of an MP3 file to play when the contact answers the call
    * Updatable via API

- tts_lang
    * For voice calls, the language of the text-to-speech voice
    * Allowed values: en-US, en-GB, en-GB-WLS, en-AU, en-IN, da-DK, nl-NL, fr-FR, fr-CA,
        de-DE, is-IS, it-IT, pl-PL, pt-BR, pt-PT, ru-RU, es-ES, es-US, sv-SE
    * Updatable via API

- tts_voice
    * For voice calls, the text-to-speech voice
    * Allowed values: female, male
    * Updatable via API

- message_type
    * Type of scheduled message
    * Allowed values: sms, mms, ussd, ussd_session, call, chat, service
    * Read-only

- time_created (UNIX timestamp)
    * Time the scheduled message was created in Telerivet
    * Read-only

- start_time (UNIX timestamp)
    * The time that the message will be sent (or first sent for recurring messages)
    * Updatable via API

- end_time (UNIX timestamp)
    * Time after which a recurring message will stop (not applicable to non-recurring
        scheduled messages)
    * Updatable via API

- prev_time (UNIX timestamp)
    * The most recent time that Telerivet has sent this scheduled message (null if it has
        never been sent)
    * Read-only

- next_time (UNIX timestamp)
    * The next upcoming time that Telerivet will sent this scheduled message (null if it
        will not be sent again)
    * Read-only

- occurrences (int)
    * Number of times this scheduled message has already been sent
    * Read-only

- replace_variables (bool)
    * Set to true if Telerivet will render variables like [[contact.name]] in the message
        content, false otherwise
    * Updatable via API

- track_clicks (boolean)
    * If true, URLs in the message content will automatically be replaced with unique
        short URLs
    * Updatable via API

- media (array)
    * For text messages containing media files, this is an array of objects with the
        properties `url`, `type` (MIME type), `filename`, and `size` (file size in bytes).
        Unknown properties are null. This property is undefined for messages that do not
        contain media files. Note: For files uploaded via the Telerivet web app, the URL is
        temporary and may not be valid for more than 1 day.
    * Read-only

- route_params (Hash)
    * Route-specific parameters to use when sending the message.

        When sending messages via chat apps such as WhatsApp, the route_params
        parameter can be used to send messages with app-specific features such as quick
        replies and link buttons.

        For more details, see [Route-Specific Parameters](#route_params).
    * Updatable via API

- vars (Hash)
    * Custom variables stored for this scheduled message (copied to Message when sent).
        Variable names may be up to 32 characters in length and can contain the characters
        a-z, A-Z, 0-9, and _.
        Values may be strings, numbers, or boolean (true/false).
        String values may be up to 4096 bytes in length when encoded as UTF-8.
        Up to 100 variables are supported per object.
        Setting a variable to null will delete the variable.
    * Updatable via API

- label_ids (array)
    * IDs of labels to add to the Message
    * Updatable via API

- relative_scheduled_id
    * ID of the relative scheduled message this scheduled message was created from, if
        applicable
    * Read-only

- project_id
    * ID of the project this scheduled message belongs to
    * Read-only

- is_template (bool)
    * Set to true if Telerivet will render variables like [[contact.name]] in the message
        content
    * Read-only

Instance Method Summary collapse

Methods inherited from Entity

#get, #initialize, #load, #set, #set_data, #to_s, #vars

Constructor Details

This class inherits a constructor from Telerivet::Entity

Instance Method Details

#audio_urlObject



269
270
271
# File 'lib/telerivet/scheduledmessage.rb', line 269

def audio_url
    get('audio_url')
end

#audio_url=(value) ⇒ Object



273
274
275
# File 'lib/telerivet/scheduledmessage.rb', line 273

def audio_url=(value)
    set('audio_url', value)
end

#contact_idObject



237
238
239
# File 'lib/telerivet/scheduledmessage.rb', line 237

def contact_id
    get('contact_id')
end

#contact_id=(value) ⇒ Object



241
242
243
# File 'lib/telerivet/scheduledmessage.rb', line 241

def contact_id=(value)
    set('contact_id', value)
end

#contentObject



197
198
199
# File 'lib/telerivet/scheduledmessage.rb', line 197

def content
    get('content')
end

#content=(value) ⇒ Object



201
202
203
# File 'lib/telerivet/scheduledmessage.rb', line 201

def content=(value)
    set('content', value)
end

#deleteObject

Cancels this scheduled message.



189
190
191
# File 'lib/telerivet/scheduledmessage.rb', line 189

def delete()
    @api.do_request("DELETE", get_base_api_path())
end

#end_timeObject



309
310
311
# File 'lib/telerivet/scheduledmessage.rb', line 309

def end_time
    get('end_time')
end

#end_time=(value) ⇒ Object



313
314
315
# File 'lib/telerivet/scheduledmessage.rb', line 313

def end_time=(value)
    set('end_time', value)
end

#get_base_api_pathObject



377
378
379
# File 'lib/telerivet/scheduledmessage.rb', line 377

def get_base_api_path()
    "/projects/#{get('project_id')}/scheduled/#{get('id')}"
end

#group_idObject



229
230
231
# File 'lib/telerivet/scheduledmessage.rb', line 229

def group_id
    get('group_id')
end

#group_id=(value) ⇒ Object



233
234
235
# File 'lib/telerivet/scheduledmessage.rb', line 233

def group_id=(value)
    set('group_id', value)
end

#idObject



193
194
195
# File 'lib/telerivet/scheduledmessage.rb', line 193

def id
    get('id')
end

#is_templateObject



373
374
375
# File 'lib/telerivet/scheduledmessage.rb', line 373

def is_template
    get('is_template')
end

#label_idsObject



357
358
359
# File 'lib/telerivet/scheduledmessage.rb', line 357

def label_ids
    get('label_ids')
end

#label_ids=(value) ⇒ Object



361
362
363
# File 'lib/telerivet/scheduledmessage.rb', line 361

def label_ids=(value)
    set('label_ids', value)
end

#mediaObject



345
346
347
# File 'lib/telerivet/scheduledmessage.rb', line 345

def media
    get('media')
end

#message_typeObject



293
294
295
# File 'lib/telerivet/scheduledmessage.rb', line 293

def message_type
    get('message_type')
end

#next_timeObject



321
322
323
# File 'lib/telerivet/scheduledmessage.rb', line 321

def next_time
    get('next_time')
end

#occurrencesObject



325
326
327
# File 'lib/telerivet/scheduledmessage.rb', line 325

def occurrences
    get('occurrences')
end

#prev_timeObject



317
318
319
# File 'lib/telerivet/scheduledmessage.rb', line 317

def prev_time
    get('prev_time')
end

#project_idObject



369
370
371
# File 'lib/telerivet/scheduledmessage.rb', line 369

def project_id
    get('project_id')
end

#recipientsObject



221
222
223
# File 'lib/telerivet/scheduledmessage.rb', line 221

def recipients
    get('recipients')
end

#recipients_strObject



225
226
227
# File 'lib/telerivet/scheduledmessage.rb', line 225

def recipients_str
    get('recipients_str')
end

#relative_scheduled_idObject



365
366
367
# File 'lib/telerivet/scheduledmessage.rb', line 365

def relative_scheduled_id
    get('relative_scheduled_id')
end

#replace_variablesObject



329
330
331
# File 'lib/telerivet/scheduledmessage.rb', line 329

def replace_variables
    get('replace_variables')
end

#replace_variables=(value) ⇒ Object



333
334
335
# File 'lib/telerivet/scheduledmessage.rb', line 333

def replace_variables=(value)
    set('replace_variables', value)
end

#route_idObject



253
254
255
# File 'lib/telerivet/scheduledmessage.rb', line 253

def route_id
    get('route_id')
end

#route_id=(value) ⇒ Object



257
258
259
# File 'lib/telerivet/scheduledmessage.rb', line 257

def route_id=(value)
    set('route_id', value)
end

#route_paramsObject



349
350
351
# File 'lib/telerivet/scheduledmessage.rb', line 349

def route_params
    get('route_params')
end

#route_params=(value) ⇒ Object



353
354
355
# File 'lib/telerivet/scheduledmessage.rb', line 353

def route_params=(value)
    set('route_params', value)
end

#rruleObject



205
206
207
# File 'lib/telerivet/scheduledmessage.rb', line 205

def rrule
    get('rrule')
end

#rrule=(value) ⇒ Object



209
210
211
# File 'lib/telerivet/scheduledmessage.rb', line 209

def rrule=(value)
    set('rrule', value)
end

#saveObject

Saves any fields or custom variables that have changed for this scheduled message.



182
183
184
# File 'lib/telerivet/scheduledmessage.rb', line 182

def save()
    super
end

#service_idObject



261
262
263
# File 'lib/telerivet/scheduledmessage.rb', line 261

def service_id
    get('service_id')
end

#service_id=(value) ⇒ Object



265
266
267
# File 'lib/telerivet/scheduledmessage.rb', line 265

def service_id=(value)
    set('service_id', value)
end

#start_timeObject



301
302
303
# File 'lib/telerivet/scheduledmessage.rb', line 301

def start_time
    get('start_time')
end

#start_time=(value) ⇒ Object



305
306
307
# File 'lib/telerivet/scheduledmessage.rb', line 305

def start_time=(value)
    set('start_time', value)
end

#time_createdObject



297
298
299
# File 'lib/telerivet/scheduledmessage.rb', line 297

def time_created
    get('time_created')
end

#timezone_idObject



213
214
215
# File 'lib/telerivet/scheduledmessage.rb', line 213

def timezone_id
    get('timezone_id')
end

#timezone_id=(value) ⇒ Object



217
218
219
# File 'lib/telerivet/scheduledmessage.rb', line 217

def timezone_id=(value)
    set('timezone_id', value)
end

#to_numberObject



245
246
247
# File 'lib/telerivet/scheduledmessage.rb', line 245

def to_number
    get('to_number')
end

#to_number=(value) ⇒ Object



249
250
251
# File 'lib/telerivet/scheduledmessage.rb', line 249

def to_number=(value)
    set('to_number', value)
end

#track_clicksObject



337
338
339
# File 'lib/telerivet/scheduledmessage.rb', line 337

def track_clicks
    get('track_clicks')
end

#track_clicks=(value) ⇒ Object



341
342
343
# File 'lib/telerivet/scheduledmessage.rb', line 341

def track_clicks=(value)
    set('track_clicks', value)
end

#tts_langObject



277
278
279
# File 'lib/telerivet/scheduledmessage.rb', line 277

def tts_lang
    get('tts_lang')
end

#tts_lang=(value) ⇒ Object



281
282
283
# File 'lib/telerivet/scheduledmessage.rb', line 281

def tts_lang=(value)
    set('tts_lang', value)
end

#tts_voiceObject



285
286
287
# File 'lib/telerivet/scheduledmessage.rb', line 285

def tts_voice
    get('tts_voice')
end

#tts_voice=(value) ⇒ Object



289
290
291
# File 'lib/telerivet/scheduledmessage.rb', line 289

def tts_voice=(value)
    set('tts_voice', value)
end