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