Commit cbc96f12e46c887d9bddf6a0ab574af6cf98a585
Exists in
theme-brasil-digital-from-staging
and in
9 other branches
Merge branch 'noosfero_grape_api' into rails3_api
Conflicts: Rakefile
Showing
2 changed files
with
14 additions
and
0 deletions
Show diff stats
lib/api/api.rb
| ... | ... | @@ -19,5 +19,15 @@ module API |
| 19 | 19 | mount V1::Categories |
| 20 | 20 | mount Session |
| 21 | 21 | |
| 22 | + # hook point which allow plugins to add Grape::API extensions to API::API | |
| 23 | + #finds for plugins which has api mount points classes defined (the class should extends Grape::API) | |
| 24 | + @plugins = Noosfero::Plugin.all.map { |p| p.constantize } | |
| 25 | + @plugins.each do |klass| | |
| 26 | + if klass.public_methods.include? 'api_mount_points' | |
| 27 | + klass.api_mount_points.each do |mount_class| | |
| 28 | + mount mount_class if mount_class && ( mount_class < Grape::API ) | |
| 29 | + end | |
| 30 | + end | |
| 31 | + end | |
| 22 | 32 | end |
| 23 | 33 | end | ... | ... |
lib/noosfero/plugin.rb
| ... | ... | @@ -149,6 +149,10 @@ class Noosfero::Plugin |
| 149 | 149 | def has_admin_url? |
| 150 | 150 | File.exists?(File.join(root_path, 'controllers', "#{name.underscore}_admin_controller.rb")) |
| 151 | 151 | end |
| 152 | + | |
| 153 | + # -> define grape class used to map resource api provided by the plugin | |
| 154 | + def api_mount_points | |
| 155 | + end | |
| 152 | 156 | end |
| 153 | 157 | |
| 154 | 158 | def expanded_template(file_path, locals = {}) | ... | ... |