源战役
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 

240 行
11 KiB

%% ---------------------------------------------------------------------------
%% @doc relationship.hrl
%% @author hjh
%% @since 2016-12-06
%% @deprecated 关系
%% ---------------------------------------------------------------------------
%% 常量配置参数
-define(RELA_NUM_LIMIT, 1).
-define(COUPON_SEND_CONF, 2).
-define(COUPON_GIFT_CONF, 3).
%% 玩家关系缓存
-define(ETS_ROLE_RELA, ets_role_rela). %% 缓存玩家关系和请求状态
-define(UPDATE_RELA, 1). %% 更新关系
-define(UPDATE_RESPONSE_STATUS, 2). %% 更新好友回应状态
%% 人数上限
-define(FRIEND_NUM_LIMIT, data_rela:get_rela_value(?RELA_NUM_LIMIT)). %% 好友数量上限
-define(NEARLLY_NUM_LIMIT, data_rela:get_rela_value(?RELA_NUM_LIMIT)). %% 最近联系人名单上限
%% 推荐好友参数
-define(RECOMMENDED_ROLE_POOL, 30). %% 推荐池
-define(RECOMMENDED_SEARCH_CD, 5). %% 推荐列表刷新CD
-define(RECOMMENDED_LIST_MAX_LEN, 10). %% 推荐好友显示最大数量
-define(RECOMMENDED_OPPOSITE_ROLE, 7). %% 异性推荐人数
%% 社交删增操作通知类别
-define(RELA_UPDATE_REMOVE, 0). %% 从社交列表移除玩家
-define(RELA_UPDATE_ADD, 1). %% 从社交列表增加玩家
%% 回复好友申请类型
-define(REPLY_TYPE_REFUSE, 0). %% 拒绝
-define(REPLY_TYPE_AGREE, 1). %% 同意
-define(REPLY_TYPE_PULL_BLACK, 2). %% 拉黑
%% 好友申请处理状态
-define(ASK_RESPONSE_SUSPEND, 0). %% 挂起不理会
-define(ASK_RESPONSE_REFUSE, 1). %% 拒绝
-define(ASK_RESPONSE_AGREE, 2). %% 同意
%% 好友请求有效时间
-define(FRIEND_ASK_VAILD_TIME, 86400). %% 过期的在玩家登陆或者服务器重启时会清理掉
%% 获得亲密度的方式
%% 类型1000之前的为后台配置亲密度获得方式配置的类型,其他类型从1000之后开始
-define(INTIMACY_TYPE_DUN, 1). %% 各类副本
-define(INTIMACY_TYPE_MON, 2). %% 各类怪物
-define(INTIMACY_TYPE_PRESENT, 1000). %% 赠送物品
-define(INTIMACY_TYPE_SHOW_LVE, 1001). %% 秀恩爱
-define(INTIMACY_TYPE_CLEAN, 1002). %% 清空
%% 社交关系类别(查询和更新使用)
-define(RELA_LIST_TYPE_FRIEND, 1). %% 好友列表
-define(RELA_LIST_TYPE_FETTERS, 2). %% 羁绊列表
-define(RELA_LIST_TYPE_ENEMY, 3). %% 仇人列表
-define(RELA_LIST_TYPE_BLACK, 4). %% 黑名单,非正式社交类别,供限制聊天使用
-define(RELA_LIST_TYPE_RECENT_CHAT, 5). %% 最近联系
-define(RELA_LIST_TYPE_SINGLE_FRIEND, 6). %% 单向好友列表
%% 社交关系操作
-define(RELA_DEL_FRIEND, 1). %% 删除好友
-define(RELA_DEL_FETTERS, 2). %% 删除羁绊
% -define(RELA_ADD_BLACK, 2). %% 拉黑
% -define(RELA_DEL_BLACK, 3). %% 取消拉黑
% -define(RELA_DEL_ENEMY, 4). %% 删除仇人
%% ---------------- 关系类型定义(关系唯一,不会同时存在两条关系数据,存于数据库中) ------------------------------
-define(RELA_TYPE_NONE, 0). %% 没有关系
-define(RELA_TYPE_FRIEND, 1). %% 好友
-define(RELA_TYPE_FETTERS, 2). %% 羁绊(实际db存储的数据还是1-好友关系)
% -define(RELA_TYPE_ENEMY, 3). %% 仇人
% -define(RELA_TYPE_BLACK, 4). %% 黑名单
-define(RELA_TYPE_SINGLE_FRIEND, 6). %% 单向好友
-define(RELA_FRIEND_TYPES, [?RELA_TYPE_FRIEND]).
-define(RELA_FETTERS_TYPES, [?RELA_TYPE_FETTERS]).
-define(RELA_SINGLE_FRIEND_TYPES, [?RELA_TYPE_SINGLE_FRIEND]).
% -define(RELA_BLACK_TYPES, [?RELA_TYPE_BLACK]).
% -define(RELA_ENEMY_TYPES, [?RELA_TYPE_ENEMY]).
%% -----------------------------------------------------------------------
%% --------------------------关系操作(日志)-----------------------------
-define(ADD_FRIEND, 1). %% 同意添加好友
-define(BE_ADD_FRIEND, 2). %% 被同意添加好友
-define(DEL_FRIEND, 3). %% 删除好友
-define(BE_DEL_FRIEND, 4). %% 被删除好友
-define(ADD_BLACK, 5). %% 拉黑
-define(BE_ADD_BLACK, 6). %% 被拉黑
-define(DEL_BLACK, 7). %% 取消拉黑
-define(ADD_FETTERS, 8). %% 自动添加羁绊
-define(DEL_FETTERS, 9). %% 移除羁绊
%% ---------------------------玩家进程定义--------------------------------
-define(RELAS_KEY, relas). %% 进程字典
-define(FRIEND_ASK_LIST, rela_friend_ask_list). %% 好友请求列表
-define(FRIEND_RECOMMEND_LIST, rela_recommended_list). %% 好友推荐列表
-define(FRIEND_SEARCH_TIME, rela_last_search_time). %% 好友推荐列表最后刷新时间
-define(LAST_RELA_LIST, last_rela_list). %% 最近联系人列表
%% -----------------------------------------------------------------------
%% 最近联系人上限
-define(LAST_RELA_CHAT_LIMIT, 10).
-record(intimacy_lv_cfg, {
lv = 0,
color = 0,
name = "",
intimacy = 0,
attr = []
}).
-record(intimacy_obtain_cfg, {
type = 0, %% 亲密度获得类型
trigger_obj = 0, %% 触发对象id
intimacy = 0, %% 增加亲密度
times = 0 %% 次数限制 4点重置
}).
%% 关系记录(玩家进程)
-record(rela, {
role_id = 0, % 玩家id
other_rid = 0, % 关系另一方的玩家id
rela_type = 0, % 关系类型
intimacy = 0, % 亲密度
contribute = 0, % 本方的亲密度贡献
last_chat_time = 0, % 最后聊天时间
last_chat_utime = 0, % 最后聊天的数据库更新时间
ctime = 0 % 关系记录创建时间
}).
%% 好友请求
-record(friend_ask, {
role_id = 0,
ask_id = 0,
time = 0
}).
%% 最近联系人(人物进程内)|初步限制在10人以内
-record(last_rela_chat, {
role_id = 0, %% 玩家id
other_id = 0, %% 对方id
time = 0 %% 最近聊天时间
}).
%% 每日社交票券
-record(role_rela_coupon, {
id = 0, %% 玩家id
send_list = [], %% 今日已赠送列表
send_time = 0, %% 今日最新赠送时间
gift_list = [], %% 今日已领取列表 [{FromId, State},...]
gift_time = 0 %% 今日最新领取&接收时间
}).
%% 玩家在对方所处的关系状态
-record(ets_role_rela, {
key = {0, 0} %% {RoleId, OppoId}
,rela = 0 %% 我(RoleId)在对方所处的关系状态
,res_status = 0 %% 回复请求加好友状态
}).
%% 计数器类型
-define(RELA_COUPON_SEND, 1).
-define(RELA_COUPON_GIFT, 2).
%% 票券状态
-define(COUPON_RECEIVING, 0).
-define(COUPON_RECEIVED, 1).
%% 票卷类型
-define(COUPON_FRIEND, 1).
-define(COUPON_MATE, 2).
%% 亲密度增加类型
%% 亲密度增加时统计贡献度使用
-define(ACTIVE_CON, active_contribute).
-define(PASS_CON, passive_contribute).
-define(sql_rela_select_by_role_id,
<<"select role_id, other_rid, rela_type, intimacy, contribute, last_chat_time, ctime from relationship where role_id = ~p">>).
-define(sql_single_rela_select_by_role_id,
<<"select role_id, other_rid, rela_type, intimacy, contribute, last_chat_time, ctime from relationship where other_rid = ~p">>).
-define(sql_rela_select_rela_type_from_other,
<<"select rela_type from relationship where role_id = ~p and other_rid = ~p">>).
-define(sql_rela_select_by_rid_and_oid,
<<"select role_id, other_rid, rela_type, intimacy, contribute, last_chat_time, ctime from relationship where role_id = ~p and other_rid = ~p">>).
% -define(sql_rela_select_by_rid_and_type,
% <<"select role_id, other_rid, rela_type, intimacy, contribute, last_chat_time, ctime from relationship where role_id = ~p and rela_type = ~p">>).
% -define(sql_rela_insert,
% <<"insert into relationship (from_id, to_id, rela_type, ctime) values(~p, ~p, ~p, ~p)">>).
-define(sql_update_last_chat_time,
<<"update relationship set last_chat_time = ~p where (role_id = ~p and other_rid = ~p) or (other_rid = ~p and role_id = ~p)">>).
-define(sql_del_out_time_friend_ask_by_role_id,
<<"delete from rela_friend_ask where time < ~p and role_id = ~p">>).
-define(sql_get_friend_ask_by_role_id,
<<"select role_id, ask_id, time from rela_friend_ask where role_id = ~p">>).
-define(sql_get_friend_ask_by_oppo_role_id,
<<"select role_id, ask_id, time from rela_friend_ask where role_id = ~p and ask_id = ~p">>).
-define(sql_add_friend_ask,
<<"replace into rela_friend_ask(role_id, ask_id, time) values(~p, ~p, ~p)">>).
-define(db_del_friend_ask_by_asker_id,
<<"delete from rela_friend_ask where role_id = ~p and ask_id = ~p">>).
-define(db_del_one_role_all_friend_ask,
<<"delete from rela_friend_ask where role_id = ~p">>).
-define(sql_save_role_rela,
<<"replace into relationship (role_id, other_rid, rela_type, intimacy, contribute, last_chat_time, ctime) values(~p, ~p, ~p, ~p, ~p, ~p, ~p)">>).
-define(sql_del_role_rela,
<<"delete from relationship where role_id = ~p and other_rid = ~p">>).
-define(sql_update_intimacy,
<<"update relationship set intimacy = ~p, contribute = ~p where role_id = ~p and other_rid = ~p">>).
-define(sql_select_rela_data_by_rela,
<<"select role_id, rela_type from relationship where other_rid = ~p and rela_type in(~s)">>).
-define(sql_get_last_relas_by_role_id,
<<"select role_id, other_id, time from last_rela_chat where role_id = ~p">>).
-define(sql_del_last_rela_by_role_id,
<<"delete from last_rela_chat where role_id = ~p and other_id = ~p">>).
-define(sql_select_last_rela_data,
<<"select role_id from last_rela_chat where other_id = ~p">>).
-define(sql_replace_into_last_rela,
<<"replace into last_rela_chat (role_id, other_id, time) values ~ts">>).
-define(sql_select_role_coupon_list,
<<"select op_role, coupon_type, type, status, time from role_coupon_list where role_id = ~p">>).
-define(sql_replace_role_coupon_list,
<<"replace into role_coupon_list set role_id = ~p, op_role = ~p, coupon_type = ~p, type = ~p, status = ~p, time = ~p">>).
-define(sql_batch_replace_role_coupon_list,
<<"replace into role_coupon_list(role_id, op_role, coupon_type, type, status, time) values ~ts">>).
-define(sql_batch_replace_val,
<<"(~p, ~p, ~p, ~p, ~p, ~p)">>).
-define(sql_update_role_coupon_list,
<<"update role_coupon_list set status = ~p where role_id = ~p and op_role = ~p and coupon_type = ~p and type = ~p">>).
-define(sql_truncate_role_coupon_list,
<<"truncate table role_coupon_list">>).