%% ---------------------------------------------------------------------------
|
|
%% @doc 跨服竞榜活动头文件.
|
|
%% @author zhaoyu
|
|
%% @since 2018-11-27
|
|
%% ---------------------------------------------------------------------------
|
|
-ifndef(RACE_RANK_HRL).
|
|
-define(RACE_RANK_HRL, ok).
|
|
|
|
%% 还没结算
|
|
-define(NOT_SETTLEMENT, 0).
|
|
%% 排行榜最大上榜人数
|
|
-define(RR_RANK_MAX, 100).
|
|
|
|
-define(TYPE_RACE,1). %%寻常冲榜
|
|
-define(TYPE_WISH,2). %%许愿冲榜
|
|
|
|
-define(TYPE_POOL_RACE,0). %%正常奖池
|
|
-define(TYPE_POOL_COIN,1). %%金币奖池
|
|
-define(TYPE_POOL_RUNE,2). %%符文奖池
|
|
|
|
|
|
%% 跨服竞榜活动-时间配置
|
|
-record(race_rank_act, {
|
|
act_id = 0 %% 活动Id
|
|
,type = 0 %% 1冲榜2许愿池
|
|
,open_day = 0 %% 开服多少天后可以参与
|
|
,name = <<>> %% 活动名
|
|
,start_time = 0 %% 活动开始时间
|
|
,end_time = 0 %% 活动结束时间
|
|
,show_time = 0 %% 展示时间
|
|
,lv = 0 %% 玩家参加活动需要达到的等级
|
|
,condition = [] %% 条件
|
|
}
|
|
).
|
|
|
|
%% 跨服竞榜活动-奖池奖励配置
|
|
-record(race_rank_draw_pool, {
|
|
act_id = 0 %% 活动Id
|
|
,type = 0 %% 0冲榜1金币2符文
|
|
,stage = 0 %% 世界等级阶段
|
|
,award_id = 0 %% 奖励Id
|
|
,award = [] %% 奖励
|
|
,loading_times = 0 %% 入库次数
|
|
,weight = 0 %% 权重
|
|
,is_broadcast = 0 %% 是否发送传闻(1发 0不发)
|
|
,is_tv = 0 %% 是否上电视(1上 0不上)
|
|
}
|
|
).
|
|
|
|
%% 跨服竞榜活动-排名奖励
|
|
-record(race_rank_award, {
|
|
act_id = 0 %% 活动Id
|
|
,stage = 0 %% 世界等级阶段
|
|
,min_rank = 0 %% 排名上限
|
|
,max_rank = 0 %% 排名下限
|
|
,need_score = 0 %% 最低上榜要求
|
|
,award = [] %% 奖励
|
|
}
|
|
).
|
|
|
|
%% 跨服竞榜活动-积分阶段奖励
|
|
-record(race_rank_times_award, {
|
|
act_id = 0 %% 活动Id
|
|
,stage = 0 %% 世界等级阶段
|
|
,award_id = 0 %% 奖励Id
|
|
,need_score = 0 %% 所需积分
|
|
,server_score = 0 %% 所需全服积分
|
|
,award = [] %% 奖励
|
|
}
|
|
).
|
|
|
|
|
|
%% 跨服竞榜活动信息
|
|
-record(rr_act_info, {
|
|
act_id = 0 %% 活动Id
|
|
,status = 0 %% 已结算奖励:结算时的时间戳;还没结算奖励:0
|
|
,start_time = 0 %% 活动开始时间
|
|
,end_time = 0 %% 活动结束时间
|
|
,show_end_time = 0 %% 展示结束时间
|
|
}).
|
|
|
|
|
|
%% race_rank_act进程state
|
|
-record(race_rank_act_info, {
|
|
opening = [] %% 正在开启中/展示中的活动[#rr_act_info{}]
|
|
,ref = 0 %% 活动开启结束定时器
|
|
,scores = [] %% 本服积分
|
|
}).
|
|
|
|
%% race_rank_mgr进程state
|
|
-record(rr_rank_state, {
|
|
server2zone_dict = #{} %% 按ServerId查询ZoneId的索引数据
|
|
,acts_rank = [] %% 排行榜数据[#rr_act_rank{}]
|
|
}
|
|
).
|
|
|
|
%% 竟榜活动排行榜
|
|
-record(rr_act_rank, {
|
|
act_id = 0 %% 活动Id
|
|
,ranks = [] %% 排行榜数据[#rr_rank{}]
|
|
}
|
|
).
|
|
|
|
%% 排行榜数据
|
|
-record(rr_rank, {
|
|
act_id = 0 %% 活动Id
|
|
,zone_id = 0 %% 分区Id
|
|
,roles = [] %% 排行榜数据[#rr_rank_role{}]
|
|
}
|
|
).
|
|
|
|
%% 排行榜角色数据
|
|
-record(rr_rank_role, {
|
|
act_id = 0 %% 活动Id
|
|
,zone_id = 0 %% 分区Id
|
|
,role_id = 0 %% 角色Id
|
|
,role_name = <<>> %% 角色名
|
|
,server_id = 0 %% 服务器Id(后台唯一服号)
|
|
,server_num = 0 %% 服务器编号(玩家可见的服编号)
|
|
,score = 0 %% 积分
|
|
,time = 0 %% 时间戳
|
|
,ranking = 0 %% 排名
|
|
}
|
|
).
|
|
|
|
%% 角色竞榜活动数据
|
|
-record(role_race_rank, {
|
|
act_data = [] %% 角色竞榜活动数据:[#rr_act_data{}]
|
|
}
|
|
).
|
|
|
|
%% 角色竞榜活动数据
|
|
-record(rr_act_data, {
|
|
act_id = 0 %% 活动Id
|
|
,times = 0 %% 累计次数
|
|
,buy_ten_times = 0 %% 抽十次的累计次数
|
|
,buy_ten_time = 0 %% 最近一次抽十次的时间戳
|
|
,score = 0 %% 积分
|
|
,use_free_times = 0 %% 已使用免费次数
|
|
,free_time = 0 %% 最近一次使用免费次数的时间戳
|
|
,award_log = [] %% 累计次数奖励领取记录[AwardId]
|
|
,valid_time = 0 %% 数据有效截止时间戳
|
|
|
|
,coin = 0 %%金币
|
|
,stage = 0 %%当前阶段 累计充值阶段
|
|
,time = 0 %%充值时间 =
|
|
,coin_draw = 0 %%金币祈愿次数
|
|
,coin_time = 0 %%金币祈愿时间
|
|
,rune_draw = 0 %%符文祈愿次数
|
|
,rune_time = 0 %%符文祈愿时间
|
|
}
|
|
).
|
|
|
|
%% 活动世界等级阶段数据
|
|
-record(rr_act_stage, {
|
|
act_id = 0 %% 活动Id
|
|
,stage = 0 %% 世界等级阶段
|
|
,valid_time = 0 %% 数据有效截止时间戳(等于活动的show_end_time)
|
|
}
|
|
).
|
|
|
|
|
|
%% race_rank_opening_act数据表语句.
|
|
%% 活动展示期过后清理数据
|
|
-define(RR_ACT_SELECT, <<"SELECT `act_id`,`status` FROM `race_rank_opening_act`">>).
|
|
-define(RR_ACT_BATCH, <<"REPLACE INTO race_rank_opening_act (`act_id`,`status`)">>).
|
|
-define(RR_ACT_DEL, <<"DELETE FROM race_rank_opening_act WHERE `act_id`=~p">>).
|
|
-define(RR_ACT_DEL_ALL, <<"TRUNCATE TABLE race_rank_opening_act">>).
|
|
|
|
|
|
%% race_rank数据表语句.
|
|
-define(RR_RANK_SELECT, <<"SELECT `act_id`,`zone_id`,`rid`,`rname`,`server_id`"
|
|
",`server_num`,`score`,`time` FROM `race_rank`">>).
|
|
-define(RR_RANK_BATCH, <<"REPLACE INTO race_rank (`act_id`,`zone_id`,`rid`,`rname`,`server_id`"
|
|
",`server_num`,`score`,`time`) VALUES ~ts">>).
|
|
-define(RR_RANK_REPLACE, <<"REPLACE INTO race_rank (`act_id`,`zone_id`,`rid`,`rname`,`server_id`"
|
|
",`server_num`,`score`,`time`) VALUES (~p, ~p, ~p, '~ts', ~p,~p, ~p, ~p)">>).
|
|
-define(RR_RANK_DEL, <<"DELETE FROM race_rank WHERE `act_id`=~p AND `rid`=~p">>).
|
|
-define(RR_RANK_BATCH_DEL, <<"DELETE FROM race_rank WHERE `act_id`=~p AND `rid` IN (~ts)">>).
|
|
-define(RR_RANK_DEL_ACT, <<"DELETE FROM race_rank WHERE `act_id`=~p">>).
|
|
-define(RR_RANK_DEL_ALL, <<"TRUNCATE TABLE race_rank">>).
|
|
|
|
-define(RR_RANK_LOG_BATCH, <<"REPLACE INTO race_rank (`act_id`,`zone_id`,`rid`,`rname`,`server_id`"
|
|
",`server_num`,`score`,`time`) VALUES ~ts">>).
|
|
|
|
|
|
%% role_race_rank数据表语句.
|
|
-define(RR_ROLE_SELECT, <<"SELECT `act_id`,`times`,`buy_ten_times`,`buy_ten_time`,`score`,`use_free_times`,`free_time`,`award_log`"
|
|
",`valid_time`,`coin`,`stage`,`time`,`coin_draw`,`coin_time`,`rune_draw`,`rune_time` FROM `role_race_rank` WHERE `rid`=~p">>).
|
|
-define(RR_ROLE_REPLACE, <<"REPLACE INTO role_race_rank (`rid`,`act_id`,`times`,`buy_ten_times`,`buy_ten_time`,`score`,`use_free_times`,`free_time`"
|
|
",`award_log`,`valid_time`,`coin`,`stage`,`time`,`coin_draw`,`coin_time`,`rune_draw`,`rune_time`) VALUES (~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, '~ts', ~p,~p, ~p, ~p, ~p, ~p, ~p,~p)">>).
|
|
-define(RR_ROLE_DEL, <<"DELETE FROM role_race_rank WHERE `act_id`=~p">>).
|
|
-define(RR_ROLE_DEL_ROLE, <<"DELETE FROM role_race_rank WHERE `act_id`=~p AND `rid`=~p">>).
|
|
-define(RR_ROLE_DEL_ALL, <<"TRUNCATE TABLE role_race_rank">>).
|
|
|
|
%% log_race_rank数据表语句.
|
|
-define(RR_LOG_RANK_BATCH, <<"REPLACE INTO log_race_rank_kf (`act_id`,`zone_id`,`role_id`,`rname`,`server_id`"
|
|
",`server_num`,`stime`,`etime`,`score`,`rank`,`ctime`,`time`) VALUES ~ts">>).
|
|
|
|
-define(RR_LOG_RANK_REPLACE, <<"REPLACE INTO log_race_rank (`act_id`,`zone_id`,`role_id`,`rname`,`stime`,`etime`,`score`,`rank`,`ctime`,`time`) VALUES (~p,~p,~p,'~ts',~p,~p,~p,~p,~p,~p)">>).
|
|
|
|
%% race_rank_server_score数据表语句.
|
|
-define(SQL_SERVER_SCORE_GET, <<"SELECT `act_id`,`score`,`time` FROM `race_rank_server_score`">>).
|
|
-define(SQL_SERVER_SCORE_REPLACE, <<"REPLACE INTO `race_rank_server_score` (`act_id`,`score`,`time`) VALUES (~p, ~p, ~p)">>).
|
|
-define(SQL_SERVER_SCORE_DEL, <<"DELETE FROM `race_rank_server_score` WHERE `act_id`=~p">>).
|
|
|
|
-endif. %% RACE_RANK_HRL
|
|
|