lib/comet/models/spanned_destination_location.rb
# frozen_string_literal: true # Copyright (c) 2020-2023 Comet Licensing Ltd. # Please see the LICENSE file for usage information. # # SPDX-License-Identifier: MIT require 'json' module Comet # SpannedDestinationLocation is a typed class wrapper around the underlying Comet Server API data structure. class SpannedDestinationLocation # A list of underlying destinations, that will be combined and presented as one. # @type [Array<Comet::DestinationLocation>] span_targets attr_accessor :span_targets # If true, this Spanned destination will use a consistent hashing scheme # to immediately find specific files on exactly one of the target destinations. # In the Static Slots mode, the span targets cannot be moved or merged, and # the files must always remain in their original location. # # If false, the Spanned destination system will search all targets to find # the requested file. This is slightly slower, but allows you to freely merge, # split, and reorder the underlying destination locations. # # The default option is false. # @type [Boolean] span_use_static_slots attr_accessor :span_use_static_slots # @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations attr_accessor :unknown_json_fields def initialize clear end def clear @span_targets = [] @unknown_json_fields = {} end # @param [String] json_string The complete object in JSON format def from_json(json_string) raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String from_hash(JSON.parse(json_string)) end # @param [Hash] obj The complete object as a Ruby hash def from_hash(obj) raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash obj.each do |k, v| case k when 'SpanTargets' if v.nil? @span_targets = [] else @span_targets = Array.new(v.length) v.each_with_index do |v1, i1| @span_targets[i1] = Comet::DestinationLocation.new @span_targets[i1].from_hash(v1) end end when 'SpanUseStaticSlots' @span_use_static_slots = v else @unknown_json_fields[k] = v end end end # @return [Hash] The complete object as a Ruby hash def to_hash ret = {} ret['SpanTargets'] = @span_targets ret['SpanUseStaticSlots'] = @span_use_static_slots @unknown_json_fields.each do |k, v| ret[k] = v end ret end # @return [Hash] The complete object as a Ruby hash def to_h to_hash end # @return [String] The complete object as a JSON string def to_json(options = {}) to_hash.to_json(options) end end end