summaryrefslogtreecommitdiff
path: root/lib/gitlab_reference_counter.rb
blob: dc08f428a9866d68987f0a2757d73a711cccac21 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
require_relative 'gitlab_init'
require_relative 'gitlab_net'

class GitlabReferenceCounter
  REFERENCE_EXPIRE_TIME = 600

  attr_reader :path, :key

  def initialize(path)
    @path = path
    @key = "git-receive-pack-reference-counter:#{path}"
  end

  def value
    (redis_client.get(key) || 0).to_i
  end

  def increase
    redis_cmd do
      redis_client.incr(key)
      redis_client.expire(key, REFERENCE_EXPIRE_TIME)
    end
  end

  def decrease
    redis_cmd do
      current_value = redis_client.decr(key)
      if current_value < 0
        $logger.warn "Reference counter for #{path} decreased when its value was less than 1. Reseting the counter."
        redis_client.del(key)
      end
    end
  end

  private

  def redis_client
    @redis_client ||= GitlabNet.new.redis_client
  end

  def redis_cmd
    begin
      yield
      true
    rescue => e
      message = "GitLab: An unexpected error occurred in writing to Redis: #{e}"
      $stderr.puts message
      $logger.error message
      false
    end
  end
end