%% --------------------------------------------------------------------------- %% @doc 全民动员. %% @author zmh %% @since 20200811 %% --------------------------------------------------------------------------- -define(MOBILIZE_ACT_DATA(Type, SubType), {mobilize_act_data, Type, SubType}). -define(MOBILIZE_DAY_REWARD_DEFAULT_NEED, 999). %% 天数奖励默认需要完成任务数量(配置缺失时) -define(MOBILIZE_CALC_UPDATE, 1). %% 数值更新 -define(MOBILIZE_CALC_SUM, 2). %% 数值累加 -define(MOBILIZE_POWER_CALC_DAY, 7). %% 战力任务计算天数 -define(MOBILIZE_EQUIP_GEM_CALC_DAY, 6). %% 装备宝石任务计算天数 -define(MOBILIZE_SPEC_TASK_TYPE_LIST, [gems, combat]). %% 假数据进度 -record(fake_cord, { id = {0,0,0}, %% {tasktype, fakeid, start_day} act = 0, %% 活动子ID stime = 0, %% 活动开启时间 etime = 0, %% 活动结束时间(任务结束时间) ltime = 0, %% 上次更新时间 remain_score = 0, %% 待补助分(还剩需要补助多少) per_score = 0, %% 单次补助分 remain_times = 0, %% 如果还不够,继续补助次数(事实上很少用) remain_click = 0, %% 多出来的补助次数(事实上很少用) process = 0, %% 进度 real_pro = 0 %% 真实进度 }). %% 活动数据 -record(mobilize_act_data, { type = 0, subtype = 0, act_data = [], time = 0 %% 上次更新时间 }). %% 全员动员 玩家完整数据 -record(mobilize_role, { day_list = [] %% 天数区间奖励[#mobilize_day{}...] ,task_stat = #{} %% 任务完成度统计{{start,end}=>[#mobilize_task{}...]} }). %% 全员动员 玩家大奖进度数据 -record(mobilize_day, { day_interval = {} %% {start, end} 天数区间 ,total = 0 %% 任务总进度 ,state = 0 %% 是否已领取奖励 }). %% 全员动员 玩家任务进度 -record(mobilize_task, { task_type = 0 %% 任务类型Id - Key ,task_pro = 0 %% 任务进度 ,day_interval = {} %% {start, end} 天数区间(非重要数据) ,task_award_log = [] %% 任务奖励领取进度[task_id1,id2...] ,time = 0 %% 最近更新任务进度时间戳 }). %% ------------------------------- 配置 ------------------------------------------- %% 任务奖励配置 -record(custom_mobilize_task, { task_type = 0 %% 任务类型Id ,task_id = 0 %% 任务Id ,day = 0 %% 开始天数 ,end_day = 0 %% 结算天数 ,server_pro = 0 %% 全服进度 ,person_pro = 0 %% 个人进度 ,gain_con = 0 %% 领取条件 ,desc = 0 %% 任务描述 ,reward = [] %% 任务奖励 ,link = [] %% 前端跳转 }). %% 天数奖励配置 -record(base_custom_mobilize_day, { subtype = 0 %% 活动子Id ,day = 0 %% 开始天数 ,end_day = 0 %% 结算天数 ,reward = [] %% 奖励 ,need_num = 0 %% 需要完成任务数量 ,show_model = [] %% 前端展示模型 }). %% ------------------------------- db ------------------------------------------- %% db mobilize_task %% mobilize_days_reward %% 任务 -define(SAVE_MOBILIZE_TASK, <<"REPLACE INTO mobilize_task (`role_id`, `sub_type`, `start_day`, `end_day`, `task_type`, `progress`, `award_log`, `time`) VALUES (~p, ~p, ~p, ~p, ~p, ~p, '~ts', ~p)">>). -define(SELECT_MOBILIZE_TASK, <<"SELECT `start_day`, `end_day`, `task_type`, `progress`, `award_log`, `time` FROM mobilize_task WHERE `role_id` = ~p AND `sub_type` = ~p">>). %% 天数大奖 -define(SAVE_MOBILIZE_DAYS_REWARD, <<"REPLACE INTO mobilize_days_reward (`role_id`, `sub_type`, `start_day`, `end_day`, `total`, `state`) VALUES (~p, ~p, ~p, ~p, ~p, ~p)">>). -define(SELECT_MOBILIZE_DAYS_REWARD, <<"SELECT `start_day`, `end_day`, `total`, `state` FROM mobilize_days_reward WHERE `role_id`=~p AND `sub_type`=~p">>). %% 假数据 -define(SQL_MOBILIZE_FAKE_GET,<<"SELECT `task_type`,`fake_id`,`act`,`day`,`stime`,`etime`,`ltime`,`remain_score`,`per_score`,`remain_times`,`remain_click`,`process`,`real_pro` FROM `mobilize_fake_cord`">>). -define(SQL_MOBILIZE_FAKE_SAVE, "REPLACE INTO `mobilize_fake_cord` (`task_type`,`fake_id`,`act`,`day`,`stime`,`etime`,`ltime`,`remain_score`,`per_score`,`remain_times`,`remain_click`,`process`,`real_pro`) values ~ts"). -define(SQL_MOBILIZE_FAKE_LOG_BATCH, "REPLACE INTO `log_mobilize_progress` (`act`,`task_type`,`desc`,`fake`,`process`,`real_pro`,`day`,`time`) values ~ts"). -define(SQL_FAKE_PROCESS_UPDATE, <<"UPDATE `mobilize_fake_cord` SET `ltime`= ~p,`process`=~p,`real_pro`=~p WHERE `task_type` = ~p and `fake_id`=~p and `act` = ~p and `day` =~p">>). %%进度相关 -define(SQL_FAKE_CLICK_UPDATE, <<"UPDATE `mobilize_fake_cord` SET `ltime`= ~p,`remain_score`= ~p,`per_score`= ~p,`remain_times`= ~p,`remain_click`= ~p,`process`=~p,`real_pro`=~p WHERE `task_type` = ~p and `fake_id`=~p and `act` = ~p and `day` =~p">>). %%计数器相关更新 %% 战力任务数据 -define(SQL_SAVE_MOBILIZE_POWER, <<"insert into mobilize_power (`role_id`, `power`) values (~p, ~p)">>). -define(SQL_SELECT_MOBILIZE_POWER, <<"select `power` from mobilize_power where `role_id` = ~p limit 1">>).