Commit eb626edd3fe2602321080e231cf748afc86d4700

Authored by Riyad Preukschas
1 parent 4d0af232

Replace all stat command line calls with ruby equivalents

lib/tasks/gitlab/check.rake
... ... @@ -502,7 +502,7 @@ namespace :gitlab do
502 502 return
503 503 end
504 504  
505   - if `stat --printf %a #{gitolite_config_path}` == "750"
  505 + if File.stat(gitolite_config_path).mode.to_s(8).ends_with?("750")
506 506 puts "yes".green
507 507 else
508 508 puts "no".red
... ... @@ -526,12 +526,11 @@ namespace :gitlab do
526 526 return
527 527 end
528 528  
529   - if `stat --printf %U #{gitolite_config_path}` == gitolite_ssh_user && # user
530   - `stat --printf %G #{gitolite_config_path}` == gitolite_ssh_user #group
  529 + if File.stat(gitolite_config_path).uid == uid_for(gitolite_ssh_user) &&
  530 + File.stat(gitolite_config_path).gid == gid_for(gitolite_ssh_user)
531 531 puts "yes".green
532 532 else
533 533 puts "no".red
534   - puts "#{gitolite_config_path} is not owned by #{gitolite_ssh_user}".red
535 534 try_fixing_it(
536 535 "sudo chown -R #{gitolite_ssh_user}:#{gitolite_ssh_user} #{gitolite_config_path}"
537 536 )
... ... @@ -722,7 +721,7 @@ namespace :gitlab do
722 721 return
723 722 end
724 723  
725   - if `stat --printf %a #{repo_base_path}` == "6770"
  724 + if File.stat(repo_base_path).mode.to_s(8).ends_with?("6770")
726 725 puts "yes".green
727 726 else
728 727 puts "no".red
... ... @@ -746,12 +745,11 @@ namespace :gitlab do
746 745 return
747 746 end
748 747  
749   - if `stat --printf %U #{repo_base_path}` == gitolite_ssh_user && # user
750   - `stat --printf %G #{repo_base_path}` == gitolite_ssh_user #group
  748 + if File.stat(repo_base_path).uid == uid_for(gitolite_ssh_user) &&
  749 + File.stat(repo_base_path).gid == gid_for(gitolite_ssh_user)
751 750 puts "yes".green
752 751 else
753 752 puts "no".red
754   - puts "#{repo_base_path} is not owned by #{gitolite_ssh_user}".red
755 753 try_fixing_it(
756 754 "sudo chown -R #{gitolite_ssh_user}:#{gitolite_ssh_user} #{repo_base_path}"
757 755 )
... ... @@ -832,7 +830,8 @@ namespace :gitlab do
832 830 next
833 831 end
834 832  
835   - if run_and_match("stat --format %N #{project_hook_file}", /#{hook_file}.+->.+#{gitolite_hook_file}/)
  833 + if File.lstat(project_hook_file).symlink? &&
  834 + File.realpath(project_hook_file) == File.realpath(gitolite_hook_file)
836 835 puts "ok".green
837 836 else
838 837 puts "not a link to Gitolite's hook".red
... ...
lib/tasks/gitlab/task_helpers.rake
... ... @@ -45,6 +45,15 @@ namespace :gitlab do
45 45 end
46 46 end
47 47  
  48 + def uid_for(user_name)
  49 + run("id -u #{user_name}").chomp.to_i
  50 + end
  51 +
  52 + def gid_for(group_name)
  53 + group_line = File.read("/etc/group").lines.select{|l| l.start_with?("#{group_name}:")}.first
  54 + group_line.split(":")[2].to_i
  55 + end
  56 +
48 57 def warn_user_is_not_gitlab
49 58 unless @warned_user_not_gitlab
50 59 current_user = run("whoami").chomp
... ...