diff options
Diffstat (limited to 'lib/api/entities.rb')
| -rw-r--r-- | lib/api/entities.rb | 61 | 
1 files changed, 37 insertions, 24 deletions
| diff --git a/lib/api/entities.rb b/lib/api/entities.rb index bd0c54a1b04..e13463ec66b 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -65,12 +65,12 @@ module API      end      class Hook < Grape::Entity -      expose :id, :url, :created_at, :push_events, :tag_push_events, :repository_update_events +      expose :id, :url, :created_at, :push_events, :tag_push_events, :merge_requests_events, :repository_update_events        expose :enable_ssl_verification      end      class ProjectHook < Hook -      expose :project_id, :issues_events, :merge_requests_events +      expose :project_id, :issues_events        expose :note_events, :pipeline_events, :wiki_page_events        expose :job_events      end @@ -205,22 +205,15 @@ module API        expose :build_artifacts_size, as: :job_artifacts_size      end -    class Member < UserBasic -      expose :access_level do |user, options| -        member = options[:member] || options[:source].members.find_by(user_id: user.id) -        member.access_level -      end -      expose :expires_at do |user, options| -        member = options[:member] || options[:source].members.find_by(user_id: user.id) -        member.expires_at -      end +    class Member < Grape::Entity +      expose :user, merge: true, using: UserBasic +      expose :access_level +      expose :expires_at      end -    class AccessRequester < UserBasic -      expose :requested_at do |user, options| -        access_requester = options[:access_requester] || options[:source].requesters.find_by(user_id: user.id) -        access_requester.requested_at -      end +    class AccessRequester < Grape::Entity +      expose :user, merge: true, using: UserBasic +      expose :requested_at      end      class Group < Grape::Entity @@ -278,7 +271,7 @@ module API      end      class CommitDetail < Commit -      expose :stats, using: Entities::CommitStats +      expose :stats, using: Entities::CommitStats, if: :stats        expose :status        expose :last_pipeline, using: 'API::Entities::PipelineBasic'      end @@ -507,7 +500,15 @@ module API        expose :work_in_progress?, as: :work_in_progress        expose :milestone, using: Entities::Milestone        expose :merge_when_pipeline_succeeds -      expose :merge_status + +      # Ideally we should deprecate `MergeRequest#merge_status` exposure and +      # use `MergeRequest#mergeable?` instead (boolean). +      # See https://gitlab.com/gitlab-org/gitlab-ce/issues/42344 for more +      # information. +      expose :merge_status do |merge_request| +        merge_request.check_if_can_be_merged +        merge_request.merge_status +      end        expose :diff_head_sha, as: :sha        expose :merge_commit_sha        expose :user_notes_count @@ -554,13 +555,18 @@ module API      end      class SSHKey < Grape::Entity -      expose :id, :title, :key, :created_at, :can_push +      expose :id, :title, :key, :created_at      end      class SSHKeyWithUser < SSHKey        expose :user, using: Entities::UserPublic      end +    class DeployKeysProject < Grape::Entity +      expose :deploy_key, merge: true, using: Entities::SSHKey +      expose :can_push +    end +      class GPGKey < Grape::Entity        expose :id, :key, :created_at      end @@ -714,10 +720,7 @@ module API        expose :job_events        # Expose serialized properties        expose :properties do |service, options| -        field_names = service.fields -          .select { |field| options[:include_passwords] || field[:type] != 'password' } -          .map { |field| field[:name] } -        service.properties.slice(*field_names) +        service.properties.slice(*service.api_field_names)        end      end @@ -918,7 +921,7 @@ module API      class Trigger < Grape::Entity        expose :id        expose :token, :description -      expose :created_at, :updated_at, :deleted_at, :last_used +      expose :created_at, :updated_at, :last_used        expose :owner, using: Entities::UserBasic      end @@ -1155,5 +1158,15 @@ module API          pages_domain        end      end + +    class Application < Grape::Entity +      expose :uid, as: :application_id +      expose :redirect_uri, as: :callback_url +    end + +    # Use with care, this exposes the secret +    class ApplicationWithSecret < Application +      expose :secret +    end    end  end | 
