Commit 0b3e9fd2189753ae4007b53c2c588fca741738ef
1 parent
e53b47b4
Exists in
master
and in
4 other branches
WebEditor: Check if save is possible
Showing
2 changed files
with
7 additions
and
6 deletions
 
Show diff stats
app/controllers/tree_controller.rb
| ... | ... | @@ -25,9 +25,8 @@ class TreeController < ProjectResourceController | 
| 25 | 25 | end | 
| 26 | 26 | |
| 27 | 27 | def update | 
| 28 | - last_commit = @project.commits(@ref, @path, 1).first.sha | |
| 29 | - file_editor = Gitlab::FileEditor.new(current_user, @project) | |
| 30 | - if file_editor.can_edit?(@path, last_commit) | |
| 28 | + file_editor = Gitlab::FileEditor.new(current_user, @project, @ref) | |
| 29 | + if file_editor.can_edit?(@path, params[:last_commit]) | |
| 31 | 30 | file_editor.update(@path, params[:content]) | 
| 32 | 31 | redirect_to project_tree_path(@project, @id), :notice => "File has been successfully changed" | 
| 33 | 32 | else | ... | ... | 
lib/gitlab/file_editor.rb
| 1 | 1 | module Gitlab | 
| 2 | 2 | class FileEditor | 
| 3 | 3 | |
| 4 | - attr_accessor :user, :project | |
| 4 | + attr_accessor :user, :project, :ref | |
| 5 | 5 | |
| 6 | - def initialize(user, project) | |
| 6 | + def initialize(user, project, ref) | |
| 7 | 7 | self.user = user | 
| 8 | 8 | self.project = project | 
| 9 | + self.ref = ref | |
| 9 | 10 | end | 
| 10 | 11 | |
| 11 | 12 | def can_edit?(path, last_commit) | 
| 12 | - true | |
| 13 | + current_last_commit = @project.commits(ref, path, 1).first.sha | |
| 14 | + last_commit == current_last_commit | |
| 13 | 15 | end | 
| 14 | 16 | |
| 15 | 17 | def update(path, content) | ... | ... |