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 = {}) | ... | ... |