add: rank not include deleted project
This commit is contained in:
parent
2273b4817e
commit
46405e704a
|
@ -22,7 +22,7 @@ class Organizations::OrganizationsController < Organizations::BaseController
|
||||||
@can_create_project = @organization.can_create_project?(current_user.id)
|
@can_create_project = @organization.can_create_project?(current_user.id)
|
||||||
@is_admin = can_edit_org?
|
@is_admin = can_edit_org?
|
||||||
@is_member = @organization.is_member?(current_user.id)
|
@is_member = @organization.is_member?(current_user.id)
|
||||||
Cache::V2::OwnerCommonService.new(@organization.login, @organization.mail).read
|
Cache::V2::OwnerCommonService.new(@organization.id).read
|
||||||
end
|
end
|
||||||
|
|
||||||
def create
|
def create
|
||||||
|
|
|
@ -2,9 +2,10 @@ class ProjectRankController < ApplicationController
|
||||||
# 根据时间获取热门项目
|
# 根据时间获取热门项目
|
||||||
def index
|
def index
|
||||||
$redis_cache.zunionstore("recent-days-project-rank", get_timeable_key_names)
|
$redis_cache.zunionstore("recent-days-project-rank", get_timeable_key_names)
|
||||||
|
$redis_cache.zrem("recent-days-project-rank", $redis_cache.smembers("v2-project-rank-deleted"))
|
||||||
@project_rank = $redis_cache.zrevrange("recent-days-project-rank", 0, 4, withscores: true)
|
@project_rank = $redis_cache.zrevrange("recent-days-project-rank", 0, 4, withscores: true)
|
||||||
rescue Exception => e
|
rescue Exception => e
|
||||||
@project_rack = []
|
@project_rank = []
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -191,7 +191,7 @@ class ProjectsController < ApplicationController
|
||||||
|
|
||||||
def simple
|
def simple
|
||||||
# 为了缓存活跃项目的基本信息,后续删除
|
# 为了缓存活跃项目的基本信息,后续删除
|
||||||
Cache::V2::ProjectCommonService.new(@project.id).reset
|
Cache::V2::ProjectCommonService.new(@project.id).read
|
||||||
json_response(@project, current_user)
|
json_response(@project, current_user)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -52,7 +52,7 @@ class UsersController < ApplicationController
|
||||||
@projects_mirrior_count = user_projects.mirror.size
|
@projects_mirrior_count = user_projects.mirror.size
|
||||||
@projects_sync_mirrior_count = user_projects.sync_mirror.size
|
@projects_sync_mirrior_count = user_projects.sync_mirror.size
|
||||||
# 为了缓存活跃用户的基本信息,后续删除
|
# 为了缓存活跃用户的基本信息,后续删除
|
||||||
Cache::V2::OwnerCommonService.new(@user.login, @user.mail).read
|
Cache::V2::OwnerCommonService.new(@user.id).read
|
||||||
end
|
end
|
||||||
|
|
||||||
def watch_users
|
def watch_users
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
class CacheAsyncClearJob < ApplicationJob
|
||||||
|
queue_as :cache
|
||||||
|
|
||||||
|
def perform(type, id=nil)
|
||||||
|
case type
|
||||||
|
when "project_common_service"
|
||||||
|
Cache::V2::ProjectCommonService.new(id).clear
|
||||||
|
when "owner_common_service"
|
||||||
|
Cache::V2::OwnnerCommonService.new(id).clear
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -7,6 +7,8 @@ class CacheAsyncResetJob < ApplicationJob
|
||||||
Cache::V2::PlatformStatisticService.new.reset
|
Cache::V2::PlatformStatisticService.new.reset
|
||||||
when "project_common_service"
|
when "project_common_service"
|
||||||
Cache::V2::ProjectCommonService.new(id).reset
|
Cache::V2::ProjectCommonService.new(id).reset
|
||||||
|
when "owner_common_service"
|
||||||
|
Cache::V2::OwnnerCommonService.new(id).reset
|
||||||
when "user_statistic_service"
|
when "user_statistic_service"
|
||||||
Cache::V2::UserStatisticService.new(id).reset
|
Cache::V2::UserStatisticService.new(id).reset
|
||||||
end
|
end
|
||||||
|
|
|
@ -7,6 +7,8 @@ class CacheAsyncSetJob < ApplicationJob
|
||||||
Cache::V2::PlatformStatisticService.new(params).call
|
Cache::V2::PlatformStatisticService.new(params).call
|
||||||
when "project_common_service"
|
when "project_common_service"
|
||||||
Cache::V2::ProjectCommonService.new(id, params).call
|
Cache::V2::ProjectCommonService.new(id, params).call
|
||||||
|
when "owner_common_service"
|
||||||
|
Cache::V2::OwnnerCommonService.new(id, params).call
|
||||||
when "user_statistic_service"
|
when "user_statistic_service"
|
||||||
Cache::V2::UserStatisticService.new(id, params).call
|
Cache::V2::UserStatisticService.new(id, params).call
|
||||||
end
|
end
|
||||||
|
|
|
@ -84,7 +84,7 @@ class Organization < Owner
|
||||||
after_save :reset_cache_data
|
after_save :reset_cache_data
|
||||||
|
|
||||||
def reset_cache_data
|
def reset_cache_data
|
||||||
Cache::V2::OwnerCommonService.new(self.login, self.mail).reset
|
Cache::V2::OwnerCommonService.new(self.id).reset
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.build(name, nickname, gitea_token=nil)
|
def self.build(name, nickname, gitea_token=nil)
|
||||||
|
|
|
@ -128,7 +128,7 @@ class Project < ApplicationRecord
|
||||||
has_many :pinned_projects, dependent: :destroy
|
has_many :pinned_projects, dependent: :destroy
|
||||||
has_many :has_pinned_users, through: :pinned_projects, source: :user
|
has_many :has_pinned_users, through: :pinned_projects, source: :user
|
||||||
has_many :webhooks, class_name: "Gitea::Webhook", primary_key: :gpid, foreign_key: :repo_id
|
has_many :webhooks, class_name: "Gitea::Webhook", primary_key: :gpid, foreign_key: :repo_id
|
||||||
after_create :init_project_common, :incre_user_statistic, :incre_platform_statistic
|
after_create :incre_user_statistic, :incre_platform_statistic
|
||||||
after_save :check_project_members, :reset_cache_data
|
after_save :check_project_members, :reset_cache_data
|
||||||
before_save :set_invite_code, :reset_unmember_followed, :set_recommend_and_is_pinned
|
before_save :set_invite_code, :reset_unmember_followed, :set_recommend_and_is_pinned
|
||||||
before_destroy :decre_project_common
|
before_destroy :decre_project_common
|
||||||
|
@ -169,12 +169,8 @@ class Project < ApplicationRecord
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def init_project_common
|
|
||||||
CacheAsyncResetJob.perform_later("project_common_service", self.id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def decre_project_common
|
def decre_project_common
|
||||||
$redis_cache.del("v2-project-common:#{self.id}")
|
CacheAsyncClearJob.perform_later('project_common_service', self.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
def incre_user_statistic
|
def incre_user_statistic
|
||||||
|
|
|
@ -207,7 +207,7 @@ class User < Owner
|
||||||
validate :validate_password_length
|
validate :validate_password_length
|
||||||
|
|
||||||
def reset_cache_data
|
def reset_cache_data
|
||||||
Cache::V2::OwnerCommonService.new(self.login, self.mail).reset
|
Cache::V2::OwnerCommonService.new(self.id).reset
|
||||||
end
|
end
|
||||||
|
|
||||||
# 用户参与的所有项目
|
# 用户参与的所有项目
|
||||||
|
|
|
@ -1,12 +1,13 @@
|
||||||
class Cache::V2::OwnerCommonService < ApplicationService
|
class Cache::V2::OwnerCommonService < ApplicationService
|
||||||
include AvatarHelper
|
include AvatarHelper
|
||||||
attr_reader :owner_id, :login, :name, :avatar_url, :email
|
attr_reader :owner_id, :name
|
||||||
attr_accessor :owner
|
attr_accessor :owner, :login, :email
|
||||||
|
|
||||||
def initialize(login, email, params={})
|
def initialize(owner_id, params={})
|
||||||
@login = login
|
@owner_id = owner_id
|
||||||
@email = email
|
@email = params[:email]
|
||||||
@name = params[:name]
|
@name = params[:name]
|
||||||
|
@avatar_url = params[:avatar_url]
|
||||||
end
|
end
|
||||||
|
|
||||||
def read
|
def read
|
||||||
|
@ -14,7 +15,6 @@ class Cache::V2::OwnerCommonService < ApplicationService
|
||||||
end
|
end
|
||||||
|
|
||||||
def call
|
def call
|
||||||
load_owner
|
|
||||||
set_owner_common
|
set_owner_common
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -22,9 +22,15 @@ class Cache::V2::OwnerCommonService < ApplicationService
|
||||||
reset_owner_common
|
reset_owner_common
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def clear
|
||||||
|
clear_owner_common
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def load_owner
|
def load_owner
|
||||||
@owner = Owner.find_by(login: @login)
|
@owner = Owner.find_by_id @owner_id
|
||||||
|
@login = @owner&.login
|
||||||
|
@email ||= @owner&.mail
|
||||||
end
|
end
|
||||||
|
|
||||||
def owner_common_key
|
def owner_common_key
|
||||||
|
@ -32,35 +38,47 @@ class Cache::V2::OwnerCommonService < ApplicationService
|
||||||
end
|
end
|
||||||
|
|
||||||
def owner_common_key_by_id
|
def owner_common_key_by_id
|
||||||
"v2-owner-common:#{@owner.id}"
|
"v2-owner-common:#{@owner&.id}"
|
||||||
end
|
end
|
||||||
|
|
||||||
def owner_common
|
def owner_common
|
||||||
$redis_cache.hgetall(owner_common_key).blank? ? reset_owner_common : $redis_cache.hgetall(owner_common_key)
|
result = $redis_cache.hgetall(owner_common_key_by_id)
|
||||||
|
result.blank? ? reset_owner_common : result
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_owner_common
|
def set_owner_common
|
||||||
if $redis_cache.hgetall(owner_common_key).blank?
|
if $redis_cache.hgetall(owner_common_key_by_id).blank?
|
||||||
reset_owner_common
|
reset_owner_common
|
||||||
return
|
return
|
||||||
end
|
else
|
||||||
if @name.present?
|
load_owner
|
||||||
if $redis_cache.hget(owner_common_key, "name").nil?
|
return if @owner.nil?
|
||||||
reset_owner_name
|
if @name.present?
|
||||||
else
|
if $redis_cache.hget(owner_common_key, "name").nil?
|
||||||
$redis_cache.hset(owner_common_key, "name", @name)
|
reset_owner_name
|
||||||
$redis_cache.hset(owner_common_key, "avatar_url", url_to_avatar(owner))
|
else
|
||||||
|
$redis_cache.hset(owner_common_key, "name", @name)
|
||||||
$redis_cache.hset(owner_common_key_by_id, "name", @name)
|
$redis_cache.hset(owner_common_key_by_id, "name", @name)
|
||||||
$redis_cache.hset(owner_common_key_by_id, "avatar_url", url_to_avatar(owner))
|
end
|
||||||
end
|
end
|
||||||
end
|
if @email.present?
|
||||||
if @email.present?
|
if $redis_cache.hget(owner_common_key, "email").nil?
|
||||||
if $redis_cache.hget(owner_common_key, "email").nil?
|
reset_owner_email
|
||||||
reset_owner_email
|
else
|
||||||
else
|
# 更改邮箱这里把旧数据删除
|
||||||
$redis_cache.hset(owner_common_key, "email", @email)
|
$redis_cache.del("v2-owner-common:#{@login}-*")
|
||||||
$redis_cache.hset(owner_common_key_by_id, "email", @email)
|
$redis_cache.hset(owner_common_key, "email", @email)
|
||||||
|
$redis_cache.hset(owner_common_key_by_id, "email", @email)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if @avatar_url.present?
|
||||||
|
if $redis_cache.hget(owner_common_key, "avatar_url").nil?
|
||||||
|
reset_owner_avatar_url
|
||||||
|
else
|
||||||
|
$redis_cache.hset(owner_common_key, "avatar_url", @avatar_url)
|
||||||
|
$redis_cache.hset(owner_common_key_by_id, "avatar_url", @avatar_url)
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -88,20 +106,30 @@ class Cache::V2::OwnerCommonService < ApplicationService
|
||||||
|
|
||||||
def reset_owner_name
|
def reset_owner_name
|
||||||
$redis_cache.hset(owner_common_key, "name", owner&.real_name)
|
$redis_cache.hset(owner_common_key, "name", owner&.real_name)
|
||||||
$redis_cache.hset(owner_common_key, "avatar_url", url_to_avatar(owner))
|
|
||||||
$redis_cache.hset(owner_common_key_by_id, "name", owner&.real_name)
|
$redis_cache.hset(owner_common_key_by_id, "name", owner&.real_name)
|
||||||
|
end
|
||||||
|
|
||||||
|
def reset_owner_avatar_url
|
||||||
|
$redis_cache.hset(owner_common_key, "avatar_url", url_to_avatar(owner))
|
||||||
$redis_cache.hset(owner_common_key_by_id, "avatar_url", url_to_avatar(owner))
|
$redis_cache.hset(owner_common_key_by_id, "avatar_url", url_to_avatar(owner))
|
||||||
end
|
end
|
||||||
|
|
||||||
def reset_owner_common
|
def reset_owner_common
|
||||||
load_owner
|
clear_owner_common
|
||||||
$redis_cache.del(owner_common_key)
|
|
||||||
reset_owner_id
|
reset_owner_id
|
||||||
reset_owner_type
|
reset_owner_type
|
||||||
reset_owner_login
|
reset_owner_login
|
||||||
reset_owner_email
|
reset_owner_email
|
||||||
reset_owner_name
|
reset_owner_name
|
||||||
|
reset_owner_avatar_url
|
||||||
|
|
||||||
$redis_cache.hgetall(owner_common_key)
|
$redis_cache.hgetall(owner_common_key)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def clear_owner_common
|
||||||
|
load_owner
|
||||||
|
return if @owner.nil?
|
||||||
|
$redis_cache.del(owner_common_key)
|
||||||
|
$redis_cache.del(owner_common_key_by_id)
|
||||||
|
end
|
||||||
end
|
end
|
|
@ -64,7 +64,9 @@ class Cache::V2::PlatformStatisticService < ApplicationService
|
||||||
end
|
end
|
||||||
|
|
||||||
def platform_statistic
|
def platform_statistic
|
||||||
$redis_cache.hgetall(platform_statistic_key).blank? ? reset_platform_statistic : $redis_cache.hgetall(platform_statistic_key)
|
result = $redis_cache.hgetall(platform_statistic_key)
|
||||||
|
|
||||||
|
result.blank? ? reset_platform_statistic : result
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_platform_statistic
|
def set_platform_statistic
|
||||||
|
|
|
@ -28,6 +28,10 @@ class Cache::V2::ProjectCommonService < ApplicationService
|
||||||
reset_project_common
|
reset_project_common
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def clear
|
||||||
|
clear_project_common
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def load_project
|
def load_project
|
||||||
@project = Project.find_by_id(project_id)
|
@project = Project.find_by_id(project_id)
|
||||||
|
@ -78,109 +82,75 @@ class Cache::V2::ProjectCommonService < ApplicationService
|
||||||
end
|
end
|
||||||
|
|
||||||
def project_common
|
def project_common
|
||||||
$redis_cache.hgetall(project_common_key).blank? ? reset_project_common : $redis_cache.hgetall(project_common_key)
|
result = $redis_cache.hgetall(project_common_key)
|
||||||
|
result.blank? ? reset_project_common : result
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_project_common
|
def set_project_common
|
||||||
if $redis_cache.hgetall(project_common_key).blank?
|
if $redis_cache.hgetall(project_common_key).blank?
|
||||||
reset_project_common
|
reset_project_common
|
||||||
return
|
return
|
||||||
end
|
else
|
||||||
load_project
|
load_project
|
||||||
return unless @project.is_full_public
|
return unless @project.is_full_public
|
||||||
if @owner_id.present?
|
if @owner_id.present?
|
||||||
if $redis_cache.hget(project_common_key, owner_id_key).nil?
|
if $redis_cache.hget(project_common_key, owner_id_key).nil?
|
||||||
reset_project_owner_id
|
reset_project_owner_id
|
||||||
else
|
else
|
||||||
$redis_cache.hset(project_common_key, owner_id_key, @owner_id)
|
$redis_cache.hset(project_common_key, owner_id_key, @owner_id)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
if @name.present?
|
||||||
if @name.present?
|
if $redis_cache.hget(project_common_key, name_key).nil?
|
||||||
if $redis_cache.hget(project_common_key, name_key).nil?
|
reset_project_name
|
||||||
reset_project_name
|
else
|
||||||
else
|
$redis_cache.hset(project_common_key, name_key, @name)
|
||||||
$redis_cache.hset(project_common_key, name_key, @name)
|
end
|
||||||
end
|
end
|
||||||
end
|
if @identifier.present?
|
||||||
if @identifier.present?
|
if $redis_cache.hget(project_common_key, identifier_key).nil?
|
||||||
if $redis_cache.hget(project_common_key, identifier_key).nil?
|
reset_project_identifier
|
||||||
reset_project_identifier
|
else
|
||||||
else
|
$redis_cache.hset(project_common_key, identifier_key, @identifier)
|
||||||
$redis_cache.hset(project_common_key, identifier_key, @identifier)
|
end
|
||||||
end
|
end
|
||||||
end
|
if @description.present?
|
||||||
if @description.present?
|
if $redis_cache.hget(project_common_key, description_key).nil?
|
||||||
if $redis_cache.hget(project_common_key, description_key).nil?
|
reset_project_description
|
||||||
reset_project_description
|
else
|
||||||
else
|
$redis_cache.hset(project_common_key, description_key, @description)
|
||||||
$redis_cache.hset(project_common_key, description_key, @description)
|
end
|
||||||
end
|
end
|
||||||
end
|
if @visits.present?
|
||||||
if @visits.present?
|
|
||||||
if $redis_cache.hget(project_common_key, visits_key).nil?
|
|
||||||
reset_project_visits
|
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {visits: @visits})
|
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {visits: @visits})
|
|
||||||
else
|
|
||||||
puts project_common_key
|
|
||||||
puts visits_key
|
|
||||||
puts @visits
|
|
||||||
$redis_cache.hincrby(project_common_key, visits_key, @visits.to_s)
|
$redis_cache.hincrby(project_common_key, visits_key, @visits.to_s)
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {visits: @visits})
|
Cache::V2::ProjectRankService.call(@project_id, {visits: @visits})
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {visits: @visits})
|
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {visits: @visits})
|
||||||
end
|
end
|
||||||
end
|
if @watchers.present?
|
||||||
if @watchers.present?
|
|
||||||
if $redis_cache.hget(project_common_key, watchers_key).nil?
|
|
||||||
reset_project_watchers
|
|
||||||
else
|
|
||||||
$redis_cache.hincrby(project_common_key, watchers_key, @watchers)
|
$redis_cache.hincrby(project_common_key, watchers_key, @watchers)
|
||||||
end
|
end
|
||||||
end
|
if @praises.present?
|
||||||
if @praises.present?
|
|
||||||
if $redis_cache.hget(project_common_key, praises_key).nil?
|
|
||||||
reset_project_praises
|
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {praises: @praises})
|
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {praises: @praises})
|
|
||||||
else
|
|
||||||
$redis_cache.hincrby(project_common_key, praises_key, @praises)
|
$redis_cache.hincrby(project_common_key, praises_key, @praises)
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {praises: @praises})
|
Cache::V2::ProjectRankService.call(@project_id, {praises: @praises})
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {praises: @praises})
|
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {praises: @praises})
|
||||||
end
|
end
|
||||||
end
|
if @forks.present?
|
||||||
if @forks.present?
|
|
||||||
if $redis_cache.hget(project_common_key, forks_key).nil?
|
|
||||||
reset_project_forks
|
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {forks: @forks})
|
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {forks: @forks})
|
|
||||||
else
|
|
||||||
$redis_cache.hincrby(project_common_key, forks_key, @forks)
|
$redis_cache.hincrby(project_common_key, forks_key, @forks)
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {forks: @forks})
|
Cache::V2::ProjectRankService.call(@project_id, {forks: @forks})
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {forks: @forks})
|
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {forks: @forks})
|
||||||
end
|
end
|
||||||
end
|
if @issues.present?
|
||||||
if @issues.present?
|
|
||||||
if $redis_cache.hget(project_common_key, issues_key).nil?
|
|
||||||
reset_project_issues
|
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {issues: @issues})
|
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {issues: @issues})
|
|
||||||
else
|
|
||||||
$redis_cache.hincrby(project_common_key, issues_key, @issues)
|
$redis_cache.hincrby(project_common_key, issues_key, @issues)
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {issues: @issues})
|
Cache::V2::ProjectRankService.call(@project_id, {issues: @issues})
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {issues: @issues})
|
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {issues: @issues})
|
||||||
end
|
end
|
||||||
end
|
if @pullrequests.present?
|
||||||
if @pullrequests.present?
|
|
||||||
if $redis_cache.hget(project_common_key, pullrequests_key).nil?
|
|
||||||
reset_project_pullrequests
|
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {pullrequests: @pullrequests})
|
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {pullrequests: @pullrequests})
|
|
||||||
else
|
|
||||||
$redis_cache.hincrby(project_common_key, pullrequests_key, @pullrequests)
|
$redis_cache.hincrby(project_common_key, pullrequests_key, @pullrequests)
|
||||||
Cache::V2::ProjectRankService.call(@project_id, {pullrequests: @pullrequests})
|
Cache::V2::ProjectRankService.call(@project_id, {pullrequests: @pullrequests})
|
||||||
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {pullrequests: @pullrequests})
|
Cache::V2::ProjectDateRankService.call(@project_id, Date.today, {pullrequests: @pullrequests})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
$redis_cache.hgetall(project_common_key)
|
$redis_cache.hgetall(project_common_key)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -241,4 +211,9 @@ class Cache::V2::ProjectCommonService < ApplicationService
|
||||||
|
|
||||||
$redis_cache.hgetall(project_common_key)
|
$redis_cache.hgetall(project_common_key)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def clear_project_common
|
||||||
|
$redis_cache.del(project_common_key)
|
||||||
|
Cache::V2::ProjectRankService.new(@project_id).clear
|
||||||
|
end
|
||||||
end
|
end
|
|
@ -23,6 +23,10 @@ class Cache::V2::ProjectRankService < ApplicationService
|
||||||
reset_project_rank
|
reset_project_rank
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def clear
|
||||||
|
clear_project_rank
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def load_project_common
|
def load_project_common
|
||||||
@project_common = Cache::V2::ProjectCommonService.new(@project_id).read
|
@project_common = Cache::V2::ProjectCommonService.new(@project_id).read
|
||||||
|
@ -33,7 +37,8 @@ class Cache::V2::ProjectRankService < ApplicationService
|
||||||
end
|
end
|
||||||
|
|
||||||
def project_rank
|
def project_rank
|
||||||
$redis_cache.zscore(project_rank_key, @project_id).blank? ? reset_project_rank : $redis_cache.zscore(project_rank_key, @project_id)
|
result = $redis_cache.zscore(project_rank_key, @project_id)
|
||||||
|
result.blank? ? reset_project_rank : result
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_project_rank
|
def set_project_rank
|
||||||
|
@ -41,23 +46,24 @@ class Cache::V2::ProjectRankService < ApplicationService
|
||||||
if $redis_cache.zscore(project_rank_key, @project_id).blank?
|
if $redis_cache.zscore(project_rank_key, @project_id).blank?
|
||||||
reset_project_rank
|
reset_project_rank
|
||||||
return
|
return
|
||||||
|
else
|
||||||
|
if @visits.present?
|
||||||
|
$redis_cache.zincrby(project_rank_key, @visits.to_i * 1, @project_id)
|
||||||
|
end
|
||||||
|
if @praises.present?
|
||||||
|
$redis_cache.zincrby(project_rank_key, @praises.to_i * 5, @project_id)
|
||||||
|
end
|
||||||
|
if @forks.present?
|
||||||
|
$redis_cache.zincrby(project_rank_key, @forks.to_i * 5, @project_id)
|
||||||
|
end
|
||||||
|
if @issues.present?
|
||||||
|
$redis_cache.zincrby(project_rank_key, @issues.to_i * 10, @project_id)
|
||||||
|
end
|
||||||
|
if @pullrequests.present?
|
||||||
|
$redis_cache.zincrby(project_rank_key, @pullrequests.to_i * 10, @project_id)
|
||||||
|
end
|
||||||
|
reset_user_project_rank
|
||||||
end
|
end
|
||||||
if @visits.present?
|
|
||||||
$redis_cache.zincrby(project_rank_key, @visits.to_i * 1, @project_id)
|
|
||||||
end
|
|
||||||
if @praises.present?
|
|
||||||
$redis_cache.zincrby(project_rank_key, @praises.to_i * 5, @project_id)
|
|
||||||
end
|
|
||||||
if @forks.present?
|
|
||||||
$redis_cache.zincrby(project_rank_key, @forks.to_i * 5, @project_id)
|
|
||||||
end
|
|
||||||
if @issues.present?
|
|
||||||
$redis_cache.zincrby(project_rank_key, @issues.to_i * 10, @project_id)
|
|
||||||
end
|
|
||||||
if @pullrequests.present?
|
|
||||||
$redis_cache.zincrby(project_rank_key, @pullrequests.to_i * 10, @project_id)
|
|
||||||
end
|
|
||||||
reset_user_project_rank
|
|
||||||
|
|
||||||
$redis_cache.zscore(project_rank_key, @project_id)
|
$redis_cache.zscore(project_rank_key, @project_id)
|
||||||
end
|
end
|
||||||
|
@ -74,4 +80,8 @@ class Cache::V2::ProjectRankService < ApplicationService
|
||||||
def reset_user_project_rank
|
def reset_user_project_rank
|
||||||
$redis_cache.zadd("v2-user-project-rank:#{@project_common["owner_id"]}", $redis_cache.zscore(project_rank_key, @project_id), @project_id)
|
$redis_cache.zadd("v2-user-project-rank:#{@project_common["owner_id"]}", $redis_cache.zscore(project_rank_key, @project_id), @project_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def clear_project_rank
|
||||||
|
$redis_cache.sadd('v2-project-rank-deleted', @project_id)
|
||||||
|
end
|
||||||
end
|
end
|
|
@ -12,6 +12,7 @@ class Cache::V2::UserStatisticService < ApplicationService
|
||||||
@project_praise_count = params[:project_praise_count]
|
@project_praise_count = params[:project_praise_count]
|
||||||
@project_watcher_count = params[:project_watcher_count]
|
@project_watcher_count = params[:project_watcher_count]
|
||||||
@pullrequest_count = params[:pullrequest_count]
|
@pullrequest_count = params[:pullrequest_count]
|
||||||
|
Cache::V2::OwnerCommonService.new(user_id).read
|
||||||
end
|
end
|
||||||
|
|
||||||
def read
|
def read
|
||||||
|
@ -65,7 +66,8 @@ class Cache::V2::UserStatisticService < ApplicationService
|
||||||
end
|
end
|
||||||
|
|
||||||
def user_statistic
|
def user_statistic
|
||||||
$redis_cache.hgetall(user_statistic_key).blank? ? reset_user_statistic : $redis_cache.hgetall(user_statistic_key)
|
result = $redis_cache.hgetall(user_statistic_key)
|
||||||
|
result.blank? ? reset_user_statistic : result
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_user_statistic
|
def set_user_statistic
|
||||||
|
|
Loading…
Reference in New Issue