about summary refs log tree commit diff
path: root/app/controllers/api/v1/timelines/base_controller.rb
diff options
context:
space:
mode:
authorMatt Jankowski <mjankowski@thoughtbot.com>2017-05-23 12:11:39 -0400
committerEugen Rochko <eugen@zeonfederated.com>2017-05-23 18:11:39 +0200
commit4289ed1d13b9c3b91663581c44635105c4bc0412 (patch)
tree5f8f006a47676ac15bb0374c21a2dea4a6a40910 /app/controllers/api/v1/timelines/base_controller.rb
parent256e3adc1d9508423aab8fcfb13745c9f85ff948 (diff)
Refactor of API timeline actions (#3263)
- Increase coverage to exercise all parts of each action
- Move into namespace to share common code
- Misc refactor of each action for smaller methods, simpler code
Diffstat (limited to 'app/controllers/api/v1/timelines/base_controller.rb')
-rw-r--r--app/controllers/api/v1/timelines/base_controller.rb30
1 files changed, 30 insertions, 0 deletions
diff --git a/app/controllers/api/v1/timelines/base_controller.rb b/app/controllers/api/v1/timelines/base_controller.rb
new file mode 100644
index 000000000..4eb29e74a
--- /dev/null
+++ b/app/controllers/api/v1/timelines/base_controller.rb
@@ -0,0 +1,30 @@
+# frozen_string_literal: true
+
+module Api::V1::Timelines
+  class BaseController < ApiController
+    respond_to :json
+    after_action :insert_pagination_headers, unless: -> { @statuses.empty? }
+
+    private
+
+    def cache_collection(raw)
+      super(raw, Status)
+    end
+
+    def pagination_params(core_params)
+      params.permit(:local, :limit).merge(core_params)
+    end
+
+    def insert_pagination_headers
+      set_pagination_headers(next_path, prev_path)
+    end
+
+    def next_path
+      raise 'Override in child controllers'
+    end
+
+    def prev_path
+      raise 'Override in child controllers'
+    end
+  end
+end