|
%% ---------------------------------------------------------------------------
|
|
%% @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">>).
|