telerivet 1.4.5 → 1.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/telerivet/airtimetransaction.rb +139 -0
- data/lib/telerivet/broadcast.rb +12 -1
- data/lib/telerivet/contact.rb +31 -10
- data/lib/telerivet/datatable.rb +20 -8
- data/lib/telerivet/group.rb +14 -17
- data/lib/telerivet/label.rb +11 -2
- data/lib/telerivet/message.rb +52 -32
- data/lib/telerivet/organization.rb +80 -0
- data/lib/telerivet/phone.rb +11 -2
- data/lib/telerivet/project.rb +683 -22
- data/lib/telerivet/scheduledmessage.rb +11 -0
- data/lib/telerivet/service.rb +45 -7
- data/lib/telerivet/task.rb +151 -0
- data/lib/telerivet.rb +1 -1
- metadata +4 -2
| @@ -135,6 +135,13 @@ module Telerivet | |
| 135 135 | 
             
            #           temporary and may not be valid for more than 1 day.
         | 
| 136 136 | 
             
            #       * Read-only
         | 
| 137 137 | 
             
            #   
         | 
| 138 | 
            +
            #   - route_params (Hash)
         | 
| 139 | 
            +
            #       * Route-specific parameters to use when sending the message. The parameters object may
         | 
| 140 | 
            +
            #           have keys matching the `phone_type` field of a phone (basic route) that may be used to
         | 
| 141 | 
            +
            #           send the message. The corresponding value is an object with route-specific parameters
         | 
| 142 | 
            +
            #           to use when sending a message with that type of route.
         | 
| 143 | 
            +
            #       * Read-only
         | 
| 144 | 
            +
            #   
         | 
| 138 145 | 
             
            #   - vars (Hash)
         | 
| 139 146 | 
             
            #       * Custom variables stored for this scheduled message (copied to Message when sent)
         | 
| 140 147 | 
             
            #       * Updatable via API
         | 
| @@ -258,6 +265,10 @@ class ScheduledMessage < Entity | |
| 258 265 | 
             
                    get('media')
         | 
| 259 266 | 
             
                end
         | 
| 260 267 |  | 
| 268 | 
            +
                def route_params
         | 
| 269 | 
            +
                    get('route_params')
         | 
| 270 | 
            +
                end
         | 
| 271 | 
            +
             | 
| 261 272 | 
             
                def label_ids
         | 
| 262 273 | 
             
                    get('label_ids')
         | 
| 263 274 | 
             
                end
         | 
    
        data/lib/telerivet/service.rb
    CHANGED
    
    | @@ -97,7 +97,7 @@ class Service < Entity | |
| 97 97 | 
             
                #     
         | 
| 98 98 | 
             
                #     - context
         | 
| 99 99 | 
             
                #         * The name of the context in which this service is invoked
         | 
| 100 | 
            -
                #         * Allowed values: message, call, contact, project
         | 
| 100 | 
            +
                #         * Allowed values: message, call, ussd_session, row, contact, project
         | 
| 101 101 | 
             
                #         * Required
         | 
| 102 102 | 
             
                #     
         | 
| 103 103 | 
             
                #     - event
         | 
| @@ -109,11 +109,49 @@ class Service < Entity | |
| 109 109 | 
             
                #         * Required if context is 'message'
         | 
| 110 110 | 
             
                #     
         | 
| 111 111 | 
             
                #     - contact_id
         | 
| 112 | 
            -
                #         * The ID of the contact this service is triggered for
         | 
| 113 | 
            -
                # | 
| 112 | 
            +
                #         * The ID of the contact this service is triggered for (either `contact_id` or
         | 
| 113 | 
            +
                #             `phone_number` is required if `context` is 'contact')
         | 
| 114 | 
            +
                #     
         | 
| 115 | 
            +
                #     - phone_number
         | 
| 116 | 
            +
                #         * The phone number of the contact this service is triggered for (either `contact_id`
         | 
| 117 | 
            +
                #             or `phone_number` is required if `context` is 'contact'). If no  contact exists with
         | 
| 118 | 
            +
                #             this phone number, a new contact will be created.
         | 
| 119 | 
            +
                #     
         | 
| 120 | 
            +
                #     - variables (Hash)
         | 
| 121 | 
            +
                #         * Object containing up to 25 temporary variable names and their corresponding values
         | 
| 122 | 
            +
                #             to set when invoking the service. Values may be strings, numbers, or boolean
         | 
| 123 | 
            +
                #             (true/false). String values may be up to 4096 bytes in length. Arrays and objects
         | 
| 124 | 
            +
                #             are not supported. Within Custom Actions, each variable can be used like `[[$name]]`
         | 
| 125 | 
            +
                #             (with a leading `$` character and surrounded by double square brackets). Within a
         | 
| 126 | 
            +
                #             Cloud Script API service or JavaScript action, each variable will be available as a
         | 
| 127 | 
            +
                #             global JavaScript variable like `$name` (with a leading `$` character).
         | 
| 128 | 
            +
                #     
         | 
| 129 | 
            +
                #     - route_id
         | 
| 130 | 
            +
                #         * The ID of the phone or route that the service will use for sending messages by
         | 
| 131 | 
            +
                #             default
         | 
| 132 | 
            +
                #     
         | 
| 133 | 
            +
                #     - async (bool)
         | 
| 134 | 
            +
                #         * If set to true, the service will be invoked asynchronously. By default, queued
         | 
| 135 | 
            +
                #             services will be invoked one at a time for each project.
         | 
| 114 136 | 
             
                #   
         | 
| 115 137 | 
             
                # Returns:
         | 
| 116 | 
            -
                #      | 
| 138 | 
            +
                #     (associative array)
         | 
| 139 | 
            +
                #       - return_value (any)
         | 
| 140 | 
            +
                #           * Return value of the service. May be any JSON type (boolean, number, string,
         | 
| 141 | 
            +
                #               array, object, or null). (Undefined if async=true.)
         | 
| 142 | 
            +
                #       
         | 
| 143 | 
            +
                #       - log_entries (array)
         | 
| 144 | 
            +
                #           * Array of log entry strings generated by the service. (Undefined if async=true.)
         | 
| 145 | 
            +
                #       
         | 
| 146 | 
            +
                #       - errors (array)
         | 
| 147 | 
            +
                #           * Array of error message strings generated by the service. (Undefined if
         | 
| 148 | 
            +
                #               async=true.)
         | 
| 149 | 
            +
                #       
         | 
| 150 | 
            +
                #       - sent_messages (array of objects)
         | 
| 151 | 
            +
                #           * Array of messages sent by the service (Undefined if async=true.)
         | 
| 152 | 
            +
                #       
         | 
| 153 | 
            +
                #       - airtime_transactions (array of objects)
         | 
| 154 | 
            +
                #           * Array of airtime transactions sent by the service (Undefined if async=true.)
         | 
| 117 155 | 
             
                #
         | 
| 118 156 | 
             
                def invoke(options)        
         | 
| 119 157 | 
             
                    invoke_result = @api.do_request('POST', get_base_api_path() + '/invoke', options)
         | 
| @@ -210,9 +248,9 @@ class Service < Entity | |
| 210 248 | 
             
                #     
         | 
| 211 249 | 
             
                #     - vars (Hash)
         | 
| 212 250 | 
             
                #         * Filter states by value of a custom variable (e.g. vars[email], vars[foo], etc.)
         | 
| 213 | 
            -
                #         * Allowed modifiers: vars[foo][ | 
| 214 | 
            -
                #             vars[foo][ | 
| 215 | 
            -
                #             vars[foo][ | 
| 251 | 
            +
                #         * Allowed modifiers: vars[foo][ne], vars[foo][prefix], vars[foo][not_prefix],
         | 
| 252 | 
            +
                #             vars[foo][gte], vars[foo][gt], vars[foo][lt], vars[foo][lte], vars[foo][min],
         | 
| 253 | 
            +
                #             vars[foo][max], vars[foo][exists]
         | 
| 216 254 | 
             
                #     
         | 
| 217 255 | 
             
                #     - sort
         | 
| 218 256 | 
             
                #         * Sort the results based on a field
         | 
| @@ -0,0 +1,151 @@ | |
| 1 | 
            +
             | 
| 2 | 
            +
            module Telerivet
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            #
         | 
| 5 | 
            +
            # Represents an asynchronous task that is applied to all entities matching a filter.
         | 
| 6 | 
            +
            # 
         | 
| 7 | 
            +
            # Tasks include services applied to contacts, messages, or data rows; adding
         | 
| 8 | 
            +
            # or removing contacts from a group; blocking or unblocking sending messages to a contact;
         | 
| 9 | 
            +
            # updating a custom variable; deleting contacts, messages, or data rows; or
         | 
| 10 | 
            +
            # exporting data to CSV.
         | 
| 11 | 
            +
            # 
         | 
| 12 | 
            +
            # Fields:
         | 
| 13 | 
            +
            # 
         | 
| 14 | 
            +
            #   - id (string, max 34 characters)
         | 
| 15 | 
            +
            #       * ID of the task
         | 
| 16 | 
            +
            #       * Read-only
         | 
| 17 | 
            +
            #   
         | 
| 18 | 
            +
            #   - task_type (string)
         | 
| 19 | 
            +
            #       * The task type
         | 
| 20 | 
            +
            #       * Read-only
         | 
| 21 | 
            +
            #   
         | 
| 22 | 
            +
            #   - task_params (Hash)
         | 
| 23 | 
            +
            #       * Parameters applied to all matching rows (specific to `task_type`). See
         | 
| 24 | 
            +
            #           [project.createTask](#Project.createTask).
         | 
| 25 | 
            +
            #       * Read-only
         | 
| 26 | 
            +
            #   
         | 
| 27 | 
            +
            #   - filter_type
         | 
| 28 | 
            +
            #       * Type of filter defining the rows that the task is applied to
         | 
| 29 | 
            +
            #       * Read-only
         | 
| 30 | 
            +
            #   
         | 
| 31 | 
            +
            #   - filter_params (Hash)
         | 
| 32 | 
            +
            #       * Parameters defining the rows that the task is applied to (specific to
         | 
| 33 | 
            +
            #           `filter_type`). See [project.createTask](#Project.createTask).
         | 
| 34 | 
            +
            #       * Read-only
         | 
| 35 | 
            +
            #   
         | 
| 36 | 
            +
            #   - time_created (UNIX timestamp)
         | 
| 37 | 
            +
            #       * Time the task was created in Telerivet
         | 
| 38 | 
            +
            #       * Read-only
         | 
| 39 | 
            +
            #   
         | 
| 40 | 
            +
            #   - time_active (UNIX timestamp)
         | 
| 41 | 
            +
            #       * Time Telerivet started executing the task
         | 
| 42 | 
            +
            #       * Read-only
         | 
| 43 | 
            +
            #   
         | 
| 44 | 
            +
            #   - time_complete (UNIX timestamp)
         | 
| 45 | 
            +
            #       * Time Telerivet finished executing the task
         | 
| 46 | 
            +
            #       * Read-only
         | 
| 47 | 
            +
            #   
         | 
| 48 | 
            +
            #   - total_rows (int)
         | 
| 49 | 
            +
            #       * The total number of rows matching the filter (null if not known)
         | 
| 50 | 
            +
            #       * Read-only
         | 
| 51 | 
            +
            #   
         | 
| 52 | 
            +
            #   - current_row (int)
         | 
| 53 | 
            +
            #       * The number of rows that have been processed so far
         | 
| 54 | 
            +
            #       * Read-only
         | 
| 55 | 
            +
            #   
         | 
| 56 | 
            +
            #   - status (string)
         | 
| 57 | 
            +
            #       * The current status of the task
         | 
| 58 | 
            +
            #       * Allowed values: created, queued, active, complete, failed, cancelled
         | 
| 59 | 
            +
            #       * Read-only
         | 
| 60 | 
            +
            #   
         | 
| 61 | 
            +
            #   - vars (Hash)
         | 
| 62 | 
            +
            #       * Custom variables stored for this task
         | 
| 63 | 
            +
            #       * Read-only
         | 
| 64 | 
            +
            #   
         | 
| 65 | 
            +
            #   - table_id (string, max 34 characters)
         | 
| 66 | 
            +
            #       * ID of the data table this task is applied to (if applicable)
         | 
| 67 | 
            +
            #       * Read-only
         | 
| 68 | 
            +
            #   
         | 
| 69 | 
            +
            #   - user_id (string, max 34 characters)
         | 
| 70 | 
            +
            #       * ID of the Telerivet user who created the task (if applicable)
         | 
| 71 | 
            +
            #       * Read-only
         | 
| 72 | 
            +
            #   
         | 
| 73 | 
            +
            #   - project_id
         | 
| 74 | 
            +
            #       * ID of the project this task belongs to
         | 
| 75 | 
            +
            #       * Read-only
         | 
| 76 | 
            +
            #
         | 
| 77 | 
            +
            class Task < Entity
         | 
| 78 | 
            +
                #
         | 
| 79 | 
            +
                # Cancels a task that is not yet complete.
         | 
| 80 | 
            +
                # 
         | 
| 81 | 
            +
                # Returns:
         | 
| 82 | 
            +
                #     Telerivet::Task
         | 
| 83 | 
            +
                #
         | 
| 84 | 
            +
                def cancel()
         | 
| 85 | 
            +
                    require_relative 'task'
         | 
| 86 | 
            +
                    Task.new(@api, @api.do_request("POST", get_base_api_path() + "/cancel"))
         | 
| 87 | 
            +
                end
         | 
| 88 | 
            +
             | 
| 89 | 
            +
                def id
         | 
| 90 | 
            +
                    get('id')
         | 
| 91 | 
            +
                end
         | 
| 92 | 
            +
             | 
| 93 | 
            +
                def task_type
         | 
| 94 | 
            +
                    get('task_type')
         | 
| 95 | 
            +
                end
         | 
| 96 | 
            +
             | 
| 97 | 
            +
                def task_params
         | 
| 98 | 
            +
                    get('task_params')
         | 
| 99 | 
            +
                end
         | 
| 100 | 
            +
             | 
| 101 | 
            +
                def filter_type
         | 
| 102 | 
            +
                    get('filter_type')
         | 
| 103 | 
            +
                end
         | 
| 104 | 
            +
             | 
| 105 | 
            +
                def filter_params
         | 
| 106 | 
            +
                    get('filter_params')
         | 
| 107 | 
            +
                end
         | 
| 108 | 
            +
             | 
| 109 | 
            +
                def time_created
         | 
| 110 | 
            +
                    get('time_created')
         | 
| 111 | 
            +
                end
         | 
| 112 | 
            +
             | 
| 113 | 
            +
                def time_active
         | 
| 114 | 
            +
                    get('time_active')
         | 
| 115 | 
            +
                end
         | 
| 116 | 
            +
             | 
| 117 | 
            +
                def time_complete
         | 
| 118 | 
            +
                    get('time_complete')
         | 
| 119 | 
            +
                end
         | 
| 120 | 
            +
             | 
| 121 | 
            +
                def total_rows
         | 
| 122 | 
            +
                    get('total_rows')
         | 
| 123 | 
            +
                end
         | 
| 124 | 
            +
             | 
| 125 | 
            +
                def current_row
         | 
| 126 | 
            +
                    get('current_row')
         | 
| 127 | 
            +
                end
         | 
| 128 | 
            +
             | 
| 129 | 
            +
                def status
         | 
| 130 | 
            +
                    get('status')
         | 
| 131 | 
            +
                end
         | 
| 132 | 
            +
             | 
| 133 | 
            +
                def table_id
         | 
| 134 | 
            +
                    get('table_id')
         | 
| 135 | 
            +
                end
         | 
| 136 | 
            +
             | 
| 137 | 
            +
                def user_id
         | 
| 138 | 
            +
                    get('user_id')
         | 
| 139 | 
            +
                end
         | 
| 140 | 
            +
             | 
| 141 | 
            +
                def project_id
         | 
| 142 | 
            +
                    get('project_id')
         | 
| 143 | 
            +
                end
         | 
| 144 | 
            +
             | 
| 145 | 
            +
                def get_base_api_path()
         | 
| 146 | 
            +
                    "/projects/#{get('project_id')}/tasks/#{get('id')}"
         | 
| 147 | 
            +
                end
         | 
| 148 | 
            +
             
         | 
| 149 | 
            +
            end
         | 
| 150 | 
            +
             | 
| 151 | 
            +
            end
         | 
    
        data/lib/telerivet.rb
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: telerivet
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1. | 
| 4 | 
            +
              version: 1.6.1
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Jesse Young
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2022-07-18 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies: []
         | 
| 13 13 | 
             
            description: Ruby client library for Telerivet REST API
         | 
| 14 14 | 
             
            email: support@telerivet.com
         | 
| @@ -18,6 +18,7 @@ extra_rdoc_files: [] | |
| 18 18 | 
             
            files:
         | 
| 19 19 | 
             
            - lib/cacert.pem
         | 
| 20 20 | 
             
            - lib/telerivet.rb
         | 
| 21 | 
            +
            - lib/telerivet/airtimetransaction.rb
         | 
| 21 22 | 
             
            - lib/telerivet/apicursor.rb
         | 
| 22 23 | 
             
            - lib/telerivet/broadcast.rb
         | 
| 23 24 | 
             
            - lib/telerivet/contact.rb
         | 
| @@ -34,6 +35,7 @@ files: | |
| 34 35 | 
             
            - lib/telerivet/route.rb
         | 
| 35 36 | 
             
            - lib/telerivet/scheduledmessage.rb
         | 
| 36 37 | 
             
            - lib/telerivet/service.rb
         | 
| 38 | 
            +
            - lib/telerivet/task.rb
         | 
| 37 39 | 
             
            homepage: http://telerivet.com
         | 
| 38 40 | 
             
            licenses:
         | 
| 39 41 | 
             
            - MIT
         |