notebook/app/controllers/admin_controller.rb
2021-05-02 16:24:36 -07:00

100 lines
2.4 KiB
Ruby

class AdminController < ApplicationController
layout 'admin'
layout 'application', only: [:unsubscribe, :perform_unsubscribe]
before_action :authenticate_user!
before_action :require_admin_access, unless: -> { Rails.env.development? }
def dashboard
@reports = EndOfDayAnalyticsReport.order('day DESC').limit(90)
end
def content_type
type_whitelist = Rails.application.config.content_types[:all].map(&:name)
type = params[:type]
return unless type_whitelist.include?(type)
@content_type = type.constantize
@relation_name = type.downcase.pluralize.to_sym
end
def universes
end
def characters
end
def locations
end
def items
end
def images
@images = ImageUpload.offset(params[:page].to_i * 500).limit(500)
.includes(:content) #.where.not(audited: true)
.order('id DESC')
end
def masquerade
masqueree = User.find_by(id: params[:user_id])
sign_in masqueree
redirect_to root_path
end
def unsubscribe
end
def reported_shares
reported_share_ids = ContentPageShareReport.where(approved_at: nil).pluck(:content_page_share_id)
@feed = ContentPageShare.where(id: reported_share_ids)
.order('created_at DESC')
.includes([:content_page, :user, :share_comments])
.limit(100)
end
def churn
end
def hate
@posts = Thredded::PrivatePost.order('id DESC').limit(params.fetch(:limit, 500)).includes(:postable)
@list = params[:matchlist]
end
def spam
@posts = Thredded::PrivatePost
.where('content ILIKE ?', "%http%")
.order('id DESC')
.limit(params.fetch(:limit, 500))
.includes(:postable)
# @posts = Thredded::PrivatePost.where('content ILIKE ?', "%http%").order('id DESC').limit(5).includes(:postable)
end
def perform_unsubscribe
emails = params[:emails].split(/[\r|\n]+/)
@users = User.where(email: emails)
@users.each do |user|
if user.on_premium_plan?
SubscriptionService.cancel_all_existing_subscriptions(user)
UnsubscribedMailer.unsubscribed(user).deliver_now! if Rails.env.production?
end
end
@users.update_all(selected_billing_plan_id: 1)
end
def promos
@codes = PageUnlockPromoCode.all.includes(:promotions)
end
private
def require_admin_access
unless user_signed_in? && current_user.site_administrator
redirect_to root_path, notice: "You don't have permission to view that!"
end
end
end