lib/clever-ruby/models/course.rb in commonlit-clever-ruby-2.1.6.beta1 vs lib/clever-ruby/models/course.rb in commonlit-clever-ruby-2.1.6.beta2
- old
+ new
@@ -1,72 +1,86 @@
=begin
-#Data API
+#Clever API
-#Serves the Clever Data API
+#The Clever API
OpenAPI spec version: 2.1.0
Generated by: https://github.com/swagger-api/swagger-codegen.git
-Swagger Codegen version: 2.4.37
-
+Swagger Codegen version: 3.0.51
=end
require 'date'
module Clever
class Course
+ attr_accessor :district
+
attr_accessor :id
attr_accessor :name
attr_accessor :number
- attr_accessor :district
-
# Attribute mapping from ruby-style variable name to JSON key.
def self.attribute_map
{
+ :'district' => :'district',
:'id' => :'id',
:'name' => :'name',
- :'number' => :'number',
- :'district' => :'district'
+ :'number' => :'number'
}
end
# Attribute type mapping.
- def self.swagger_types
+ def self.openapi_types
{
- :'id' => :'String',
- :'name' => :'String',
- :'number' => :'String',
- :'district' => :'String'
+ :'district' => :'Object',
+ :'id' => :'Object',
+ :'name' => :'Object',
+ :'number' => :'Object'
}
end
+ # List of attributes with nullable: true
+ def self.openapi_nullable
+ Set.new([
+ :'name',
+ :'number'
+ ])
+ end
+
# Initializes the object
# @param [Hash] attributes Model attributes in the form of hash
def initialize(attributes = {})
- return unless attributes.is_a?(Hash)
+ if (!attributes.is_a?(Hash))
+ fail ArgumentError, "The input argument (attributes) must be a hash in `Clever::Course` initialize method"
+ end
- # convert string to symbol for hash key
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
+ # 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 `Clever::Course`. 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.has_key?(:'id')
+ if attributes.key?(:'district')
+ self.district = attributes[:'district']
+ end
+
+ if attributes.key?(:'id')
self.id = attributes[:'id']
end
- if attributes.has_key?(:'name')
+ if attributes.key?(:'name')
self.name = attributes[:'name']
end
- if attributes.has_key?(:'number')
+ if attributes.key?(:'number')
self.number = attributes[:'number']
end
-
- if attributes.has_key?(:'district')
- self.district = attributes[:'district']
- 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
@@ -83,43 +97,52 @@
# Checks equality by comparing each attribute.
# @param [Object] Object to be compared
def ==(o)
return true if self.equal?(o)
self.class == o.class &&
+ district == o.district &&
id == o.id &&
name == o.name &&
- number == o.number &&
- district == o.district
+ number == o.number
end
# @see the `==` method
# @param [Object] Object to be compared
def eql?(o)
self == o
end
# Calculates hash code according to all attributes.
- # @return [Fixnum] Hash code
+ # @return [Integer] Hash code
def hash
- [id, name, number, district].hash
+ [district, id, name, number].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.swagger_types.each_pair do |key, type|
+ 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
+ elsif attributes[self.class.attribute_map[key]].nil? && self.class.openapi_nullable.include?(key)
+ self.send("#{key}=", nil)
+ end
end
self
end
@@ -137,11 +160,11 @@
value.to_s
when :Integer
value.to_i
when :Float
value.to_f
- when :BOOLEAN
+ when :Boolean
if value.to_s =~ /\A(true|t|yes|y|1)\z/i
true
else
false
end
@@ -158,12 +181,11 @@
value.each do |k, v|
hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
end
end
else # model
- temp_model = Clever.const_get(type).new
- temp_model.build_from_hash(value)
+ Clever.const_get(type).build_from_hash(value)
end
end
# Returns the string representation of the object
# @return [String] String presentation of the object
@@ -181,11 +203,15 @@
# @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)
- next if value.nil?
+ 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
@@ -203,9 +229,7 @@
elsif value.respond_to? :to_hash
value.to_hash
else
value
end
- end
-
- end
+ end end
end