Class: Twilio::REST::Preview::Sync::ServiceContext::DocumentContext::DocumentPermissionContext

Inherits:
InstanceContext
  • Object
show all
Defined in:
lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb

Instance Method Summary collapse

Constructor Details

#initialize(version, service_sid, document_sid, identity) ⇒ DocumentPermissionContext

Initialize the DocumentPermissionContext

Parameters:

  • version (Version)

    Version that contains the resource

  • service_sid (String)

    The unique SID identifier of the Sync Service Instance.

  • document_sid (String)

    Identifier of the Sync Document. Either a SID or a unique name.

  • identity (String)

    Arbitrary string identifier representing a human user associated with an FPA token, assigned by the developer.



141
142
143
144
145
146
147
148
149
# File 'lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb', line 141

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

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

    
end

Instance Method Details

#deleteBoolean

Delete the DocumentPermissionInstance

Returns:

  • (Boolean)

    True if delete succeeds, false otherwise



153
154
155
156
157
158
159
160
# File 'lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb', line 153

def delete

    headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
    
    
    
    @version.delete('DELETE', @uri, headers: headers)
end

#fetchDocumentPermissionInstance

Fetch the DocumentPermissionInstance

Returns:



165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
# File 'lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb', line 165

def fetch

    headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
    
    
    
    
    
    payload = @version.fetch('GET', @uri, headers: headers)
    DocumentPermissionInstance.new(
        @version,
        payload,
        service_sid: @solution[:service_sid],
        document_sid: @solution[:document_sid],
        identity: @solution[:identity],
    )
end

#inspectObject

Provide a detailed, user friendly representation



227
228
229
230
# File 'lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb', line 227

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

#to_sObject

Provide a user friendly representation



220
221
222
223
# File 'lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb', line 220

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

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

Update the DocumentPermissionInstance

Parameters:

  • read (Boolean) (defaults to: nil)

    Boolean flag specifying whether the identity can read the Sync Document.

  • write (Boolean) (defaults to: nil)

    Boolean flag specifying whether the identity can update the Sync Document.

  • manage (Boolean) (defaults to: nil)

    Boolean flag specifying whether the identity can delete the Sync Document.

Returns:



189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
# File 'lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb', line 189

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

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

    headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
    
    
    
    
    
    payload = @version.update('POST', @uri, data: data, headers: headers)
    DocumentPermissionInstance.new(
        @version,
        payload,
        service_sid: @solution[:service_sid],
        document_sid: @solution[:document_sid],
        identity: @solution[:identity],
    )
end