Разработка программы лояльности криптобиржи
Программа лояльности удерживает трейдеров на платформе через систему вознаграждений за активность. В крипто-контексте это сложнее обычного retail loyalty: токеномика, fee discounts, staking rewards — всё это должно быть сбалансировано, чтобы не создавать инфляционного давления на exchange токен.
Компоненты программы лояльности
Tier система (уровни)
Классический подход: уровни определяются по объёму торгов за 30 дней или по количеству застейканных exchange токенов:
| Tier | Объём/30d | Или стейкинг | Maker fee | Taker fee | Cashback |
|---|---|---|---|---|---|
| Bronze | < $10K | < 100 BNB | 0.10% | 0.10% | 0% |
| Silver | $10K+ | 100+ BNB | 0.08% | 0.09% | 5% |
| Gold | $100K+ | 500+ BNB | 0.06% | 0.08% | 10% |
| Platinum | $1M+ | 2000+ BNB | 0.04% | 0.06% | 15% |
| Diamond | $10M+ | 10000+ BNB | 0.02% | 0.04% | 20% |
Binance BNB — классический пример: холдинг BNB даёт 25% скидку на все fees плюс используется для определения тира.
Exchange токен как механизм лояльности
// Упрощённая схема fee discount через холдинг токена
contract FeeDiscountCalculator {
address public exchangeToken;
mapping(address => uint256) public stakedBalance;
function getFeeDiscount(address trader) external view returns (uint256) {
uint256 staked = stakedBalance[trader];
if (staked >= 10_000 * 1e18) return 50; // 50% скидка
if (staked >= 2_000 * 1e18) return 40;
if (staked >= 500 * 1e18) return 30;
if (staked >= 100 * 1e18) return 20;
if (staked >= 10 * 1e18) return 10;
return 0;
}
function getEffectiveFee(
address trader,
uint256 baseFee
) external view returns (uint256) {
uint256 discount = this.getFeeDiscount(trader);
return baseFee * (100 - discount) / 100;
}
}
Points система
Накопительные баллы (loyalty points) за торговую активность, которые можно обменивать на rewards:
class LoyaltyPointsService:
# Базовые правила начисления
EARN_RATES = {
'spot_trading': 1, # 1 point за $1 volume
'futures_trading': 0.5, # 0.5 points за $1 (меньше маржа)
'deposit': 100, # 100 points за первый депозит
'kyc_complete': 500, # 500 points за KYC
'mobile_app_trade': 1.5, # бонус за мобильное приложение
}
async def add_points_for_trade(self, user_id: str, trade: Trade):
base_points = trade.volume_usd * self.EARN_RATES['spot_trading']
# Множитель за tier
tier = await self.get_user_tier(user_id)
tier_multiplier = {'bronze': 1.0, 'silver': 1.2, 'gold': 1.5, 'platinum': 2.0}
multiplier = tier_multiplier.get(tier, 1.0)
# Бонус активности (streak)
streak_bonus = await self.get_streak_bonus(user_id)
total_points = int(base_points * multiplier * streak_bonus)
await self.db.add_points(user_id, total_points, 'trade', trade.id)
await self.check_tier_upgrade(user_id)
Streak механика
Ежедневные серии торговли поощряют retention:
async def update_trading_streak(self, user_id: str, trade_date: date):
profile = await self.db.get_loyalty_profile(user_id)
last_trade_date = profile.last_trade_date
if last_trade_date == trade_date:
return # уже торговали сегодня
if last_trade_date == trade_date - timedelta(days=1):
new_streak = profile.current_streak + 1
else:
new_streak = 1 # streak сломан
max_streak = max(profile.max_streak, new_streak)
# Milestone rewards
milestones = {7: 500, 30: 3000, 90: 15000, 365: 100000}
if new_streak in milestones:
await self.award_milestone(user_id, milestones[new_streak])
await self.db.update_streak(user_id, new_streak, max_streak, trade_date)
Redemption (обмен наград)
Баллы можно обменивать на:
- Fee credits: оплата следующих fee баллами
- Exchange токены: покупка по фиксированному курсу
- NFT badges: цифровые ачивменты на основе достижений
- Hardware wallet: физические призы за крупные накопления
- Доступ к закрытым функциям: ранний доступ к новым торговым парам, повышенные лимиты
class RewardRedemption:
CATALOG = {
'fee_credit_10': {'points': 1000, 'value_usd': 10, 'type': 'fee_credit'},
'exchange_token_100': {'points': 8000, 'value_usd': 90, 'type': 'token'},
'hardware_wallet': {'points': 150_000, 'value_usd': 70, 'type': 'physical'},
}
async def redeem(self, user_id: str, reward_id: str):
reward = self.CATALOG.get(reward_id)
if not reward:
raise InvalidReward
balance = await self.db.get_points_balance(user_id)
if balance < reward['points']:
raise InsufficientPoints
async with self.db.transaction():
await self.db.deduct_points(user_id, reward['points'])
await self.fulfill_reward(user_id, reward)
Антизлоупотребление
Программы лояльности привлекают злоупотребления: wash trading ради баллов, множественные аккаунты. Защиты:
- Баллы начисляются только за net volume (не за самоторговлю)
- Детекция wash trading: одновременные bid/ask с похожих устройств
- Ограничение maximum points per day независимо от объёма
- KYC required для любого redemption выше порога
Хорошо спроектированная программа лояльности увеличивает retention на 20-40% и volume на 15-30%. Плохо спроектированная — создаёт drain на P&L через злоупотребления.







