|
|
require 'inifile'
|
|
require 'inifile'
|
|
|
|
|
require 'timeout'
|
|
|
class Gitosis
|
|
class Gitosis
|
|
|
|
class AccessDenied < StandardError; end
|
|
|
|
|
|
|
|
def pull
|
|
def pull
|
|
|
# create tmp dir
|
|
# create tmp dir
|
| ... | @@ -20,6 +21,7 @@ class Gitosis |
... | @@ -20,6 +21,7 @@ class Gitosis |
|
|
end
|
|
end
|
|
|
|
|
|
|
|
def configure
|
|
def configure
|
|
|
|
status = Timeout::timeout(5) {
|
|
|
File.open(File.join(Dir.tmpdir,"gitme-gitosis.lock"), "w+") do |f|
|
|
File.open(File.join(Dir.tmpdir,"gitme-gitosis.lock"), "w+") do |f|
|
|
|
f.flock(File::LOCK_EX)
|
|
f.flock(File::LOCK_EX)
|
|
|
|
|
|
| ... | @@ -29,6 +31,9 @@ class Gitosis |
... | @@ -29,6 +31,9 @@ class Gitosis |
|
|
|
|
|
|
|
f.flock(File::LOCK_UN)
|
|
f.flock(File::LOCK_UN)
|
|
|
end
|
|
end
|
|
|
|
}
|
|
|
|
rescue Exception => ex
|
|
|
|
raise Gitosis::AccessDenied.new("gitosis timeout")
|
|
|
end
|
|
end
|
|
|
|
|
|
|
|
def destroy_project(project)
|
|
def destroy_project(project)
|
| ... | @@ -61,5 +66,4 @@ class Gitosis |
... | @@ -61,5 +66,4 @@ class Gitosis |
|
|
|
|
|
|
|
conf.write
|
|
conf.write
|
|
|
end
|
|
end
|
|
|
|
|
|
|
|
end |
|
end |