wesley-key-sdk 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/LICENSE +28 -0
- data/README.md +126 -0
- data/lib/swagger_petstore/api_helper.rb +10 -0
- data/lib/swagger_petstore/client.rb +84 -0
- data/lib/swagger_petstore/configuration.rb +127 -0
- data/lib/swagger_petstore/controllers/base_controller.rb +60 -0
- data/lib/swagger_petstore/controllers/pet_controller.rb +206 -0
- data/lib/swagger_petstore/controllers/store_controller.rb +94 -0
- data/lib/swagger_petstore/controllers/user_controller.rb +165 -0
- data/lib/swagger_petstore/exceptions/api_exception.rb +21 -0
- data/lib/swagger_petstore/exceptions/o_auth_provider_exception.rb +64 -0
- data/lib/swagger_petstore/http/auth/api_key.rb +42 -0
- data/lib/swagger_petstore/http/auth/http_basic.rb +50 -0
- data/lib/swagger_petstore/http/auth/petstore_auth.rb +98 -0
- data/lib/swagger_petstore/http/http_call_back.rb +10 -0
- data/lib/swagger_petstore/http/http_method_enum.rb +10 -0
- data/lib/swagger_petstore/http/http_request.rb +10 -0
- data/lib/swagger_petstore/http/http_response.rb +10 -0
- data/lib/swagger_petstore/http/proxy_settings.rb +13 -0
- data/lib/swagger_petstore/models/api_response.rb +81 -0
- data/lib/swagger_petstore/models/base_model.rb +110 -0
- data/lib/swagger_petstore/models/category.rb +71 -0
- data/lib/swagger_petstore/models/category2.rb +71 -0
- data/lib/swagger_petstore/models/content_type_enum.rb +20 -0
- data/lib/swagger_petstore/models/o_auth_provider_error_enum.rb +45 -0
- data/lib/swagger_petstore/models/o_auth_scope_petstore_auth_enum.rb +23 -0
- data/lib/swagger_petstore/models/o_auth_token.rb +96 -0
- data/lib/swagger_petstore/models/order.rb +120 -0
- data/lib/swagger_petstore/models/pet.rb +117 -0
- data/lib/swagger_petstore/models/pet_request.rb +117 -0
- data/lib/swagger_petstore/models/status1_enum.rb +26 -0
- data/lib/swagger_petstore/models/status2_enum.rb +26 -0
- data/lib/swagger_petstore/models/status_enum.rb +26 -0
- data/lib/swagger_petstore/models/store_order_request.rb +120 -0
- data/lib/swagger_petstore/models/tag.rb +71 -0
- data/lib/swagger_petstore/models/user.rb +132 -0
- data/lib/swagger_petstore/models/user_request.rb +132 -0
- data/lib/swagger_petstore/utilities/date_time_helper.rb +11 -0
- data/lib/swagger_petstore/utilities/file_wrapper.rb +28 -0
- data/lib/swagger_petstore.rb +62 -0
- data/test/controllers/controller_test_base.rb +37 -0
- data/test/controllers/test_store_controller.rb +31 -0
- data/test/http_response_catcher.rb +19 -0
- metadata +156 -0
@@ -0,0 +1,110 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# Base model.
|
8
|
+
# rubocop:disable all
|
9
|
+
class BaseModel < CoreLibrary::BaseModel
|
10
|
+
# Returns a Hash representation of the current object.
|
11
|
+
def to_hash
|
12
|
+
# validating the model being serialized
|
13
|
+
self.class.validate(self) if self.class.respond_to?(:validate)
|
14
|
+
|
15
|
+
hash = {}
|
16
|
+
instance_variables.each do |name|
|
17
|
+
value = instance_variable_get(name)
|
18
|
+
name = name[1..]
|
19
|
+
if name == 'additional_properties'
|
20
|
+
additional_properties = process_additional_properties(value, self.class.names)
|
21
|
+
hash.merge!(additional_properties)
|
22
|
+
else
|
23
|
+
key = self.class.names.key?(name) ? self.class.names[name] : name
|
24
|
+
optional_fields = self.class.optionals
|
25
|
+
nullable_fields = self.class.nullables
|
26
|
+
if value.nil?
|
27
|
+
next unless nullable_fields.include?(name)
|
28
|
+
|
29
|
+
if !optional_fields.include?(name) && !nullable_fields.include?(name)
|
30
|
+
raise ArgumentError,
|
31
|
+
"`#{name}` cannot be nil in `#{self.class}`. Please specify a valid value."
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
hash[key] = nil
|
36
|
+
unless value.nil?
|
37
|
+
if respond_to?("to_custom_#{name}")
|
38
|
+
if (value.instance_of? Array) || (value.instance_of? Hash)
|
39
|
+
params = [hash, key]
|
40
|
+
hash[key] = send("to_custom_#{name}", *params)
|
41
|
+
else
|
42
|
+
hash[key] = send("to_custom_#{name}")
|
43
|
+
end
|
44
|
+
elsif respond_to?("to_union_type_#{name}")
|
45
|
+
hash[key] = send("to_union_type_#{name}")
|
46
|
+
elsif value.instance_of? Array
|
47
|
+
hash[key] = value.map { |v| v.is_a?(BaseModel) ? v.to_hash : v }
|
48
|
+
elsif value.instance_of? Hash
|
49
|
+
hash[key] = {}
|
50
|
+
value.each do |k, v|
|
51
|
+
hash[key][k] = v.is_a?(BaseModel) ? v.to_hash : v
|
52
|
+
end
|
53
|
+
else
|
54
|
+
hash[key] = value.is_a?(BaseModel) ? value.to_hash : value
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
hash
|
60
|
+
end
|
61
|
+
|
62
|
+
# Processes additional properties, ensuring no conflicts with existing properties.
|
63
|
+
def process_additional_properties(additional_properties, existing_prop_names)
|
64
|
+
hash = {}
|
65
|
+
additional_properties.each do |name, value|
|
66
|
+
check_for_conflict(name, existing_prop_names)
|
67
|
+
|
68
|
+
hash[name] = if value.is_a?(Array)
|
69
|
+
process_array(value)
|
70
|
+
elsif value.is_a?(Hash)
|
71
|
+
process_hash(value)
|
72
|
+
else
|
73
|
+
process_basic_value(value)
|
74
|
+
end
|
75
|
+
end
|
76
|
+
hash
|
77
|
+
end
|
78
|
+
|
79
|
+
# Checks if an additional property conflicts with a model's existing property.
|
80
|
+
def check_for_conflict(name, existing_prop_names)
|
81
|
+
return unless existing_prop_names.key?(name)
|
82
|
+
|
83
|
+
raise ArgumentError, "An additional property key, '#{name}' conflicts with one of the model's properties"
|
84
|
+
end
|
85
|
+
|
86
|
+
# Processes an array of values, recursively calling `to_hash` on BaseModel objects.
|
87
|
+
def process_array(value)
|
88
|
+
value.map { |v| v.is_a?(BaseModel) ? v.to_hash : v }
|
89
|
+
end
|
90
|
+
|
91
|
+
# Processes a hash of values, recursively calling `to_hash` on BaseModel objects.
|
92
|
+
def process_hash(value)
|
93
|
+
value.transform_values do |v|
|
94
|
+
v.is_a?(BaseModel) ? v.to_hash : v
|
95
|
+
end
|
96
|
+
end
|
97
|
+
|
98
|
+
# Processes a basic value (non-array, non-hash).
|
99
|
+
def process_basic_value(value)
|
100
|
+
value.is_a?(BaseModel) ? value.to_hash : value
|
101
|
+
end
|
102
|
+
|
103
|
+
# Returns a JSON representation of the curent object.
|
104
|
+
def to_json(options = {})
|
105
|
+
hash = to_hash
|
106
|
+
hash.to_json(options)
|
107
|
+
end
|
108
|
+
end
|
109
|
+
# rubocop:enable all
|
110
|
+
end
|
@@ -0,0 +1,71 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# Category Model.
|
8
|
+
class Category < BaseModel
|
9
|
+
SKIP = Object.new
|
10
|
+
private_constant :SKIP
|
11
|
+
|
12
|
+
# TODO: Write general description for this method
|
13
|
+
# @return [Integer]
|
14
|
+
attr_accessor :id
|
15
|
+
|
16
|
+
# TODO: Write general description for this method
|
17
|
+
# @return [String]
|
18
|
+
attr_accessor :name
|
19
|
+
|
20
|
+
# A mapping from model property names to API property names.
|
21
|
+
def self.names
|
22
|
+
@_hash = {} if @_hash.nil?
|
23
|
+
@_hash['id'] = 'id'
|
24
|
+
@_hash['name'] = 'name'
|
25
|
+
@_hash
|
26
|
+
end
|
27
|
+
|
28
|
+
# An array for optional fields
|
29
|
+
def self.optionals
|
30
|
+
%w[
|
31
|
+
id
|
32
|
+
name
|
33
|
+
]
|
34
|
+
end
|
35
|
+
|
36
|
+
# An array for nullable fields
|
37
|
+
def self.nullables
|
38
|
+
[]
|
39
|
+
end
|
40
|
+
|
41
|
+
def initialize(id = SKIP, name = SKIP)
|
42
|
+
@id = id unless id == SKIP
|
43
|
+
@name = name unless name == SKIP
|
44
|
+
end
|
45
|
+
|
46
|
+
# Creates an instance of the object from a hash.
|
47
|
+
def self.from_hash(hash)
|
48
|
+
return nil unless hash
|
49
|
+
|
50
|
+
# Extract variables from the hash.
|
51
|
+
id = hash.key?('id') ? hash['id'] : SKIP
|
52
|
+
name = hash.key?('name') ? hash['name'] : SKIP
|
53
|
+
|
54
|
+
# Create object from extracted values.
|
55
|
+
Category.new(id,
|
56
|
+
name)
|
57
|
+
end
|
58
|
+
|
59
|
+
# Provides a human-readable string representation of the object.
|
60
|
+
def to_s
|
61
|
+
class_name = self.class.name.split('::').last
|
62
|
+
"<#{class_name} id: #{@id}, name: #{@name}>"
|
63
|
+
end
|
64
|
+
|
65
|
+
# Provides a debugging-friendly string with detailed object information.
|
66
|
+
def inspect
|
67
|
+
class_name = self.class.name.split('::').last
|
68
|
+
"<#{class_name} id: #{@id.inspect}, name: #{@name.inspect}>"
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
@@ -0,0 +1,71 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# Category2 Model.
|
8
|
+
class Category2 < BaseModel
|
9
|
+
SKIP = Object.new
|
10
|
+
private_constant :SKIP
|
11
|
+
|
12
|
+
# TODO: Write general description for this method
|
13
|
+
# @return [Integer]
|
14
|
+
attr_accessor :id
|
15
|
+
|
16
|
+
# TODO: Write general description for this method
|
17
|
+
# @return [String]
|
18
|
+
attr_accessor :name
|
19
|
+
|
20
|
+
# A mapping from model property names to API property names.
|
21
|
+
def self.names
|
22
|
+
@_hash = {} if @_hash.nil?
|
23
|
+
@_hash['id'] = 'id'
|
24
|
+
@_hash['name'] = 'name'
|
25
|
+
@_hash
|
26
|
+
end
|
27
|
+
|
28
|
+
# An array for optional fields
|
29
|
+
def self.optionals
|
30
|
+
%w[
|
31
|
+
id
|
32
|
+
name
|
33
|
+
]
|
34
|
+
end
|
35
|
+
|
36
|
+
# An array for nullable fields
|
37
|
+
def self.nullables
|
38
|
+
[]
|
39
|
+
end
|
40
|
+
|
41
|
+
def initialize(id = SKIP, name = SKIP)
|
42
|
+
@id = id unless id == SKIP
|
43
|
+
@name = name unless name == SKIP
|
44
|
+
end
|
45
|
+
|
46
|
+
# Creates an instance of the object from a hash.
|
47
|
+
def self.from_hash(hash)
|
48
|
+
return nil unless hash
|
49
|
+
|
50
|
+
# Extract variables from the hash.
|
51
|
+
id = hash.key?('id') ? hash['id'] : SKIP
|
52
|
+
name = hash.key?('name') ? hash['name'] : SKIP
|
53
|
+
|
54
|
+
# Create object from extracted values.
|
55
|
+
Category2.new(id,
|
56
|
+
name)
|
57
|
+
end
|
58
|
+
|
59
|
+
# Provides a human-readable string representation of the object.
|
60
|
+
def to_s
|
61
|
+
class_name = self.class.name.split('::').last
|
62
|
+
"<#{class_name} id: #{@id}, name: #{@name}>"
|
63
|
+
end
|
64
|
+
|
65
|
+
# Provides a debugging-friendly string with detailed object information.
|
66
|
+
def inspect
|
67
|
+
class_name = self.class.name.split('::').last
|
68
|
+
"<#{class_name} id: #{@id.inspect}, name: #{@name.inspect}>"
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# Content-Type.
|
8
|
+
class ContentTypeEnum
|
9
|
+
CONTENT_TYPE_ENUM = [
|
10
|
+
# TODO: Write general description for ENUM_APPLICATIONXWWWFORMURLENCODED
|
11
|
+
ENUM_APPLICATIONXWWWFORMURLENCODED = 'application/x-www-form-urlencoded'.freeze
|
12
|
+
].freeze
|
13
|
+
|
14
|
+
def self.validate(value)
|
15
|
+
return false if value.nil?
|
16
|
+
|
17
|
+
CONTENT_TYPE_ENUM.include?(value)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# OAuth 2 Authorization error codes
|
8
|
+
class OAuthProviderErrorEnum
|
9
|
+
O_AUTH_PROVIDER_ERROR_ENUM = [
|
10
|
+
# The request is missing a required parameter, includes an unsupported
|
11
|
+
# parameter value (other than grant type), repeats a parameter, includes
|
12
|
+
# multiple credentials, utilizes more than one mechanism for
|
13
|
+
# authenticating the client, or is otherwise malformed.
|
14
|
+
INVALID_REQUEST = 'invalid_request'.freeze,
|
15
|
+
|
16
|
+
# Client authentication failed (e.g., unknown client, no client
|
17
|
+
# authentication included, or unsupported authentication method).
|
18
|
+
INVALID_CLIENT = 'invalid_client'.freeze,
|
19
|
+
|
20
|
+
# The provided authorization grant (e.g., authorization code, resource
|
21
|
+
# owner credentials) or refresh token is invalid, expired, revoked, does
|
22
|
+
# not match the redirection URI used in the authorization request, or was
|
23
|
+
# issued to another client.
|
24
|
+
INVALID_GRANT = 'invalid_grant'.freeze,
|
25
|
+
|
26
|
+
# The authenticated client is not authorized to use this authorization
|
27
|
+
# grant type.
|
28
|
+
UNAUTHORIZED_CLIENT = 'unauthorized_client'.freeze,
|
29
|
+
|
30
|
+
# The authorization grant type is not supported by the authorization
|
31
|
+
# server.
|
32
|
+
UNSUPPORTED_GRANT_TYPE = 'unsupported_grant_type'.freeze,
|
33
|
+
|
34
|
+
# The requested scope is invalid, unknown, malformed, or exceeds the scope
|
35
|
+
# granted by the resource owner.
|
36
|
+
INVALID_SCOPE = 'invalid_scope'.freeze
|
37
|
+
].freeze
|
38
|
+
|
39
|
+
def self.validate(value)
|
40
|
+
return false if value.nil?
|
41
|
+
|
42
|
+
O_AUTH_PROVIDER_ERROR_ENUM.include?(value)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# OAuth 2 scopes supported by the API
|
8
|
+
class OAuthScopePetstoreAuthEnum
|
9
|
+
O_AUTH_SCOPE_PETSTORE_AUTH_ENUM = [
|
10
|
+
# read your pets
|
11
|
+
READPETS = 'read:pets'.freeze,
|
12
|
+
|
13
|
+
# modify pets in your account
|
14
|
+
WRITEPETS = 'write:pets'.freeze
|
15
|
+
].freeze
|
16
|
+
|
17
|
+
def self.validate(value)
|
18
|
+
return false if value.nil?
|
19
|
+
|
20
|
+
O_AUTH_SCOPE_PETSTORE_AUTH_ENUM.include?(value)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,96 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# OAuth 2 Authorization endpoint response
|
8
|
+
class OAuthToken < BaseModel
|
9
|
+
SKIP = Object.new
|
10
|
+
private_constant :SKIP
|
11
|
+
|
12
|
+
# Access token
|
13
|
+
# @return [String]
|
14
|
+
attr_accessor :access_token
|
15
|
+
|
16
|
+
# Type of access token
|
17
|
+
# @return [String]
|
18
|
+
attr_accessor :token_type
|
19
|
+
|
20
|
+
# Time in seconds before the access token expires
|
21
|
+
# @return [Integer]
|
22
|
+
attr_accessor :expires_in
|
23
|
+
|
24
|
+
# List of scopes granted
|
25
|
+
# This is a space-delimited list of strings.
|
26
|
+
# @return [String]
|
27
|
+
attr_accessor :scope
|
28
|
+
|
29
|
+
# Time of token expiry as unix timestamp (UTC)
|
30
|
+
# @return [Integer]
|
31
|
+
attr_accessor :expiry
|
32
|
+
|
33
|
+
# Refresh token
|
34
|
+
# Used to get a new access token when it expires.
|
35
|
+
# @return [String]
|
36
|
+
attr_accessor :refresh_token
|
37
|
+
|
38
|
+
# A mapping from model property names to API property names.
|
39
|
+
def self.names
|
40
|
+
@_hash = {} if @_hash.nil?
|
41
|
+
@_hash['access_token'] = 'access_token'
|
42
|
+
@_hash['token_type'] = 'token_type'
|
43
|
+
@_hash['expires_in'] = 'expires_in'
|
44
|
+
@_hash['scope'] = 'scope'
|
45
|
+
@_hash['expiry'] = 'expiry'
|
46
|
+
@_hash['refresh_token'] = 'refresh_token'
|
47
|
+
@_hash
|
48
|
+
end
|
49
|
+
|
50
|
+
# An array for optional fields
|
51
|
+
def self.optionals
|
52
|
+
%w[
|
53
|
+
expires_in
|
54
|
+
scope
|
55
|
+
expiry
|
56
|
+
refresh_token
|
57
|
+
]
|
58
|
+
end
|
59
|
+
|
60
|
+
# An array for nullable fields
|
61
|
+
def self.nullables
|
62
|
+
[]
|
63
|
+
end
|
64
|
+
|
65
|
+
def initialize(access_token = nil, token_type = nil, expires_in = SKIP,
|
66
|
+
scope = SKIP, expiry = SKIP, refresh_token = SKIP)
|
67
|
+
@access_token = access_token
|
68
|
+
@token_type = token_type
|
69
|
+
@expires_in = expires_in unless expires_in == SKIP
|
70
|
+
@scope = scope unless scope == SKIP
|
71
|
+
@expiry = expiry unless expiry == SKIP
|
72
|
+
@refresh_token = refresh_token unless refresh_token == SKIP
|
73
|
+
end
|
74
|
+
|
75
|
+
# Creates an instance of the object from a hash.
|
76
|
+
def self.from_hash(hash)
|
77
|
+
return nil unless hash
|
78
|
+
|
79
|
+
# Extract variables from the hash.
|
80
|
+
access_token = hash.key?('access_token') ? hash['access_token'] : nil
|
81
|
+
token_type = hash.key?('token_type') ? hash['token_type'] : nil
|
82
|
+
expires_in = hash.key?('expires_in') ? hash['expires_in'] : SKIP
|
83
|
+
scope = hash.key?('scope') ? hash['scope'] : SKIP
|
84
|
+
expiry = hash.key?('expiry') ? hash['expiry'] : SKIP
|
85
|
+
refresh_token = hash.key?('refresh_token') ? hash['refresh_token'] : SKIP
|
86
|
+
|
87
|
+
# Create object from extracted values.
|
88
|
+
OAuthToken.new(access_token,
|
89
|
+
token_type,
|
90
|
+
expires_in,
|
91
|
+
scope,
|
92
|
+
expiry,
|
93
|
+
refresh_token)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
@@ -0,0 +1,120 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
require 'date'
|
7
|
+
module SwaggerPetstore
|
8
|
+
# Order Model.
|
9
|
+
class Order < BaseModel
|
10
|
+
SKIP = Object.new
|
11
|
+
private_constant :SKIP
|
12
|
+
|
13
|
+
# TODO: Write general description for this method
|
14
|
+
# @return [Integer]
|
15
|
+
attr_accessor :id
|
16
|
+
|
17
|
+
# TODO: Write general description for this method
|
18
|
+
# @return [Integer]
|
19
|
+
attr_accessor :pet_id
|
20
|
+
|
21
|
+
# TODO: Write general description for this method
|
22
|
+
# @return [Integer]
|
23
|
+
attr_accessor :quantity
|
24
|
+
|
25
|
+
# TODO: Write general description for this method
|
26
|
+
# @return [DateTime]
|
27
|
+
attr_accessor :ship_date
|
28
|
+
|
29
|
+
# TODO: Write general description for this method
|
30
|
+
# @return [Status1Enum]
|
31
|
+
attr_accessor :status
|
32
|
+
|
33
|
+
# TODO: Write general description for this method
|
34
|
+
# @return [TrueClass | FalseClass]
|
35
|
+
attr_accessor :complete
|
36
|
+
|
37
|
+
# A mapping from model property names to API property names.
|
38
|
+
def self.names
|
39
|
+
@_hash = {} if @_hash.nil?
|
40
|
+
@_hash['id'] = 'id'
|
41
|
+
@_hash['pet_id'] = 'petId'
|
42
|
+
@_hash['quantity'] = 'quantity'
|
43
|
+
@_hash['ship_date'] = 'shipDate'
|
44
|
+
@_hash['status'] = 'status'
|
45
|
+
@_hash['complete'] = 'complete'
|
46
|
+
@_hash
|
47
|
+
end
|
48
|
+
|
49
|
+
# An array for optional fields
|
50
|
+
def self.optionals
|
51
|
+
%w[
|
52
|
+
id
|
53
|
+
pet_id
|
54
|
+
quantity
|
55
|
+
ship_date
|
56
|
+
status
|
57
|
+
complete
|
58
|
+
]
|
59
|
+
end
|
60
|
+
|
61
|
+
# An array for nullable fields
|
62
|
+
def self.nullables
|
63
|
+
[]
|
64
|
+
end
|
65
|
+
|
66
|
+
def initialize(id = SKIP, pet_id = SKIP, quantity = SKIP, ship_date = SKIP,
|
67
|
+
status = SKIP, complete = SKIP)
|
68
|
+
@id = id unless id == SKIP
|
69
|
+
@pet_id = pet_id unless pet_id == SKIP
|
70
|
+
@quantity = quantity unless quantity == SKIP
|
71
|
+
@ship_date = ship_date unless ship_date == SKIP
|
72
|
+
@status = status unless status == SKIP
|
73
|
+
@complete = complete unless complete == SKIP
|
74
|
+
end
|
75
|
+
|
76
|
+
# Creates an instance of the object from a hash.
|
77
|
+
def self.from_hash(hash)
|
78
|
+
return nil unless hash
|
79
|
+
|
80
|
+
# Extract variables from the hash.
|
81
|
+
id = hash.key?('id') ? hash['id'] : SKIP
|
82
|
+
pet_id = hash.key?('petId') ? hash['petId'] : SKIP
|
83
|
+
quantity = hash.key?('quantity') ? hash['quantity'] : SKIP
|
84
|
+
ship_date = if hash.key?('shipDate')
|
85
|
+
(DateTimeHelper.from_rfc3339(hash['shipDate']) if hash['shipDate'])
|
86
|
+
else
|
87
|
+
SKIP
|
88
|
+
end
|
89
|
+
status = hash.key?('status') ? hash['status'] : SKIP
|
90
|
+
complete = hash.key?('complete') ? hash['complete'] : SKIP
|
91
|
+
|
92
|
+
# Create object from extracted values.
|
93
|
+
Order.new(id,
|
94
|
+
pet_id,
|
95
|
+
quantity,
|
96
|
+
ship_date,
|
97
|
+
status,
|
98
|
+
complete)
|
99
|
+
end
|
100
|
+
|
101
|
+
def to_custom_ship_date
|
102
|
+
DateTimeHelper.to_rfc3339(ship_date)
|
103
|
+
end
|
104
|
+
|
105
|
+
# Provides a human-readable string representation of the object.
|
106
|
+
def to_s
|
107
|
+
class_name = self.class.name.split('::').last
|
108
|
+
"<#{class_name} id: #{@id}, pet_id: #{@pet_id}, quantity: #{@quantity}, ship_date:"\
|
109
|
+
" #{@ship_date}, status: #{@status}, complete: #{@complete}>"
|
110
|
+
end
|
111
|
+
|
112
|
+
# Provides a debugging-friendly string with detailed object information.
|
113
|
+
def inspect
|
114
|
+
class_name = self.class.name.split('::').last
|
115
|
+
"<#{class_name} id: #{@id.inspect}, pet_id: #{@pet_id.inspect}, quantity:"\
|
116
|
+
" #{@quantity.inspect}, ship_date: #{@ship_date.inspect}, status: #{@status.inspect},"\
|
117
|
+
" complete: #{@complete.inspect}>"
|
118
|
+
end
|
119
|
+
end
|
120
|
+
end
|
@@ -0,0 +1,117 @@
|
|
1
|
+
# swagger_petstore
|
2
|
+
#
|
3
|
+
# This file was automatically generated by APIMATIC v3.0
|
4
|
+
# ( https://www.apimatic.io ).
|
5
|
+
|
6
|
+
module SwaggerPetstore
|
7
|
+
# Pet Model.
|
8
|
+
class Pet < BaseModel
|
9
|
+
SKIP = Object.new
|
10
|
+
private_constant :SKIP
|
11
|
+
|
12
|
+
# TODO: Write general description for this method
|
13
|
+
# @return [Integer]
|
14
|
+
attr_accessor :id
|
15
|
+
|
16
|
+
# TODO: Write general description for this method
|
17
|
+
# @return [Category2]
|
18
|
+
attr_accessor :category
|
19
|
+
|
20
|
+
# TODO: Write general description for this method
|
21
|
+
# @return [String]
|
22
|
+
attr_accessor :name
|
23
|
+
|
24
|
+
# TODO: Write general description for this method
|
25
|
+
# @return [Array[String]]
|
26
|
+
attr_accessor :photo_urls
|
27
|
+
|
28
|
+
# TODO: Write general description for this method
|
29
|
+
# @return [Array[Tag]]
|
30
|
+
attr_accessor :tags
|
31
|
+
|
32
|
+
# TODO: Write general description for this method
|
33
|
+
# @return [StatusEnum]
|
34
|
+
attr_accessor :status
|
35
|
+
|
36
|
+
# A mapping from model property names to API property names.
|
37
|
+
def self.names
|
38
|
+
@_hash = {} if @_hash.nil?
|
39
|
+
@_hash['id'] = 'id'
|
40
|
+
@_hash['category'] = 'category'
|
41
|
+
@_hash['name'] = 'name'
|
42
|
+
@_hash['photo_urls'] = 'photoUrls'
|
43
|
+
@_hash['tags'] = 'tags'
|
44
|
+
@_hash['status'] = 'status'
|
45
|
+
@_hash
|
46
|
+
end
|
47
|
+
|
48
|
+
# An array for optional fields
|
49
|
+
def self.optionals
|
50
|
+
%w[
|
51
|
+
id
|
52
|
+
category
|
53
|
+
tags
|
54
|
+
status
|
55
|
+
]
|
56
|
+
end
|
57
|
+
|
58
|
+
# An array for nullable fields
|
59
|
+
def self.nullables
|
60
|
+
[]
|
61
|
+
end
|
62
|
+
|
63
|
+
def initialize(name = nil, photo_urls = nil, id = SKIP, category = SKIP,
|
64
|
+
tags = SKIP, status = SKIP)
|
65
|
+
@id = id unless id == SKIP
|
66
|
+
@category = category unless category == SKIP
|
67
|
+
@name = name
|
68
|
+
@photo_urls = photo_urls
|
69
|
+
@tags = tags unless tags == SKIP
|
70
|
+
@status = status unless status == SKIP
|
71
|
+
end
|
72
|
+
|
73
|
+
# Creates an instance of the object from a hash.
|
74
|
+
def self.from_hash(hash)
|
75
|
+
return nil unless hash
|
76
|
+
|
77
|
+
# Extract variables from the hash.
|
78
|
+
name = hash.key?('name') ? hash['name'] : nil
|
79
|
+
photo_urls = hash.key?('photoUrls') ? hash['photoUrls'] : nil
|
80
|
+
id = hash.key?('id') ? hash['id'] : SKIP
|
81
|
+
category = Category2.from_hash(hash['category']) if hash['category']
|
82
|
+
# Parameter is an array, so we need to iterate through it
|
83
|
+
tags = nil
|
84
|
+
unless hash['tags'].nil?
|
85
|
+
tags = []
|
86
|
+
hash['tags'].each do |structure|
|
87
|
+
tags << (Tag.from_hash(structure) if structure)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
tags = SKIP unless hash.key?('tags')
|
92
|
+
status = hash.key?('status') ? hash['status'] : SKIP
|
93
|
+
|
94
|
+
# Create object from extracted values.
|
95
|
+
Pet.new(name,
|
96
|
+
photo_urls,
|
97
|
+
id,
|
98
|
+
category,
|
99
|
+
tags,
|
100
|
+
status)
|
101
|
+
end
|
102
|
+
|
103
|
+
# Provides a human-readable string representation of the object.
|
104
|
+
def to_s
|
105
|
+
class_name = self.class.name.split('::').last
|
106
|
+
"<#{class_name} id: #{@id}, category: #{@category}, name: #{@name}, photo_urls:"\
|
107
|
+
" #{@photo_urls}, tags: #{@tags}, status: #{@status}>"
|
108
|
+
end
|
109
|
+
|
110
|
+
# Provides a debugging-friendly string with detailed object information.
|
111
|
+
def inspect
|
112
|
+
class_name = self.class.name.split('::').last
|
113
|
+
"<#{class_name} id: #{@id.inspect}, category: #{@category.inspect}, name: #{@name.inspect},"\
|
114
|
+
" photo_urls: #{@photo_urls.inspect}, tags: #{@tags.inspect}, status: #{@status.inspect}>"
|
115
|
+
end
|
116
|
+
end
|
117
|
+
end
|