# ----------------------------------------------------------------------------
#
# Copyright (c) 2018-2020 Aspose Pty Ltd. All rights reserved.
#
#
# Permission is hereby granted, free of charge, to any person obtaining a
# copy of this software and associated documentation files (the "Software"),
# to deal in the Software without restriction, including without limitation
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
# and/or sell copies of the Software, and to permit persons to whom the
# Software is furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
# ----------------------------------------------------------------------------
require 'uri'
module AsposeEmailCloud
# StorageApi operations.
class StorageApi
attr_reader :api_invoker
# Initializes a new instance of the StorageApi class.
# @param [String] client_secret Key to access the server.
# @param [String] client_id ID to access the server.
# @param [String] base_url Server URL.
# @param [String] api_version Api version.
# @param [Object] debug Debug switch [true, false].
# def initialize(client_secret = nil, client_id = nil, base_url = 'api-qa.aspose.cloud', api_version = 'v4.0', debug = false)
# @api_client = ApiClient.new(client_secret, client_id, base_url, api_version, debug)
# end
# Initializes a new instance of the StorageApi class.
# @param [ApiInvoker] api_invoker
def initialize(api_invoker)
@api_invoker = api_invoker
end
# Get disc usage
# @param [GetDiscUsageRequest] request Request object.
# @return [DiscUsage]
def get_disc_usage(request)
http_request = request.to_http_info(@api_invoker.api_client)
@api_invoker.make_request(http_request, :GET, 'DiscUsage')
end
# Get file versions
# @param [GetFileVersionsRequest] request Request object.
# @return [FileVersions]
def get_file_versions(request)
http_request = request.to_http_info(@api_invoker.api_client)
@api_invoker.make_request(http_request, :GET, 'FileVersions')
end
# Check if file or folder exists
# @param [ObjectExistsRequest] request Request object.
# @return [ObjectExist]
def object_exists(request)
http_request = request.to_http_info(@api_invoker.api_client)
@api_invoker.make_request(http_request, :GET, 'ObjectExist')
end
# Check if storage exists
# @param [StorageExistsRequest] request Request object.
# @return [StorageExist]
def exists(request)
http_request = request.to_http_info(@api_invoker.api_client)
@api_invoker.make_request(http_request, :GET, 'StorageExist')
end
end
end