class ChangesetsController < ApplicationController
include UserMethods
+ include PaginationMethods
layout "site"
before_action :authorize_web
before_action :set_locale
- before_action -> { check_database_readable(:need_api => true) }, :only => [:index, :feed, :show]
+ before_action -> { check_database_readable(:need_api => true) }
before_action :require_oauth, :only => :show
- before_action :check_database_writable, :only => [:subscribe, :unsubscribe]
authorize_resource
##
# list non-empty changesets in reverse chronological order
def index
- param! :max_id, Integer, :min => 1
+ param! :before, Integer, :min => 1
+ param! :after, Integer, :min => 1
- @params = params.permit(:display_name, :bbox, :friends, :nearby, :max_id, :list)
+ @params = params.permit(:display_name, :bbox, :friends, :nearby, :before, :after, :list)
- if request.format == :atom && @params[:max_id]
- redirect_to url_for(@params.merge(:max_id => nil)), :status => :moved_permanently
+ if request.format == :atom && (@params[:before] || @params[:after])
+ redirect_to url_for(@params.merge(:before => nil, :after => nil)), :status => :moved_permanently
return
end
elsif @params[:bbox]
changesets = conditions_bbox(changesets, BoundingBox.from_bbox_params(params))
elsif @params[:friends] && current_user
- changesets = changesets.where(:user => current_user.friends.identifiable)
+ changesets = changesets.where(:user => current_user.followings.identifiable)
elsif @params[:nearby] && current_user
changesets = changesets.where(:user => current_user.nearby)
end
- changesets = changesets.where(:changesets => { :id => ..@params[:max_id] }) if @params[:max_id]
-
- @changesets = changesets.order("changesets.id DESC").limit(20).preload(:user, :changeset_tags, :comments)
+ @changesets, @newer_changesets_id, @older_changesets_id = get_page_items(changesets, :includes => [:user, :changeset_tags, :comments])
render :action => :index, :layout => false
end
render :template => "browse/not_found", :status => :not_found, :layout => map_layout
end
- ##
- # subscribe to a changeset
- def subscribe
- @changeset = Changeset.find(params[:id])
-
- if request.post?
- @changeset.subscribe(current_user) unless @changeset.subscribed?(current_user)
-
- redirect_to changeset_path(@changeset)
- end
- rescue ActiveRecord::RecordNotFound
- render :action => "no_such_entry", :status => :not_found
- end
-
- ##
- # unsubscribe from a changeset
- def unsubscribe
- @changeset = Changeset.find(params[:id])
-
- if request.post?
- @changeset.unsubscribe(current_user)
-
- redirect_to changeset_path(@changeset)
- end
- rescue ActiveRecord::RecordNotFound
- render :action => "no_such_entry", :status => :not_found
- end
-
private
#------------------------------------------------------------