Commit 6b36f806 authored by Max Woolf's avatar Max Woolf

Merge branch 'pb-expose-job-permissions-graphql' into 'master'

Expose user permissions on JobType

See merge request gitlab-org/gitlab!60427
parents eab3c92b 8c9c6042
...@@ -8,6 +8,8 @@ module Types ...@@ -8,6 +8,8 @@ module Types
connection_type_class(Types::CountableConnectionType) connection_type_class(Types::CountableConnectionType)
expose_permissions Types::PermissionTypes::Ci::Job
field :id, ::Types::GlobalIDType[::CommitStatus].as('JobID'), null: true, field :id, ::Types::GlobalIDType[::CommitStatus].as('JobID'), null: true,
description: 'ID of the job.' description: 'ID of the job.'
field :pipeline, Types::Ci::PipelineType, null: true, field :pipeline, Types::Ci::PipelineType, null: true,
......
# frozen_string_literal: true
module Types
module PermissionTypes
module Ci
class Job < BasePermissionType
graphql_name 'JobPermissions'
abilities :read_job_artifacts, :read_build
ability_field :update_build, calls_gitaly: true
end
end
end
end
---
title: Expose user permissions on JobType
merge_request: 60427
author:
type: added
...@@ -7242,6 +7242,7 @@ Represents the total number of issues and their weights for a particular day. ...@@ -7242,6 +7242,7 @@ Represents the total number of issues and their weights for a particular day.
| <a id="cijobstatus"></a>`status` | [`CiJobStatus`](#cijobstatus) | Status of the job. | | <a id="cijobstatus"></a>`status` | [`CiJobStatus`](#cijobstatus) | Status of the job. |
| <a id="cijobtags"></a>`tags` | [`[String!]`](#string) | Tags for the current job. | | <a id="cijobtags"></a>`tags` | [`[String!]`](#string) | Tags for the current job. |
| <a id="cijobtriggered"></a>`triggered` | [`Boolean`](#boolean) | Whether the job was triggered. | | <a id="cijobtriggered"></a>`triggered` | [`Boolean`](#boolean) | Whether the job was triggered. |
| <a id="cijobuserpermissions"></a>`userPermissions` | [`JobPermissions!`](#jobpermissions) | Permissions for the current user on the resource. |
### `CiJobArtifact` ### `CiJobArtifact`
...@@ -9455,6 +9456,16 @@ four standard [pagination arguments](#connection-pagination-arguments): ...@@ -9455,6 +9456,16 @@ four standard [pagination arguments](#connection-pagination-arguments):
| <a id="jirauserjiradisplayname"></a>`jiraDisplayName` | [`String!`](#string) | Display name of the Jira user. | | <a id="jirauserjiradisplayname"></a>`jiraDisplayName` | [`String!`](#string) | Display name of the Jira user. |
| <a id="jirauserjiraemail"></a>`jiraEmail` | [`String`](#string) | Email of the Jira user, returned only for users with public emails. | | <a id="jirauserjiraemail"></a>`jiraEmail` | [`String`](#string) | Email of the Jira user, returned only for users with public emails. |
### `JobPermissions`
#### Fields
| Name | Type | Description |
| ---- | ---- | ----------- |
| <a id="jobpermissionsreadbuild"></a>`readBuild` | [`Boolean!`](#boolean) | Indicates the user can perform `read_build` on this resource. |
| <a id="jobpermissionsreadjobartifacts"></a>`readJobArtifacts` | [`Boolean!`](#boolean) | Indicates the user can perform `read_job_artifacts` on this resource. |
| <a id="jobpermissionsupdatebuild"></a>`updateBuild` | [`Boolean!`](#boolean) | Indicates the user can perform `update_build` on this resource. |
### `Label` ### `Label`
#### Fields #### Fields
......
...@@ -5,6 +5,7 @@ require 'spec_helper' ...@@ -5,6 +5,7 @@ require 'spec_helper'
RSpec.describe Types::Ci::JobType do RSpec.describe Types::Ci::JobType do
specify { expect(described_class.graphql_name).to eq('CiJob') } specify { expect(described_class.graphql_name).to eq('CiJob') }
specify { expect(described_class).to require_graphql_authorizations(:read_commit_status) } specify { expect(described_class).to require_graphql_authorizations(:read_commit_status) }
specify { expect(described_class).to expose_permissions_using(Types::PermissionTypes::Ci::Job) }
it 'exposes the expected fields' do it 'exposes the expected fields' do
expected_fields = %i[ expected_fields = %i[
...@@ -38,6 +39,7 @@ RSpec.describe Types::Ci::JobType do ...@@ -38,6 +39,7 @@ RSpec.describe Types::Ci::JobType do
status status
tags tags
triggered triggered
userPermissions
] ]
expect(described_class).to have_graphql_fields(*expected_fields) expect(described_class).to have_graphql_fields(*expected_fields)
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Types::PermissionTypes::Ci::Job do
it 'has expected permission fields' do
expected_permissions = [
:read_job_artifacts, :read_build, :update_build
]
expect(described_class).to have_graphql_fields(expected_permissions).only
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment