Class: Twilio::REST::Serverless::V1::ServiceContext::AssetContext

Inherits:
InstanceContext
  • Object
show all
Defined in:
lib/twilio-ruby/rest/serverless/v1/service/asset.rb,
lib/twilio-ruby/rest/serverless/v1/service/asset/asset_version.rb

Overview

PLEASE NOTE that this class contains beta products that are subject to change. Use them with caution.

Defined Under Namespace

Classes: AssetVersionContext, AssetVersionInstance, AssetVersionList, AssetVersionPage

Instance Method Summary collapse

Constructor Details

#initialize(version, service_sid, sid) ⇒ AssetContext

Initialize the AssetContext

Parameters:

  • version (Version)

    Version that contains the resource

  • service_sid (String)

    The SID of the Service to update the Asset resource from.

  • sid (String)

    The SID that identifies the Asset resource to update.



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

def initialize(version, service_sid, sid)
    super(version)

    # Path Solution
    @solution = { service_sid: service_sid, sid: sid,  }
    @uri = "/Services/#{@solution[:service_sid]}/Assets/#{@solution[:sid]}"

    # Dependents
    @asset_versions = nil
end

Instance Method Details

#asset_versions(sid = :unset) ⇒ AssetVersionList, AssetVersionContext

Access the asset_versions

Returns:

Raises:

  • (ArgumentError)


214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
# File 'lib/twilio-ruby/rest/serverless/v1/service/asset.rb', line 214

def asset_versions(sid=:unset)

    raise ArgumentError, 'sid cannot be nil' if sid.nil?

    if sid != :unset
        return AssetVersionContext.new(@version, @solution[:service_sid], @solution[:sid],sid )
    end

    unless @asset_versions
        @asset_versions = AssetVersionList.new(
            @version, service_sid: @solution[:service_sid], asset_sid: @solution[:sid], )
    end

 @asset_versions
end

#deleteBoolean

Delete the AssetInstance

Returns:

  • (Boolean)

    True if delete succeeds, false otherwise



170
171
172
173
# File 'lib/twilio-ruby/rest/serverless/v1/service/asset.rb', line 170

def delete

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

#fetchAssetInstance

Fetch the AssetInstance

Returns:



178
179
180
181
182
183
184
185
186
187
# File 'lib/twilio-ruby/rest/serverless/v1/service/asset.rb', line 178

def fetch

    payload = @version.fetch('GET', @uri)
    AssetInstance.new(
        @version,
        payload,
        service_sid: @solution[:service_sid],
        sid: @solution[:sid],
    )
end

#inspectObject

Provide a detailed, user friendly representation



239
240
241
242
# File 'lib/twilio-ruby/rest/serverless/v1/service/asset.rb', line 239

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

#to_sObject

Provide a user friendly representation



232
233
234
235
# File 'lib/twilio-ruby/rest/serverless/v1/service/asset.rb', line 232

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

#update(friendly_name: nil) ⇒ AssetInstance

Update the AssetInstance

Parameters:

  • friendly_name (String) (defaults to: nil)

    A descriptive string that you create to describe the Asset resource. It can be a maximum of 255 characters.

Returns:



193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
# File 'lib/twilio-ruby/rest/serverless/v1/service/asset.rb', line 193

def update(
    friendly_name: nil
)

    data = Twilio::Values.of({
        'FriendlyName' => friendly_name,
    })

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