gitlab-org--gitlab-foss/app/controllers/notes_controller.rb

47 lines
975 B
Ruby
Raw Normal View History

class NotesController < ProjectResourceController
2011-10-08 17:36:38 -04:00
# Authorize
2011-12-15 16:57:46 -05:00
before_filter :authorize_read_note!
before_filter :authorize_write_note!, only: [:create]
2011-10-08 17:36:38 -04:00
respond_to :js
2012-02-24 02:16:06 -05:00
def index
2012-02-27 13:29:27 -05:00
notes
if params[:target_type] == "merge_request"
@mixed_targets = true
@main_target_type = params[:target_type].camelize
end
2012-02-27 13:29:27 -05:00
respond_with(@notes)
2012-02-24 02:16:06 -05:00
end
2011-10-08 17:36:38 -04:00
def create
2012-07-31 01:32:49 -04:00
@note = Notes::CreateContext.new(project, current_user, params).execute
2011-10-08 17:36:38 -04:00
respond_to do |format|
format.html {redirect_to :back}
format.js
2011-10-08 17:36:38 -04:00
end
end
def destroy
@note = @project.notes.find(params[:id])
2011-10-17 06:39:03 -04:00
return access_denied! unless can?(current_user, :admin_note, @note)
2011-10-08 17:36:38 -04:00
@note.destroy
respond_to do |format|
format.js { render nothing: true }
2011-10-08 17:36:38 -04:00
end
end
2012-08-08 05:25:24 -04:00
def preview
render text: view_context.markdown(params[:note])
2012-08-08 05:25:24 -04:00
end
protected
2012-02-24 02:16:06 -05:00
2012-02-27 13:29:27 -05:00
def notes
2012-07-31 01:32:49 -04:00
@notes = Notes::LoadContext.new(project, current_user, params).execute
2012-02-24 02:16:06 -05:00
end
2011-10-08 17:36:38 -04:00
end