=begin #Composio OpenAPI #Composio SDK: Equip your agent with high-quality tools and build your real-world usecase The version of the OpenAPI document: 1.0.0 =end require 'cgi' module Composio class APIKeysApi attr_accessor :api_client def initialize(api_client = ApiClient.default) @api_client = api_client end # Generate api key # # @param name [String] The name of the API key to be generated # @param body [GenerateAPIKeyReqDTO] # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name def generate(name:, extra: {}) _body = {} _body[:name] = name if name != SENTINEL generate_api_key_req_dto = _body api_response = generate_with_http_info_impl(generate_api_key_req_dto, extra) api_response.data end # Generate api key # # @param name [String] The name of the API key to be generated # @param body [GenerateAPIKeyReqDTO] # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name def generate_with_http_info(name:, extra: {}) _body = {} _body[:name] = name if name != SENTINEL generate_api_key_req_dto = _body generate_with_http_info_impl(generate_api_key_req_dto, extra) end # Generate api key # @param generate_api_key_req_dto [GenerateAPIKeyReqDTO] GenerateAPIKeyReqDTO # @param [Hash] opts the optional parameters # @return [APIKeyResDTO] private def generate_impl(generate_api_key_req_dto, opts = {}) data, _status_code, _headers = generate_with_http_info(generate_api_key_req_dto, opts) data end # Generate api key # @param generate_api_key_req_dto [GenerateAPIKeyReqDTO] GenerateAPIKeyReqDTO # @param [Hash] opts the optional parameters # @return [APIResponse] data is APIKeyResDTO, status code, headers and response private def generate_with_http_info_impl(generate_api_key_req_dto, opts = {}) if @api_client.config.debugging @api_client.config.logger.debug 'Calling API: APIKeysApi.generate ...' end # verify the required parameter 'generate_api_key_req_dto' is set if @api_client.config.client_side_validation && generate_api_key_req_dto.nil? fail ArgumentError, "Missing the required parameter 'generate_api_key_req_dto' when calling APIKeysApi.generate" end # resource path local_var_path = '/api/v1/api_keys' # query parameters query_params = opts[:query_params] || {} # header parameters header_params = opts[:header_params] || {} # HTTP header 'Accept' (if needed) header_params['Accept'] = @api_client.select_header_accept(['application/json']) # HTTP header 'Content-Type' content_type = @api_client.select_header_content_type(['application/json']) if !content_type.nil? header_params['Content-Type'] = content_type end # form parameters form_params = opts[:form_params] || {} # http body (model) post_body = opts[:debug_body] || @api_client.object_to_http_body(generate_api_key_req_dto) # return_type return_type = opts[:debug_return_type] || 'APIKeyResDTO' # auth_names auth_names = opts[:debug_auth_names] || ['api_key'] new_options = opts.merge( :operation => :"APIKeysApi.generate", :header_params => header_params, :query_params => query_params, :form_params => form_params, :body => post_body, :auth_names => auth_names, :return_type => return_type ) data, status_code, headers, response = @api_client.call_api(:POST, local_var_path, new_options) if @api_client.config.debugging @api_client.config.logger.debug "API called: APIKeysApi#generate\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" end APIResponse::new(data, status_code, headers, response) end # List api keys # # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name def list(extra: {}) api_response = list_with_http_info_impl(extra) api_response.data end # List api keys # # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name def list_with_http_info(extra: {}) list_with_http_info_impl(extra) end # List api keys # @param [Hash] opts the optional parameters # @return [Array] private def list_impl(opts = {}) data, _status_code, _headers = list_with_http_info(opts) data end # List api keys # @param [Hash] opts the optional parameters # @return [APIResponse] data is Array, status code, headers and response private def list_with_http_info_impl(opts = {}) if @api_client.config.debugging @api_client.config.logger.debug 'Calling API: APIKeysApi.list ...' end # resource path local_var_path = '/api/v1/api_keys' # query parameters query_params = opts[:query_params] || {} # header parameters header_params = opts[:header_params] || {} # HTTP header 'Accept' (if needed) header_params['Accept'] = @api_client.select_header_accept(['application/json']) # form parameters form_params = opts[:form_params] || {} # http body (model) post_body = opts[:debug_body] # return_type return_type = opts[:debug_return_type] || 'Array' # auth_names auth_names = opts[:debug_auth_names] || ['api_key'] new_options = opts.merge( :operation => :"APIKeysApi.list", :header_params => header_params, :query_params => query_params, :form_params => form_params, :body => post_body, :auth_names => auth_names, :return_type => return_type ) data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options) if @api_client.config.debugging @api_client.config.logger.debug "API called: APIKeysApi#list\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" end APIResponse::new(data, status_code, headers, response) end # Delete api key # # @param id [String] # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name def remove(id:, extra: {}) api_response = remove_with_http_info_impl(id, extra) api_response.data end # Delete api key # # @param id [String] # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name def remove_with_http_info(id:, extra: {}) remove_with_http_info_impl(id, extra) end # Delete api key # @param id [String] # @param [Hash] opts the optional parameters # @return [DeleteAPIKeyResponseDTO] private def remove_impl(id, opts = {}) data, _status_code, _headers = remove_with_http_info(id, opts) data end # Delete api key # @param id [String] # @param [Hash] opts the optional parameters # @return [APIResponse] data is DeleteAPIKeyResponseDTO, status code, headers and response private def remove_with_http_info_impl(id, opts = {}) if @api_client.config.debugging @api_client.config.logger.debug 'Calling API: APIKeysApi.remove ...' end # verify the required parameter 'id' is set if @api_client.config.client_side_validation && id.nil? fail ArgumentError, "Missing the required parameter 'id' when calling APIKeysApi.remove" end pattern = Regexp.new(/[^\/#\?]+?/) if @api_client.config.client_side_validation && id !~ pattern fail ArgumentError, "invalid value for 'id' when calling APIKeysApi.remove, must conform to the pattern #{pattern}." end # resource path local_var_path = '/api/v1/api_keys/{id}'.sub('{' + 'id' + '}', CGI.escape(id.to_s)) # query parameters query_params = opts[:query_params] || {} # header parameters header_params = opts[:header_params] || {} # HTTP header 'Accept' (if needed) header_params['Accept'] = @api_client.select_header_accept(['application/json']) # form parameters form_params = opts[:form_params] || {} # http body (model) post_body = opts[:debug_body] # return_type return_type = opts[:debug_return_type] || 'DeleteAPIKeyResponseDTO' # auth_names auth_names = opts[:debug_auth_names] || ['api_key'] new_options = opts.merge( :operation => :"APIKeysApi.remove", :header_params => header_params, :query_params => query_params, :form_params => form_params, :body => post_body, :auth_names => auth_names, :return_type => return_type ) data, status_code, headers, response = @api_client.call_api(:DELETE, local_var_path, new_options) if @api_client.config.debugging @api_client.config.logger.debug "API called: APIKeysApi#remove\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" end APIResponse::new(data, status_code, headers, response) end end # top-level client access to avoid having the user to insantiate their own API instances APIKeys = APIKeysApi::new end