diff options
Diffstat (limited to 'lib/api')
| -rw-r--r-- | lib/api/commits.rb | 61 | ||||
| -rw-r--r-- | lib/api/entities.rb | 8 | 
2 files changed, 69 insertions, 0 deletions
| diff --git a/lib/api/commits.rb b/lib/api/commits.rb index 4a67313430a..6c5391b98c8 100644 --- a/lib/api/commits.rb +++ b/lib/api/commits.rb @@ -50,6 +50,67 @@ module API          not_found! "Commit" unless commit          commit.diffs        end + +      # Get a commit's comments +      # +      # Parameters: +      #   id (required) - The ID of a project +      #   sha (required) - The commit hash +      # Examples: +      #   GET /projects/:id/repository/commits/:sha/comments +      get ':id/repository/commits/:sha/comments' do +        sha = params[:sha] +        commit = user_project.repository.commit(sha) +        not_found! 'Commit' unless commit +        notes = Note.where(commit_id: commit.id) +        present paginate(notes), with: Entities::CommitNote +      end + +      # Post comment to commit +      # +      # Parameters: +      #   id (required) - The ID of a project +      #   sha (required) - The commit hash +      #   note (required) - Text of comment +      #   path (optional) - The file path +      #   line (optional) - The line number +      #   line_type (optional) - The type of line (new or old) +      # Examples: +      #   POST /projects/:id/repository/commits/:sha/comments +      post ':id/repository/commits/:sha/comments' do +        required_attributes! [:note] + +        sha = params[:sha] +        commit = user_project.repository.commit(sha) +        not_found! 'Commit' unless commit +        opts = { +          note: params[:note], +          noteable_type: 'Commit', +          commit_id: commit.id +        } + +        if params[:path] && params[:line] && params[:line_type] +          commit.diffs.each do |diff| +            next unless diff.new_path == params[:path] +            lines = Gitlab::Diff::Parser.new.parse(diff.diff.lines.to_a) + +            lines.each do |line| +              next unless line.new_pos == params[:line].to_i && line.type == params[:line_type] +              break opts[:line_code] = Gitlab::Diff::LineCode.generate(diff.new_path, line.new_pos, line.old_pos) +            end + +            break if opts[:line_code] +          end +        end + +        note = ::Notes::CreateService.new(user_project, current_user, opts).execute + +        if note.save +          present note, with: Entities::CommitNote +        else +          not_found! +        end +      end      end    end  end diff --git a/lib/api/entities.rb b/lib/api/entities.rb index ffa3e8a149e..c7b86ed3d76 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -158,6 +158,14 @@ module API        expose :author, using: Entities::UserBasic      end +    class CommitNote < Grape::Entity +      expose :note +      expose(:path) { |note| note.diff_file_name } +      expose(:line) { |note| note.diff_new_line } +      expose(:line_type) { |note| note.diff_line_type } +      expose :author, using: Entities::UserBasic +    end +      class Event < Grape::Entity        expose :title, :project_id, :action_name        expose :target_id, :target_type, :author_id | 
