Class: Twilio::REST::Sync::V1::ServiceContext::SyncMapContext::SyncMapPermissionContext

Inherits:
InstanceContext
  • Object
show all
Defined in:
lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb

Instance Method Summary collapse

Constructor Details

#initialize(version, service_sid, map_sid, identity) ⇒ SyncMapPermissionContext

Initialize the SyncMapPermissionContext

Parameters:

  • version (Version)

    Version that contains the resource

  • service_sid (String)

    The SID of the [Sync Service](www.twilio.com/docs/sync/api/service) with the Sync Map Permission resource to update. Can be the Service’s ‘sid` value or `default`.

  • map_sid (String)

    The SID of the Sync Map with the Sync Map Permission resource to update. Can be the Sync Map resource’s ‘sid` or its `unique_name`.

  • identity (String)

    The application-defined string that uniquely identifies the User’s Sync Map Permission resource to update.



137
138
139
140
141
142
143
144
145
# File 'lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb', line 137

def initialize(version, service_sid, map_sid, identity)
    super(version)

    # Path Solution
    @solution = { service_sid: service_sid, map_sid: map_sid, identity: identity,  }
    @uri = "/Services/#{@solution[:service_sid]}/Maps/#{@solution[:map_sid]}/Permissions/#{@solution[:identity]}"

    
end

Instance Method Details

#deleteBoolean

Delete the SyncMapPermissionInstance

Returns:

  • (Boolean)

    True if delete succeeds, false otherwise



149
150
151
152
# File 'lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb', line 149

def delete

    @version.delete('DELETE', @uri)
end

#fetchSyncMapPermissionInstance

Fetch the SyncMapPermissionInstance

Returns:



157
158
159
160
161
162
163
164
165
166
167
# File 'lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb', line 157

def fetch

    payload = @version.fetch('GET', @uri)
    SyncMapPermissionInstance.new(
        @version,
        payload,
        service_sid: @solution[:service_sid],
        map_sid: @solution[:map_sid],
        identity: @solution[:identity],
    )
end

#inspectObject

Provide a detailed, user friendly representation



207
208
209
210
# File 'lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb', line 207

def inspect
    context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
    "#<Twilio.Sync.V1.SyncMapPermissionContext #{context}>"
end

#to_sObject

Provide a user friendly representation



200
201
202
203
# File 'lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb', line 200

def to_s
    context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
    "#<Twilio.Sync.V1.SyncMapPermissionContext #{context}>"
end

#update(read: nil, write: nil, manage: nil) ⇒ SyncMapPermissionInstance

Update the SyncMapPermissionInstance

Parameters:

  • read (Boolean) (defaults to: nil)

    Whether the identity can read the Sync Map and its Items. Default value is ‘false`.

  • write (Boolean) (defaults to: nil)

    Whether the identity can create, update, and delete Items in the Sync Map. Default value is ‘false`.

  • manage (Boolean) (defaults to: nil)

    Whether the identity can delete the Sync Map. Default value is ‘false`.

Returns:



175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
# File 'lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb', line 175

def update(
    read: nil, 
    write: nil, 
    manage: nil
)

    data = Twilio::Values.of({
        'Read' => read,
        'Write' => write,
        'Manage' => manage,
    })

    payload = @version.update('POST', @uri, data: data)
    SyncMapPermissionInstance.new(
        @version,
        payload,
        service_sid: @solution[:service_sid],
        map_sid: @solution[:map_sid],
        identity: @solution[:identity],
    )
end