Module: Asana::Resources::AttachmentUploading Private

Included in:
Task
Defined in:
lib/asana/resource_includes/attachment_uploading.rb

Overview

This module is part of a private API. You should avoid using this module if possible, as it may be removed or be changed in the future.

Mixin to add the ability to upload an attachment to a specific Asana resource (a Task, really).

Instance Method Summary collapse

Instance Method Details

#attach(filename: required('filename'), mime: required('mime'), options: {}, **data) ⇒ Object

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Uploads a new attachment to the resource.

Parameters:

  • filename (String) (defaults to: required('filename'))

    the absolute path of the file to upload.

  • mime (String) (defaults to: required('mime'))

    the MIME type of the file

  • options (Hash) (defaults to: {})

    the request I/O options

  • data (Hash)

    extra attributes to post

  • rubocop:disable

    Metrics/AbcSize

  • rubocop:disable

    Metrics/MethodLength



15
16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'lib/asana/resource_includes/attachment_uploading.rb', line 15

def attach(filename: required('filename'),
           mime: required('mime'),
           options: {}, **data)
  path = File.expand_path(filename)
  unless File.exist?(path)
    raise ArgumentError, "file #{filename} doesn't exist"
  end
  upload = Faraday::UploadIO.new(path, mime)
  response = client.post("/#{self.class.plural_name}/#{id}/attachments",
                         body: data,
                         upload: upload,
                         options: options)
  Attachment.new(parse(response).first, client: client)
end