Class: OCI::IdentityDomains::Models::PatchOp
- Inherits:
-
Object
- Object
- OCI::IdentityDomains::Models::PatchOp
- Defined in:
- lib/oci/identity_domains/models/patch_op.rb
Overview
See Section 3.5.2. HTTP PATCH is an OPTIONAL server function that enables clients to update one or more attributes of a SCIM resource using a sequence of operations to "add", "remove", or "replace" values. Clients may discover service provider support for PATCH by querying the service provider configuration. The general form of the SCIM patch request is based on JavaScript Object Notation (JSON) Patch [RFC6902]. One difference between SCIM patch and JSON patch is that SCIM servers do not support array indexing and do not support [RFC6902] operation types relating to array element manipulation such as "move". A patch request, regardless of the number of operations, SHALL be treated as atomic. If a single operation encounters an error condition, the original SCIM resource MUST be restored, and a failure status SHALL be returned.
Instance Attribute Summary collapse
-
#operations ⇒ Array<OCI::IdentityDomains::Models::Operations>
[Required] The body of an HTTP PATCH request MUST contain the attribute "Operations", whose value is an array of one or more patch operations.
-
#schemas ⇒ Array<String>
[Required] The schemas attribute is an array of Strings which allows introspection of the supported schema version for a SCIM representation as well any schema extensions supported by that representation.
Class Method Summary collapse
-
.attribute_map ⇒ Object
Attribute mapping from ruby-style variable name to JSON key.
-
.swagger_types ⇒ Object
Attribute type mapping.
Instance Method Summary collapse
-
#==(other) ⇒ Object
Checks equality by comparing each attribute.
-
#build_from_hash(attributes) ⇒ Object
Builds the object from hash.
- #eql?(other) ⇒ Boolean
-
#hash ⇒ Fixnum
Calculates hash code according to all attributes.
-
#initialize(attributes = {}) ⇒ PatchOp
constructor
Initializes the object.
-
#to_hash ⇒ Hash
Returns the object in the form of hash.
-
#to_s ⇒ String
Returns the string representation of the object.
Constructor Details
#initialize(attributes = {}) ⇒ PatchOp
Initializes the object
47 48 49 50 51 52 53 54 55 56 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 47 def initialize(attributes = {}) return unless attributes.is_a?(Hash) # convert string to symbol for hash key attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v } self.schemas = attributes[:'schemas'] if attributes[:'schemas'] self.operations = attributes[:'Operations'] if attributes[:'Operations'] end |
Instance Attribute Details
#operations ⇒ Array<OCI::IdentityDomains::Models::Operations>
[Required] The body of an HTTP PATCH request MUST contain the attribute "Operations", whose value is an array of one or more patch operations.
17 18 19 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 17 def operations @operations end |
#schemas ⇒ Array<String>
[Required] The schemas attribute is an array of Strings which allows introspection of the supported schema version for a SCIM representation as well any schema extensions supported by that representation. Each String value must be a unique URI. All representations of SCIM schema MUST include a non-zero value array with value(s) of the URIs supported by that representation. Duplicate values MUST NOT be included. Value order is not specified and MUST not impact behavior. REQUIRED.
13 14 15 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 13 def schemas @schemas end |
Class Method Details
.attribute_map ⇒ Object
Attribute mapping from ruby-style variable name to JSON key.
20 21 22 23 24 25 26 27 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 20 def self.attribute_map { # rubocop:disable Style/SymbolLiteral 'schemas': :'schemas', 'operations': :'Operations' # rubocop:enable Style/SymbolLiteral } end |
.swagger_types ⇒ Object
Attribute type mapping.
30 31 32 33 34 35 36 37 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 30 def self.swagger_types { # rubocop:disable Style/SymbolLiteral 'schemas': :'Array<String>', 'operations': :'Array<OCI::IdentityDomains::Models::Operations>' # rubocop:enable Style/SymbolLiteral } end |
Instance Method Details
#==(other) ⇒ Object
Checks equality by comparing each attribute.
65 66 67 68 69 70 71 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 65 def ==(other) return true if equal?(other) self.class == other.class && schemas == other.schemas && operations == other.operations end |
#build_from_hash(attributes) ⇒ Object
Builds the object from hash
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 96 def build_from_hash(attributes) return nil unless attributes.is_a?(Hash) self.class.swagger_types.each_pair do |key, type| if type =~ /^Array<(.*)>/i # check to ensure the input is an array given that the the attribute # is documented as an array but the input is not if attributes[self.class.attribute_map[key]].is_a?(Array) public_method("#{key}=").call( attributes[self.class.attribute_map[key]] .map { |v| OCI::Internal::Util.convert_to_type(Regexp.last_match(1), v) } ) end elsif !attributes[self.class.attribute_map[key]].nil? public_method("#{key}=").call( OCI::Internal::Util.convert_to_type(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 |
#eql?(other) ⇒ Boolean
76 77 78 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 76 def eql?(other) self == other end |
#hash ⇒ Fixnum
Calculates hash code according to all attributes.
85 86 87 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 85 def hash [schemas, operations].hash end |
#to_hash ⇒ Hash
Returns the object in the form of hash
129 130 131 132 133 134 135 136 137 138 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 129 def to_hash hash = {} self.class.attribute_map.each_pair do |attr, param| value = public_method(attr).call next if value.nil? && !instance_variable_defined?("@#{attr}") hash[param] = _to_hash(value) end hash end |
#to_s ⇒ String
Returns the string representation of the object
123 124 125 |
# File 'lib/oci/identity_domains/models/patch_op.rb', line 123 def to_s to_hash.to_s end |