require "ribose/file_uploader" module Ribose class SpaceFile < Ribose::Base include Ribose::Actions::All include Ribose::Actions::Fetch include Ribose::Actions::Update include Ribose::Actions::Delete # List Files for Space # # This interface retrieves the files for any specific space, and # the usages is pretty simple all we need to do, provide the space # id and it will return the files as `Sawyer::Resource` # # @param space_id [String] The spcific space Id # @param options [Hash] Query parameters as a Hash # @return [Array] # def self.all(space_id, options = {}) new(space_id: space_id, **options).all end # Fetch a space file # # This interface retrieve the details for a single file in any # given user space. The response is a `Sawyer::Resource`. # # @param space_id [String] The space UUID # @param file_id [String] The space file ID # @return [Sawyer::Resource] # def self.fetch(space_id, file_id, options = {}) new(space_id: space_id, resource_id: file_id, **options).fetch end # Download a space file # # @param space_id [UUID] The Space UUID # @param file_id [Integer] The File Id # @param options [Hash] Options as key and value pair. # # Two important keys are :version_id, and :output and # if these are provided then it will use those otherwise # it will do additional request to retirve those details # def self.download(space_id, file_id, options = {}) options[:version_id] ||= fetch(space_id, file_id).current_version_id Ribose::FileVersion.download(space_id, file_id, **options) end # Create a new file upload # # @param space_id [String] The Space UUID # @param file [String] The complete path for the file # @param attributes [Hash] The file attributes as Hash # @return [Sawyer::Resource] The file upload response. # def self.create(space_id, file:, **attributes) upload = FileUploader.upload(space_id, attributes.merge(file: file)) upload[:attachment] end # Update a space file # # @param space_id [String] The Space UUID # @param file_id [String] The space file ID # @param attributes [Hash] The file attributes # @return [Sawyer::Resource] # def self.update(space_id, file_id, attributes) new(space_id: space_id, resource_id: file_id, **attributes).update end # Delete a space file # # @param space_id [String] The Space UUID # @param file_id [String] The space file ID # def self.delete(space_id, file_id, options = {}) new(space_id: space_id, resource_id: file_id, **options).delete end def fetch_icon Ribose::Request.get([resource_path, "icon"].join("/")) end # Fetch a space file icon # # @param space_id [String] The Space UUID # @param file_id [String] The space file ID # @return [Sawyer::Resource] # def self.fetch_icon(space_id, file_id, options = {}) new(space_id: space_id, resource_id: file_id, **options).fetch_icon end private attr_reader :space_id def resource "file" end def resource_key "file_info" end def resources_path ["spaces", space_id, "file", "files"].join("/") end def extract_local_attributes @space_id = attributes.delete(:space_id) end end end