require_relative 'api_request_base' # 添付ファイル一覧リクエスト用クラス # @ref https://github.com/growi/growi/blob/master/lib/routes/attachment.js class GApiRequestAttachmentsList < GApiRequestBase # コンストラクタ # @override # @param [Hash] param APIリクエストのパラメータ def initialize(param = {}) super('/_api/attachments.list', METHOD_GET, { page_id: param[:page_id] }) end # リクエストを実行する # @override # @param [String] entry_point APIのエントリーポイントとなるURL(ex. http://localhost:3000/_api/pages.list) # @param [Hash] rest_client_param RestClientのパラメータ # @return [Array] リクエスト実行結果 def execute(entry_point, rest_client_param: {}) if invalid? return validation_msg end params = { method: :get, url: entry_point, headers: { params: @param } }.merge(rest_client_param) ret = JSON.parse RestClient::Request.execute params if (ret['ok'] == false) return GCInvalidRequest.new "API return false with msg: #{ret['msg']}" end attachments = [] ret['attachments'].each do |attachment| attachments.push(GrowiAttachment.new(attachment)) end return GApiReturn.new(ok: ret['ok'], data: attachments) end protected # バリデーションエラーを取得する # @return [nil/GCInvalidRequest] バリデーションエラー結果 def _invalid if ! (@param[:page_id]) GCInvalidRequest.new 'Parameter page_id is required.' end end end # 添付ファイル追加リクエスト用クラス # @ref https://github.com/growi/growi/blob/master/lib/routes/attachment.js class GApiRequestAttachmentsAdd < GApiRequestBase # コンストラクタ # @override # @param [Hash] param APIリクエストのパラメータ def initialize(param = {}) super('/_api/attachments.add', METHOD_POST, { page_id: param[:page_id], file: param[:file] }) end # リクエストを実行する # @override # @param [String] entry_point APIのエントリーポイントとなるURL(ex. http://localhost:3000/_api/pages.list) # @param [Hash] rest_client_param RestClientのパラメータ # @return [Array] リクエスト実行結果 def execute(entry_point, rest_client_param: {}) if invalid? return validation_msg end params = { method: :post, url: entry_point, payload: { access_token: @param[:access_token], page_id: @param[:page_id], file: @param[:file] } }.merge(rest_client_param) ret = JSON.parse RestClient::Request.execute params if (ret['ok'] == false) return GCInvalidRequest.new "API return false with msg: #{ret['msg']}" end data = { page: GrowiPage.new(ret['page']), attachment: GrowiAttachment.new(ret['attachment']) } return GApiReturn.new(ok: ret['ok'], data: data) end protected # バリデーションエラーを取得する # @return [nil/GCInvalidRequest] バリデーションエラー結果 def _invalid if ! (@param[:file] && @param[:page_id]) GCInvalidRequest.new 'Parameters file and page_id are required.' end end end # 添付ファイル削除リクエスト用クラス # @ref https://github.com/growi/growi/blob/master/lib/routes/attachment.js class GApiRequestAttachmentsRemove < GApiRequestBase # コンストラクタ # @override # @param [Hash] param APIリクエストのパラメータ def initialize(param = {}) super('/_api/attachments.remove', METHOD_POST, { attachment_id: param[:attachment_id] }) end # リクエストを実行する # @override # @param [String] entry_point APIのエントリーポイントとなるURL(ex. http://localhost:3000/_api/pages.list) # @param [Hash] rest_client_param RestClientのパラメータ # @return [Array] リクエスト実行結果 def execute(entry_point, rest_client_param: {}) if invalid? return validation_msg end params = { method: :post, url: entry_point, payload: @param.to_json, headers: { content_type: :json, accept: :json } }.merge(rest_client_param) ret = JSON.parse RestClient::Request.execute params if (ret['ok'] == false) return GCInvalidRequest.new "API return false with msg: #{ret['msg']}" end return GApiReturn.new(ok: ret['ok'], data: nil) end protected # バリデーションエラーを取得する # @return [nil/GCInvalidRequest] バリデーションエラー結果 def _invalid if ! (@param[:attachment_id]) GCInvalidRequest.new 'Parameter attachment_id is required.' end end end