As we reevaluate how to best support and maintain Staging Ref in the future, we encourage development teams using this environment to highlight their use cases in the following issue: https://gitlab.com/gitlab-com/gl-infra/software-delivery/framework/software-delivery-framework-issue-tracker/-/issues/36.

Skip to content
Snippets Groups Projects
Commit c110d110 authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets
Browse files

Fix and refactor redis command

parent 34d1be9b
No related branches found
No related tags found
No related merge requests found
Loading
Loading
@@ -26,4 +26,23 @@ class GitlabConfig
def redis
@config['redis'] ||= {}
end
def redis_namespace
redis['namespace'] || 'resque:gitlab'
end
# Build redis command to write update event in gitlab queue
def redis_command
if redis.empty?
# Default to old method of connecting to redis
# for users that haven't updated their configuration
"env -i redis-cli"
else
if redis.has_key?("socket")
"#{redis['bin']} -s #{redis['socket']}"
else
"#{redis['bin']} -h #{redis['host']} -p #{redis['port']}"
end
end
end
end
Loading
Loading
@@ -2,8 +2,10 @@ require_relative 'gitlab_init'
require_relative 'gitlab_net'
class GitlabUpdate
attr_reader :config
def initialize(repo_path, key_id, refname)
config = GitlabConfig.new
@config = GitlabConfig.new
@repo_path = repo_path.strip
@repo_name = repo_path
Loading
Loading
@@ -17,8 +19,6 @@ class GitlabUpdate
@oldrev = ARGV[1]
@newrev = ARGV[2]
@redis = config.redis
end
def exec
Loading
Loading
@@ -53,16 +53,7 @@ class GitlabUpdate
end
def update_redis
if !@redis.empty? && !@redis.has_key?("socket")
redis_command = "#{@redis['bin']} -h #{@redis['host']} -p #{@redis['port']}"
elsif !@redis.empty? && @redis.has_key?("socket")
redis_command = "#{@redis['bin']} -s #{@redis['socket']}"
else
# Default to old method of connecting to redis for users that haven't updated their configuration
redis_command = "env -i redis-cli"
end
command = "#{redis_command} rpush '#{@redis['namespace']}:queue:post_receive' '{\"class\":\"PostReceive\",\"args\":[\"#{@repo_path}\",\"#{@oldrev}\",\"#{@newrev}\",\"#{@refname}\",\"#{@key_id}\"]}' > /dev/null 2>&1"
command = "#{config.redis_command} rpush '#{config.redis_namespace}:queue:post_receive' '{\"class\":\"PostReceive\",\"args\":[\"#{@repo_path}\",\"#{@oldrev}\",\"#{@newrev}\",\"#{@refname}\",\"#{@key_id}\"]}' > /dev/null 2>&1"
system(command)
end
end
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment