diff options
| author | Tomasz Maczukin <tomasz@maczukin.pl> | 2016-02-10 12:26:56 +0100 | 
|---|---|---|
| committer | Tomasz Maczukin <tomasz@maczukin.pl> | 2016-02-19 13:18:48 +0100 | 
| commit | 24eed1c5c1cbbad7081625ad98d06d151933f583 (patch) | |
| tree | 271efe36978ae032409c7e6b63f434201adbd400 | |
| parent | 36e7ffea5de84102a7306faf679cdb5b81920f19 (diff) | |
| download | gitlab-ce-24eed1c5c1cbbad7081625ad98d06d151933f583.tar.gz | |
Modify runner projects selecting method in runners API
| -rw-r--r-- | lib/api/entities.rb | 6 | ||||
| -rw-r--r-- | lib/api/runners.rb | 6 | 
2 files changed, 4 insertions, 8 deletions
| diff --git a/lib/api/entities.rb b/lib/api/entities.rb index a8c00542d35..3f1594994c9 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -387,12 +387,12 @@ module API        expose :tag_list        expose :version, :revision, :platform, :architecture        expose :contacted_at, as: :last_contact -      expose :token, if: lambda { |runner, options| options[:user_is_admin] || !runner.is_shared? } +      expose :token, if: lambda { |runner, options| options[:current_user].is_admin? || !runner.is_shared? }        expose :projects, with: Entities::RunnerProjectDetails do |runner, options| -        if options[:user_is_admin] +        if options[:current_user].is_admin?            runner.projects          else -          runner.projects.where(id: options[:available_projects_ids]) +          options[:current_user].authorized_projects.where(id: runner.projects)          end        end      end diff --git a/lib/api/runners.rb b/lib/api/runners.rb index e807d2eccf0..03803ede9fc 100644 --- a/lib/api/runners.rb +++ b/lib/api/runners.rb @@ -33,11 +33,7 @@ module API          runner = get_runner(params[:id])          authenticate_show_runner!(runner) -        available_projects_ids = runner.projects.select{ |p| can?(current_user, :read_project, p) } -                                       .map(&:id) unless current_user.is_admin? - -        present runner, with: Entities::RunnerDetails, user_is_admin: current_user.is_admin?, -                        available_projects_ids: available_projects_ids +        present runner, with: Entities::RunnerDetails, current_user: current_user        end        # Update runner's details | 
