diff options
| author | Mark Fletcher <mark@gitlab.com> | 2018-04-21 19:02:21 +0100 | 
|---|---|---|
| committer | Mark Fletcher <mark@gitlab.com> | 2018-04-23 08:22:16 +0100 | 
| commit | 5716167775280e5a830443ccb095e2879814f783 (patch) | |
| tree | 65ad93877ae801d5fee7476726a30633d0e0785a /lib/api/projects.rb | |
| parent | c212908aad9b32352653dfe9ca966f148c8dfc1a (diff) | |
| download | gitlab-ce-5716167775280e5a830443ccb095e2879814f783.tar.gz | |
Fix project creation for user endpoint bug
In this endpoint the `jobs_enabled` parameter must be
translated to `builds_enabled` before being passed to
the `Projects::CreateService`.
Diffstat (limited to 'lib/api/projects.rb')
| -rw-r--r-- | lib/api/projects.rb | 10 | 
1 files changed, 8 insertions, 2 deletions
| diff --git a/lib/api/projects.rb b/lib/api/projects.rb index 51b3b0459f3..8871792060b 100644 --- a/lib/api/projects.rb +++ b/lib/api/projects.rb @@ -74,6 +74,11 @@ module API          present options[:with].prepare_relation(projects, options), options        end + +      def translate_params_for_compatibility(params) +        params[:builds_enabled] = params.delete(:jobs_enabled) if params.key?(:jobs_enabled) +        params +      end      end      resource :users, requirements: API::PROJECT_ENDPOINT_REQUIREMENTS do @@ -123,7 +128,7 @@ module API        end        post do          attrs = declared_params(include_missing: false) -        attrs[:builds_enabled] = attrs.delete(:jobs_enabled) if attrs.key?(:jobs_enabled) +        attrs = translate_params_for_compatibility(attrs)          project = ::Projects::CreateService.new(current_user, attrs).execute          if project.saved? @@ -155,6 +160,7 @@ module API          not_found!('User') unless user          attrs = declared_params(include_missing: false) +        attrs = translate_params_for_compatibility(attrs)          project = ::Projects::CreateService.new(user, attrs).execute          if project.saved? @@ -276,7 +282,7 @@ module API          authorize! :rename_project, user_project if attrs[:name].present?          authorize! :change_visibility_level, user_project if attrs[:visibility].present? -        attrs[:builds_enabled] = attrs.delete(:jobs_enabled) if attrs.key?(:jobs_enabled) +        attrs = translate_params_for_compatibility(attrs)          result = ::Projects::UpdateService.new(user_project, current_user, attrs).execute | 
