Sha256: d7373b808010050f2b7a26093fc970dc84ad0b721af9f2cf7d530f70669933cf

Contents?: true

Size: 1.44 KB

Versions: 20

Compression:

Stored size: 1.44 KB

Contents

# frozen_string_literal: true

# Copyright 2018 Aerospike, Inc.
#
# Portions may be licensed to Aerospike, Inc. under one or more contributor
# license agreements.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may not
# use this file except in compliance with the License. You may obtain a copy of
# the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations under
# the License.

module Aerospike
  class Node
    module Verify
      # Fetch and set partition generation. If partitions needs to be refreshed
      # this will be indicated in node.partition_changed
      module PartitionGeneration
        class << self
          def call(node, info_map)
            gen_string = info_map.fetch('partition-generation', nil)

            raise Aerospike::Exceptions::Parse.new('partition-generation is empty') if gen_string.to_s.empty?

            generation = gen_string.to_i

            node.partition_generation.update(generation)

            return unless node.partition_generation.changed?
            Aerospike.logger.info("Node #{node.name} partition generation #{generation} changed")
          end
        end
      end
    end
  end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
aerospike-2.22.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.21.1 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.21.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.20.1 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.20.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.19.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.18.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.17.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.16.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.15.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.14.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.13.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.12.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.11.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.10.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.9.1 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.9.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.8.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.7.0 lib/aerospike/node/verify/partition_generation.rb
aerospike-2.6.0 lib/aerospike/node/verify/partition_generation.rb