Bug Bounty Program
Program Overview
Raydium's full bug bounty program with ImmuneFi can be found at the below link
The bug bounty program covers Raydium's open-source Concentrated Liquidity Market Maker (CLMM) smart contracts and is focused on preventing thefts and freezing of funds. UI bugs do not qualify for the bug bounty program.
The bug bounty program will launch in partnership with ImmuneFi, however, the below rewards still apply prior to launch.
If you have information on vulnerabilities or bugs, please go through official channels on the ImmuneFi program site: https://immunefi.com/bounty/raydium/
Rewards
Rewards are distributed according to the impact of the vulnerability based on the Immunefi Vulnerability Severity Classification System V2.2.
Smart Contracts
Critical USD 50,000 to USD 505,000
High USD 40,000
Medium USD 5,000
All bug reports must include a Proof of Concept (PoC) demonstrating how the vulnerability can be exploited to impact an asset-in-scope to be eligible for a reward. Critical and High severity bug reports should also include a suggestion for a fix. Explanations and statements are not accepted as PoC and code is required.
Critical smart contract vulnerabilities are capped at 10% of economic damage, primarily taking into consideration funds at risk, but also PR and branding aspects, at the discretion of the team. However, there is a minimum reward of USD 50 000.
The following vulnerabilities are not eligible for a reward:
All vulnerabilities marked in the Ottersec security review are not eligible for a reward.
The CLMM contract emits trading fees and farming yield tokens to LPs. If tokens from the vault or fees were drained by an attacker, however, users would not be able to claim yield and transactions would fail. This is by design and not a vulnerability
Payouts are handled by Raydium directly and are denominated in USD. However, payouts are done in RAY.
Assets in Scope
Only those in the Assets in Scope table are considered as in-scope of the bug bounty program.
Documentation and instruction for PoC can be found here:
A public testnet of Raydium can be found at https://explorer.solana.com/address/proKtffCScMcwkFkPHFcuHawN7mWxRkhyh8PGxkTwYx. However, note that testing on the public testnet is prohibited by the program rules. The public testnet is provided for reference only.
If a Critical Impact can be caused to any other asset managed by Raydium that isn’t on this table but for which the impact is in the Impacts in Scope section below, you are encouraged to submit it for consideration. This only applies to Critical impacts.
Target
Type
Smart Contract - collect_fund_fee
Smart Contract - collect_protocol_fee
Smart Contract - create_operation_account
Smart Contract - admin/mod
Smart Contract - transfer_reward_owner
Smart Contract - update_amm_config
Smart Contract - update_operation_account
Smart Contract - update_pool_status
Smart Contract - close_position
Smart Contract - collect_remaining_rewards
Smart Contract - create_pool
Smart Contract - decrease_liquidity
Smart Contract - increase_liquidity
Smart Contract - initialize_reward
Smart Contract - instructions/mod
Smart Contract - open_position
Smart Contract - set_reward_params
Smart Contract - swap
Smart Contract - swap_router_base_in
Smart Contract - update_reward_info
Smart Contract - big_num
Smart Contract - fixed_point
Smart Contract - full_math
Smart Contract - liquidity_math
Smart Contract - libraries/mod
Smart Contract - sqrt_price_math
Smart Contract - swap_math
Smart Contract - tick_array_bit_map
Smart Contract - tick_math
Smart Contract - unsafe_math
Smart Contract - config
Smart Contract - states/mod
Smart Contract - operation_account
Smart Contract - oracle
Smart Contract - personal_position
Smart Contract - pool
Smart Contract - protocol_position
Smart Contract - tick_array
Smart Contract - access_control
Smart Contract - util/mod
Smart Contract - system
Smart Contract - token
Smart Contract - error
Smart Contract - lib
Impacts in Scope
Only the following impacts are accepted within this bug bounty program. All other impacts are not considered as in-scope, even if they affect something in the assets in scope table.
Critical
Direct theft of any user funds, whether at-rest or in-motion, other than unclaimed yield
Permanent freezing of funds
Vulnerabilities that could freeze user funds permanently or involve the draining or theft of funds without user transaction approval
High
Theft of unclaimed yield
Permanent freezing of unclaimed yield
Temporary freezing of funds for any amount of time
Vulnerabilities that could freeze user funds temporarily or intentionally alter the value of user funds
Medium
Smart contract unable to operate due to lack of token funds
Block stuffing for profit
Griefing (e.g. no profit motive for an attacker, but damage to the users or the protocol)
Theft of gas
Unbounded gas consumption
Out of Scope & Rules
The following vulnerabilities are excluded from the rewards for this bug bounty program:
Attacks that the reporter has already exploited themselves, leading to damage
Attacks requiring access to leaked keys/credentials
Attacks requiring access to privileged addresses (governance, strategist)
Smart Contracts and Blockchain
Incorrect data supplied by third party oracles
Not to exclude oracle manipulation/flash loan attacks
Basic economic governance attacks (e.g. 51% attack)
Lack of liquidity
Best practice critiques
Sybil attacks
Centralization risks
The following activities are prohibited by this bug bounty program:
Any testing with mainnet or public testnet contracts; all testing should be done on private testnets
Any testing with pricing oracles or third party smart contracts
Attempting phishing or other social engineering attacks against our employees and/or customers
Any testing with third party systems and applications (e.g. browser extensions) as well as websites (e.g. SSO providers, advertising networks)
Any denial of service attacks
Automated testing of services that generates significant amounts of traffic
Public disclosure of an unpatched vulnerability in an embargoed bounty
Last updated