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 |