get '/stats/?' do expires 14400, :public, :must_revalidate # 4 hours @stats = { total_sites: Site.count, total_unbanned_sites: Site.where(is_banned: false).count, total_banned_sites: Site.where(is_banned: true).count, total_nsfw_sites: Site.where(is_nsfw: true).count, total_unbanned_nsfw_sites: Site.where(is_banned: false, is_nsfw: true).count, total_banned_nsfw_sites: Site.where(is_banned: true, is_nsfw: true).count } # Start with the date of the first created site start = Site.select(:created_at). exclude(created_at: nil). order(:created_at). first[:created_at].to_date runner = start monthly_stats = [] now = Date.today until runner.to_time > now.next_month.to_time monthly_stats.push( date: runner, sites_created: Site.where(created_at: runner..runner.next_month).count, total_from_start: Site.where(created_at: start..runner.next_month).count, supporters: Site.where(created_at: start..runner.next_month).exclude(stripe_customer_id: nil).count, ) runner = runner.next_month end @stats[:monthly_stats] = monthly_stats customers = Stripe::Customer.all limit: 100000 @stats[:total_recurring_revenue] = 0.0 subscriptions = [] @stats[:cancelled_subscriptions] = 0 customers.each do |customer| sub = {created_at: Time.at(customer.created)} if customer[:subscriptions][:data].empty? @stats[:cancelled_subscriptions] += 1 next end next if customer[:subscriptions][:data].first[:plan][:amount] == 0 sub[:status] = 'active' plan = customer[:subscriptions][:data].first[:plan] sub[:amount] = (plan[:amount] / 100.0).round(2) if(plan[:interval] == 'year') sub[:amount] = (sub[:amount] / 12).round(2) end @stats[:total_recurring_revenue] += sub[:amount] subscriptions.push sub end @stats[:subscriptions] = subscriptions erb :'stats' end