diff options
| -rw-r--r-- | app/models/ci/runner.rb | 2 | ||||
| -rw-r--r-- | app/views/projects/runners/_form.html.haml | 6 | ||||
| -rw-r--r-- | app/views/projects/runners/show.html.haml | 3 | ||||
| -rw-r--r-- | lib/api/entities.rb | 1 | ||||
| -rw-r--r-- | lib/api/runners.rb | 2 | ||||
| -rw-r--r-- | lib/ci/api/runners.rb | 3 | 
6 files changed, 14 insertions, 3 deletions
| diff --git a/app/models/ci/runner.rb b/app/models/ci/runner.rb index 5c42c94e4dc..7a3dfaa4e61 100644 --- a/app/models/ci/runner.rb +++ b/app/models/ci/runner.rb @@ -4,7 +4,7 @@ module Ci      LAST_CONTACT_TIME = 5.minutes.ago      AVAILABLE_SCOPES = %w[specific shared active paused online] -    FORM_EDITABLE = %i[description tag_list active run_untagged] +    FORM_EDITABLE = %i[description tag_list active run_untagged locked]      has_many :builds, class_name: 'Ci::Build'      has_many :runner_projects, dependent: :destroy, class_name: 'Ci::RunnerProject' diff --git a/app/views/projects/runners/_form.html.haml b/app/views/projects/runners/_form.html.haml index d62f5c8f131..67839fafd28 100644 --- a/app/views/projects/runners/_form.html.haml +++ b/app/views/projects/runners/_form.html.haml @@ -13,6 +13,12 @@          = f.check_box :run_untagged          %span.light Indicates whether this runner can pick jobs without tags    .form-group +    = label :locked, 'Exclusive to this project', class: 'control-label' +    .col-sm-10 +      .checkbox +        = f.check_box :locked +        %span.light Indicates whether this runner can be enabled for other projects +  .form-group      = label_tag :token, class: 'control-label' do        Token      .col-sm-10 diff --git a/app/views/projects/runners/show.html.haml b/app/views/projects/runners/show.html.haml index f24e1b9144e..fc6424402ae 100644 --- a/app/views/projects/runners/show.html.haml +++ b/app/views/projects/runners/show.html.haml @@ -23,6 +23,9 @@        %td Can run untagged jobs        %td= @runner.run_untagged? ? 'Yes' : 'No'      %tr +      %td Exclusive to this project +      %td= @runner.locked? ? 'Yes' : 'No' +    %tr        %td Tags        %td          - @runner.tag_list.each do |tag| diff --git a/lib/api/entities.rb b/lib/api/entities.rb index 50d69274b2e..16eeca8c8ac 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -413,6 +413,7 @@ module API      class RunnerDetails < Runner        expose :tag_list        expose :run_untagged +      expose :locked        expose :version, :revision, :platform, :architecture        expose :contacted_at        expose :token, if: lambda { |runner, options| options[:current_user].is_admin? || !runner.is_shared? } diff --git a/lib/api/runners.rb b/lib/api/runners.rb index 4faba9dc87b..2d09b6193d9 100644 --- a/lib/api/runners.rb +++ b/lib/api/runners.rb @@ -49,7 +49,7 @@ module API          runner = get_runner(params[:id])          authenticate_update_runner!(runner) -        attrs = attributes_for_keys [:description, :active, :tag_list, :run_untagged] +        attrs = attributes_for_keys [:description, :active, :tag_list, :run_untagged, :locked]          if runner.update(attrs)            present runner, with: Entities::RunnerDetails, current_user: current_user          else diff --git a/lib/ci/api/runners.rb b/lib/ci/api/runners.rb index 0c41f22c7c5..b4b7261fa3b 100644 --- a/lib/ci/api/runners.rb +++ b/lib/ci/api/runners.rb @@ -29,7 +29,8 @@ module Ci            required_attributes! [:token]            attributes = { description: params[:description], -                         tag_list: params[:tag_list] } +                         tag_list: params[:tag_list], +                         locked: !!params[:locked] }            unless params[:run_untagged].nil?              attributes[:run_untagged] = params[:run_untagged] | 
