WebEditor: base implementation
This commit is contained in:
parent
0b3e9fd218
commit
42bdfd021b
4 changed files with 55 additions and 10 deletions
|
@ -9,14 +9,48 @@ module Gitlab
|
|||
self.ref = ref
|
||||
end
|
||||
|
||||
def update(path, content, commit_message, last_commit)
|
||||
return false unless can_edit?(path, last_commit)
|
||||
|
||||
Grit::Git.with_timeout(10.seconds) do
|
||||
lock_file = Rails.root.join("tmp", "#{project.path}.lock")
|
||||
|
||||
File.open(lock_file, "w+") do |f|
|
||||
f.flock(File::LOCK_EX)
|
||||
|
||||
unless project.satellite.exists?
|
||||
raise "Satellite doesn't exist"
|
||||
end
|
||||
|
||||
project.satellite.clear
|
||||
|
||||
Dir.chdir(project.satellite.path) do
|
||||
r = Grit::Repo.new('.')
|
||||
r.git.sh "git reset --hard"
|
||||
r.git.sh "git fetch origin"
|
||||
r.git.sh "git config user.name \"#{user.name}\""
|
||||
r.git.sh "git config user.email \"#{user.email}\""
|
||||
r.git.sh "git checkout -b #{ref} origin/#{ref}"
|
||||
File.open(path, 'w'){|f| f.write(content)}
|
||||
r.git.sh "git add ."
|
||||
r.git.sh "git commit -am '#{commit_message}'"
|
||||
output = r.git.sh "git push origin #{ref}"
|
||||
if output =~ /reject/
|
||||
return false
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
true
|
||||
|
||||
end
|
||||
|
||||
protected
|
||||
def can_edit?(path, last_commit)
|
||||
current_last_commit = @project.commits(ref, path, 1).first.sha
|
||||
last_commit == current_last_commit
|
||||
end
|
||||
|
||||
def update(path, content)
|
||||
true
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
|
|
|
@ -28,13 +28,13 @@ module Gitlab
|
|||
|
||||
def process
|
||||
Grit::Git.with_timeout(30.seconds) do
|
||||
lock_file = Rails.root.join("tmp", "merge_repo_#{project.path}.lock")
|
||||
lock_file = Rails.root.join("tmp", "#{project.path}.lock")
|
||||
|
||||
File.open(lock_file, "w+") do |f|
|
||||
f.flock(File::LOCK_EX)
|
||||
|
||||
unless project.satellite.exists?
|
||||
raise "You should run: rake gitlab:app:enable_automerge"
|
||||
raise "Satellite doesn't exist"
|
||||
end
|
||||
|
||||
project.satellite.clear
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue