diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2015-07-07 10:57:41 +0000 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2015-07-07 10:57:41 +0000 |
commit | f76092c06dd1f3b40a6d32ad3d62ea09bf32d1a0 (patch) | |
tree | 31b0ead46e605f7d3c4ede969f0c1c933b6cc471 /lib/api/settings.rb | |
parent | 41e6b8d8d8bb183e9313219aa65ea6a786c76133 (diff) | |
parent | 603ceea21a0144ff1900106efa0c17e759eeceef (diff) | |
download | gitlab-ce-f76092c06dd1f3b40a6d32ad3d62ea09bf32d1a0.tar.gz |
Merge branch 'settings-via-api' into 'master'
API to set application settings for admin
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
See merge request !934
Diffstat (limited to 'lib/api/settings.rb')
-rw-r--r-- | lib/api/settings.rb | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/lib/api/settings.rb b/lib/api/settings.rb new file mode 100644 index 00000000000..c885fcd7ea3 --- /dev/null +++ b/lib/api/settings.rb @@ -0,0 +1,35 @@ +module API + class Settings < Grape::API + before { authenticated_as_admin! } + + helpers do + def current_settings + @current_setting ||= + (ApplicationSetting.current || ApplicationSetting.create_from_defaults) + end + end + + # Get current applicaiton settings + # + # Example Request: + # GET /application/settings + get "application/settings" do + present current_settings, with: Entities::ApplicationSetting + end + + # Modify applicaiton settings + # + # Example Request: + # PUT /application/settings + put "application/settings" do + attributes = current_settings.attributes.keys - ["id"] + attrs = attributes_for_keys(attributes) + + if current_settings.update_attributes(attrs) + present current_settings, with: Entities::ApplicationSetting + else + render_validation_error!(current_settings) + end + end + end +end |