|
|
- %% ---------------------------------------------------------------------------
- %% @doc 交易市场头文件
- %% @author zhaoyu
- %% @since 2019-12-17
- %% ---------------------------------------------------------------------------
-
- -ifndef(MARKET_HRL).
- -define(MARKET_HRL, ok).
-
- %% 交易市场-交易市场物品信息ets。保存数据格式:[#market_goods{}]
- -define(MARKET_GOODS_ETS, market_goods_ets). %% 正在出售的商品
-
- %% 交易市场-交易市场玩家出价信息ets。保存数据格式:[#market_bid{}]
- -define(MARKET_BID_ETS, market_bid_ets).
-
- %% 交易市场-入库提醒订阅信息ets。保存数据格式:[#market_reminder{}]
- -define(MARKET_REMINDER_ETS, market_reminder_ets).
-
- %% 交易市场-系统补给商品数据信息ets。保存数据格式:[#market_supply{}]
- -define(MARKET_SUPPLY_ETS, market_supply_ets).
-
- %% 市场成交记录类型-世界记录
- -define(MARKET_DEAL_LOG_WORLD, 1).
- %% 市场成交记录类型-公会记录
- -define(MARKET_DEAL_LOG_GUILD, 2).
- %% 市场成交记录类型-角色记录
- -define(MARKET_DEAL_LOG_ROLE, 3).
-
- %% 拍卖类型-世界拍卖
- -define(MARKET_SELL_TYPE_WORLD, 1).
- %% 拍卖类型-公会拍卖
- -define(MARKET_SELL_TYPE_GUILD, 2).
-
- %% 可上架区域-社团和世界都可以上架
- -define(MARKET_RANGE_ALL, 0).
- %% 可上架区域-只能上架世界
- -define(MARKET_RANGE_WORLD, 1).
- %% 可上架区域-只能上架社团
- -define(MARKET_RANGE_GUILD, 2).
-
-
- %% 系统-角色Id, 系统回购后再出售的出售者
- -define(MARKET_SYS_ROLE_ID, 1).
- %% 系统-最大角色id : 模块功能id,
- -define(MARKET_SYS_MAX_ROLE_ID, 655).
-
- %% 日计数器
- -define(MARKET_COUNTER_DAILY_REMINDER, 1).
-
- %% 市场操作
- -define(MARKET_OPERATION_MANUAL_ON, 1). %% 手动上架
- -define(MARKET_OPERATION_MANUAL_OFF, 2). %% 手动下架
- -define(MARKET_OPERATION_SETTLEMENT, 3). %% 成交
- -define(MARKET_OPERATION_SYS_DEL, 4). %% 系统删除
- -define(MARKET_OPERATION_SYS_ON, 5). %% 系统上架
- -define(MARKET_OPERATION_SYS_OFF, 6). %% 系统下架
- -define(MARKET_OPERATION_OFF_TO_WORLD, 7). %% 下架流拍至世界
-
- %% 购买方式
- -define(MARKET_BUY_TYPE_NORMAL, 1). %% 购买方式-正常竞拍
- -define(MARKET_BUY_TYPE_EQUIP_AUTO, 2). %% 购买方式-装备进化升星自动
-
- %% 买卖身份
- -define(MARKET_SELLER, 1).
- -define(MARKET_BUYER, 2).
- %% 推荐子类配置
- -record(market_recommend_cfg, {
- id = 0 %% 推荐Id
- ,name = <<>> %% 名称
- ,sell_type = 0 %% 商品大类Id
- ,sell_sub_type = 0 %% 商品子类Id
- ,quality_range = {0, 0} %% 物品品质区间
- }
- ).
-
- %% 系统回购配置
- -record(market_buyback_cfg, {
- goods_id = 0 %% 可回购物品Id
- ,open_day_min = 0 %% 开服天数
- ,open_day_max = 0 %% 开服天数
- ,sell_again = 0 %% 是否系统上架(1是,0否)
- ,buyback_time = {0, 0} %% 开售多少秒后,系统可以在此时间范围内随机回购
- }
- ).
-
-
- %% 系统补货配置
- -record(market_sys_sell_cfg, {
- goods_id = 0 %% 物品Id
- ,open_day_min = 0 %% 开服天数
- ,open_day_max = 0 %% 开服天数
- ,trigger_sys_sell_num = 0 %% 累积上架多少数量后会触发系统补充机制
- ,trigger_num = 0 %% 市场上在售少于多少后触发系统进行补货
- ,sell_num = 0 %% 每次补货数量
- ,sell_max_num = 0 %% 每日补货数量上限
- }
- ).
-
-
- %% 交易市场管理进程state
- -record(market_mgr, {
- off_time_list = [] %% 每个竞拍子类最早结束的定时信息 [#m_off_time_info{}}]
- ,buyback_time_list = [] %% 每个物品最早被系统回购的定时信息 [#m_buyback_time_info{}}]
- ,all_deal_log_list = [] %% 成交记录列表-[#deal_log_type{}]
- }
- ).
-
- %% 每个竞拍子类最早结束的定时信息
- -record(m_off_time_info, {
- key = {0, 0} %% 每个子类key {Type, SubType}
- ,min_off_time = 0 %% 竞拍结束时间戳
- ,timer_ref = 0 %% 竞拍结束定时器 TimerRef
- }
- ).
-
- %% 每个物品最早被系统回购的定时信息
- -record(m_buyback_time_info, {
- goods_type_id = 0 %% 回购物品类型Id
- ,min_time = 0 %% 系统回购时间戳
- ,timer_ref = 0 %% 系统回购定时器 TimerRef
- }
- ).
-
- %% 交易市场物品信息
- -record(market_goods, {
- id = 0 %% 交易市场商品拍卖Id
- ,role_id = 0 %% 出售玩家角色Id, 非玩家出售的商品id为1或者功能id
- ,goods_id = 0 %% 物品唯一Id
- ,goods_type_id = 0 %% 物品类型Id
- ,num = 0 %% 物品数量
- ,lev = 0 %% 物品等级
- ,color = 0 %% 物品品质
- ,price = 0 %% 目前竞拍价格
- ,sell_type = 0 %% 上架类型:1:世界上架2:社团上架
- ,guild_id = 0 %% 公会Id
- ,time = 0 %% 物品上架时间
- ,off_time = 0 %% 物品拍卖截止时间
- ,sys_buyback_time = 0 %% 系统回购时间戳-0表示系统不回购
- ,sys_buyback_count = 0 %% 系统回购次数
- ,is_to_world = 0 %% 公会上架流拍是否上架世界:0:否1:是
- ,bidder_id = 0 %% 最高出价玩家Id
- ,extra_attr = [] %% 物品额外特殊属性
- ,bid_count = 0 %% 出价次数
- ,off_shelf = 0 %% 是否下架:超时没人买就会下架
-
- %% 下面的字段不保存数据库
- ,type = 0 %% 商品大类
- ,sub_type = 0 %% 商品子类
- ,buyout_price = 0 %% 交易一口价(为0时无一口价)
- ,career = [] %% 职业限制:[]为不限
- ,sex = 0 %% 性别限制,0为不限,1为男,2为女
- ,series = 0 %% 装备套数
- }
- ).
-
- %% 交易市场玩家出价信息
- -record(market_bid, {
- key = {0, 0} %% key: {RoleId, Id}
- ,id = 0 %% 交易市场商品拍卖Id
- ,role_id = 0 %% 出价玩家角色Id
- ,role_name = 0 %% 出价玩家角色名字
- ,price = 0 %% 竞价
- ,time = 0 %% 最后一次出价时间戳
- }
- ).
-
-
- %% 交易市场玩家关注
- -record(market_like, {
- id = 0 %% 交易市场商品拍卖Id
- ,role_id = 0 %% 玩家角色Id
- ,time = 0 %% 关注时间戳
- }
- ).
-
- %% 入库提醒订阅信息
- -record(market_reminder, {
- key = {0, 0} %% Key: {RoleId, GoodsTypeId}
- ,role_id = 0 %% 玩家角色Id
- ,goods_type_id = 0 %% 物品类型Id
- }
- ).
-
-
- %% 系统补给商品数据信息
- -record(market_supply, {
- goods_type_id = 0 %% 物品类型Id
- ,num = 0 %% 全服玩家累积上架物品数量
- ,supply_num = 0 %% 系统今日累积补给数量
- ,time = 0 %% 系统最近一次补给时间戳
- }
- ).
-
-
- %% 筛选参数
- -record(market_select, {
- sell_type = 0 %% 拍卖类型 1:世界拍卖 2:公会拍卖
- ,type = 0 %% 商品大类
- ,sub_type = 0 %% 商品子类
- ,lev = {0, 0} %% 等级范围
- ,color = {0, 0} %% 品质范围
- ,series = 0 %% 装备套数
- ,career = 0 %% 职业限制:0为不限
- ,sex = 0 %% 性别限制,0为不限,1为男,2为女
- ,guild_id = 0 %% 公会Id
- }
- ).
-
- %% 交易市场成交记录
- -record(market_deal_log, {
- id = 0 %% 交易市场商品拍卖Id
- ,role_id = 0 %% 出售玩家角色Id
- ,get_role_id = 0 %% 获得者玩家Id
- ,get_role_name = 0 %% 获得者名字
- ,goods_id = 0 %% 物品唯一Id
- ,goods_type_id = 0 %% 物品类型Id
- ,num = 0 %% 物品数量
- ,lev = 0 %% 物品等级
- ,color = 0 %% 物品品质
- ,price = 0 %% 成交价格
- ,sell_type = 0 %% 上架类型:1:世界上架2:社团上架
- ,guild_id = 0 %% 公会Id
- ,time = 0 %% 物品上架时间
- ,deal_time = 0 %% 成交时间戳
- ,deal_type = 0 %% 成交类型:0:竞价1:一口价
- ,log_type = 0 %% 成交记录大类
- ,extra_attr = [] %% 物品额外特殊属性
-
- %% 下面的字段不保存数据库
- ,type = 0 %% 商品大类
- ,sub_type = 0 %% 商品子类
- }
- ).
-
- %% 交易市场交易记录
- -record(deal_log_type, {
- log_key = {0, 0} %% 成交记录大类-{SellType, LogType}
- ,log_list = [] %% 成交记录列表-[#market_deal_log{}]
- }
- ).
-
-
- %% 交易市场成交记录
- -record(market_role_deal_log, {
- id = 0 %% 交易市场商品拍卖Id
- ,role_id = 0 %% 角色Id
- ,rela_role_id = 0 %% 关联玩家Id
- ,goods_type_id = 0 %% 物品类型Id
- ,num = 0 %% 物品数量
- ,price = 0 %% 成交价格
- ,sell_type = 0 %% 上架类型:1:世界上架2:社团上架
- ,guild_id = 0 %% 公会Id
- ,time = 0 %% 物品上架时间
- ,deal_time = 0 %% 成交时间戳
- ,deal_type = 0 %% 成交类型:0:竞价1:一口价2:卖出
- ,extra_attr = [] %% 物品额外特殊属性
- }
- ).
-
- %% 角色交易市场数据
- -record(market_data, {
- deal_log_list = [] %% 成交记录列表-[#market_role_deal_log{}]
- ,like_list = [] %% 角色关注的物品列表-[#market_like{}]
- ,like_num = 0 %% 角色关注的物品数量
- ,reminder_list = [] %% 角色入库提醒订阅信息列表-[GoodsTypeId]
- }
- ).
-
-
-
- %% 交易市场出售的商品信息(竞拍时间结束自动下架的物品也保存在这个表)
- -define(SAVE_MARKET_GOODS, <<"REPLACE INTO `market_goods` (`id`, `role_id`, `goods_id`, `goods_type_id`, `num`, `lev`"
- ", `color`, `price`, `sell_type`, `guild_id`, `time`, `off_time`, `sys_buyback_time`, `is_to_world`, `bidder_id`, `extra_attr`, `sys_buyback_count`, `off_shelf`)"
- " values (~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, '~ts', ~p, ~p)">>).
-
- -define(BATCH_SAVE_MARKET_GOODS, <<"REPLACE INTO `market_goods` (`id`, `role_id`, `goods_id`, `goods_type_id`, `num`, `lev`"
- ", `color`, `price`, `sell_type`, `guild_id`, `time`, `off_time`, `sys_buyback_time`, `is_to_world`, `bidder_id`, `extra_attr`, `sys_buyback_count`, `off_shelf`)"
- " values ~ts">>).
-
- -define(LOAD_MARKET_GOODS, <<"SELECT `id`, `role_id`, `goods_id`, `goods_type_id`, `num`, `lev`, `color`, `price`"
- ", `sell_type`, `guild_id`, `time`, `off_time`, `sys_buyback_time`, `is_to_world`, `bidder_id`, `extra_attr`, `sys_buyback_count`, `off_shelf` FROM `market_goods`">>).
-
- -define(DEL_MARKET_GOODS, <<"DELETE FROM `market_goods` WHERE `id` = ~p AND `role_id` = ~p">>).
-
-
-
- %% 交易市场玩家竞拍出价
- -define(SAVE_MARKET_BID, <<"REPLACE INTO `market_bid_info` (`id`, `role_id`, `role_name`, `price`, `time`) values (~p, ~p, '~ts', ~p, ~p)">>).
- -define(LOAD_MARKET_BID, <<"SELECT `id`, `role_id`, `role_name`, `price`, `time` FROM `market_bid_info`">>).
- -define(DEL_ROLE_MARKET_BID, <<"DELETE FROM `market_bid_info` WHERE `id` = ~p AND `role_id` = ~p">>).
- -define(DEL_MARKET_BID, <<"DELETE FROM `market_bid_info` WHERE `id` = ~p">>).
-
-
- %% 玩家竞拍关注
- -define(SAVE_MARKET_LIKE, <<"REPLACE INTO `market_like_info` (`id`, `role_id`, `time`) values (~p, ~p, ~p)">>).
- -define(LOAD_MARKET_LIKE, <<"SELECT `id`, `role_id`, `time` FROM `market_like_info` WHERE `role_id` = ~p">>).
- -define(DEL_MARKET_LIKE, <<"DELETE FROM `market_like_info` WHERE `id` = ~p AND `role_id` = ~p">>).
- -define(DEL_MARKET_LIKE_BY_ID, <<"DELETE FROM `market_like_info` WHERE `id` = ~p">>).
-
- %% 交易市场成交记录
- -define(SAVE_MARKET_DEAL_LOG, <<"REPLACE INTO `market_deal_log` (`id`, `role_id`, `get_role_id`, `get_role_name`, `goods_id`"
- ", `goods_type_id`, `num`, `lev`, `color`, `price`, `sell_type`, `guild_id`, `time`, `deal_time`, `deal_type`, `log_type`"
- ", `extra_attr`) values ~ts">>).
-
- -define(LOAD_MARKET_DEAL_LOG, <<"SELECT `id`, `role_id`, `get_role_id`, `get_role_name`, `goods_id`, `goods_type_id`, `num`, `lev`"
- ", `color`, `price`, `sell_type`, `guild_id`, `time`, `deal_time`, `deal_type`, `log_type`, `extra_attr` FROM `market_deal_log`">>).
-
- -define(DEL_MARKET_DEAL_LOG, <<"DELETE FROM `market_deal_log` WHERE `id` = ~p">>).
- -define(DEL_ALL_MARKET_DEAL_LOG, <<"TRUNCATE TABLE `market_deal_log`">>).
-
-
- %% 角色交易市场成交记录
- -define(SAVE_M_ROLE_DEAL_LOG, <<"REPLACE INTO `market_role_deal_log` (`id`, `role_id`, `rela_role_id`, `goods_type_id`"
- ", `num`, `price`, `sell_type`, `guild_id`, `time`, `deal_time`, `deal_type`, `extra_attr`)"
- " VALUES ~ts">>).
-
- -define(LOAD_M_ROLE_DEAL_LOG, <<"SELECT `id`, `role_id`, `rela_role_id`, `goods_type_id`, `num`, `price`, `sell_type`, `guild_id`"
- ", `time`, `deal_time`, `deal_type`, `extra_attr` FROM `market_role_deal_log` WHERE `role_id` = ~p">>).
-
- -define(DEL_M_ROLE_DEAL_LOG, <<"DELETE FROM `market_role_deal_log` WHERE `id` = ~p AND `role_id` = ~p">>).
- -define(DEL_M_ROLE_DEAL_LOG_BY_TIME, <<"DELETE FROM `market_role_deal_log` WHERE `role_id` = ~p AND `deal_time` <= ~p">>).
-
-
- %% 交易市场入库提醒订阅信息
- -define(SAVE_MARKET_REMINDER, <<"REPLACE INTO `market_reminder_info` (`role_id`, `reminder_list`) values (~p, '~ts')">>).
-
- -define(LOAD_MARKET_REMINDER, <<"SELECT `reminder_list` FROM `market_reminder_info` WHERE `role_id` = ~p">>).
-
- -define(DEL_MARKET_REMINDER, <<"DELETE FROM `market_reminder_info` WHERE `role_id` = ~p">>).
-
-
- %% 交易市场系统补给商品数据
- -define(SAVE_MARKET_SUPPLY, <<"REPLACE INTO `market_goods_supply_info` (`goods_type_id`, `num`, `supply_num`, `time`) values (~p, ~p, ~p, ~p)">>).
- -define(BATCH_SAVE_MARKET_SUPPLY, <<"REPLACE INTO `market_goods_supply_info` (`goods_type_id`, `num`, `supply_num`, `time`) values ~ts">>).
-
- -define(LOAD_MARKET_SUPPLY, <<"SELECT `goods_type_id`, `num`, `supply_num`, `time` FROM `market_goods_supply_info`">>).
-
-
-
- -endif. %% MARKET_HRL
-
-
|