diff --git a/.gitignore b/.gitignore index 0cb6eeb..33c0f8a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,9 +1,56 @@ -/.bundle/ -/.yardoc -/Gemfile.lock -/_yardoc/ +*.gem +*.rbc +/.config /coverage/ -/doc/ +/InstalledFiles /pkg/ /spec/reports/ +/spec/examples.txt +/test/tmp/ +/test/version_tmp/ /tmp/ + +# Used by dotenv library to load environment variables. +# .env + +# Ignore Byebug command history file. +.byebug_history + +## Specific to RubyMotion: +.dat* +.repl_history +build/ +*.bridgesupport +build-iPhoneOS/ +build-iPhoneSimulator/ + +## Specific to RubyMotion (use of CocoaPods): +# +# We recommend against adding the Pods directory to your .gitignore. However +# you should judge for yourself, the pros and cons are mentioned at: +# https://guides.cocoapods.org/using/using-cocoapods.html#should-i-check-the-pods-directory-into-source-control +# +# vendor/Pods/ + +## Documentation cache and generated files: +/.yardoc/ +/_yardoc/ +/doc/ +/rdoc/ + +## Environment normalization: +/.bundle/ +/vendor/bundle +/lib/bundler/man/ + +# for a library or gem, you might want to ignore these files since the code is +# intended to run in multiple environments; otherwise, check them in: +# Gemfile.lock +# .ruby-version +# .ruby-gemset + +# unless supporting rvm < 1.11.0 or doing something fancy, ignore this: +.rvmrc + +# Used by RuboCop. Remote config files pulled in from inherit_from directive. +# .rubocop-https?--* \ No newline at end of file diff --git a/.rspec b/.rspec new file mode 100644 index 0000000..83e16f8 --- /dev/null +++ b/.rspec @@ -0,0 +1,2 @@ +--color +--require spec_helper diff --git a/.rubocop.yml b/.rubocop.yml new file mode 100644 index 0000000..df46058 --- /dev/null +++ b/.rubocop.yml @@ -0,0 +1,148 @@ +# This file is based on https://github.com/rails/rails/blob/master/.rubocop.yml (MIT license) +# Automatically generated by OpenAPI Generator (https://openapi-generator.tech) +AllCops: + TargetRubyVersion: 2.4 + # RuboCop has a bunch of cops enabled by default. This setting tells RuboCop + # to ignore them, so only the ones explicitly set in this file are enabled. + DisabledByDefault: true + Exclude: + - '**/templates/**/*' + - '**/vendor/**/*' + - 'actionpack/lib/action_dispatch/journey/parser.rb' + +# Prefer &&/|| over and/or. +Style/AndOr: + Enabled: true + +# Align `when` with `case`. +Layout/CaseIndentation: + Enabled: true + +# Align comments with method definitions. +Layout/CommentIndentation: + Enabled: true + +Layout/ElseAlignment: + Enabled: true + +Layout/EmptyLineAfterMagicComment: + Enabled: true + +# In a regular class definition, no empty lines around the body. +Layout/EmptyLinesAroundClassBody: + Enabled: true + +# In a regular method definition, no empty lines around the body. +Layout/EmptyLinesAroundMethodBody: + Enabled: true + +# In a regular module definition, no empty lines around the body. +Layout/EmptyLinesAroundModuleBody: + Enabled: true + +Layout/FirstArgumentIndentation: + Enabled: true + +# Use Ruby >= 1.9 syntax for hashes. Prefer { a: :b } over { :a => :b }. +Style/HashSyntax: + Enabled: false + +# Method definitions after `private` or `protected` isolated calls need one +# extra level of indentation. +Layout/IndentationConsistency: + Enabled: true + EnforcedStyle: indented_internal_methods + +# Two spaces, no tabs (for indentation). +Layout/IndentationWidth: + Enabled: true + +Layout/LeadingCommentSpace: + Enabled: true + +Layout/SpaceAfterColon: + Enabled: true + +Layout/SpaceAfterComma: + Enabled: true + +Layout/SpaceAroundEqualsInParameterDefault: + Enabled: true + +Layout/SpaceAroundKeyword: + Enabled: true + +Layout/SpaceAroundOperators: + Enabled: true + +Layout/SpaceBeforeComma: + Enabled: true + +Layout/SpaceBeforeFirstArg: + Enabled: true + +Style/DefWithParentheses: + Enabled: true + +# Defining a method with parameters needs parentheses. +Style/MethodDefParentheses: + Enabled: true + +Style/FrozenStringLiteralComment: + Enabled: false + EnforcedStyle: always + +# Use `foo {}` not `foo{}`. +Layout/SpaceBeforeBlockBraces: + Enabled: true + +# Use `foo { bar }` not `foo {bar}`. +Layout/SpaceInsideBlockBraces: + Enabled: true + +# Use `{ a: 1 }` not `{a:1}`. +Layout/SpaceInsideHashLiteralBraces: + Enabled: true + +Layout/SpaceInsideParens: + Enabled: true + +# Check quotes usage according to lint rule below. +#Style/StringLiterals: +# Enabled: true +# EnforcedStyle: single_quotes + +# Detect hard tabs, no hard tabs. +Layout/Tab: + Enabled: true + +# Blank lines should not have any spaces. +Layout/TrailingEmptyLines: + Enabled: true + +# No trailing whitespace. +Layout/TrailingWhitespace: + Enabled: false + +# Use quotes for string literals when they are enough. +Style/RedundantPercentQ: + Enabled: true + +# Align `end` with the matching keyword or starting expression except for +# assignments, where it should be aligned with the LHS. +Layout/EndAlignment: + Enabled: true + EnforcedStyleAlignWith: variable + AutoCorrect: true + +# Use my_method(my_arg) not my_method( my_arg ) or my_method my_arg. +Lint/RequireParentheses: + Enabled: true + +Style/RedundantReturn: + Enabled: true + AllowMultipleReturnValues: true + +Style/Semicolon: + Enabled: true + AllowAsExpressionSeparator: true diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..0fde555 --- /dev/null +++ b/.travis.yml @@ -0,0 +1,11 @@ +language: ruby +cache: bundler +rvm: + - 2.3 + - 2.4 + - 2.5 +script: + - bundle install --path vendor/bundle + - bundle exec rspec + - gem build Meli.gemspec + - gem install ./Meli-3.0.0.gem diff --git a/Gemfile b/Gemfile index b3b7acb..c2e3127 100644 --- a/Gemfile +++ b/Gemfile @@ -1,4 +1,9 @@ source 'https://rubygems.org' -# Specify your gem's dependencies in meliz.gemspec gemspec + +group :development, :test do + gem 'rake', '~> 13.0.1' + gem 'pry-byebug' + gem 'rubocop', '~> 0.66.0' +end diff --git a/README.md b/README.md old mode 100755 new mode 100644 index fa1be19..2c5ac69 --- a/README.md +++ b/README.md @@ -1,133 +1,137 @@ -# MercadoLibre's Ruby SDK -This is the official Ruby SDK for MercadoLibre's Platform. +

+ + Mercado Libre Developers + +

+ MercadoLibre's Ruby SDK +
+

-## How do I install it? +

This is the official Ruby SDK for MercadoLibre's Platform.

- clone repository - https://github.com/mercadolibre/ruby-sdk.git +## Installation -## Using Bundler +### Build a gem -Add it to your Gemfile: +To build the Ruby code into a gem: - gem 'meli', '~> 1.0.2' - -And then install - - bundle install - -## How do I use it? - -The first thing to do is to instance a ```Meli``` class. You'll need to give a ```clientId``` and a ```clientSecret```. You can obtain both after creating your own application. For more information on this please read: [creating an application](http://developers.mercadolibre.com/application-manager/) - -### Including the Lib -Include the lib meli in your project - -### Attention -Don't forget to set the authentication URL of your country in file lib/config.yml - -```ruby -require 'lib/meli' +```shell +gem build meli.gemspec ``` -Start the development! -### Create an instance of Meli class -Simple like this -```ruby -meli = Meli.new(1234, "a secret") -``` -With this instance you can start working on MercadoLibre's APIs. - -There are some design considerations worth to mention. - -1. This SDK is just a thin layer on top of an http client to handle all the OAuth WebServer flow for you. +Then either install the gem locally: -2. There is JSON parsing. this SDK will include [json](http://rubygems.org/gems/json) gem for internal usage. - -3. If you already have the access_token and the refresh_token you can pass in the constructor - -```ruby -meli = Meli.new(1234, "a secret", "Access_Token", "Refresh_Token") +```shell +gem install ./meli-3.0.0.gem ``` -## How do I redirect users to authorize my application? +(for development, run `gem install --dev ./meli-3.0.0.gem` to install the development dependencies) -This is a 2 step process. +or publish the gem to a gem hosting service, e.g. [RubyGems](https://rubygems.org/). -First get the link to redirect the user. This is very easy! Just: +Finally add this to the Gemfile: -```ruby -redirectUrl = meli.auth_url("http://somecallbackurl") -``` - -This will give you the url to redirect the user. You need to specify a callback url which will be the one that the user will redirected after a successfull authrization process. + gem 'meli', '~> 3.0.0' -Once the user is redirected to your callback url, you'll receive in the query string, a parameter named ```code```. You'll need this for the second part of the process. +### Install from Git -```ruby -meli.authorize("the received code", "http://somecallbackurl") -``` +If the Ruby gem is hosted at a git repository: [https://github.com/mercadolibre/ruby-sdk](https://github.com/mercadolibre/ruby-sdk), then add the following in the Gemfile: -This will get an ```access_token``` and a ```refresh_token``` (is case your application has the ```offline_access```) for your application and your user. + gem 'meli', :git => 'https://github.com/mercadolibre/ruby-sdk.git' -At this stage your are ready to make call to the API on behalf of the user. +### Include the Ruby code directly -#### Making GET calls +Include the Ruby code directly using `-I` as follows: -```ruby -params = {:access_token => meli.access_token} -response = meli.get("/users/me", params) +```shell +ruby -Ilib script.rb ``` -The response body will not be converted from json to Ruby hash - -Look this simple way to resolve this: - +## Usage ```ruby - #convert json into a ruby hash -resp_hash = JSON.parse response.body -puts resp_hahs["KEY"] +# Auth URLs Options by country + +# 1: "https://auth.mercadolibre.com.ar" +# 2: "https://auth.mercadolivre.com.br" +# 3: "https://auth.mercadolibre.com.co" +# 4: "https://auth.mercadolibre.com.mx" +# 5: "https://auth.mercadolibre.com.uy" +# 6: "https://auth.mercadolibre.cl" +# 7: "https://auth.mercadolibre.com.cr" +# 8: "https://auth.mercadolibre.com.ec" +# 9: "https://auth.mercadolibre.com.ve" +# 10: "https://auth.mercadolibre.com.pa" +# 11: "https://auth.mercadolibre.com.pe" +# 12: "https://auth.mercadolibre.com.do" +# 13: "https://auth.mercadolibre.com.bo" +# 14: "https://auth.mercadolibre.com.py" + +# For example in your app +client_id = "Your client_id" +redirect_uri = "Your redirect uri" +puts ''+ Authenticate + '' ``` +his will give you the url to redirect the user. You need to specify a callback url which will be the one that the user will redirected after a successfull authrization process. -#### Making POST calls +Once the user is redirected to your callback url, you'll receive in the query string, a parameter named code. You'll need this for the second part of the process -```ruby -params = {:access_token => meli.access_token} - - #we are cool, the sdk will convert this body into json for you -body = {:foo => "bar", :bar => "foo"} - -response = meli.post("/items", body, params) -``` - -#### Making PUT calls +## Examples for OAuth - get token ```ruby -params = {:access_token => meli.access_token} - - #we are cool, the sdk will convert this body into json for you -body = {:foo => "bar", :bar => "foo"} - -response = meli.put("/items/123", body, params) +# load the gem +require 'Meli' + +api_instance = Meli::OAuth20Api.new +opts = { + grant_type: 'authorization_code', # String | + client_id: 'client_id_example', # String | + client_secret: 'client_secret_example', # String | + redirect_uri: 'redirect_uri_example', # String | + code: 'code_example', # String | + refresh_token: 'refresh_token_example' # String | +} + +begin + #Request Access Token + result = api_instance.get_token(opts) + p result +rescue Meli::ApiError => e + puts "Exception when calling OAuth20Api->get_token: #{e}" +end ``` -#### Making DELETE calls + +## Example using the RestClient with a POST Item ```ruby -params = {:access_token => meli.access_token} -response = meli.delete("/questions/123", params) +# load the gem +require 'Meli' + +api_instance = Meli::RestClientApi.new +resource = 'resource_example' # String | +access_token = 'access_token_example' # String | +body = nil # Object | + +begin + #Resourse path POST + result = api_instance.resource_post(resource, access_token, body) + p result +rescue Meli::ApiError => e + puts "Exception when calling RestClientApi->resource_post: #{e}" +end ``` -## Examples -Don't forget to check out our examples codes in the folder [examples](https://github.com/mercadolibre/ruby-sdk/tree/master/examples) +## Documentation & Important notes -## Community +##### The URIs are relative to https://api.mercadolibre.com -You can contact us if you have questions using the standard communication channels described in the [developer's site](http://developers.mercadolibre.com/community/) +##### The Authorization URLs: +###### Remember set your correct country ID +###### https://auth.mercadolibre.{country_domain} -## I want to contribute! +##### All docs for the library are located [here](https://github.com/mercadolibre/ruby-sdk/tree/master/docs) -That is great! Just fork the project in github. Create a topic branch, write some code, and add some tests for your new code. +##### Check out our examples codes in the folder [examples](https://github.com/mercadolibre/ruby-sdk/tree/master/examples) -Thanks for helping! +##### Don’t forget to check out our [developer site](https://developers.mercadolibre.com/) diff --git a/Rakefile b/Rakefile index 809eb56..c72ca30 100644 --- a/Rakefile +++ b/Rakefile @@ -1,2 +1,10 @@ require "bundler/gem_tasks" +begin + require 'rspec/core/rake_task' + + RSpec::Core::RakeTask.new(:spec) + task default: :spec +rescue LoadError + # no rspec available +end diff --git a/docs/Attributes.md b/docs/Attributes.md new file mode 100644 index 0000000..5123d21 --- /dev/null +++ b/docs/Attributes.md @@ -0,0 +1,31 @@ +# Meli::Attributes + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**id** | **String** | | [optional] +**name** | **String** | | [optional] +**value_id** | **String** | | [optional] +**value_name** | **String** | | [optional] +**value_struct** | [**AttributesValueStruct**](AttributesValueStruct.md) | | [optional] +**values** | [**Array<AttributesValues>**](AttributesValues.md) | | [optional] +**attribute_group_id** | **String** | | [optional] +**attribute_group_name** | **String** | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::Attributes.new(id: DATA_STORAGE_CAPACITY, + name: Capacidad de almacenamiento de datos, + value_id: null, + value_name: 8 GB, + value_struct: null, + values: null, + attribute_group_id: OTHERS, + attribute_group_name: Otros) +``` + + diff --git a/docs/AttributesValueStruct.md b/docs/AttributesValueStruct.md new file mode 100644 index 0000000..70baef2 --- /dev/null +++ b/docs/AttributesValueStruct.md @@ -0,0 +1,19 @@ +# Meli::AttributesValueStruct + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**number** | **Float** | | [optional] +**unit** | **String** | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::AttributesValueStruct.new(number: 8, + unit: GB) +``` + + diff --git a/docs/AttributesValues.md b/docs/AttributesValues.md new file mode 100644 index 0000000..b341249 --- /dev/null +++ b/docs/AttributesValues.md @@ -0,0 +1,21 @@ +# Meli::AttributesValues + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**id** | **String** | | [optional] +**name** | **String** | | [optional] +**struct** | [**AttributesValueStruct**](AttributesValueStruct.md) | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::AttributesValues.new(id: null, + name: 8 GB, + struct: null) +``` + + diff --git a/docs/CategoriesApi.md b/docs/CategoriesApi.md new file mode 100644 index 0000000..66379ca --- /dev/null +++ b/docs/CategoriesApi.md @@ -0,0 +1,150 @@ +# Meli::CategoriesApi + +All URIs are relative to *https://api.mercadolibre.com* + +Method | HTTP request | Description +------------- | ------------- | ------------- +[**categories_category_id_get**](CategoriesApi.md#categories_category_id_get) | **GET** /categories/{category_id} | Return by category. +[**sites_site_id_categories_get**](CategoriesApi.md#sites_site_id_categories_get) | **GET** /sites/{site_id}/categories | Return a categories by site. +[**sites_site_id_domain_discovery_search_get**](CategoriesApi.md#sites_site_id_domain_discovery_search_get) | **GET** /sites/{site_id}/domain_discovery/search | Predictor + + + +## categories_category_id_get + +> Object categories_category_id_get(category_id) + +Return by category. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::CategoriesApi.new +category_id = 'category_id_example' # String | + +begin + #Return by category. + result = api_instance.categories_category_id_get(category_id) + p result +rescue Meli::ApiError => e + puts "Exception when calling CategoriesApi->categories_category_id_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **category_id** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## sites_site_id_categories_get + +> Object sites_site_id_categories_get(site_id) + +Return a categories by site. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::CategoriesApi.new +site_id = 'site_id_example' # String | + +begin + #Return a categories by site. + result = api_instance.sites_site_id_categories_get(site_id) + p result +rescue Meli::ApiError => e + puts "Exception when calling CategoriesApi->sites_site_id_categories_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **site_id** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## sites_site_id_domain_discovery_search_get + +> Object sites_site_id_domain_discovery_search_get(site_id, q, limit) + +Predictor + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::CategoriesApi.new +site_id = 'site_id_example' # String | +q = 'q_example' # String | +limit = 'limit_example' # String | + +begin + #Predictor + result = api_instance.sites_site_id_domain_discovery_search_get(site_id, q, limit) + p result +rescue Meli::ApiError => e + puts "Exception when calling CategoriesApi->sites_site_id_domain_discovery_search_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **site_id** | **String**| | + **q** | **String**| | + **limit** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + diff --git a/docs/InlineObject.md b/docs/InlineObject.md new file mode 100644 index 0000000..6ec3d16 --- /dev/null +++ b/docs/InlineObject.md @@ -0,0 +1,27 @@ +# Meli::InlineObject + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**grant_type** | **String** | | [optional] +**client_id** | **String** | | [optional] +**client_secret** | **String** | | [optional] +**redirect_uri** | **String** | | [optional] +**code** | **String** | | [optional] +**refresh_token** | **String** | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::InlineObject.new(grant_type: authorization_code, + client_id: null, + client_secret: null, + redirect_uri: null, + code: null, + refresh_token: null) +``` + + diff --git a/docs/Item.md b/docs/Item.md new file mode 100644 index 0000000..4c3d486 --- /dev/null +++ b/docs/Item.md @@ -0,0 +1,41 @@ +# Meli::Item + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**title** | **String** | | +**category_id** | **String** | | +**price** | **Integer** | | +**currency_id** | **String** | | +**available_quantity** | **String** | | +**buying_mode** | **String** | | +**listing_type_id** | **String** | | +**condition** | **String** | | +**description** | **String** | | +**video_id** | **String** | | +**pictures** | [**Array<ItemPictures>**](ItemPictures.md) | | +**attributes** | [**Array<Attributes>**](Attributes.md) | | [optional] +**variations** | [**Array<Variations>**](Variations.md) | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::Item.new(title: Item de test - No Ofertar, + category_id: MLA5991, + price: 350, + currency_id: ARS, + available_quantity: 12, + buying_mode: buy_it_now, + listing_type_id: bronze, + condition: new, + description: Item de Teste. Mercado Livre SDK, + video_id: RXWn6kftTHY, + pictures: null, + attributes: null, + variations: null) +``` + + diff --git a/docs/ItemPictures.md b/docs/ItemPictures.md new file mode 100644 index 0000000..b73fd77 --- /dev/null +++ b/docs/ItemPictures.md @@ -0,0 +1,17 @@ +# Meli::ItemPictures + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**source** | **String** | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::ItemPictures.new(source: https://http2.mlstatic.com/storage/developers-site-cms-admin/openapi/319968615067-mp3.jpg) +``` + + diff --git a/docs/ItemsApi.md b/docs/ItemsApi.md new file mode 100644 index 0000000..d6775bc --- /dev/null +++ b/docs/ItemsApi.md @@ -0,0 +1,152 @@ +# Meli::ItemsApi + +All URIs are relative to *https://api.mercadolibre.com* + +Method | HTTP request | Description +------------- | ------------- | ------------- +[**items_id_get**](ItemsApi.md#items_id_get) | **GET** /items/{id} | Return a Item. +[**items_id_put**](ItemsApi.md#items_id_put) | **PUT** /items/{id} | Update a Item. +[**items_post**](ItemsApi.md#items_post) | **POST** /items | Create a Item. + + + +## items_id_get + +> Object items_id_get(id) + +Return a Item. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::ItemsApi.new +id = 'id_example' # String | + +begin + #Return a Item. + result = api_instance.items_id_get(id) + p result +rescue Meli::ApiError => e + puts "Exception when calling ItemsApi->items_id_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **id** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## items_id_put + +> Object items_id_put(id, access_token, item) + +Update a Item. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::ItemsApi.new +id = 'id_example' # String | +access_token = 'access_token_example' # String | +item = Meli::Item.new # Item | + +begin + #Update a Item. + result = api_instance.items_id_put(id, access_token, item) + p result +rescue Meli::ApiError => e + puts "Exception when calling ItemsApi->items_id_put: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **id** | **String**| | + **access_token** | **String**| | + **item** | [**Item**](Item.md)| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: application/json +- **Accept**: application/json + + +## items_post + +> Object items_post(access_token, item) + +Create a Item. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::ItemsApi.new +access_token = 'access_token_example' # String | +item = Meli::Item.new # Item | + +begin + #Create a Item. + result = api_instance.items_post(access_token, item) + p result +rescue Meli::ApiError => e + puts "Exception when calling ItemsApi->items_post: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **access_token** | **String**| | + **item** | [**Item**](Item.md)| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: application/json +- **Accept**: application/json + diff --git a/docs/ItemsHealthApi.md b/docs/ItemsHealthApi.md new file mode 100644 index 0000000..249d78c --- /dev/null +++ b/docs/ItemsHealthApi.md @@ -0,0 +1,150 @@ +# Meli::ItemsHealthApi + +All URIs are relative to *https://api.mercadolibre.com* + +Method | HTTP request | Description +------------- | ------------- | ------------- +[**items_id_health_actions_get**](ItemsHealthApi.md#items_id_health_actions_get) | **GET** /items/{id}/health/actions | Return item health actions by id. +[**items_id_health_get**](ItemsHealthApi.md#items_id_health_get) | **GET** /items/{id}/health | Return health by id. +[**sites_site_id_health_levels_get**](ItemsHealthApi.md#sites_site_id_health_levels_get) | **GET** /sites/{site_id}/health_levels | Return health levels. + + + +## items_id_health_actions_get + +> Object items_id_health_actions_get(id, access_token) + +Return item health actions by id. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::ItemsHealthApi.new +id = 'id_example' # String | +access_token = 'access_token_example' # String | + +begin + #Return item health actions by id. + result = api_instance.items_id_health_actions_get(id, access_token) + p result +rescue Meli::ApiError => e + puts "Exception when calling ItemsHealthApi->items_id_health_actions_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **id** | **String**| | + **access_token** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## items_id_health_get + +> Object items_id_health_get(id, access_token) + +Return health by id. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::ItemsHealthApi.new +id = 'id_example' # String | +access_token = 'access_token_example' # String | + +begin + #Return health by id. + result = api_instance.items_id_health_get(id, access_token) + p result +rescue Meli::ApiError => e + puts "Exception when calling ItemsHealthApi->items_id_health_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **id** | **String**| | + **access_token** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## sites_site_id_health_levels_get + +> Object sites_site_id_health_levels_get(site_id) + +Return health levels. + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::ItemsHealthApi.new +site_id = 'site_id_example' # String | + +begin + #Return health levels. + result = api_instance.sites_site_id_health_levels_get(site_id) + p result +rescue Meli::ApiError => e + puts "Exception when calling ItemsHealthApi->sites_site_id_health_levels_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **site_id** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + diff --git a/docs/OAuth20Api.md b/docs/OAuth20Api.md new file mode 100644 index 0000000..464ea19 --- /dev/null +++ b/docs/OAuth20Api.md @@ -0,0 +1,117 @@ +# Meli::OAuth20Api + +All URIs are relative to *https://api.mercadolibre.com* + +Method | HTTP request | Description +------------- | ------------- | ------------- +[**auth**](OAuth20Api.md#auth) | **GET** /authorization | Authentication Endpoint +[**get_token**](OAuth20Api.md#get_token) | **POST** /oauth/token | Request Access Token + + + +## auth + +> auth(response_type, client_id, redirect_uri) + +Authentication Endpoint + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::OAuth20Api.new +response_type = 'code' # String | +client_id = 'client_id_example' # String | +redirect_uri = 'redirect_uri_example' # String | + +begin + #Authentication Endpoint + api_instance.auth(response_type, client_id, redirect_uri) +rescue Meli::ApiError => e + puts "Exception when calling OAuth20Api->auth: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **response_type** | **String**| | [default to 'code'] + **client_id** | **String**| | + **redirect_uri** | **String**| | + +### Return type + +nil (empty response body) + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## get_token + +> Object get_token(opts) + +Request Access Token + +Partner makes a request to the token endpoint by adding the following parameters described below + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::OAuth20Api.new +opts = { + grant_type: 'grant_type_example', # String | + client_id: 'client_id_example', # String | + client_secret: 'client_secret_example', # String | + redirect_uri: 'redirect_uri_example', # String | + code: 'code_example', # String | + refresh_token: 'refresh_token_example' # String | +} + +begin + #Request Access Token + result = api_instance.get_token(opts) + p result +rescue Meli::ApiError => e + puts "Exception when calling OAuth20Api->get_token: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **grant_type** | **String**| | [optional] + **client_id** | **String**| | [optional] + **client_secret** | **String**| | [optional] + **redirect_uri** | **String**| | [optional] + **code** | **String**| | [optional] + **refresh_token** | **String**| | [optional] + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: application/x-www-form-urlencoded +- **Accept**: application/json + diff --git a/docs/RestClientApi.md b/docs/RestClientApi.md new file mode 100644 index 0000000..763c449 --- /dev/null +++ b/docs/RestClientApi.md @@ -0,0 +1,204 @@ +# Meli::RestClientApi + +All URIs are relative to *https://api.mercadolibre.com* + +Method | HTTP request | Description +------------- | ------------- | ------------- +[**resource_delete**](RestClientApi.md#resource_delete) | **DELETE** /{resource} | Resource path DELETE +[**resource_get**](RestClientApi.md#resource_get) | **GET** /{resource} | Resource path GET +[**resource_post**](RestClientApi.md#resource_post) | **POST** /{resource} | Resourse path POST +[**resource_put**](RestClientApi.md#resource_put) | **PUT** /{resource} | Resourse path PUT + + + +## resource_delete + +> Object resource_delete(resource, access_token) + +Resource path DELETE + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::RestClientApi.new +resource = 'resource_example' # String | +access_token = 'access_token_example' # String | + +begin + #Resource path DELETE + result = api_instance.resource_delete(resource, access_token) + p result +rescue Meli::ApiError => e + puts "Exception when calling RestClientApi->resource_delete: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **resource** | **String**| | + **access_token** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## resource_get + +> Object resource_get(resource, access_token) + +Resource path GET + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::RestClientApi.new +resource = 'resource_example' # String | +access_token = 'access_token_example' # String | + +begin + #Resource path GET + result = api_instance.resource_get(resource, access_token) + p result +rescue Meli::ApiError => e + puts "Exception when calling RestClientApi->resource_get: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **resource** | **String**| | + **access_token** | **String**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: Not defined +- **Accept**: application/json + + +## resource_post + +> Object resource_post(resource, access_token, body) + +Resourse path POST + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::RestClientApi.new +resource = 'resource_example' # String | +access_token = 'access_token_example' # String | +body = nil # Object | + +begin + #Resourse path POST + result = api_instance.resource_post(resource, access_token, body) + p result +rescue Meli::ApiError => e + puts "Exception when calling RestClientApi->resource_post: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **resource** | **String**| | + **access_token** | **String**| | + **body** | **Object**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: application/json +- **Accept**: application/json + + +## resource_put + +> Object resource_put(resource, access_token, body) + +Resourse path PUT + +### Example + +```ruby +# load the gem +require 'Meli' + +api_instance = Meli::RestClientApi.new +resource = 'resource_example' # String | +access_token = 'access_token_example' # String | +body = nil # Object | + +begin + #Resourse path PUT + result = api_instance.resource_put(resource, access_token, body) + p result +rescue Meli::ApiError => e + puts "Exception when calling RestClientApi->resource_put: #{e}" +end +``` + +### Parameters + + +Name | Type | Description | Notes +------------- | ------------- | ------------- | ------------- + **resource** | **String**| | + **access_token** | **String**| | + **body** | **Object**| | + +### Return type + +**Object** + +### Authorization + +No authorization required + +### HTTP request headers + +- **Content-Type**: application/json +- **Accept**: application/json + diff --git a/docs/Variations.md b/docs/Variations.md new file mode 100644 index 0000000..5a1a9ef --- /dev/null +++ b/docs/Variations.md @@ -0,0 +1,25 @@ +# Meli::Variations + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**price** | **Integer** | | [optional] +**attribute_combinations** | [**Array<VariationsAttributeCombinations>**](VariationsAttributeCombinations.md) | | [optional] +**available_quantity** | **Integer** | | [optional] +**sold_quantity** | **Integer** | | [optional] +**picture_ids** | **Array<String>** | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::Variations.new(price: 350, + attribute_combinations: null, + available_quantity: 2, + sold_quantity: 0, + picture_ids: null) +``` + + diff --git a/docs/VariationsAttributeCombinations.md b/docs/VariationsAttributeCombinations.md new file mode 100644 index 0000000..3cb99cc --- /dev/null +++ b/docs/VariationsAttributeCombinations.md @@ -0,0 +1,21 @@ +# Meli::VariationsAttributeCombinations + +## Properties + +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**name** | **String** | | [optional] +**value_id** | **String** | | [optional] +**value_name** | **String** | | [optional] + +## Code Sample + +```ruby +require 'Meli' + +instance = Meli::VariationsAttributeCombinations.new(name: Color, + value_id: 283165, + value_name: Gris) +``` + + diff --git a/examples/delete.rb b/examples/delete.rb deleted file mode 100644 index f20b5e9..0000000 --- a/examples/delete.rb +++ /dev/null @@ -1,16 +0,0 @@ -#!/usr/bin/ruby - -require 'rubygems' -require '../lib/meli' -require 'json' - -meli = Meli.new(CLIENT_ID, CLIENT_SECRET, ACCESS_TOKEN, REFRESH_TOKEN) - -response = meli.delete("/questions/QUESTION_ID", {:access_token => meli.access_token}) - -#Json format -puts response.body - -#ruby hash format -res = JSON.parse response.body -puts res.inspect diff --git a/examples/example_login.rb b/examples/example_login.rb deleted file mode 100644 index cc7be25..0000000 --- a/examples/example_login.rb +++ /dev/null @@ -1,18 +0,0 @@ -require "rubygems" -require 'lib/meli' -require 'sinatra' -require 'json' - -set :meli, Meli.new(CLIENT_ID, CLIENT_SECRET, ACCESS_TOKEN, REFRESH_TOKEN) -disable :reload - -get '/authorize' do - content_type :text - settings.meli.authorize(params["code"], CALLBACK_URI) if params["code"] - #Don't Forget to Save this data! - "SUCESS! Token: #{settings.meli.access_token} RefresToken: #{settings.meli.refresh_token}" -end - -get '/login' do - "Login" -end diff --git a/examples/get.rb b/examples/get.rb deleted file mode 100644 index f5c408f..0000000 --- a/examples/get.rb +++ /dev/null @@ -1,16 +0,0 @@ -#!/usr/bin/ruby - -require 'rubygems' -require '../lib/meli' -require 'json' - -meli = Meli.new(CLIENT_ID, CLIENT_SECRET, ACCESS_TOKEN, REFRESH_TOKEN) - -response = meli.get("/items/MLB488622999") - -#Json format -puts response.body - -#ruby hash format -res = JSON.parse response.body -puts res.inspect diff --git a/examples/get_token.rb b/examples/get_token.rb new file mode 100644 index 0000000..6c9d1a7 --- /dev/null +++ b/examples/get_token.rb @@ -0,0 +1,21 @@ +# You need use this code in to the main folder +# Load the gem +require 'Meli' + +api_instance = Meli::OAuth20Api.new +opts = { + grant_type: 'authorization_code', # Or 'refresh_token' if you need get one new token + client_id: 'client_id_example', # Your client_id + client_secret: 'client_secret_example', # Your client_secret + redirect_uri: 'redirect_uri_example', # Your redirect_uri + code: 'code_example', # The parameter CODE who was received in the query. + refresh_token: 'refresh_token_example' # Your refresh_token +} + +begin + #Request Access Token + result = api_instance.get_token(opts) + p result +rescue Meli::ApiError => e + puts "Exception when calling OAuth20Api->get_token: #{e}" +end \ No newline at end of file diff --git a/examples/post.rb b/examples/post.rb deleted file mode 100644 index d396854..0000000 --- a/examples/post.rb +++ /dev/null @@ -1,31 +0,0 @@ -#!/usr/bin/ruby - -require 'rubygems' -require '../lib/meli' - -meli = Meli.new(CLIENT_ID, CLIENT_SECRET, ACCESS_TOKEN, REFRESH_TOKEN) - -body = {"condition"=>"new", - "warranty"=>"60 dias", - "currency_id"=>"BRL", - "accepts_mercadopago"=>true, - "description"=>"Lindo Ray_Ban_Original_Wayfarer", - "listing_type_id"=>"bronze", - "title"=>"\303\223culos Ray Ban Aviador Que Troca As Lentes Lan\303\247amento!", - "available_quantity"=>64, - "price"=>289, - "subtitle"=>"Acompanha 3 Pares De Lentes!! Compra 100% Segura", - "buying_mode"=>"buy_it_now", - "category_id"=>"MLB5125", - "pictures"=>[{"source"=>"http://upload.wikimedia.org/wikipedia/commons/f/fd/Ray_Ban_Original_Wayfarer.jpg"}, - {"source"=>"http://en.wikipedia.org/wiki/File:Teashades.gif"}] -} - -response = meli.post("/items", body, {:access_token => meli.access_token}) - -#Json format -puts response.body - -#ruby hash format -res = JSON.parse response.body -puts res.inspect diff --git a/examples/put.rb b/examples/put.rb deleted file mode 100644 index ba9aef5..0000000 --- a/examples/put.rb +++ /dev/null @@ -1,17 +0,0 @@ -#!/usr/bin/ruby - -require 'rubygems' -require '../lib/meli' - -meli = Meli.new(CLIENT_ID, CLIENT_SECRET, ACCESS_TOKEN, REFRESH_TOKEN) - -body = {"title"=>"New Title", "price"=>1000} - -response = meli.put("/items/#{ITEM_ID}", body, {:access_token => meli.access_token}) - -#Json format -puts response.body - -#ruby hash format -res = JSON.parse response.body -puts res.inspect diff --git a/examples/restclient_post.rb b/examples/restclient_post.rb new file mode 100644 index 0000000..7a361b0 --- /dev/null +++ b/examples/restclient_post.rb @@ -0,0 +1,73 @@ +# You need use this code in to the main folder +# Load the gem +require 'Meli' + +api_instance = Meli::RestClientApi.new +resource = 'items' # A resource example like items, search, category, etc. +access_token = 'access_token_example' # Your access token. +body = { + "title": "Item de test from ruby - No Ofertar", + "category_id": "MLA5991", + "price": "350", + "currency_id": "ARS", + "available_quantity": "12", + "buying_mode": "buy_it_now", + "listing_type_id": "bronze", + "condition": "new", + "description": "Item de Teste. Mercado Livre SDK", + "video_id": "RXWn6kftTHY", + "pictures": [ + { + "source": "https://http2.mlstatic.com/storage/developers-site-cms-admin/openapi/319968615067-mp3.jpg" + } + ], + "attributes": [ + { + "id": "DATA_STORAGE_CAPACITY", + "name": "Capacidad de almacenamiento de datos", + "value_id": "null", + "value_name": "8 GB", + "value_struct": { + "number": 8, + "unit": "GB" + }, + "values": [ + { + "id": "null", + "name": "8 GB", + "struct": { + "number": 8, + "unit": "GB" + } + } + ], + "attribute_group_id": "OTHERS", + "attribute_group_name": "Otros" + } + ], + "variations": [ + { + "price": 350, + "attribute_combinations": [ + { + "name": "Color", + "value_id": "283165", + "value_name": "Gris" + } + ], + "available_quantity": 2, + "sold_quantity": 0, + "picture_ids": [ + "882629-MLA40983876214_032020" + ] + } + ] +} + +begin + #Resourse path POST + result = api_instance.resource_post(resource, access_token, body) + p result +rescue Meli::ApiError => e + puts "Exception when calling RestClientApi->resource_post: #{e}" +end diff --git a/lib/config.yml b/lib/config.yml deleted file mode 100755 index 84320b8..0000000 --- a/lib/config.yml +++ /dev/null @@ -1,21 +0,0 @@ -config: - sdk_version: MELI-RUBY-SDK-2.0.0 - api_root_url: https://api.mercadolibre.com - auth_url: https://auth.mercadolivre.com.br/authorization # # Don't forget to set the URL of your country. - oauth_url: /oauth/token - -# Set the auth_url according to your country - -#MLA https://auth.mercadolibre.com.ar/authorization # Argentina -#MLB https://auth.mercadolivre.com.br/authorization # Brasil -#MCO https://auth.mercadolibre.com.co/authorization # Colombia -#MCR https://auth.mercadolibre.com.cr/authorization # Costa Rica -#MEC https://auth.mercadolibre.com.ec/authorization # Ecuador -#MLC https://auth.mercadolibre.cl/authorization # Chile -#MLM https://auth.mercadolibre.com.mx/authorization # Mexico -#MLU https://auth.mercadolibre.com.uy/authorization # Uruguay -#MLV https://auth.mercadolibre.com.ve/authorization # Venezuela -#MPA https://auth.mercadolibre.com.pa/authorization # Panama -#MPE https://auth.mercadolibre.com.pe/authorization # Peru -#MPT https://auth.mercadolibre.com.pt/authorization # Prtugal -#MRD https://auth.mercadolibre.com.do/authorization # Dominicana diff --git a/lib/meli.rb b/lib/meli.rb index ae79463..ffa3774 100644 --- a/lib/meli.rb +++ b/lib/meli.rb @@ -1,159 +1,52 @@ -# encoding: UTF-8 - -require 'rubygems' -require 'net/http' -require 'net/https' -require 'json' -require 'uri' -require 'yaml' - -class Meli - attr_accessor :access_token, :refresh_token - attr_reader :secret, :app_id, :https - - config = YAML.load_file(File.expand_path(File.dirname(__FILE__) + "/config.yml")) - SDK_VERSION = config["config"]["sdk_version"] - API_ROOT_URL = config["config"]["api_root_url"] - AUTH_URL = config["config"]["auth_url"] - OAUTH_URL = config["config"]["oauth_url"] - - #constructor - def initialize(app_id = nil, secret = nil, access_token = nil, refresh_token = nil) - @access_token = access_token - @refresh_token = refresh_token - @app_id = app_id - @secret = secret - api_url = URI.parse API_ROOT_URL - @https = Net::HTTP.new(api_url.host, api_url.port) - @https.use_ssl = true - @https.verify_mode = OpenSSL::SSL::VERIFY_PEER - @https.ssl_version = :TLSv1 - end - - #AUTH METHODS - def auth_url(redirect_URI) - params = {:client_id => @app_id, :response_type => 'code', :redirect_uri => redirect_URI} - url = "#{AUTH_URL}?#{to_url_params(params)}" - end - - def authorize(code, redirect_URI) - params = { :grant_type => 'authorization_code', :client_id => @app_id, :client_secret => @secret, :code => code, :redirect_uri => redirect_URI} - - uri = make_path(OAUTH_URL, params) - - req = Net::HTTP::Post.new(uri.path) - req['Accept'] = 'application/json' - req['User-Agent'] = SDK_VERSION - req['Content-Type'] = "application/x-www-form-urlencoded" - req.set_form_data(params) - response = @https.request(req) - - case response - when Net::HTTPSuccess - response_info = JSON.parse response.body - #convert hash keys to symbol - response_info = Hash[response_info.map{ |k, v| [k.to_sym, v] }] - - @access_token = response_info[:access_token] - if response_info.has_key?(:refresh_token) - @refresh_token = response_info[:refresh_token] - else - @refresh_token = '' # offline_access not set up - end - @access_token - else - # response code isn't a 200; raise an exception - response.error! - end - - end - - def get_refresh_token() - if !@refresh_token.nil? and !@refresh_token.empty? - params = {:grant_type => 'refresh_token', :client_id => @app_id, :client_secret => @secret, :refresh_token => @refresh_token} - - uri = make_path(OAUTH_URL, params) - - req = Net::HTTP::Post.new(uri.path) - req['Accept'] = 'application/json' - req['User-Agent'] = SDK_VERSION - req['Content-Type'] = "application/x-www-form-urlencoded" - req.set_form_data(params) - response = @https.request(req) - - case response - when Net::HTTPSuccess - response_info = JSON.parse response.body - - #convert hash keys to symbol - response_info = Hash[response_info.map{ |k, v| [k.to_sym, v] }] - - @access_token = response_info[:access_token] - @refresh_token = response_info[:refresh_token] - else - # response code isn't a 200; raise an exception - response.error! - end - else - raise "Offline-Access is not allowed." - end - end - - - #REQUEST METHODS - def execute(req) - req['Accept'] = 'application/json' - req['User-Agent'] = SDK_VERSION - req['Content-Type'] = 'application/json' - response = @https.request(req) - end - - def get(path, params = {}) - uri = make_path(path, params) - req = Net::HTTP::Get.new("#{uri.path}?#{uri.query}") - execute req - end - - def post(path, body, params = {}) - uri = make_path(path, params) - req = Net::HTTP::Post.new("#{uri.path}?#{uri.query}") - req.set_form_data(params) - req.body = body.to_json unless body.nil? - execute req - end - - def put(path, body, params = {}) - uri = make_path(path, params) - req = Net::HTTP::Put.new("#{uri.path}?#{uri.query}") - req.set_form_data(params) - req.body = body.to_json unless body.nil? - execute req - end - - def delete(path, params = {}) - uri = make_path(path, params) - req = Net::HTTP::Delete.new("#{uri.path}?#{uri.query}") - execute req - end - - def options(path, params = {}) - uri = make_path(path, params) - req = Net::HTTP::Options.new("#{uri.path}?#{uri.query}") - execute req - end - -private - def to_url_params(params) - URI.escape(params.collect{|k,v| "#{k}=#{v}"}.join('&')) - end - - def make_path(path, params = {}) - # Making Path and add a leading / if not exist - path = "/#{path}" unless path =~ /^\// - path = "#{API_ROOT_URL}#{path}" - - path = "#{path}?#{to_url_params(params)}" if params.keys.size > 0 - uri = URI.parse path - end - -end #class +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +# Common files +require 'Meli/api_client' +require 'Meli/api_error' +require 'Meli/version' +require 'Meli/configuration' + +# Models +require 'Meli/models/attributes' +require 'Meli/models/attributes_value_struct' +require 'Meli/models/attributes_values' +require 'Meli/models/inline_object' +require 'Meli/models/item' +require 'Meli/models/item_pictures' +require 'Meli/models/variations' +require 'Meli/models/variations_attribute_combinations' + +# APIs +require 'Meli/api/categories_api' +require 'Meli/api/items_api' +require 'Meli/api/items_health_api' +require 'Meli/api/o_auth20_api' +require 'Meli/api/rest_client_api' + +module Meli + class << self + # Customize default settings for the SDK using block. + # Meli.configure do |config| + # config.username = "xxx" + # config.password = "xxx" + # end + # If no block given, return the default Configuration object. + def configure + if block_given? + yield(Configuration.default) + else + Configuration.default + end + end + end +end diff --git a/lib/meli/api/categories_api.rb b/lib/meli/api/categories_api.rb new file mode 100644 index 0000000..3bbe242 --- /dev/null +++ b/lib/meli/api/categories_api.rb @@ -0,0 +1,216 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'cgi' + +module Meli + class CategoriesApi + attr_accessor :api_client + + def initialize(api_client = ApiClient.default) + @api_client = api_client + end + # Return by category. + # @param category_id [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def categories_category_id_get(category_id, opts = {}) + data, _status_code, _headers = categories_category_id_get_with_http_info(category_id, opts) + data + end + + # Return by category. + # @param category_id [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def categories_category_id_get_with_http_info(category_id, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: CategoriesApi.categories_category_id_get ...' + end + # verify the required parameter 'category_id' is set + if @api_client.config.client_side_validation && category_id.nil? + fail ArgumentError, "Missing the required parameter 'category_id' when calling CategoriesApi.categories_category_id_get" + end + # resource path + local_var_path = '/categories/{category_id}'.sub('{' + 'category_id' + '}', CGI.escape(category_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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: CategoriesApi#categories_category_id_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Return a categories by site. + # @param site_id [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def sites_site_id_categories_get(site_id, opts = {}) + data, _status_code, _headers = sites_site_id_categories_get_with_http_info(site_id, opts) + data + end + + # Return a categories by site. + # @param site_id [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def sites_site_id_categories_get_with_http_info(site_id, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: CategoriesApi.sites_site_id_categories_get ...' + end + # verify the required parameter 'site_id' is set + if @api_client.config.client_side_validation && site_id.nil? + fail ArgumentError, "Missing the required parameter 'site_id' when calling CategoriesApi.sites_site_id_categories_get" + end + # resource path + local_var_path = '/sites/{site_id}/categories'.sub('{' + 'site_id' + '}', CGI.escape(site_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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: CategoriesApi#sites_site_id_categories_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Predictor + # @param site_id [String] + # @param q [String] + # @param limit [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def sites_site_id_domain_discovery_search_get(site_id, q, limit, opts = {}) + data, _status_code, _headers = sites_site_id_domain_discovery_search_get_with_http_info(site_id, q, limit, opts) + data + end + + # Predictor + # @param site_id [String] + # @param q [String] + # @param limit [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def sites_site_id_domain_discovery_search_get_with_http_info(site_id, q, limit, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: CategoriesApi.sites_site_id_domain_discovery_search_get ...' + end + # verify the required parameter 'site_id' is set + if @api_client.config.client_side_validation && site_id.nil? + fail ArgumentError, "Missing the required parameter 'site_id' when calling CategoriesApi.sites_site_id_domain_discovery_search_get" + end + # verify the required parameter 'q' is set + if @api_client.config.client_side_validation && q.nil? + fail ArgumentError, "Missing the required parameter 'q' when calling CategoriesApi.sites_site_id_domain_discovery_search_get" + end + # verify the required parameter 'limit' is set + if @api_client.config.client_side_validation && limit.nil? + fail ArgumentError, "Missing the required parameter 'limit' when calling CategoriesApi.sites_site_id_domain_discovery_search_get" + end + # resource path + local_var_path = '/sites/{site_id}/domain_discovery/search'.sub('{' + 'site_id' + '}', CGI.escape(site_id.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'q'] = q + query_params[:'limit'] = limit + + # 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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: CategoriesApi#sites_site_id_domain_discovery_search_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + end +end diff --git a/lib/meli/api/items_api.rb b/lib/meli/api/items_api.rb new file mode 100644 index 0000000..19c1f4d --- /dev/null +++ b/lib/meli/api/items_api.rb @@ -0,0 +1,226 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'cgi' + +module Meli + class ItemsApi + attr_accessor :api_client + + def initialize(api_client = ApiClient.default) + @api_client = api_client + end + # Return a Item. + # @param id [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def items_id_get(id, opts = {}) + data, _status_code, _headers = items_id_get_with_http_info(id, opts) + data + end + + # Return a Item. + # @param id [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def items_id_get_with_http_info(id, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: ItemsApi.items_id_get ...' + 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 ItemsApi.items_id_get" + end + # resource path + local_var_path = '/items/{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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: ItemsApi#items_id_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Update a Item. + # @param id [String] + # @param access_token [String] + # @param item [Item] + # @param [Hash] opts the optional parameters + # @return [Object] + def items_id_put(id, access_token, item, opts = {}) + data, _status_code, _headers = items_id_put_with_http_info(id, access_token, item, opts) + data + end + + # Update a Item. + # @param id [String] + # @param access_token [String] + # @param item [Item] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def items_id_put_with_http_info(id, access_token, item, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: ItemsApi.items_id_put ...' + 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 ItemsApi.items_id_put" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling ItemsApi.items_id_put" + end + # verify the required parameter 'item' is set + if @api_client.config.client_side_validation && item.nil? + fail ArgumentError, "Missing the required parameter 'item' when calling ItemsApi.items_id_put" + end + # resource path + local_var_path = '/items/{id}'.sub('{' + 'id' + '}', CGI.escape(id.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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' + header_params['Content-Type'] = @api_client.select_header_content_type(['application/json']) + + # form parameters + form_params = opts[:form_params] || {} + + # http body (model) + post_body = opts[:body] || @api_client.object_to_http_body(item) + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:PUT, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: ItemsApi#items_id_put\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Create a Item. + # @param access_token [String] + # @param item [Item] + # @param [Hash] opts the optional parameters + # @return [Object] + def items_post(access_token, item, opts = {}) + data, _status_code, _headers = items_post_with_http_info(access_token, item, opts) + data + end + + # Create a Item. + # @param access_token [String] + # @param item [Item] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def items_post_with_http_info(access_token, item, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: ItemsApi.items_post ...' + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling ItemsApi.items_post" + end + # verify the required parameter 'item' is set + if @api_client.config.client_side_validation && item.nil? + fail ArgumentError, "Missing the required parameter 'item' when calling ItemsApi.items_post" + end + # resource path + local_var_path = '/items' + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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' + header_params['Content-Type'] = @api_client.select_header_content_type(['application/json']) + + # form parameters + form_params = opts[:form_params] || {} + + # http body (model) + post_body = opts[:body] || @api_client.object_to_http_body(item) + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:POST, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: ItemsApi#items_post\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + end +end diff --git a/lib/meli/api/items_health_api.rb b/lib/meli/api/items_health_api.rb new file mode 100644 index 0000000..017459a --- /dev/null +++ b/lib/meli/api/items_health_api.rb @@ -0,0 +1,216 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'cgi' + +module Meli + class ItemsHealthApi + attr_accessor :api_client + + def initialize(api_client = ApiClient.default) + @api_client = api_client + end + # Return item health actions by id. + # @param id [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def items_id_health_actions_get(id, access_token, opts = {}) + data, _status_code, _headers = items_id_health_actions_get_with_http_info(id, access_token, opts) + data + end + + # Return item health actions by id. + # @param id [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def items_id_health_actions_get_with_http_info(id, access_token, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: ItemsHealthApi.items_id_health_actions_get ...' + 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 ItemsHealthApi.items_id_health_actions_get" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling ItemsHealthApi.items_id_health_actions_get" + end + # resource path + local_var_path = '/items/{id}/health/actions'.sub('{' + 'id' + '}', CGI.escape(id.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: ItemsHealthApi#items_id_health_actions_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Return health by id. + # @param id [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def items_id_health_get(id, access_token, opts = {}) + data, _status_code, _headers = items_id_health_get_with_http_info(id, access_token, opts) + data + end + + # Return health by id. + # @param id [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def items_id_health_get_with_http_info(id, access_token, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: ItemsHealthApi.items_id_health_get ...' + 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 ItemsHealthApi.items_id_health_get" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling ItemsHealthApi.items_id_health_get" + end + # resource path + local_var_path = '/items/{id}/health'.sub('{' + 'id' + '}', CGI.escape(id.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: ItemsHealthApi#items_id_health_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Return health levels. + # @param site_id [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def sites_site_id_health_levels_get(site_id, opts = {}) + data, _status_code, _headers = sites_site_id_health_levels_get_with_http_info(site_id, opts) + data + end + + # Return health levels. + # @param site_id [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def sites_site_id_health_levels_get_with_http_info(site_id, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: ItemsHealthApi.sites_site_id_health_levels_get ...' + end + # verify the required parameter 'site_id' is set + if @api_client.config.client_side_validation && site_id.nil? + fail ArgumentError, "Missing the required parameter 'site_id' when calling ItemsHealthApi.sites_site_id_health_levels_get" + end + # resource path + local_var_path = '/sites/{site_id}/health_levels'.sub('{' + 'site_id' + '}', CGI.escape(site_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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: ItemsHealthApi#sites_site_id_health_levels_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + end +end diff --git a/lib/meli/api/o_auth20_api.rb b/lib/meli/api/o_auth20_api.rb new file mode 100644 index 0000000..79a1343 --- /dev/null +++ b/lib/meli/api/o_auth20_api.rb @@ -0,0 +1,178 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'cgi' + +module Meli + class OAuth20Api + attr_accessor :api_client + + def initialize(api_client = ApiClient.default) + @api_client = api_client + end + # Authentication Endpoint + # @param response_type [String] + # @param client_id [String] + # @param redirect_uri [String] + # @param [Hash] opts the optional parameters + # @return [nil] + def auth(response_type, client_id, redirect_uri, opts = {}) + auth_with_http_info(response_type, client_id, redirect_uri, opts) + nil + end + + # Authentication Endpoint + # @param response_type [String] + # @param client_id [String] + # @param redirect_uri [String] + # @param [Hash] opts the optional parameters + # @return [Array<(nil, Integer, Hash)>] nil, response status code and response headers + def auth_with_http_info(response_type, client_id, redirect_uri, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: OAuth20Api.auth ...' + end + # verify the required parameter 'response_type' is set + if @api_client.config.client_side_validation && response_type.nil? + fail ArgumentError, "Missing the required parameter 'response_type' when calling OAuth20Api.auth" + end + # verify enum value + allowable_values = ["code"] + if @api_client.config.client_side_validation && !allowable_values.include?(response_type) + fail ArgumentError, "invalid value for \"response_type\", must be one of #{allowable_values}" + end + # verify the required parameter 'client_id' is set + if @api_client.config.client_side_validation && client_id.nil? + fail ArgumentError, "Missing the required parameter 'client_id' when calling OAuth20Api.auth" + end + # verify the required parameter 'redirect_uri' is set + if @api_client.config.client_side_validation && redirect_uri.nil? + fail ArgumentError, "Missing the required parameter 'redirect_uri' when calling OAuth20Api.auth" + end + # resource path + local_var_path = '/authorization' + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'response_type'] = response_type + query_params[:'client_id'] = client_id + query_params[:'redirect_uri'] = redirect_uri + + # 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[:body] + + # return_type + return_type = opts[:return_type] + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: OAuth20Api#auth\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Request Access Token + # Partner makes a request to the token endpoint by adding the following parameters described below + # @param [Hash] opts the optional parameters + # @option opts [String] :grant_type + # @option opts [String] :client_id + # @option opts [String] :client_secret + # @option opts [String] :redirect_uri + # @option opts [String] :code + # @option opts [String] :refresh_token + # @return [Object] + def get_token(opts = {}) + data, _status_code, _headers = get_token_with_http_info(opts) + data + end + + # Request Access Token + # Partner makes a request to the token endpoint by adding the following parameters described below + # @param [Hash] opts the optional parameters + # @option opts [String] :grant_type + # @option opts [String] :client_id + # @option opts [String] :client_secret + # @option opts [String] :redirect_uri + # @option opts [String] :code + # @option opts [String] :refresh_token + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def get_token_with_http_info(opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: OAuth20Api.get_token ...' + end + # resource path + local_var_path = '/oauth/token' + + # 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' + header_params['Content-Type'] = @api_client.select_header_content_type(['application/x-www-form-urlencoded']) + + # form parameters + form_params = opts[:form_params] || {} + form_params['grant_type'] = opts[:'grant_type'] if !opts[:'grant_type'].nil? + form_params['client_id'] = opts[:'client_id'] if !opts[:'client_id'].nil? + form_params['client_secret'] = opts[:'client_secret'] if !opts[:'client_secret'].nil? + form_params['redirect_uri'] = opts[:'redirect_uri'] if !opts[:'redirect_uri'].nil? + form_params['code'] = opts[:'code'] if !opts[:'code'].nil? + form_params['refresh_token'] = opts[:'refresh_token'] if !opts[:'refresh_token'].nil? + + # http body (model) + post_body = opts[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:POST, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: OAuth20Api#get_token\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + end +end diff --git a/lib/meli/api/rest_client_api.rb b/lib/meli/api/rest_client_api.rb new file mode 100644 index 0000000..b4b4476 --- /dev/null +++ b/lib/meli/api/rest_client_api.rb @@ -0,0 +1,306 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'cgi' + +module Meli + class RestClientApi + attr_accessor :api_client + + def initialize(api_client = ApiClient.default) + @api_client = api_client + end + # Resource path DELETE + # @param resource [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def resource_delete(resource, access_token, opts = {}) + data, _status_code, _headers = resource_delete_with_http_info(resource, access_token, opts) + data + end + + # Resource path DELETE + # @param resource [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def resource_delete_with_http_info(resource, access_token, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: RestClientApi.resource_delete ...' + end + # verify the required parameter 'resource' is set + if @api_client.config.client_side_validation && resource.nil? + fail ArgumentError, "Missing the required parameter 'resource' when calling RestClientApi.resource_delete" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling RestClientApi.resource_delete" + end + # resource path + local_var_path = '/{resource}'.sub('{' + 'resource' + '}', CGI.escape(resource.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:DELETE, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: RestClientApi#resource_delete\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Resource path GET + # @param resource [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Object] + def resource_get(resource, access_token, opts = {}) + data, _status_code, _headers = resource_get_with_http_info(resource, access_token, opts) + data + end + + # Resource path GET + # @param resource [String] + # @param access_token [String] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def resource_get_with_http_info(resource, access_token, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: RestClientApi.resource_get ...' + end + # verify the required parameter 'resource' is set + if @api_client.config.client_side_validation && resource.nil? + fail ArgumentError, "Missing the required parameter 'resource' when calling RestClientApi.resource_get" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling RestClientApi.resource_get" + end + # resource path + local_var_path = '/{resource}'.sub('{' + 'resource' + '}', CGI.escape(resource.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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[:body] + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:GET, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: RestClientApi#resource_get\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Resourse path POST + # @param resource [String] + # @param access_token [String] + # @param body [Object] + # @param [Hash] opts the optional parameters + # @return [Object] + def resource_post(resource, access_token, body, opts = {}) + data, _status_code, _headers = resource_post_with_http_info(resource, access_token, body, opts) + data + end + + # Resourse path POST + # @param resource [String] + # @param access_token [String] + # @param body [Object] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def resource_post_with_http_info(resource, access_token, body, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: RestClientApi.resource_post ...' + end + # verify the required parameter 'resource' is set + if @api_client.config.client_side_validation && resource.nil? + fail ArgumentError, "Missing the required parameter 'resource' when calling RestClientApi.resource_post" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling RestClientApi.resource_post" + end + # verify the required parameter 'body' is set + if @api_client.config.client_side_validation && body.nil? + fail ArgumentError, "Missing the required parameter 'body' when calling RestClientApi.resource_post" + end + # resource path + local_var_path = '/{resource}'.sub('{' + 'resource' + '}', CGI.escape(resource.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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' + header_params['Content-Type'] = @api_client.select_header_content_type(['application/json']) + + # form parameters + form_params = opts[:form_params] || {} + + # http body (model) + post_body = opts[:body] || @api_client.object_to_http_body(body) + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:POST, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: RestClientApi#resource_post\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + + # Resourse path PUT + # @param resource [String] + # @param access_token [String] + # @param body [Object] + # @param [Hash] opts the optional parameters + # @return [Object] + def resource_put(resource, access_token, body, opts = {}) + data, _status_code, _headers = resource_put_with_http_info(resource, access_token, body, opts) + data + end + + # Resourse path PUT + # @param resource [String] + # @param access_token [String] + # @param body [Object] + # @param [Hash] opts the optional parameters + # @return [Array<(Object, Integer, Hash)>] Object data, response status code and response headers + def resource_put_with_http_info(resource, access_token, body, opts = {}) + if @api_client.config.debugging + @api_client.config.logger.debug 'Calling API: RestClientApi.resource_put ...' + end + # verify the required parameter 'resource' is set + if @api_client.config.client_side_validation && resource.nil? + fail ArgumentError, "Missing the required parameter 'resource' when calling RestClientApi.resource_put" + end + # verify the required parameter 'access_token' is set + if @api_client.config.client_side_validation && access_token.nil? + fail ArgumentError, "Missing the required parameter 'access_token' when calling RestClientApi.resource_put" + end + # verify the required parameter 'body' is set + if @api_client.config.client_side_validation && body.nil? + fail ArgumentError, "Missing the required parameter 'body' when calling RestClientApi.resource_put" + end + # resource path + local_var_path = '/{resource}'.sub('{' + 'resource' + '}', CGI.escape(resource.to_s)) + + # query parameters + query_params = opts[:query_params] || {} + query_params[:'access_token'] = access_token + + # 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' + header_params['Content-Type'] = @api_client.select_header_content_type(['application/json']) + + # form parameters + form_params = opts[:form_params] || {} + + # http body (model) + post_body = opts[:body] || @api_client.object_to_http_body(body) + + # return_type + return_type = opts[:return_type] || 'Object' + + # auth_names + auth_names = opts[:auth_names] || [] + + new_options = opts.merge( + :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 = @api_client.call_api(:PUT, local_var_path, new_options) + if @api_client.config.debugging + @api_client.config.logger.debug "API called: RestClientApi#resource_put\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}" + end + return data, status_code, headers + end + end +end diff --git a/lib/meli/api_client.rb b/lib/meli/api_client.rb new file mode 100644 index 0000000..7ee2980 --- /dev/null +++ b/lib/meli/api_client.rb @@ -0,0 +1,387 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' +require 'json' +require 'logger' +require 'tempfile' +require 'typhoeus' + +module Meli + class ApiClient + # The Configuration object holding settings to be used in the API client. + attr_accessor :config + + # Defines the headers to be used in HTTP requests of all API calls by default. + # + # @return [Hash] + attr_accessor :default_headers + + # Initializes the ApiClient + # @option config [Configuration] Configuration for initializing the object, default to Configuration.default + def initialize(config = Configuration.default) + @config = config + @user_agent = "MELI-RUBY-SDK-3.0.0" + @default_headers = { + 'Content-Type' => 'application/json', + 'User-Agent' => @user_agent + } + end + + def self.default + @@default ||= ApiClient.new + end + + # Call an API with given options. + # + # @return [Array<(Object, Integer, Hash)>] an array of 3 elements: + # the data deserialized from response body (could be nil), response status code and response headers. + def call_api(http_method, path, opts = {}) + request = build_request(http_method, path, opts) + response = request.run + + if @config.debugging + @config.logger.debug "HTTP response body ~BEGIN~\n#{response.body}\n~END~\n" + end + + unless response.success? + if response.timed_out? + fail ApiError.new('Connection timed out') + elsif response.code == 0 + # Errors from libcurl will be made visible here + fail ApiError.new(:code => 0, + :message => response.return_message) + else + fail ApiError.new(:code => response.code, + :response_headers => response.headers, + :response_body => response.body), + response.status_message + end + end + + if opts[:return_type] + data = deserialize(response, opts[:return_type]) + else + data = nil + end + return data, response.code, response.headers + end + + # Builds the HTTP request + # + # @param [String] http_method HTTP method/verb (e.g. POST) + # @param [String] path URL path (e.g. /account/new) + # @option opts [Hash] :header_params Header parameters + # @option opts [Hash] :query_params Query parameters + # @option opts [Hash] :form_params Query parameters + # @option opts [Object] :body HTTP body (JSON/XML) + # @return [Typhoeus::Request] A Typhoeus Request + def build_request(http_method, path, opts = {}) + url = build_request_url(path) + http_method = http_method.to_sym.downcase + + header_params = @default_headers.merge(opts[:header_params] || {}) + query_params = opts[:query_params] || {} + form_params = opts[:form_params] || {} + + + # set ssl_verifyhosts option based on @config.verify_ssl_host (true/false) + _verify_ssl_host = @config.verify_ssl_host ? 2 : 0 + + req_opts = { + :method => http_method, + :headers => header_params, + :params => query_params, + :params_encoding => @config.params_encoding, + :timeout => @config.timeout, + :ssl_verifypeer => @config.verify_ssl, + :ssl_verifyhost => _verify_ssl_host, + :sslcert => @config.cert_file, + :sslkey => @config.key_file, + :verbose => @config.debugging + } + + # set custom cert, if provided + req_opts[:cainfo] = @config.ssl_ca_cert if @config.ssl_ca_cert + + if [:post, :patch, :put, :delete].include?(http_method) + req_body = build_request_body(header_params, form_params, opts[:body]) + req_opts.update :body => req_body + if @config.debugging + @config.logger.debug "HTTP request body param ~BEGIN~\n#{req_body}\n~END~\n" + end + end + + request = Typhoeus::Request.new(url, req_opts) + download_file(request) if opts[:return_type] == 'File' + request + end + + # Builds the HTTP request body + # + # @param [Hash] header_params Header parameters + # @param [Hash] form_params Query parameters + # @param [Object] body HTTP body (JSON/XML) + # @return [String] HTTP body data in the form of string + def build_request_body(header_params, form_params, body) + # http form + if header_params['Content-Type'] == 'application/x-www-form-urlencoded' || + header_params['Content-Type'] == 'multipart/form-data' + data = {} + form_params.each do |key, value| + case value + when ::File, ::Array, nil + # let typhoeus handle File, Array and nil parameters + data[key] = value + else + data[key] = value.to_s + end + end + elsif body + data = body.is_a?(String) ? body : body.to_json + else + data = nil + end + data + end + + # Check if the given MIME is a JSON MIME. + # JSON MIME examples: + # application/json + # application/json; charset=UTF8 + # APPLICATION/JSON + # */* + # @param [String] mime MIME + # @return [Boolean] True if the MIME is application/json + def json_mime?(mime) + (mime == '*/*') || !(mime =~ /Application\/.*json(?!p)(;.*)?/i).nil? + end + + # Deserialize the response to the given return type. + # + # @param [Response] response HTTP response + # @param [String] return_type some examples: "User", "Array", "Hash" + def deserialize(response, return_type) + body = response.body + + # handle file downloading - return the File instance processed in request callbacks + # note that response body is empty when the file is written in chunks in request on_body callback + return @tempfile if return_type == 'File' + + return nil if body.nil? || body.empty? + + # return response body directly for String return type + return body if return_type == 'String' + + # ensuring a default content type + content_type = response.headers['Content-Type'] || 'application/json' + + fail "Content-Type is not supported: #{content_type}" unless json_mime?(content_type) + + begin + data = JSON.parse("[#{body}]", :symbolize_names => true)[0] + rescue JSON::ParserError => e + if %w(String Date DateTime).include?(return_type) + data = body + else + raise e + end + end + + convert_to_type data, return_type + end + + # Convert data to the given return type. + # @param [Object] data Data to be converted + # @param [String] return_type Return type + # @return [Mixed] Data in a particular type + def convert_to_type(data, return_type) + return nil if data.nil? + case return_type + when 'String' + data.to_s + when 'Integer' + data.to_i + when 'Float' + data.to_f + when 'Boolean' + data == true + when 'DateTime' + # parse date time (expecting ISO 8601 format) + DateTime.parse data + when 'Date' + # parse date time (expecting ISO 8601 format) + Date.parse data + when 'Object' + # generic object (usually a Hash), return directly + data + when /\AArray<(.+)>\z/ + # e.g. Array + sub_type = $1 + data.map { |item| convert_to_type(item, sub_type) } + when /\AHash\\z/ + # e.g. Hash + sub_type = $1 + {}.tap do |hash| + data.each { |k, v| hash[k] = convert_to_type(v, sub_type) } + end + else + # models, e.g. Pet + Meli.const_get(return_type).build_from_hash(data) + end + end + + # Save response body into a file in (the defined) temporary folder, using the filename + # from the "Content-Disposition" header if provided, otherwise a random filename. + # The response body is written to the file in chunks in order to handle files which + # size is larger than maximum Ruby String or even larger than the maximum memory a Ruby + # process can use. + # + # @see Configuration#temp_folder_path + def download_file(request) + tempfile = nil + encoding = nil + request.on_headers do |response| + content_disposition = response.headers['Content-Disposition'] + if content_disposition && content_disposition =~ /filename=/i + filename = content_disposition[/filename=['"]?([^'"\s]+)['"]?/, 1] + prefix = sanitize_filename(filename) + else + prefix = 'download-' + end + prefix = prefix + '-' unless prefix.end_with?('-') + encoding = response.body.encoding + tempfile = Tempfile.open(prefix, @config.temp_folder_path, encoding: encoding) + @tempfile = tempfile + end + request.on_body do |chunk| + chunk.force_encoding(encoding) + tempfile.write(chunk) + end + request.on_complete do |response| + if tempfile + tempfile.close + @config.logger.info "Temp file written to #{tempfile.path}, please copy the file to a proper folder "\ + "with e.g. `FileUtils.cp(tempfile.path, '/new/file/path')` otherwise the temp file "\ + "will be deleted automatically with GC. It's also recommended to delete the temp file "\ + "explicitly with `tempfile.delete`" + end + end + end + + # Sanitize filename by removing path. + # e.g. ../../sun.gif becomes sun.gif + # + # @param [String] filename the filename to be sanitized + # @return [String] the sanitized filename + def sanitize_filename(filename) + filename.gsub(/.*[\/\\]/, '') + end + + def build_request_url(path) + # Add leading and trailing slashes to path + path = "/#{path}".gsub(/\/+/, '/') + @config.base_url + path + end + + # Update hearder and query params based on authentication settings. + # + # @param [Hash] header_params Header parameters + # @param [Hash] query_params Query parameters + # @param [String] auth_names Authentication scheme name + def update_params_for_auth!(header_params, query_params, auth_names) + Array(auth_names).each do |auth_name| + auth_setting = @config.auth_settings[auth_name] + next unless auth_setting + case auth_setting[:in] + when 'header' then header_params[auth_setting[:key]] = auth_setting[:value] + when 'query' then query_params[auth_setting[:key]] = auth_setting[:value] + else fail ArgumentError, 'Authentication token must be in `query` of `header`' + end + end + end + + # Sets user agent in HTTP header + # + # @param [String] user_agent User agent (e.g. openapi-generator/ruby/1.0.0) + def user_agent=(user_agent) + @user_agent = user_agent + @default_headers['User-Agent'] = @user_agent + end + + # Return Accept header based on an array of accepts provided. + # @param [Array] accepts array for Accept + # @return [String] the Accept header (e.g. application/json) + def select_header_accept(accepts) + return nil if accepts.nil? || accepts.empty? + # use JSON when present, otherwise use all of the provided + json_accept = accepts.find { |s| json_mime?(s) } + json_accept || accepts.join(',') + end + + # Return Content-Type header based on an array of content types provided. + # @param [Array] content_types array for Content-Type + # @return [String] the Content-Type header (e.g. application/json) + def select_header_content_type(content_types) + # use application/json by default + return 'application/json' if content_types.nil? || content_types.empty? + # use JSON when present, otherwise use the first one + json_content_type = content_types.find { |s| json_mime?(s) } + json_content_type || content_types.first + end + + # Convert object (array, hash, object, etc) to JSON string. + # @param [Object] model object to be converted into JSON string + # @return [String] JSON string representation of the object + def object_to_http_body(model) + return model if model.nil? || model.is_a?(String) + local_body = nil + if model.is_a?(Array) + local_body = model.map { |m| object_to_hash(m) } + else + local_body = object_to_hash(model) + end + local_body.to_json + end + + # Convert object(non-array) to hash. + # @param [Object] obj object to be converted into JSON string + # @return [String] JSON string representation of the object + def object_to_hash(obj) + if obj.respond_to?(:to_hash) + obj.to_hash + else + obj + end + end + + # Build parameter value according to the given collection format. + # @param [String] collection_format one of :csv, :ssv, :tsv, :pipes and :multi + def build_collection_param(param, collection_format) + case collection_format + when :csv + param.join(',') + when :ssv + param.join(' ') + when :tsv + param.join("\t") + when :pipes + param.join('|') + when :multi + # return the array directly as typhoeus will handle it as expected + param + else + fail "unknown collection format: #{collection_format.inspect}" + end + end + end +end diff --git a/lib/meli/api_error.rb b/lib/meli/api_error.rb new file mode 100644 index 0000000..4cadb9f --- /dev/null +++ b/lib/meli/api_error.rb @@ -0,0 +1,57 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +module Meli + class ApiError < StandardError + attr_reader :code, :response_headers, :response_body + + # Usage examples: + # ApiError.new + # ApiError.new("message") + # ApiError.new(:code => 500, :response_headers => {}, :response_body => "") + # ApiError.new(:code => 404, :message => "Not Found") + def initialize(arg = nil) + if arg.is_a? Hash + if arg.key?(:message) || arg.key?('message') + super(arg[:message] || arg['message']) + else + super arg + end + + arg.each do |k, v| + instance_variable_set "@#{k}", v + end + else + super arg + end + end + + # Override to_s to display a friendly error message + def to_s + message + end + + def message + if @message.nil? + msg = "Error message: the server returns an error" + else + msg = @message + end + + msg += "\nHTTP status code: #{code}" if code + msg += "\nResponse headers: #{response_headers}" if response_headers + msg += "\nResponse body: #{response_body}" if response_body + + msg + end + end +end diff --git a/lib/meli/configuration.rb b/lib/meli/configuration.rb new file mode 100644 index 0000000..1db0ca0 --- /dev/null +++ b/lib/meli/configuration.rb @@ -0,0 +1,297 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +module Meli + class Configuration + # Defines url scheme + attr_accessor :scheme + + # Defines url host + attr_accessor :host + + # Defines url base path + attr_accessor :base_path + + # Defines API keys used with API Key authentications. + # + # @return [Hash] key: parameter name, value: parameter value (API key) + # + # @example parameter name is "api_key", API key is "xxx" (e.g. "api_key=xxx" in query string) + # config.api_key['api_key'] = 'xxx' + attr_accessor :api_key + + # Defines API key prefixes used with API Key authentications. + # + # @return [Hash] key: parameter name, value: API key prefix + # + # @example parameter name is "Authorization", API key prefix is "Token" (e.g. "Authorization: Token xxx" in headers) + # config.api_key_prefix['api_key'] = 'Token' + attr_accessor :api_key_prefix + + # Defines the username used with HTTP basic authentication. + # + # @return [String] + attr_accessor :username + + # Defines the password used with HTTP basic authentication. + # + # @return [String] + attr_accessor :password + + # Defines the access token (Bearer) used with OAuth2. + attr_accessor :access_token + + # Set this to enable/disable debugging. When enabled (set to true), HTTP request/response + # details will be logged with `logger.debug` (see the `logger` attribute). + # Default to false. + # + # @return [true, false] + attr_accessor :debugging + + # Defines the logger used for debugging. + # Default to `Rails.logger` (when in Rails) or logging to STDOUT. + # + # @return [#debug] + attr_accessor :logger + + # Defines the temporary folder to store downloaded files + # (for API endpoints that have file response). + # Default to use `Tempfile`. + # + # @return [String] + attr_accessor :temp_folder_path + + # The time limit for HTTP request in seconds. + # Default to 0 (never times out). + attr_accessor :timeout + + # Set this to false to skip client side validation in the operation. + # Default to true. + # @return [true, false] + attr_accessor :client_side_validation + + ### TLS/SSL setting + # Set this to false to skip verifying SSL certificate when calling API from https server. + # Default to true. + # + # @note Do NOT set it to false in production code, otherwise you would face multiple types of cryptographic attacks. + # + # @return [true, false] + attr_accessor :verify_ssl + + ### TLS/SSL setting + # Set this to false to skip verifying SSL host name + # Default to true. + # + # @note Do NOT set it to false in production code, otherwise you would face multiple types of cryptographic attacks. + # + # @return [true, false] + attr_accessor :verify_ssl_host + + ### TLS/SSL setting + # Set this to customize the certificate file to verify the peer. + # + # @return [String] the path to the certificate file + # + # @see The `cainfo` option of Typhoeus, `--cert` option of libcurl. Related source code: + # https://github.com/typhoeus/typhoeus/blob/master/lib/typhoeus/easy_factory.rb#L145 + attr_accessor :ssl_ca_cert + + ### TLS/SSL setting + # Client certificate file (for client certificate) + attr_accessor :cert_file + + ### TLS/SSL setting + # Client private key file (for client certificate) + attr_accessor :key_file + + # Set this to customize parameters encoding of array parameter with multi collectionFormat. + # Default to nil. + # + # @see The params_encoding option of Ethon. Related source code: + # https://github.com/typhoeus/ethon/blob/master/lib/ethon/easy/queryable.rb#L96 + attr_accessor :params_encoding + + attr_accessor :inject_format + + attr_accessor :force_ending_format + + def initialize + @scheme = 'https' + @host = 'api.mercadolibre.com' + @base_path = '' + @api_key = {} + @api_key_prefix = {} + @timeout = 0 + @client_side_validation = true + @verify_ssl = true + @verify_ssl_host = true + @params_encoding = nil + @cert_file = nil + @key_file = nil + @debugging = false + @inject_format = false + @force_ending_format = false + @logger = defined?(Rails) ? Rails.logger : Logger.new(STDOUT) + + yield(self) if block_given? + end + + # The default Configuration object. + def self.default + @@default ||= Configuration.new + end + + def configure + yield(self) if block_given? + end + + def scheme=(scheme) + # remove :// from scheme + @scheme = scheme.sub(/:\/\//, '') + end + + def host=(host) + # remove http(s):// and anything after a slash + @host = host.sub(/https?:\/\//, '').split('/').first + end + + def base_path=(base_path) + # Add leading and trailing slashes to base_path + @base_path = "/#{base_path}".gsub(/\/+/, '/') + @base_path = '' if @base_path == '/' + end + + def base_url + "#{scheme}://#{[host, base_path].join('/').gsub(/\/+/, '/')}".sub(/\/+\z/, '') + end + + # Gets API key (with prefix if set). + # @param [String] param_name the parameter name of API key auth + def api_key_with_prefix(param_name) + if @api_key_prefix[param_name] + "#{@api_key_prefix[param_name]} #{@api_key[param_name]}" + else + @api_key[param_name] + end + end + + # Gets Basic Auth token string + def basic_auth_token + 'Basic ' + ["#{username}:#{password}"].pack('m').delete("\r\n") + end + + # Returns Auth Settings hash for api client. + def auth_settings + { + } + end + + # Returns an array of Server setting + def server_settings + [ + { + url: "https://api.mercadolibre.com", + description: "The Marketplace API Endpoint", + }, + { + url: "https://auth.mercadolibre.com.ar", + description: "Authorization EndPoint for MLA", + }, + { + url: "https://auth.mercadolivre.com.br", + description: "Authorization EndPoint for MLB", + }, + { + url: "https://auth.mercadolibre.com.co", + description: "Authorization EndPoint for MCO", + }, + { + url: "https://auth.mercadolibre.com.mx", + description: "Authorization EndPoint for MLM", + }, + { + url: "https://auth.mercadolibre.com.uy", + description: "Authorization EndPoint for MLU", + }, + { + url: "https://auth.mercadolibre.cl", + description: "Authorization EndPoint for MLC", + }, + { + url: "https://auth.mercadolibre.com.cr", + description: "Authorization EndPoint for MCR", + }, + { + url: "https://auth.mercadolibre.com.ec", + description: "Authorization EndPoint for MEC", + }, + { + url: "https://auth.mercadolibre.com.ve", + description: "Authorization EndPoint for MLV", + }, + { + url: "https://auth.mercadolibre.com.pa", + description: "Authorization EndPoint for MPA", + }, + { + url: "https://auth.mercadolibre.com.pe", + description: "Authorization EndPoint for MLP", + }, + { + url: "https://auth.mercadolibre.com.do", + description: "Authorization EndPoint for MRD", + }, + { + url: "https://auth.mercadolibre.com.bo", + description: "Authorization EndPoint for MBO", + }, + { + url: "https://auth.mercadolibre.com.py", + description: "Authorization EndPoint for MPY", + } + ] + end + + # Returns URL based on server settings + # + # @param index array index of the server settings + # @param variables hash of variable and the corresponding value + def server_url(index, variables = {}) + servers = server_settings + + # check array index out of bound + if (index < 0 || index >= servers.size) + fail ArgumentError, "Invalid index #{index} when selecting the server. Must be less than #{servers.size}" + end + + server = servers[index] + url = server[:url] + + # go through variable and assign a value + server[:variables].each do |name, variable| + if variables.key?(name) + if (server[:variables][name][:enum_values].include? variables[name]) + url.gsub! "{" + name.to_s + "}", variables[name] + else + fail ArgumentError, "The variable `#{name}` in the server URL has invalid value #{variables[name]}. Must be #{server[:variables][name][:enum_values]}." + end + else + # use default value + url.gsub! "{" + name.to_s + "}", server[:variables][name][:default_value] + end + end + + url + end + end +end diff --git a/lib/meli/models/attributes.rb b/lib/meli/models/attributes.rb new file mode 100644 index 0000000..c1e2164 --- /dev/null +++ b/lib/meli/models/attributes.rb @@ -0,0 +1,273 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class Attributes + attr_accessor :id + + attr_accessor :name + + attr_accessor :value_id + + attr_accessor :value_name + + attr_accessor :value_struct + + attr_accessor :values + + attr_accessor :attribute_group_id + + attr_accessor :attribute_group_name + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'id' => :'id', + :'name' => :'name', + :'value_id' => :'value_id', + :'value_name' => :'value_name', + :'value_struct' => :'value_struct', + :'values' => :'values', + :'attribute_group_id' => :'attribute_group_id', + :'attribute_group_name' => :'attribute_group_name' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'id' => :'String', + :'name' => :'String', + :'value_id' => :'String', + :'value_name' => :'String', + :'value_struct' => :'AttributesValueStruct', + :'values' => :'Array', + :'attribute_group_id' => :'String', + :'attribute_group_name' => :'String' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + :'value_id', + :'value_struct', + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::Attributes` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::Attributes`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'id') + self.id = attributes[:'id'] + end + + if attributes.key?(:'name') + self.name = attributes[:'name'] + end + + if attributes.key?(:'value_id') + self.value_id = attributes[:'value_id'] + end + + if attributes.key?(:'value_name') + self.value_name = attributes[:'value_name'] + end + + if attributes.key?(:'value_struct') + self.value_struct = attributes[:'value_struct'] + end + + if attributes.key?(:'values') + if (value = attributes[:'values']).is_a?(Array) + self.values = value + end + end + + if attributes.key?(:'attribute_group_id') + self.attribute_group_id = attributes[:'attribute_group_id'] + end + + if attributes.key?(:'attribute_group_name') + self.attribute_group_name = attributes[:'attribute_group_name'] + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + id == o.id && + name == o.name && + value_id == o.value_id && + value_name == o.value_name && + value_struct == o.value_struct && + values == o.values && + attribute_group_id == o.attribute_group_id && + attribute_group_name == o.attribute_group_name + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [id, name, value_id, value_name, value_struct, values, attribute_group_id, attribute_group_name].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/attributes_value_struct.rb b/lib/meli/models/attributes_value_struct.rb new file mode 100644 index 0000000..257d6d7 --- /dev/null +++ b/lib/meli/models/attributes_value_struct.rb @@ -0,0 +1,215 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class AttributesValueStruct + attr_accessor :number + + attr_accessor :unit + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'number' => :'number', + :'unit' => :'unit' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'number' => :'Float', + :'unit' => :'String' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::AttributesValueStruct` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::AttributesValueStruct`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'number') + self.number = attributes[:'number'] + end + + if attributes.key?(:'unit') + self.unit = attributes[:'unit'] + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + number == o.number && + unit == o.unit + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [number, unit].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/attributes_values.rb b/lib/meli/models/attributes_values.rb new file mode 100644 index 0000000..1d34c31 --- /dev/null +++ b/lib/meli/models/attributes_values.rb @@ -0,0 +1,226 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class AttributesValues + attr_accessor :id + + attr_accessor :name + + attr_accessor :struct + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'id' => :'id', + :'name' => :'name', + :'struct' => :'struct' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'id' => :'String', + :'name' => :'String', + :'struct' => :'AttributesValueStruct' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + :'id', + :'struct' + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::AttributesValues` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::AttributesValues`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'id') + self.id = attributes[:'id'] + end + + if attributes.key?(:'name') + self.name = attributes[:'name'] + end + + if attributes.key?(:'struct') + self.struct = attributes[:'struct'] + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + id == o.id && + name == o.name && + struct == o.struct + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [id, name, struct].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/inline_object.rb b/lib/meli/models/inline_object.rb new file mode 100644 index 0000000..7c28a16 --- /dev/null +++ b/lib/meli/models/inline_object.rb @@ -0,0 +1,251 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class InlineObject + attr_accessor :grant_type + + attr_accessor :client_id + + attr_accessor :client_secret + + attr_accessor :redirect_uri + + attr_accessor :code + + attr_accessor :refresh_token + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'grant_type' => :'grant_type', + :'client_id' => :'client_id', + :'client_secret' => :'client_secret', + :'redirect_uri' => :'redirect_uri', + :'code' => :'code', + :'refresh_token' => :'refresh_token' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'grant_type' => :'String', + :'client_id' => :'String', + :'client_secret' => :'String', + :'redirect_uri' => :'String', + :'code' => :'String', + :'refresh_token' => :'String' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::InlineObject` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::InlineObject`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'grant_type') + self.grant_type = attributes[:'grant_type'] + end + + if attributes.key?(:'client_id') + self.client_id = attributes[:'client_id'] + end + + if attributes.key?(:'client_secret') + self.client_secret = attributes[:'client_secret'] + end + + if attributes.key?(:'redirect_uri') + self.redirect_uri = attributes[:'redirect_uri'] + end + + if attributes.key?(:'code') + self.code = attributes[:'code'] + end + + if attributes.key?(:'refresh_token') + self.refresh_token = attributes[:'refresh_token'] + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + grant_type == o.grant_type && + client_id == o.client_id && + client_secret == o.client_secret && + redirect_uri == o.redirect_uri && + code == o.code && + refresh_token == o.refresh_token + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [grant_type, client_id, client_secret, redirect_uri, code, refresh_token].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/item.rb b/lib/meli/models/item.rb new file mode 100644 index 0000000..c9e075f --- /dev/null +++ b/lib/meli/models/item.rb @@ -0,0 +1,375 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class Item + attr_accessor :title + + attr_accessor :category_id + + attr_accessor :price + + attr_accessor :currency_id + + attr_accessor :available_quantity + + attr_accessor :buying_mode + + attr_accessor :listing_type_id + + attr_accessor :condition + + attr_accessor :description + + attr_accessor :video_id + + attr_accessor :pictures + + attr_accessor :attributes + + attr_accessor :variations + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'title' => :'title', + :'category_id' => :'category_id', + :'price' => :'price', + :'currency_id' => :'currency_id', + :'available_quantity' => :'available_quantity', + :'buying_mode' => :'buying_mode', + :'listing_type_id' => :'listing_type_id', + :'condition' => :'condition', + :'description' => :'description', + :'video_id' => :'video_id', + :'pictures' => :'pictures', + :'attributes' => :'attributes', + :'variations' => :'variations' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'title' => :'String', + :'category_id' => :'String', + :'price' => :'Integer', + :'currency_id' => :'String', + :'available_quantity' => :'String', + :'buying_mode' => :'String', + :'listing_type_id' => :'String', + :'condition' => :'String', + :'description' => :'String', + :'video_id' => :'String', + :'pictures' => :'Array', + :'attributes' => :'Array', + :'variations' => :'Array' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::Item` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::Item`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'title') + self.title = attributes[:'title'] + end + + if attributes.key?(:'category_id') + self.category_id = attributes[:'category_id'] + end + + if attributes.key?(:'price') + self.price = attributes[:'price'] + end + + if attributes.key?(:'currency_id') + self.currency_id = attributes[:'currency_id'] + end + + if attributes.key?(:'available_quantity') + self.available_quantity = attributes[:'available_quantity'] + end + + if attributes.key?(:'buying_mode') + self.buying_mode = attributes[:'buying_mode'] + end + + if attributes.key?(:'listing_type_id') + self.listing_type_id = attributes[:'listing_type_id'] + end + + if attributes.key?(:'condition') + self.condition = attributes[:'condition'] + end + + if attributes.key?(:'description') + self.description = attributes[:'description'] + end + + if attributes.key?(:'video_id') + self.video_id = attributes[:'video_id'] + end + + if attributes.key?(:'pictures') + if (value = attributes[:'pictures']).is_a?(Array) + self.pictures = value + end + end + + if attributes.key?(:'attributes') + if (value = attributes[:'attributes']).is_a?(Array) + self.attributes = value + end + end + + if attributes.key?(:'variations') + if (value = attributes[:'variations']).is_a?(Array) + self.variations = value + end + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + if @title.nil? + invalid_properties.push('invalid value for "title", title cannot be nil.') + end + + if @category_id.nil? + invalid_properties.push('invalid value for "category_id", category_id cannot be nil.') + end + + if @price.nil? + invalid_properties.push('invalid value for "price", price cannot be nil.') + end + + if @currency_id.nil? + invalid_properties.push('invalid value for "currency_id", currency_id cannot be nil.') + end + + if @available_quantity.nil? + invalid_properties.push('invalid value for "available_quantity", available_quantity cannot be nil.') + end + + if @buying_mode.nil? + invalid_properties.push('invalid value for "buying_mode", buying_mode cannot be nil.') + end + + if @listing_type_id.nil? + invalid_properties.push('invalid value for "listing_type_id", listing_type_id cannot be nil.') + end + + if @condition.nil? + invalid_properties.push('invalid value for "condition", condition cannot be nil.') + end + + if @description.nil? + invalid_properties.push('invalid value for "description", description cannot be nil.') + end + + if @video_id.nil? + invalid_properties.push('invalid value for "video_id", video_id cannot be nil.') + end + + if @pictures.nil? + invalid_properties.push('invalid value for "pictures", pictures cannot be nil.') + end + + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + return false if @title.nil? + return false if @category_id.nil? + return false if @price.nil? + return false if @currency_id.nil? + return false if @available_quantity.nil? + return false if @buying_mode.nil? + return false if @listing_type_id.nil? + return false if @condition.nil? + return false if @description.nil? + return false if @video_id.nil? + return false if @pictures.nil? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + title == o.title && + category_id == o.category_id && + price == o.price && + currency_id == o.currency_id && + available_quantity == o.available_quantity && + buying_mode == o.buying_mode && + listing_type_id == o.listing_type_id && + condition == o.condition && + description == o.description && + video_id == o.video_id && + pictures == o.pictures && + attributes == o.attributes && + variations == o.variations + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [title, category_id, price, currency_id, available_quantity, buying_mode, listing_type_id, condition, description, video_id, pictures, attributes, variations].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/item_pictures.rb b/lib/meli/models/item_pictures.rb new file mode 100644 index 0000000..4a2daa0 --- /dev/null +++ b/lib/meli/models/item_pictures.rb @@ -0,0 +1,206 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class ItemPictures + attr_accessor :source + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'source' => :'source' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'source' => :'String' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::ItemPictures` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::ItemPictures`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'source') + self.source = attributes[:'source'] + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + source == o.source + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [source].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/variations.rb b/lib/meli/models/variations.rb new file mode 100644 index 0000000..2c92753 --- /dev/null +++ b/lib/meli/models/variations.rb @@ -0,0 +1,246 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class Variations + attr_accessor :price + + attr_accessor :attribute_combinations + + attr_accessor :available_quantity + + attr_accessor :sold_quantity + + attr_accessor :picture_ids + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'price' => :'price', + :'attribute_combinations' => :'attribute_combinations', + :'available_quantity' => :'available_quantity', + :'sold_quantity' => :'sold_quantity', + :'picture_ids' => :'picture_ids' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'price' => :'Integer', + :'attribute_combinations' => :'Array', + :'available_quantity' => :'Integer', + :'sold_quantity' => :'Integer', + :'picture_ids' => :'Array' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::Variations` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::Variations`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'price') + self.price = attributes[:'price'] + end + + if attributes.key?(:'attribute_combinations') + if (value = attributes[:'attribute_combinations']).is_a?(Array) + self.attribute_combinations = value + end + end + + if attributes.key?(:'available_quantity') + self.available_quantity = attributes[:'available_quantity'] + end + + if attributes.key?(:'sold_quantity') + self.sold_quantity = attributes[:'sold_quantity'] + end + + if attributes.key?(:'picture_ids') + if (value = attributes[:'picture_ids']).is_a?(Array) + self.picture_ids = value + end + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + price == o.price && + attribute_combinations == o.attribute_combinations && + available_quantity == o.available_quantity && + sold_quantity == o.sold_quantity && + picture_ids == o.picture_ids + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [price, attribute_combinations, available_quantity, sold_quantity, picture_ids].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/models/variations_attribute_combinations.rb b/lib/meli/models/variations_attribute_combinations.rb new file mode 100644 index 0000000..1801c89 --- /dev/null +++ b/lib/meli/models/variations_attribute_combinations.rb @@ -0,0 +1,224 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'date' + +module Meli + class VariationsAttributeCombinations + attr_accessor :name + + attr_accessor :value_id + + attr_accessor :value_name + + # Attribute mapping from ruby-style variable name to JSON key. + def self.attribute_map + { + :'name' => :'name', + :'value_id' => :'value_id', + :'value_name' => :'value_name' + } + end + + # Attribute type mapping. + def self.openapi_types + { + :'name' => :'String', + :'value_id' => :'String', + :'value_name' => :'String' + } + end + + # List of attributes with nullable: true + def self.openapi_nullable + Set.new([ + ]) + end + + # Initializes the object + # @param [Hash] attributes Model attributes in the form of hash + def initialize(attributes = {}) + if (!attributes.is_a?(Hash)) + fail ArgumentError, "The input argument (attributes) must be a hash in `Meli::VariationsAttributeCombinations` initialize method" + end + + # check to see if the attribute exists and convert string to symbol for hash key + attributes = attributes.each_with_object({}) { |(k, v), h| + if (!self.class.attribute_map.key?(k.to_sym)) + fail ArgumentError, "`#{k}` is not a valid attribute in `Meli::VariationsAttributeCombinations`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect + end + h[k.to_sym] = v + } + + if attributes.key?(:'name') + self.name = attributes[:'name'] + end + + if attributes.key?(:'value_id') + self.value_id = attributes[:'value_id'] + end + + if attributes.key?(:'value_name') + self.value_name = attributes[:'value_name'] + end + end + + # Show invalid properties with the reasons. Usually used together with valid? + # @return Array for valid properties with the reasons + def list_invalid_properties + invalid_properties = Array.new + invalid_properties + end + + # Check to see if the all the properties in the model are valid + # @return true if the model is valid + def valid? + true + end + + # Checks equality by comparing each attribute. + # @param [Object] Object to be compared + def ==(o) + return true if self.equal?(o) + self.class == o.class && + name == o.name && + value_id == o.value_id && + value_name == o.value_name + end + + # @see the `==` method + # @param [Object] Object to be compared + def eql?(o) + self == o + end + + # Calculates hash code according to all attributes. + # @return [Integer] Hash code + def hash + [name, value_id, value_name].hash + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def self.build_from_hash(attributes) + new.build_from_hash(attributes) + end + + # Builds the object from hash + # @param [Hash] attributes Model attributes in the form of hash + # @return [Object] Returns the model itself + def build_from_hash(attributes) + return nil unless attributes.is_a?(Hash) + self.class.openapi_types.each_pair do |key, type| + if type =~ /\AArray<(.*)>/i + # check to ensure the input is an array given that the attribute + # is documented as an array but the input is not + if attributes[self.class.attribute_map[key]].is_a?(Array) + self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) }) + end + elsif !attributes[self.class.attribute_map[key]].nil? + self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) + end # or else data not found in attributes(hash), not an issue as the data can be optional + end + + self + end + + # Deserializes the data based on type + # @param string type Data type + # @param string value Value to be deserialized + # @return [Object] Deserialized data + def _deserialize(type, value) + case type.to_sym + when :DateTime + DateTime.parse(value) + when :Date + Date.parse(value) + when :String + value.to_s + when :Integer + value.to_i + when :Float + value.to_f + when :Boolean + if value.to_s =~ /\A(true|t|yes|y|1)\z/i + true + else + false + end + when :Object + # generic object (usually a Hash), return directly + value + when /\AArray<(?.+)>\z/ + inner_type = Regexp.last_match[:inner_type] + value.map { |v| _deserialize(inner_type, v) } + when /\AHash<(?.+?), (?.+)>\z/ + k_type = Regexp.last_match[:k_type] + v_type = Regexp.last_match[:v_type] + {}.tap do |hash| + value.each do |k, v| + hash[_deserialize(k_type, k)] = _deserialize(v_type, v) + end + end + else # model + Meli.const_get(type).build_from_hash(value) + end + end + + # Returns the string representation of the object + # @return [String] String presentation of the object + def to_s + to_hash.to_s + end + + # to_body is an alias to to_hash (backward compatibility) + # @return [Hash] Returns the object in the form of hash + def to_body + to_hash + end + + # Returns the object in the form of hash + # @return [Hash] Returns the object in the form of hash + def to_hash + hash = {} + self.class.attribute_map.each_pair do |attr, param| + value = self.send(attr) + if value.nil? + is_nullable = self.class.openapi_nullable.include?(attr) + next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}")) + end + + hash[param] = _to_hash(value) + end + hash + end + + # Outputs non-array value in the form of hash + # For object, use to_hash. Otherwise, just return the value + # @param [Object] value Any valid value + # @return [Hash] Returns the value in the form of hash + def _to_hash(value) + if value.is_a?(Array) + value.compact.map { |v| _to_hash(v) } + elsif value.is_a?(Hash) + {}.tap do |hash| + value.each { |k, v| hash[k] = _to_hash(v) } + end + elsif value.respond_to? :to_hash + value.to_hash + else + value + end + end + end +end diff --git a/lib/meli/version.rb b/lib/meli/version.rb index 80b3d76..b4d9714 100644 --- a/lib/meli/version.rb +++ b/lib/meli/version.rb @@ -1,3 +1,15 @@ -require 'meli' +=begin +#MELI Markeplace SDK -Meli::VERSION = "0.0.1" +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +module Meli + VERSION = '3.0.0' +end diff --git a/meli.gemspec b/meli.gemspec index 591550a..17d1efb 100644 --- a/meli.gemspec +++ b/meli.gemspec @@ -1,29 +1,33 @@ +# -*- encoding: utf-8 -*- -# coding: utf-8 -lib = File.expand_path('../lib', __FILE__) -$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib) -require 'meli/version' +=begin +#MELI Markeplace SDK -Gem::Specification.new do |spec| - spec.name = "meli" - spec.version = Meli::VERSION - spec.authors = [""] - spec.email = [""] +#This is the official Ruby SDK for the MercadoLibre Marketplace platform. +=end - if spec.respond_to?(:metadata) - spec.metadata['allowed_push_host'] = "TODO: Set to 'http://mygemserver.com' to prevent pushes to rubygems.org, or delete to allow pushes to any server." - end +$:.push File.expand_path("../lib", __FILE__) +require "Meli/version" - spec.summary = %q{MercadoLibre's Ruby SDK} - spec.description = %q{MercadoLibre's Ruby SDK} - spec.homepage = "http://developers.mercadolibre.com" - spec.license = "MIT" +Gem::Specification.new do |s| + s.name = "Meli" + s.version = Meli::VERSION + s.platform = Gem::Platform::RUBY + s.authors = ["MELI"] + s.email = [""] + s.homepage = "https://github.com/mercadolibre/ruby-sdk" + s.summary = "MELI Markeplace SDK Ruby Gem" + s.description = "This is the official Ruby SDK for the MercadoLibre Marketplace platform." + s.license = "Unlicense" + s.required_ruby_version = ">= 1.9" - spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) } - spec.bindir = "exe" - spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) } - spec.require_paths = ["lib"] + s.add_runtime_dependency 'typhoeus', '~> 1.0', '>= 1.0.1' + s.add_runtime_dependency 'json', '~> 2.3', '>= 2.3.0' - spec.add_development_dependency "bundler", "~> 1.8" - spec.add_development_dependency "rake", "~> 10.0" + s.add_development_dependency 'rspec', '~> 3.6', '>= 3.6.0' + + s.files = `find *`.split("\n").uniq.sort.select { |f| !f.empty? } + s.test_files = `find spec/*`.split("\n") + s.executables = [] + s.require_paths = ["lib"] end diff --git a/spec/api/categories_api_spec.rb b/spec/api/categories_api_spec.rb new file mode 100644 index 0000000..a2dcc45 --- /dev/null +++ b/spec/api/categories_api_spec.rb @@ -0,0 +1,70 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' + +# Unit tests for Meli::CategoriesApi +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'CategoriesApi' do + before do + # run before each test + @api_instance = Meli::CategoriesApi.new + end + + after do + # run after each test + end + + describe 'test an instance of CategoriesApi' do + it 'should create an instance of CategoriesApi' do + expect(@api_instance).to be_instance_of(Meli::CategoriesApi) + end + end + + # unit tests for categories_category_id_get + # Return by category. + # @param category_id + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'categories_category_id_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for sites_site_id_categories_get + # Return a categories by site. + # @param site_id + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'sites_site_id_categories_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for sites_site_id_domain_discovery_search_get + # Predictor + # @param site_id + # @param q + # @param limit + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'sites_site_id_domain_discovery_search_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/api/items_api_spec.rb b/spec/api/items_api_spec.rb new file mode 100644 index 0000000..6552fbf --- /dev/null +++ b/spec/api/items_api_spec.rb @@ -0,0 +1,71 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' + +# Unit tests for Meli::ItemsApi +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'ItemsApi' do + before do + # run before each test + @api_instance = Meli::ItemsApi.new + end + + after do + # run after each test + end + + describe 'test an instance of ItemsApi' do + it 'should create an instance of ItemsApi' do + expect(@api_instance).to be_instance_of(Meli::ItemsApi) + end + end + + # unit tests for items_id_get + # Return a Item. + # @param id + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'items_id_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for items_id_put + # Update a Item. + # @param id + # @param access_token + # @param item + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'items_id_put test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for items_post + # Create a Item. + # @param access_token + # @param item + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'items_post test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/api/items_health_api_spec.rb b/spec/api/items_health_api_spec.rb new file mode 100644 index 0000000..2544314 --- /dev/null +++ b/spec/api/items_health_api_spec.rb @@ -0,0 +1,70 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' + +# Unit tests for Meli::ItemsHealthApi +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'ItemsHealthApi' do + before do + # run before each test + @api_instance = Meli::ItemsHealthApi.new + end + + after do + # run after each test + end + + describe 'test an instance of ItemsHealthApi' do + it 'should create an instance of ItemsHealthApi' do + expect(@api_instance).to be_instance_of(Meli::ItemsHealthApi) + end + end + + # unit tests for items_id_health_actions_get + # Return item health actions by id. + # @param id + # @param access_token + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'items_id_health_actions_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for items_id_health_get + # Return health by id. + # @param id + # @param access_token + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'items_id_health_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for sites_site_id_health_levels_get + # Return health levels. + # @param site_id + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'sites_site_id_health_levels_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/api/o_auth20_api_spec.rb b/spec/api/o_auth20_api_spec.rb new file mode 100644 index 0000000..a430d4e --- /dev/null +++ b/spec/api/o_auth20_api_spec.rb @@ -0,0 +1,65 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' + +# Unit tests for Meli::OAuth20Api +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'OAuth20Api' do + before do + # run before each test + @api_instance = Meli::OAuth20Api.new + end + + after do + # run after each test + end + + describe 'test an instance of OAuth20Api' do + it 'should create an instance of OAuth20Api' do + expect(@api_instance).to be_instance_of(Meli::OAuth20Api) + end + end + + # unit tests for auth + # Authentication Endpoint + # @param response_type + # @param client_id + # @param redirect_uri + # @param [Hash] opts the optional parameters + # @return [nil] + describe 'auth test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for get_token + # Request Access Token + # Partner makes a request to the token endpoint by adding the following parameters described below + # @param [Hash] opts the optional parameters + # @option opts [String] :grant_type + # @option opts [String] :client_id + # @option opts [String] :client_secret + # @option opts [String] :redirect_uri + # @option opts [String] :code + # @option opts [String] :refresh_token + # @return [Object] + describe 'get_token test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/api/rest_client_api_spec.rb b/spec/api/rest_client_api_spec.rb new file mode 100644 index 0000000..45b6693 --- /dev/null +++ b/spec/api/rest_client_api_spec.rb @@ -0,0 +1,85 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' + +# Unit tests for Meli::RestClientApi +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'RestClientApi' do + before do + # run before each test + @api_instance = Meli::RestClientApi.new + end + + after do + # run after each test + end + + describe 'test an instance of RestClientApi' do + it 'should create an instance of RestClientApi' do + expect(@api_instance).to be_instance_of(Meli::RestClientApi) + end + end + + # unit tests for resource_delete + # Resource path DELETE + # @param resource + # @param access_token + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'resource_delete test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for resource_get + # Resource path GET + # @param resource + # @param access_token + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'resource_get test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for resource_post + # Resourse path POST + # @param resource + # @param access_token + # @param body + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'resource_post test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + # unit tests for resource_put + # Resourse path PUT + # @param resource + # @param access_token + # @param body + # @param [Hash] opts the optional parameters + # @return [Object] + describe 'resource_put test' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/api_client_spec.rb b/spec/api_client_spec.rb new file mode 100644 index 0000000..678af16 --- /dev/null +++ b/spec/api_client_spec.rb @@ -0,0 +1,226 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' + +describe Meli::ApiClient do + context 'initialization' do + context 'URL stuff' do + context 'host' do + it 'removes http from host' do + Meli.configure { |c| c.host = 'http://example.com' } + expect(Meli::Configuration.default.host).to eq('example.com') + end + + it 'removes https from host' do + Meli.configure { |c| c.host = 'https://wookiee.com' } + expect(Meli::ApiClient.default.config.host).to eq('wookiee.com') + end + + it 'removes trailing path from host' do + Meli.configure { |c| c.host = 'hobo.com/v4' } + expect(Meli::Configuration.default.host).to eq('hobo.com') + end + end + + context 'base_path' do + it "prepends a slash to base_path" do + Meli.configure { |c| c.base_path = 'v4/dog' } + expect(Meli::Configuration.default.base_path).to eq('/v4/dog') + end + + it "doesn't prepend a slash if one is already there" do + Meli.configure { |c| c.base_path = '/v4/dog' } + expect(Meli::Configuration.default.base_path).to eq('/v4/dog') + end + + it "ends up as a blank string if nil" do + Meli.configure { |c| c.base_path = nil } + expect(Meli::Configuration.default.base_path).to eq('') + end + end + end + end + + describe 'params_encoding in #build_request' do + let(:config) { Meli::Configuration.new } + let(:api_client) { Meli::ApiClient.new(config) } + + it 'defaults to nil' do + expect(Meli::Configuration.default.params_encoding).to eq(nil) + expect(config.params_encoding).to eq(nil) + + request = api_client.build_request(:get, '/test') + expect(request.options[:params_encoding]).to eq(nil) + end + + it 'can be customized' do + config.params_encoding = :multi + request = api_client.build_request(:get, '/test') + expect(request.options[:params_encoding]).to eq(:multi) + end + end + + describe 'timeout in #build_request' do + let(:config) { Meli::Configuration.new } + let(:api_client) { Meli::ApiClient.new(config) } + + it 'defaults to 0' do + expect(Meli::Configuration.default.timeout).to eq(0) + expect(config.timeout).to eq(0) + + request = api_client.build_request(:get, '/test') + expect(request.options[:timeout]).to eq(0) + end + + it 'can be customized' do + config.timeout = 100 + request = api_client.build_request(:get, '/test') + expect(request.options[:timeout]).to eq(100) + end + end + + describe '#deserialize' do + it "handles Array" do + api_client = Meli::ApiClient.new + headers = { 'Content-Type' => 'application/json' } + response = double('response', headers: headers, body: '[12, 34]') + data = api_client.deserialize(response, 'Array') + expect(data).to be_instance_of(Array) + expect(data).to eq([12, 34]) + end + + it 'handles Array>' do + api_client = Meli::ApiClient.new + headers = { 'Content-Type' => 'application/json' } + response = double('response', headers: headers, body: '[[12, 34], [56]]') + data = api_client.deserialize(response, 'Array>') + expect(data).to be_instance_of(Array) + expect(data).to eq([[12, 34], [56]]) + end + + it 'handles Hash' do + api_client = Meli::ApiClient.new + headers = { 'Content-Type' => 'application/json' } + response = double('response', headers: headers, body: '{"message": "Hello"}') + data = api_client.deserialize(response, 'Hash') + expect(data).to be_instance_of(Hash) + expect(data).to eq(:message => 'Hello') + end + end + + describe "#object_to_hash" do + it 'ignores nils and includes empty arrays' do + # uncomment below to test object_to_hash for model + # api_client = Meli::ApiClient.new + # _model = Meli::ModelName.new + # update the model attribute below + # _model.id = 1 + # update the expected value (hash) below + # expected = {id: 1, name: '', tags: []} + # expect(api_client.object_to_hash(_model)).to eq(expected) + end + end + + describe '#build_collection_param' do + let(:param) { ['aa', 'bb', 'cc'] } + let(:api_client) { Meli::ApiClient.new } + + it 'works for csv' do + expect(api_client.build_collection_param(param, :csv)).to eq('aa,bb,cc') + end + + it 'works for ssv' do + expect(api_client.build_collection_param(param, :ssv)).to eq('aa bb cc') + end + + it 'works for tsv' do + expect(api_client.build_collection_param(param, :tsv)).to eq("aa\tbb\tcc") + end + + it 'works for pipes' do + expect(api_client.build_collection_param(param, :pipes)).to eq('aa|bb|cc') + end + + it 'works for multi' do + expect(api_client.build_collection_param(param, :multi)).to eq(['aa', 'bb', 'cc']) + end + + it 'fails for invalid collection format' do + expect { api_client.build_collection_param(param, :INVALID) }.to raise_error(RuntimeError, 'unknown collection format: :INVALID') + end + end + + describe '#json_mime?' do + let(:api_client) { Meli::ApiClient.new } + + it 'works' do + expect(api_client.json_mime?(nil)).to eq false + expect(api_client.json_mime?('')).to eq false + + expect(api_client.json_mime?('application/json')).to eq true + expect(api_client.json_mime?('application/json; charset=UTF8')).to eq true + expect(api_client.json_mime?('APPLICATION/JSON')).to eq true + + expect(api_client.json_mime?('application/xml')).to eq false + expect(api_client.json_mime?('text/plain')).to eq false + expect(api_client.json_mime?('application/jsonp')).to eq false + end + end + + describe '#select_header_accept' do + let(:api_client) { Meli::ApiClient.new } + + it 'works' do + expect(api_client.select_header_accept(nil)).to be_nil + expect(api_client.select_header_accept([])).to be_nil + + expect(api_client.select_header_accept(['application/json'])).to eq('application/json') + expect(api_client.select_header_accept(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8') + expect(api_client.select_header_accept(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON') + + expect(api_client.select_header_accept(['application/xml'])).to eq('application/xml') + expect(api_client.select_header_accept(['text/html', 'application/xml'])).to eq('text/html,application/xml') + end + end + + describe '#select_header_content_type' do + let(:api_client) { Meli::ApiClient.new } + + it 'works' do + expect(api_client.select_header_content_type(nil)).to eq('application/json') + expect(api_client.select_header_content_type([])).to eq('application/json') + + expect(api_client.select_header_content_type(['application/json'])).to eq('application/json') + expect(api_client.select_header_content_type(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8') + expect(api_client.select_header_content_type(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON') + expect(api_client.select_header_content_type(['application/xml'])).to eq('application/xml') + expect(api_client.select_header_content_type(['text/plain', 'application/xml'])).to eq('text/plain') + end + end + + describe '#sanitize_filename' do + let(:api_client) { Meli::ApiClient.new } + + it 'works' do + expect(api_client.sanitize_filename('sun')).to eq('sun') + expect(api_client.sanitize_filename('sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('../sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('/var/tmp/sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('./sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('..\sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('\var\tmp\sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('c:\var\tmp\sun.gif')).to eq('sun.gif') + expect(api_client.sanitize_filename('.\sun.gif')).to eq('sun.gif') + end + end +end diff --git a/spec/configuration_spec.rb b/spec/configuration_spec.rb new file mode 100644 index 0000000..8c4eead --- /dev/null +++ b/spec/configuration_spec.rb @@ -0,0 +1,42 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' + +describe Meli::Configuration do + let(:config) { Meli::Configuration.default } + + before(:each) do + # uncomment below to setup host and base_path + # require 'URI' + # uri = URI.parse("https://api.mercadolibre.com") + # Meli.configure do |c| + # c.host = uri.host + # c.base_path = uri.path + # end + end + + describe '#base_url' do + it 'should have the default value' do + # uncomment below to test default value of the base path + # expect(config.base_url).to eq("https://api.mercadolibre.com") + end + + it 'should remove trailing slashes' do + [nil, '', '/', '//'].each do |base_path| + config.base_path = base_path + # uncomment below to test trailing slashes + # expect(config.base_url).to eq("https://api.mercadolibre.com") + end + end + end +end diff --git a/spec/meli_spec.rb b/spec/meli_spec.rb deleted file mode 100644 index 8173f40..0000000 --- a/spec/meli_spec.rb +++ /dev/null @@ -1,172 +0,0 @@ -# encoding: UTF-8 - -require 'spec_helper' - -describe Meli do - - before(:each) do - @client_id = "1234567" - @secret_code = "a secret" - @access_token = "access_token" - @refresh_token = "refresh_token" - @new_access_token = "a new access_token" - @new_refresh_token = "a new refresh_token" - - @meli = Meli.new @client_id, @secret_code, @access_token, @refresh_token - - @meli.https.stub(:request) do |req| - case req.method - when "GET" - if req.path =~ /\/users\/me/ - if req.path =~ /access_token/ - Net::HTTPOK.new(1, 200, "OK") - else - Net::HTTPForbidden.new(1, 403, "Forbidden") - end - else - Net::HTTPOK.new(1, 200, "OK") - end - when "POST" - if req.path =~ /\/oauth\/token/ - if !req.path =~ /grant_type/ || !req.path =~ /client_id/ || !req.path =~ /client_secret/ - Net::HTTPForbidden.new(1, 403, "Forbidden") - else - response = Net::HTTPOK.new(1, 200, "OK") - if req.body =~ /grant_type=authorization_code/ - def response.body - {:access_token => 'access_token', :refresh_token => 'refresh_token'}.to_json - end - elsif req.body =~ /grant_type=refresh_token/ - def response.body - {:access_token => 'a new access_token', :refresh_token => 'a new refresh_token'}.to_json - end - end - end - response - else - if req.path =~ /access_token/ - Net::HTTPOK.new(1, 200, "OK") - else - Net::HTTPForbidden.new(1, 403, "Forbidden") - end - end - when "PUT" - if req.path =~ /access_token/ - Net::HTTPOK.new(1, 200, "OK") - else - Net::HTTPForbidden.new(1, 403, "Forbidden") - end - when "DELETE" - if req.path =~ /access_token/ - Net::HTTPOK.new(1, 200, "OK") - else - Net::HTTPForbidden.new(1, 403, "Forbidden") - end - else - Net::HTTPInternalServerError.new(1, 500, "Internal Server Error") - end - end #stub - end #before each - - describe "Requireds Gems" do - it "should have json gem version 1.8.0" do - Gem::Specification::find_all_by_name('json').any?.should be_true - end - end - - describe "#new" do - it "should return a Meli object" do - @meli.should be_an_instance_of Meli - end - it "should return corret app_id" do - @meli.app_id.should == @client_id - end - it "should return corret secret" do - @meli.secret.should == @secret_code - end - it "should return correct access_token" do - @meli.access_token.should == @access_token - end - it "should return correct refresh_token" do - @meli.refresh_token.should == @refresh_token - end - it "should return a net/http service" do - @meli.https.should be_an_instance_of Net::HTTP - end - it "should have a http service with ssl" do - @meli.https.use_ssl?.should be_true - end - end - - describe "http methods" do - it "should return a reponse from get" do - response = @meli.get("/items/test1") - response.should be_an_instance_of Net::HTTPOK - end - it "should return a reponse from post" do - body = {"condition"=>"new", - "warranty"=>"60 dias", - "currency_id"=>"BRL", - "accepts_mercadopago"=>true, - "description"=>"Lindo Ray_Ban_Original_Wayfarer", - "listing_type_id"=>"bronze", - "title"=>"\303\223culos Ray Ban Aviador Que Troca As Lentes Lan\303\247amento!", - "available_quantity"=>64, - "price"=>289, - "subtitle"=>"Acompanha 3 Pares De Lentes!! Compra 100% Segura", - "buying_mode"=>"buy_it_now", - "category_id"=>"MLB5125", - "pictures"=>[{"source"=>"http://upload.wikimedia.org/wikipedia/commons/f/fd/Ray_Ban_Original_Wayfarer.jpg"}, - {"source"=>"http://en.wikipedia.org/wiki/File:Teashades.gif"}] - } - response = @meli.post("/items/test1", body, {:access_token => @meli.access_token}) - response.should be_an_instance_of Net::HTTPOK - end - it "should return a reponse from put" do - body = {"title"=>"New Title", "price"=>1000} - response = @meli.put("/items/test1", body, {:access_token => @meli.access_token}) - response.should be_an_instance_of Net::HTTPOK - end - it "should return a reponse from delete" do - response = @meli.delete("/questions/123", {:access_token => @meli.access_token}) - response.should be_an_instance_of Net::HTTPOK - end - it "get should return forbidden without access_token" do - response = @meli.get("/users/me") - response.should be_an_instance_of Net::HTTPForbidden - end - it "get should return OK with access_token" do - response = @meli.get("/users/me", {:access_token => @meli.access_token}) - response.should be_an_instance_of Net::HTTPOK - end - end - - describe "Auth Url" do - it "should return the correct auth url" do - callback = "http://test.com/callback" - @meli.auth_url(callback).should match "^https\:\/\/auth.mercadolibre.com\/authorization" - @meli.auth_url(callback).should match callback - @meli.auth_url(callback).should match @client_id - @meli.auth_url(callback).should match "response_type" - end - end - - describe "Authorize" do - it "should return Access Token" do - @meli.access_token = nil - @meli.refresh_token = nil - @meli.authorize("a code from get param", "A redirect Uri") - @meli.access_token.should == @access_token - @meli.refresh_token.should == @refresh_token - end - end - - describe "Refresh Token" do - it "should return new Access Token and a new Refresh Token" do - response = @meli.get_refresh_token() - @meli.access_token.should == @new_access_token - @meli.refresh_token == @new_refresh_token - end - end - -end diff --git a/spec/models/attributes_spec.rb b/spec/models/attributes_spec.rb new file mode 100644 index 0000000..fd959e4 --- /dev/null +++ b/spec/models/attributes_spec.rb @@ -0,0 +1,83 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::Attributes +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'Attributes' do + before do + # run before each test + @instance = Meli::Attributes.new + end + + after do + # run after each test + end + + describe 'test an instance of Attributes' do + it 'should create an instance of Attributes' do + expect(@instance).to be_instance_of(Meli::Attributes) + end + end + describe 'test attribute "id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "name"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "value_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "value_name"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "value_struct"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "values"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "attribute_group_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "attribute_group_name"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/attributes_value_struct_spec.rb b/spec/models/attributes_value_struct_spec.rb new file mode 100644 index 0000000..ab04a86 --- /dev/null +++ b/spec/models/attributes_value_struct_spec.rb @@ -0,0 +1,47 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::AttributesValueStruct +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'AttributesValueStruct' do + before do + # run before each test + @instance = Meli::AttributesValueStruct.new + end + + after do + # run after each test + end + + describe 'test an instance of AttributesValueStruct' do + it 'should create an instance of AttributesValueStruct' do + expect(@instance).to be_instance_of(Meli::AttributesValueStruct) + end + end + describe 'test attribute "number"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "unit"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/attributes_values_spec.rb b/spec/models/attributes_values_spec.rb new file mode 100644 index 0000000..a9fddee --- /dev/null +++ b/spec/models/attributes_values_spec.rb @@ -0,0 +1,53 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::AttributesValues +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'AttributesValues' do + before do + # run before each test + @instance = Meli::AttributesValues.new + end + + after do + # run after each test + end + + describe 'test an instance of AttributesValues' do + it 'should create an instance of AttributesValues' do + expect(@instance).to be_instance_of(Meli::AttributesValues) + end + end + describe 'test attribute "id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "name"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "struct"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/inline_object_spec.rb b/spec/models/inline_object_spec.rb new file mode 100644 index 0000000..b1deb66 --- /dev/null +++ b/spec/models/inline_object_spec.rb @@ -0,0 +1,71 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::InlineObject +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'InlineObject' do + before do + # run before each test + @instance = Meli::InlineObject.new + end + + after do + # run after each test + end + + describe 'test an instance of InlineObject' do + it 'should create an instance of InlineObject' do + expect(@instance).to be_instance_of(Meli::InlineObject) + end + end + describe 'test attribute "grant_type"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "client_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "client_secret"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "redirect_uri"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "code"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "refresh_token"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/item_pictures_spec.rb b/spec/models/item_pictures_spec.rb new file mode 100644 index 0000000..4dbe871 --- /dev/null +++ b/spec/models/item_pictures_spec.rb @@ -0,0 +1,41 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::ItemPictures +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'ItemPictures' do + before do + # run before each test + @instance = Meli::ItemPictures.new + end + + after do + # run after each test + end + + describe 'test an instance of ItemPictures' do + it 'should create an instance of ItemPictures' do + expect(@instance).to be_instance_of(Meli::ItemPictures) + end + end + describe 'test attribute "source"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/item_spec.rb b/spec/models/item_spec.rb new file mode 100644 index 0000000..a1726b8 --- /dev/null +++ b/spec/models/item_spec.rb @@ -0,0 +1,113 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::Item +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'Item' do + before do + # run before each test + @instance = Meli::Item.new + end + + after do + # run after each test + end + + describe 'test an instance of Item' do + it 'should create an instance of Item' do + expect(@instance).to be_instance_of(Meli::Item) + end + end + describe 'test attribute "title"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "category_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "price"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "currency_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "available_quantity"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "buying_mode"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "listing_type_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "condition"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "description"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "video_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "pictures"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "attributes"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "variations"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/variations_attribute_combinations_spec.rb b/spec/models/variations_attribute_combinations_spec.rb new file mode 100644 index 0000000..4342ebc --- /dev/null +++ b/spec/models/variations_attribute_combinations_spec.rb @@ -0,0 +1,53 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::VariationsAttributeCombinations +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'VariationsAttributeCombinations' do + before do + # run before each test + @instance = Meli::VariationsAttributeCombinations.new + end + + after do + # run after each test + end + + describe 'test an instance of VariationsAttributeCombinations' do + it 'should create an instance of VariationsAttributeCombinations' do + expect(@instance).to be_instance_of(Meli::VariationsAttributeCombinations) + end + end + describe 'test attribute "name"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "value_id"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "value_name"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/models/variations_spec.rb b/spec/models/variations_spec.rb new file mode 100644 index 0000000..c4b8290 --- /dev/null +++ b/spec/models/variations_spec.rb @@ -0,0 +1,65 @@ +=begin +#MELI Markeplace SDK + +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +require 'spec_helper' +require 'json' +require 'date' + +# Unit tests for Meli::Variations +# Automatically generated by openapi-generator (https://openapi-generator.tech) +# Please update as you see appropriate +describe 'Variations' do + before do + # run before each test + @instance = Meli::Variations.new + end + + after do + # run after each test + end + + describe 'test an instance of Variations' do + it 'should create an instance of Variations' do + expect(@instance).to be_instance_of(Meli::Variations) + end + end + describe 'test attribute "price"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "attribute_combinations"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "available_quantity"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "sold_quantity"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + + describe 'test attribute "picture_ids"' do + it 'should work' do + # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers + end + end + +end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 65049f0..8873f12 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -1,3 +1,111 @@ -require File.expand_path(File.dirname(__FILE__) + '/../lib/meli') +=begin +#MELI Markeplace SDK -require 'yaml' +#This is a the codebase to generate a SDK for Open Platform Marketplace + +The version of the OpenAPI document: 3.0.0 + +Generated by: https://openapi-generator.tech +OpenAPI Generator version: 4.3.1 + +=end + +# load the gem +require 'Meli' + +# The following was generated by the `rspec --init` command. Conventionally, all +# specs live under a `spec` directory, which RSpec adds to the `$LOAD_PATH`. +# The generated `.rspec` file contains `--require spec_helper` which will cause +# this file to always be loaded, without a need to explicitly require it in any +# files. +# +# Given that it is always loaded, you are encouraged to keep this file as +# light-weight as possible. Requiring heavyweight dependencies from this file +# will add to the boot time of your test suite on EVERY test run, even for an +# individual file that may not need all of that loaded. Instead, consider making +# a separate helper file that requires the additional dependencies and performs +# the additional setup, and require it from the spec files that actually need +# it. +# +# The `.rspec` file also contains a few flags that are not defaults but that +# users commonly want. +# +# See http://rubydoc.info/gems/rspec-core/RSpec/Core/Configuration +RSpec.configure do |config| + # rspec-expectations config goes here. You can use an alternate + # assertion/expectation library such as wrong or the stdlib/minitest + # assertions if you prefer. + config.expect_with :rspec do |expectations| + # This option will default to `true` in RSpec 4. It makes the `description` + # and `failure_message` of custom matchers include text for helper methods + # defined using `chain`, e.g.: + # be_bigger_than(2).and_smaller_than(4).description + # # => "be bigger than 2 and smaller than 4" + # ...rather than: + # # => "be bigger than 2" + expectations.include_chain_clauses_in_custom_matcher_descriptions = true + end + + # rspec-mocks config goes here. You can use an alternate test double + # library (such as bogus or mocha) by changing the `mock_with` option here. + config.mock_with :rspec do |mocks| + # Prevents you from mocking or stubbing a method that does not exist on + # a real object. This is generally recommended, and will default to + # `true` in RSpec 4. + mocks.verify_partial_doubles = true + end + +# The settings below are suggested to provide a good initial experience +# with RSpec, but feel free to customize to your heart's content. +=begin + # These two settings work together to allow you to limit a spec run + # to individual examples or groups you care about by tagging them with + # `:focus` metadata. When nothing is tagged with `:focus`, all examples + # get run. + config.filter_run :focus + config.run_all_when_everything_filtered = true + + # Allows RSpec to persist some state between runs in order to support + # the `--only-failures` and `--next-failure` CLI options. We recommend + # you configure your source control system to ignore this file. + config.example_status_persistence_file_path = "spec/examples.txt" + + # Limits the available syntax to the non-monkey patched syntax that is + # recommended. For more details, see: + # - http://rspec.info/blog/2012/06/rspecs-new-expectation-syntax/ + # - http://www.teaisaweso.me/blog/2013/05/27/rspecs-new-message-expectation-syntax/ + # - http://rspec.info/blog/2014/05/notable-changes-in-rspec-3/#zero-monkey-patching-mode + config.disable_monkey_patching! + + # This setting enables warnings. It's recommended, but in some cases may + # be too noisy due to issues in dependencies. + config.warnings = true + + # Many RSpec users commonly either run the entire suite or an individual + # file, and it's useful to allow more verbose output when running an + # individual spec file. + if config.files_to_run.one? + # Use the documentation formatter for detailed output, + # unless a formatter has already been configured + # (e.g. via a command-line flag). + config.default_formatter = 'doc' + end + + # Print the 10 slowest examples and example groups at the + # end of the spec run, to help surface which specs are running + # particularly slow. + config.profile_examples = 10 + + # Run specs in random order to surface order dependencies. If you find an + # order dependency and want to debug it, you can fix the order by providing + # the seed, which is printed after each run. + # --seed 1234 + config.order = :random + + # Seed global randomization in this process using the `--seed` CLI option. + # Setting this allows you to use `--seed` to deterministically reproduce + # test failures related to randomization by passing the same `--seed` value + # as the one that triggered the failure. + Kernel.srand config.seed +=end +end