diff --git a/docs/developing/gasless.md b/docs/developing/gasless.md deleted file mode 100644 index 51531f94..00000000 --- a/docs/developing/gasless.md +++ /dev/null @@ -1,81 +0,0 @@ ---- -title: Gasless transactions -proofedDate: na -iterationBy: HB -includedInSite: true -approvedBy: na -comment: ---- - -## TL;DR - -- You may arrange a starter pack of gasless transactions within Neon EVM from info@neonevm.org - -## Introduction - -What happens if you do not yet own enough (or any) NEON to pay for your user's first transactions? Don't worry, we have you covered with a starter pack of gasless transactions. - -These transactions are still handled by your chosen [Proxy Operator](docs/developing/connect_rpc.md), however, the transaction cost is covered by us. - -## How does it work? - -1. The end-user initiates a transaction via your dApp. - -> dApps or end-users may use NeonPass to move SPL tokens from Solana or bridge assets across with a partner's bridge - -2. Your dApp makes an RPC request to the Proxy Operator for the gas price. - -:::note - -A code example is provided below to demonstrate how to make a request for the user's transaction to be considered eligible for gasless. - -::: - -3. The Proxy Operator accepts the gasless request, and nominates the Neon account as eligible for N gasless transactions. - -> If the account is not eligible, the gas is calculated as per the [normal flow](/docs/tokens/gas_fees). - -4. The dApp supporting the transaction is provided a gas cost of zero for the applicable transactions. - -6. The user signs the transaction with the zero gas price. - -7. The Proxy Operator executes the transaction. - -> The Proxy Operator pays the SOL gas fee as usual, but the commission is extracted from Neon Foundation, not the end user. - -## How do I arrange to have gasless transactions? - -If you are interested in a starter pack, then reach out to info@neonevm.org. - -You may be wondering does "N" stand for? The minimum number of gasless transactions is 3 per novel Neon Account (i.e. per end user). However, favoured partners may negotiate better deals. - - -## Request gasless transactions - -The following is an extract from a [boilerplate React App](https://codesandbox.io/s/t3fid3?file=/src/hooks/useEthereumTransaction.ts:937-1484) setup to undertake a [Neon swap](https://thirdweb.com/neon-evm-devnet/0xF3eBc32292F4BbFB83DECB97Eb42d95da968f775/sources). - - - -```JavaScript - try - { - // Get gasless transaction if user account is eligible - const rawGasPrice = await axios.post(rpcApiUrl, { - method: 'neon_gasPrice', - params: [{ from: address }], - jsonrpc: "2.0", - id: new Date().getTime() - }) - - tx.gasPrice = rawGasPrice.data?.result; - } catch (e) { - //Else, get standard GAS price - setError('Can\'t retrieve gas price for transaction') - - const rawGasPrice = await web3.eth.getGasPrice(); - - tx.gasPrice = web3.utils.toHex(rawGasPrice); - } finally { - setTx(tx) - } -``` diff --git a/docs/operating/accounts.md b/docs/operating/accounts.md index 0cf31e4d..d30c4d24 100644 --- a/docs/operating/accounts.md +++ b/docs/operating/accounts.md @@ -35,7 +35,7 @@ Operator keys should be spread [evenly between Proxy instances](operator-introdu ## Holder accounts -[Holder accounts](/docs/architecture/solana-accounts/#holder-accounts) are a crucial element of Neon EVM. Neon Proxy creates holder accounts with [rent-exempt balances](https://docs.solana.com/ru/developing/programming-model/accounts#rent) on start. The number of holder accounts created determines the TPS provided to users and can be configured with `PRX_PERM_ACCOUNT_LIMIT`. +[Holder accounts](/docs/architecture/solana-accounts/#holder-accounts) are a crucial element of Neon EVM. Neon Proxy creates holder accounts with [rent-exempt balances](https://solana.com/docs/core/accounts#rent) on start. The number of holder accounts created determines the TPS provided to users and can be configured with `PRX_PERM_ACCOUNT_LIMIT`. You may retrieve a list of Neon Operator key accounts and attached holder accounts (see [**Retrieve your balance**](#query-balance) below). diff --git a/docs/operating/transaction-gas.mdx b/docs/operating/transaction-gas.mdx index f3cc56d8..96d3881b 100644 --- a/docs/operating/transaction-gas.mdx +++ b/docs/operating/transaction-gas.mdx @@ -7,12 +7,12 @@ approvedBy: na comment: todo the zero gas for testing setup (see commented out section) --- -import Formula from '../single-source-snippets/_price_formula.mdx' -import Price from '../single-source-snippets/_gas_price_calc.mdx' +import Formula from '../single-source-snippets/_price_formula.mdx'; +import Price from '../single-source-snippets/_gas_price_calc.mdx'; ## TL;DR -Operators: +Operators: - [Configure the Operator fee](#gas-price-the-operator-fee) - [Configure oracle price sources](#calculation-configuration) @@ -26,29 +26,29 @@ Operators: Neon Proxy enables Neon Operators to earn NEON tokens by processing transactions from Neon users. -The Neon Operator economy is based on providing a custom gas price returned by the eth_gasPrice method. The Neon Proxy calculates the gas price based on the assumption that it should cover the cost of transaction processing on the Solana cluster and include the profit of the Neon Operator. The Neon Operator should include all additional costs (such as hardware rent) plus profit in their Operator Fee. +The Neon Operator economy is based on providing a custom gas price returned by the eth_gasPrice method. The Neon Proxy calculates the gas price based on the assumption that it should cover the cost of transaction processing on the Solana cluster and include the profit of the Neon Operator. The Neon Operator should include all additional costs (such as hardware rent) plus profit in their Operator Fee. -The Neon EVM calculates gas usage by tracking the SOL spent by the Neon Operator during transaction execution. The gas price includes the ratio of NEON and SOL tokens, so the payment from the Neon User to Neon Operator covers all spent SOLs. The ultimate gas price is variable because it depends on the prices of SOL and NEON. +The Neon EVM calculates gas usage by tracking the SOL spent by the Neon Operator during transaction execution. The gas price includes the ratio of NEON and SOL tokens, so the payment from the Neon User to Neon Operator covers all spent SOLs. The ultimate gas price is variable because it depends on the prices of SOL and NEON. ### Pass on gas savings Because the Neon EVM operates on Solana, not Ethereum, it takes advantage of Solana’s inexpensive transaction costs and favorable approach to only charge for storage allocation. This contrasts with Ethereum, where calculations require much more gas, and gas is charged for every change in data stored in Ethereum. As a result, gas usage on Solana is much cheaper than on Ethereum, and the Neon EVM passes these savings on to users. - ## Gas price: the Operator fee The Neon Proxy obtains the current prices of SOL and NEON tokens from the [pyth.network](http://pyth.network) oracles. - + > This ensures that the Neon Operator receives enough NEON to cover the transaction cost in SOL. -The Neon Operator configures the value of `PRX_OPERATOR_FEE`, where 1.0 represents 100% of the potential fee extraction. The value of this parameter is currently set to **1**. +The Neon Operator configures the value of `PRX_OPERATOR_FEE`, where 1.0 represents 100% of the potential fee extraction. The value of this parameter is currently set to **2.5**. Parameter `PRX_GAS_PRICE_SLIPPAGE` provides a buffer against transactions getting stuck in the mempool if there is volatility in prices of $SOL and $NEON. The value of this parameter is currently set to **0.25**. For example: - + + Neon recommended that Neon Operators should initially set `PRX_OPERATOR_FEE` to “1.0” for Mainnet launch. This allows Operators to cover their hardware costs while transaction demands are low. As demand grows, Operators may adjust their fees in response. @@ -59,17 +59,18 @@ Neon recommended that Neon Operators should initially set `PRX_OPERATOR_FEE` to An Operator has two options: - **Recommended**: set up the `PRX_MINIMAL_GAS_PRICE` to 1 as per the default value in EVMs -- Set up the `PRX_MINIMAL_GAS_PRICE` to reject low offers +- Set up the `PRX_MINIMAL_GAS_PRICE` to reject low offers > For example, by setting the gas price minimum to 65 Galan, Neon Proxy rejects transactions with a gas price of less than 65. ## Gas price: oracle configuration -If a transaction request arrives with a gas price below that of the Operator costs + Operator fee, but with a gas price larger than the designated `PRX_MINIMAL_GAS_PRICE`, the Neon Proxy accepts the transaction into mempool. -The Neon transaction will only be executed when the gas price covers Operator costs + Operator fee. If the number of transactions in the mempool grows to the `PRX_MEMPOOL_CAPACITY` (by default =4096), Neon Proxy removes the transaction with the smallest gas price from the mempool to accept transactions with the higher gas price. Therefore, it's not critical to set the `PRX_MINIMAL_GAS_PRICE` to a small value. +If a transaction request arrives with a gas price below that of the Operator costs + Operator fee, but with a gas price larger than the designated `PRX_MINIMAL_GAS_PRICE`, the Neon Proxy accepts the transaction into mempool. +The Neon transaction will only be executed when the gas price covers Operator costs + Operator fee. If the number of transactions in the mempool grows to the `PRX_MEMPOOL_CAPACITY` (by default =4096), Neon Proxy removes the transaction with the smallest gas price from the mempool to accept transactions with the higher gas price. Therefore, it's not critical to set the `PRX_MINIMAL_GAS_PRICE` to a small value. ## Calculation configuration + The Neon Proxy has several settings that accommodate the calculation of gas-price on your required network: - `PRX_PP_SOLANA_URL`: the HTTP/S address of the Solana node (Devnet/Mainnet) that provides the Pyth data account that supplies $NEON and $SOL prices @@ -77,13 +78,13 @@ The Neon Proxy has several settings that accommodate the calculation of gas-pric - `PRX_UPDATE_PYTH_MAPPING_PERIOD_SEC`: the time period to reread the Pyth mapping account. The Neon Proxy reads the Pyth mapping account at the start, gets the addresses of $NEON and $SOL accounts, and rechecks the address from the Pyth Mapping account only after `UPDATE_PYTH_MAPPING_PERIOD_SEC`. It is recommended to set this generously (e.g. 1/3/10 hours), because the price feed accounts don’t change often. - `PRX_MINIMAL_GAS_PRICE`: the minimum gas price to accept transactions into the mempool for on-chain execution - - diff --git a/docs/single-source-snippets/_gas_price_calc.mdx b/docs/single-source-snippets/_gas_price_calc.mdx index 42dea737..e70f7c94 100644 --- a/docs/single-source-snippets/_gas_price_calc.mdx +++ b/docs/single-source-snippets/_gas_price_calc.mdx @@ -1,11 +1,11 @@ -| Component | Value | Units/Definition | Calculation | -| ------------------------ | ------------ | ---------------- | ----------- | -| Sol | 50 | $ | | -| Neon | 0.5 | $ | | -| Ratio | | SOL:NEON | 120 | -| Galan ratio | | Ratio \*10-9 | 0.00000012 | -| Operator fee ratio | 1 | | | -| Proxy Gas Price Slippage | 0.25 | | | -| Adjustor | | 1+fee+slippage | 2.09 | -| **Gas price** | **0.0000002475** | NEON | Gas price formula | -| | **247.5** | Galan | +| Component | Value | Units/Definition | Calculation | +| ------------------------ | ---------------- | ----------------------- | ----------------- | +| Sol | 125 | $ | | +| Neon | 1.5 | $ | | +| Ratio | | SOL:NEON | 83.3333 | +| Galan ratio | | Ratio \*10-9 | 0.0000000833333 | +| Operator fee ratio | 2.5 | | | +| Proxy Gas Price Slippage | 0.25 | | | +| Adjustor | | 1+fee+slippage | 3.75 | +| **Gas price** | **0.0000003125** | NEON | Gas price formula | +| | **312.5** | Galan | diff --git a/docs/tokens/gas_fees.mdx b/docs/tokens/gas_fees.mdx index 4d59ff15..63975de2 100644 --- a/docs/tokens/gas_fees.mdx +++ b/docs/tokens/gas_fees.mdx @@ -4,7 +4,7 @@ proofedDate: 20231204 iterationBy: na includedInSite: true approvedBy: na -comment: Calc sheet https://docs.google.com/spreadsheets/d/1g2ms3DveyPgrG0Gf6cSwq6xhT0AgrrRus_pa9ICHP4w/edit?usp=sharing +comment: Calc sheet https://docs.google.com/spreadsheets/d/1g2ms3DveyPgrG0Gf6cSwq6xhT0AgrrRus_pa9ICHP4w/edit?usp=sharing --- import Formula from '../single-source-snippets/_price_formula.mdx' @@ -24,7 +24,7 @@ The NEON token is used to pay the “gas fees” required for transaction execut :::info Neon EVM will soon support fee payment in the same token as the transaction token for supported tokens e.g. SOL and USDC. -::: +::: > `Gas Fee` = `Gas amount` \* `Gas price` > @@ -85,11 +85,11 @@ The Gas amount is calculated with N=1 iterations and S=0 storage costs: ### Example 2: create a new account Within [Solana](https://docs.solana.com/storage_rent_economics), the rental cost for storage can be paid via one of two methods: -1. Set it and forget it. +1. Set it and forget it. > With this approach, accounts with two years' worth of rent deposited are exempt from network rent charges. By maintaining this minimum balance, the broader network benefits from reduced liquidity and the account holder can rest assured that their data is retained for continual access and usage. -2. Pay per byte. +2. Pay per byte. > The network can charge rent on a per-epoch basis, in credit for the next epoch. This rent is deducted at a rate specified in genesis, in Lamports per Kilobyte-year. @@ -119,4 +119,4 @@ To simplify the user experience, Neon takes option 1 and charges two years' wort ## What next? -If you want to get your dApp started on Neon EVM, you may be wondering how you pay for the first transactions that are required to buy the NEON required to cover gas costs. This is where our starter pack of [gasless transactions](/docs/developing/gasless) comes in. Furthermore, our "coming soon" feature will allow users to pay fees in [alternative tokens](https://neonevm.org/blog/feature-alternative-gas-fee-token). +If you want to get your dApp started on Neon EVM, you may be wondering how you pay for the first transactions that are required to buy the NEON required to cover gas costs. This is where our starter pack of gasless transactions comes in. Furthermore, our "coming soon" feature will allow users to pay fees in [alternative tokens](https://neonevm.org/blog/feature-alternative-gas-fee-token). diff --git a/sidebars.js b/sidebars.js index e5c71d67..383e5226 100644 --- a/sidebars.js +++ b/sidebars.js @@ -12,12 +12,7 @@ const sidebars = { { type: 'category', label: '🧬 Neon EVM Overview', - items: - [ - 'about/why_neon', - 'about/neon_ecosystem', - 'about/how_it_works' - ] + items: ['about/why_neon', 'about/neon_ecosystem', 'about/how_it_works'] }, { type: 'doc', @@ -32,20 +27,13 @@ const sidebars = { { type: 'category', label: '💰 Tokens', - items: [ - 'tokens/neon_token', - 'tokens/gas_fees', - 'tokens/token_list' - ] + items: ['tokens/neon_token', 'tokens/gas_fees', 'tokens/token_list'] }, { type: 'doc', label: 'Neon Proxy API', id: 'api/neon-api' }, { type: 'category', label: '💬 FAQ', - items: [ - 'faq/neon-brief-faq', - 'faq/neonpass' - ] + items: ['faq/neon-brief-faq', 'faq/neonpass'] }, { type: 'html', value: '