FEATURE: Send anonymized usage statistics to Discourse if Discourse Hub can't reach the site
This commit is contained in:
parent
fc3c34b78f
commit
f3cd5f61c5
|
@ -34,10 +34,9 @@ class SiteController < ApplicationController
|
|||
title: SiteSetting.title,
|
||||
description: SiteSetting.site_description
|
||||
}
|
||||
results[:mobile_logo_url] = SiteSetting.mobile_logo_url if SiteSetting.mobile_logo_url.present?
|
||||
|
||||
if SiteSetting.mobile_logo_url.present?
|
||||
results[:mobile_logo_url] = SiteSetting.mobile_logo_url
|
||||
end
|
||||
DiscourseHub.stats_fetched_at = Time.zone.now if request.user_agent == "Discourse Hub"
|
||||
|
||||
# this info is always available cause it can be scraped from a 404 page
|
||||
render json: results
|
||||
|
|
|
@ -1310,7 +1310,6 @@ uncategorized:
|
|||
|
||||
share_anonymized_statistics: true
|
||||
|
||||
|
||||
user_preferences:
|
||||
default_email_digest_frequency:
|
||||
enum: 'DigestEmailSiteSetting'
|
||||
|
|
|
@ -3,19 +3,27 @@ require_dependency 'version'
|
|||
|
||||
module DiscourseHub
|
||||
|
||||
STATS_FETCHED_AT_KEY = "stats_fetched_at"
|
||||
|
||||
def self.version_check_payload
|
||||
{
|
||||
installed_version: Discourse::VERSION::STRING
|
||||
}.merge!( Discourse.git_branch == "unknown" ? {} : {branch: Discourse.git_branch})
|
||||
default_payload = { installed_version: Discourse::VERSION::STRING }.merge!(Discourse.git_branch == "unknown" ? {} : {branch: Discourse.git_branch})
|
||||
default_payload.merge!(get_payload)
|
||||
end
|
||||
|
||||
def self.discourse_version_check
|
||||
get('/version_check', version_check_payload)
|
||||
end
|
||||
|
||||
def self.stats_fetched_at=(time_with_zone)
|
||||
$redis.set STATS_FETCHED_AT_KEY, time_with_zone.to_i
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def self.get_payload
|
||||
SiteSetting.share_anonymized_statistics && stats_fetched_at < 7.days.ago ? About.fetch_cached_stats.symbolize_keys : {}
|
||||
end
|
||||
|
||||
def self.get(rel_url, params={})
|
||||
singular_action :get, rel_url, params
|
||||
end
|
||||
|
@ -56,4 +64,9 @@ module DiscourseHub
|
|||
Discourse.base_url
|
||||
end
|
||||
|
||||
def self.stats_fetched_at
|
||||
t = $redis.get(STATS_FETCHED_AT_KEY)
|
||||
t ? Time.zone.at(t.to_i) : 1.year.ago
|
||||
end
|
||||
|
||||
end
|
||||
|
|
|
@ -2,11 +2,73 @@ require 'rails_helper'
|
|||
require_dependency 'discourse_hub'
|
||||
|
||||
describe DiscourseHub do
|
||||
describe '#discourse_version_check' do
|
||||
describe '.discourse_version_check' do
|
||||
it 'should return just return the json that the hub returns' do
|
||||
hub_response = {'success' => 'OK', 'latest_version' => '0.8.1', 'critical_updates' => false}
|
||||
RestClient.stubs(:get).returns( hub_response.to_json )
|
||||
expect(DiscourseHub.discourse_version_check).to eq(hub_response)
|
||||
end
|
||||
end
|
||||
|
||||
describe '.version_check_payload' do
|
||||
|
||||
describe 'when Discourse Hub has not fetched stats since past 7 days' do
|
||||
it 'should include stats' do
|
||||
DiscourseHub.stats_fetched_at = 8.days.ago
|
||||
json = JSON.parse(DiscourseHub.version_check_payload.to_json)
|
||||
|
||||
expect(json["topic_count"]).to be_present
|
||||
expect(json["post_count"]).to be_present
|
||||
expect(json["user_count"]).to be_present
|
||||
expect(json["topics_7_days"]).to be_present
|
||||
expect(json["topics_30_days"]).to be_present
|
||||
expect(json["posts_7_days"]).to be_present
|
||||
expect(json["posts_30_days"]).to be_present
|
||||
expect(json["users_7_days"]).to be_present
|
||||
expect(json["users_30_days"]).to be_present
|
||||
expect(json["active_users_7_days"]).to be_present
|
||||
expect(json["active_users_30_days"]).to be_present
|
||||
expect(json["like_count"]).to be_present
|
||||
expect(json["likes_7_days"]).to be_present
|
||||
expect(json["likes_30_days"]).to be_present
|
||||
expect(json["installed_version"]).to be_present
|
||||
expect(json["branch"]).to be_present
|
||||
end
|
||||
end
|
||||
|
||||
describe 'when Discourse Hub has fetched stats in past 7 days' do
|
||||
it 'should not include stats' do
|
||||
DiscourseHub.stats_fetched_at = 2.days.ago
|
||||
json = JSON.parse(DiscourseHub.version_check_payload.to_json)
|
||||
|
||||
expect(json["topic_count"]).not_to be_present
|
||||
expect(json["post_count"]).not_to be_present
|
||||
expect(json["user_count"]).not_to be_present
|
||||
expect(json["like_count"]).not_to be_present
|
||||
expect(json["likes_7_days"]).not_to be_present
|
||||
expect(json["likes_30_days"]).not_to be_present
|
||||
expect(json["installed_version"]).to be_present
|
||||
expect(json["branch"]).to be_present
|
||||
end
|
||||
end
|
||||
|
||||
describe 'when send_anonymize_stats is disabled' do
|
||||
describe 'when Discourse Hub has not fetched stats for the past year' do
|
||||
it 'should not include stats' do
|
||||
DiscourseHub.stats_fetched_at = 1.year.ago
|
||||
SiteSetting.share_anonymized_statistics = false
|
||||
json = JSON.parse(DiscourseHub.version_check_payload.to_json)
|
||||
|
||||
expect(json["topic_count"]).not_to be_present
|
||||
expect(json["post_count"]).not_to be_present
|
||||
expect(json["user_count"]).not_to be_present
|
||||
expect(json["like_count"]).not_to be_present
|
||||
expect(json["likes_7_days"]).not_to be_present
|
||||
expect(json["likes_30_days"]).not_to be_present
|
||||
expect(json["installed_version"]).to be_present
|
||||
expect(json["branch"]).to be_present
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue