summaryrefslogtreecommitdiff
path: root/lib/api
diff options
context:
space:
mode:
Diffstat (limited to 'lib/api')
-rw-r--r--lib/api/api.rb1
-rw-r--r--lib/api/award_emoji.rb97
-rw-r--r--lib/api/entities.rb8
-rw-r--r--lib/api/issues.rb2
4 files changed, 107 insertions, 1 deletions
diff --git a/lib/api/api.rb b/lib/api/api.rb
index 51ddd0dbfc4..7944c80cf7a 100644
--- a/lib/api/api.rb
+++ b/lib/api/api.rb
@@ -36,6 +36,7 @@ module API
mount ::API::Session
mount ::API::MergeRequests
mount ::API::Notes
+ mount ::API::AwardEmoji
mount ::API::Internal
mount ::API::SystemHooks
mount ::API::ProjectSnippets
diff --git a/lib/api/award_emoji.rb b/lib/api/award_emoji.rb
new file mode 100644
index 00000000000..26b30d30163
--- /dev/null
+++ b/lib/api/award_emoji.rb
@@ -0,0 +1,97 @@
+module API
+ class AwardEmoji < Grape::API
+ before { authenticate! }
+
+ AWARDABLES = [Issue, MergeRequest]
+
+ resource :projects do
+ AWARDABLES.each do |awardable_type|
+ awardable_string = awardable_type.to_s.underscore.pluralize
+ awardable_id_string = "#{awardable_type.to_s.underscore}_id"
+
+ # Get a list of project +awardable+ award emoji
+ #
+ # Parameters:
+ # id (required) - The ID of a project
+ # awardable_id (required) - The ID of an issue or MR
+ # Example Request:
+ # GET /projects/:id/issues/:awardable_id/award_emoji
+ get ":id/#{awardable_string}/:#{awardable_id_string}/award_emoji" do
+ awardable = user_project.send(awardable_string.to_sym).find(params[awardable_id_string.to_sym])
+
+ if can?(current_user, awardable_read_ability_name(awardable), awardable)
+ awards = paginate(awardable.award_emoji)
+ present awards, with: Entities::AwardEmoji
+ else
+ not_found!("Award Emoji")
+ end
+ end
+
+ # Get a specific award emoji
+ #
+ # Parameters:
+ # id (required) - The ID of a project
+ # awardable_id (required) - The ID of an issue or MR
+ # award_id (required) - The ID of the award
+ # Example Request:
+ # GET /projects/:id/issues/:awardable_id/award_emoji/:award_id
+ get ":id/#{awardable_string}/:#{awardable_id_string}/award_emoji/:award_id" do
+ awardable = user_project.send(awardable_string.to_sym).find(params[awardable_id_string.to_sym])
+
+ if can?(current_user, awardable_read_ability_name(awardable), awardable)
+ present awardable.award_emoji.find(params[:award_id]), with: Entities::AwardEmoji
+ else
+ not_found!("Award Emoji")
+ end
+ end
+
+ # Award a new Emoji
+ #
+ # Parameters:
+ # id (required) - The ID of a project
+ # noteable_id (required) - The ID of an issue or snippet
+ # name (required) - The name of a award_emoji (without colons)
+ # Example Request:
+ # POST /projects/:id/issues/:noteable_id/notes
+ # POST /projects/:id/snippets/:noteable_id/notes
+ post ":id/#{awardable_string}/:#{awardable_id_string}/award_emoji" do
+ required_attributes! [:name]
+
+ awardable = user_project.send(awardable_string.to_sym).find(params[awardable_id_string.to_sym])
+ not_found!('Award Emoji') unless can?(current_user, awardable_read_ability_name(awardable), awardable)
+
+ award = awardable.award_emoji.new(name: params[:name], user: current_user)
+
+ if award.save
+ present award, with: Entities::AwardEmoji
+ else
+ not_found!("Award Emoji #{award.errors.messages}")
+ end
+ end
+
+ # Delete a +awardables+ award emoji
+ #
+ # Parameters:
+ # id (required) - The ID of a project
+ # awardable_id (required) - The ID of an issue or MR
+ # award_emoji_id (required) - The ID of an award emoji
+ # Example Request:
+ # DELETE /projects/:id/issues/:noteable_id/notes/:note_id
+ delete ":id/#{awardable_string}/:#{awardable_id_string}/award_emoji/:award_id" do
+ awardable = user_project.send(awardable_string.to_sym).find(params[awardable_id_string.to_sym])
+ award = awardable.award_emoji.find(params[:award_id])
+
+ unauthorized! unless award.user == current_user || current_user.admin?
+
+ award.destroy
+ present award, with: Entities::AwardEmoji
+ end
+ end
+ end
+ helpers do
+ def awardable_read_ability_name(awardable)
+ "read_#{awardable.class.to_s.underscore.downcase}".to_sym
+ end
+ end
+ end
+end
diff --git a/lib/api/entities.rb b/lib/api/entities.rb
index cc29c7ef428..2e397643ed1 100644
--- a/lib/api/entities.rb
+++ b/lib/api/entities.rb
@@ -225,6 +225,14 @@ module API
expose(:downvote?) { |note| false }
end
+ class AwardEmoji < Grape::Entity
+ expose :id
+ expose :name
+ expose :user, using: Entities::UserBasic
+ expose :created_at, :updated_at
+ expose :awardable_id, :awardable_type
+ end
+
class MRNote < Grape::Entity
expose :note
expose :author, using: Entities::UserBasic
diff --git a/lib/api/issues.rb b/lib/api/issues.rb
index 4c43257c48a..aa0b9ca3957 100644
--- a/lib/api/issues.rb
+++ b/lib/api/issues.rb
@@ -1,6 +1,6 @@
module API
# Issues API
- class Issues < Grape::API
+ class Issues < Grape::API
before { authenticate! }
helpers ::Gitlab::AkismetHelper