From 04d088ca68c1a95ed34de1a7cccab1cf459e04f7 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Thu, 17 Oct 2024 10:18:41 +0100
Subject: [PATCH 01/18] Remove community section
---
docs/developers/community/hackathons.mdx | 164 -----------------------
sidebars.js | 16 ---
2 files changed, 180 deletions(-)
delete mode 100644 docs/developers/community/hackathons.mdx
diff --git a/docs/developers/community/hackathons.mdx b/docs/developers/community/hackathons.mdx
deleted file mode 100644
index a2cbe16de8..0000000000
--- a/docs/developers/community/hackathons.mdx
+++ /dev/null
@@ -1,164 +0,0 @@
----
-title: Hackathons
-image: /img/socialCards/hackathons.jpg
----
-
-Looking to hack on Linea and win some bounties? Here's the page where you can find all the information you need to know to get started!
-
-All winners have the opportunity to bring their project to fruition through a variety of Consensys programs:
-
-- Linea Ecosystem Investment Alliance
-- MetaMask Grants DAO
-- Consensys Scale program
-- Linea Builders Club
-
-And be featured on [X](https://twitter.com/lineabuild), [Linea Farcaster](https://warpcast.com/linea), and livestreams!
-
-:::info
-[**Get started through the Linea Builder Launchpad**](https://aspecta.id/builder-matrix/Linea-builder-launchpad)
-to find the one-stop shop for claiming builder NFTs, applying for the Linea Builders Club, getting
-access to developer workshops, and other Linea developer activations.
-
-[**Apply for the Linea Builders Club**](https://linea.deform.cc/linea-builders-club) to get exclusive
-access to tech talks, events, the Linea team, and more!
-
-[**Join the Consensys Developer Chat**](https://t.me/+rI-iPLacQXQ5MDVh) for IRL hackathons and get
-connected with the MetaMask, Phosphor, and Verax teams!
-:::
-
-## Helpful links
-
-- **Get test ETH and get help**
- - Use our [faucet or bridge to get mainnet or testnet ETH](../../users/move-funds/index.mdx). Otherwise, [ping us in our Telegram channel](https://t.me/+JMGAPixWzKQyMDY5) or find us IRL at the hackathon to request test ETH directly!
-- **Deploy a smart contract**
- - Follow our [step-by-step quickstart on how to deploy and verify a smart contract](../../developers/quickstart) with a variety of tools like Hardhat, Foundry, and more!
-- **Get access to Verax private beta**
- - Send your account address in our [Telegram chat](https://t.me/+rI-iPLacQXQ5MDVh) to get access to Verax private beta! Here's a [quick tutorial](https://docs.ver.ax/verax-documentation/developer-guides/tutorials/from-a-schema-to-an-attestation) on how to leverage Verax.
-- [**Walkthroughs and use cases**](https://youtube.com/playlist?list=PLJ06SwdM0bLrA-3EGRji4W0QI8fyA8PyW&si=vQsXrtFVUsXhygJ0)
-- [**Tutorials and guides**](../guides/community/index.mdx)
-
-## The Linea Dev Cook-Off
-
-**Create, Iterate, and Innovate!** :frog:
-
-Every month, Linea will host a mini, online buildathon to celebrate and reward continuous hacking!
-We will have a $10,000 prize pool to distribute to qualified projects.
-
-You can create a new project, iterate on an ongoing one, or revive and refresh that old side
-project you've been wanting to get back to.
-
-That means you don't need to start from scratch! The only requirement is that you're building with
-Linea, made progress on your project in the current month, and you've posted about your project on
-social (and included a frog somewhere)!
-
-This is a great opportunity to win some small prizes alongside your regular building, improve on
-past hackathon projects, and get exposure to the Linea team and community!
-
-Literally, win cool prizes for just shipping.
-
-
-
-
-
-
-
-#### Things to note
-- You can submit on behalf of a formal organization (profit-seeking company or DAO), but priority will be given to independent hackers
-- You can make multiple submissions
-- You can use old code!
-- Bonus points for adding a frog somewhere in your submission :wink: :frog:
-- Bonus points will be awarded to projects that incorporate the partner [tooling](../tooling/index.mdx)
-
-#### Examples of acceptable work
-- Flappy bird, but with frogs :frog: and on-chain
-- A step-by-step, published tutorial on how to build a (maybe frog-themed :frog:) dapp on Linea
-- A translated guide on how to build on Linea
-- A published video explainer on how to build with Linea or Linea concepts
-- Improving the UI of a hackathon project you built before
-- A Dune dashboard demonstrating something cool about Linea activity
-- An [onthis.xyz](https://onthis.xyz) shortcut to improve onchain UX
-
-#### Judging criteria
-- Functionality and technicality - How complete and complex is the project?
-- Really great UX - How easy is it for a new user to navigate or how easy it is to follow the tutorial?
-- Originality - How original and innovative is the project? Is it pushing the boundaries of on-chain use cases?
-- Goshdarnit this is cool - A catch-all vibe check for projects that are simply fun to interact with
-
-#### What counts as a qualifying submission
-
-If you're submitting a dapp or Farcaster frame...
-- Open source, public Github repo
-- Non-trivial progress made on your project during that month (as measured by your Github commit history)
-- Verified smart contract deployed on Linea Sepolia or Linea Mainnet
-- Working product demo link
-- Short video explainer and demo (less than 5 minutes) of your project and, if it's not a new project, what changes you made that month
-- Posted and tagged on Twitter ([@lineabuild](http://x.com/lineabuild)) or Farcaster ([@linea](https://warpcast.com/linea))
-
-If you're submitting a tutorial...
-- Open source, public Github repo
-- Published tutorial link
-- Non-trivial progress made on your project during that month (as measured by your Github commit history)
-- Bonus points for publishing an accompanying video explainer
-- Posted and tagged on Twitter ([@lineabuild](http://x.com/lineabuild)) or Farcaster ([@linea](https://warpcast.com/linea))
-
-If you're submitting a Dune analytics dashboard...
-- Dune dashboard link
-- Non-trivial progress made on your project during that month
-- Posted and tagged on Twitter ([@lineabuild](http://x.com/lineabuild)) or Farcaster ([@linea](https://warpcast.com/linea))
-
-Ultimately, a "high-quality" submission is quite subjective, but you can imagine invalid submissions as something like unusable demos, projects that are simply slightly modified clones of other projects, and otherwise scrapped together hacks that took little to no effort to put together.
-
-#### How to submit
-
-Register and submit [**here**](https://www.hackquest.io/en/hackathon/explore/Linea-Oct-Nov-Dev-Cook-off)
-
-### October-November 2024 (10,000 USDT in prizes!) :frog:
-
-This month, you can win a share of an 5,000 USDT prize pool for general track submissions, or a
-share of another 5,000 USDT pool for integrating Verax/Hemera. [See the Hackquest page](https://www.hackquest.io/en/hackathon/explore/Linea-Oct-Nov-Dev-Cook-off).
-
-**Due 23:59(GMT+8), November 30, 2024**
-
-#### General track: 5,000 USDT prize pool
-
-We'll be distributing 8,000 USDT amongst the top qualified projects. This can take the form of two
-outstanding projects receiving 2,500 USDT each, 10 projects receiving 500 USDT each, or, in the case
-that no submissions meet our quality bar, no prize being distributed for that month.
-
-#### Verax/Hemera track: 5,000 USDT prize pool
-
-There are five themes we suggest for hackers trying to integrate with Verax/Hemera. Prize money
-will be distributed among qualifying projects that successfully integrate with Verax/Hemera, based
-on these themes:
-
-- Theme 1: Linea Ecosystem Data Analytics App/Dashboard
-- Theme 2: SocialFi
-- Theme 3: DeFi
-- Theme 4: GameFi
-- Theme 5: DiD (Decentralized Identity)
-
-For more detailed information about building for his track, please refer to the "Verax/Hemera
-Themes” section on [Hackquest](https://www.hackquest.io/en/hackathon/explore/Linea-Oct-Nov-Dev-Cook-off).
-
-:::note
-A full list of additional resources is available on Hackquest.
-:::
-
-#### Blockchain for Good Award (BGA): up to 500 USDT
-
-The BGA award of 300-500 USDT is available on top of the main 5,000 USDT prize pool for this track,
-awarded for projects that meet one or more of the UN's 17 Sustainable Development Goals, and
-available for 1-2 projects
-
-Entry is optional. To enter, however, you do not need to submit or prepare any additional materials.
-
-## Other hackathons
-
-Look forward to finding us IRL at:
-- [ETHGlobal Bangkok](https://ethglobal.com/events/bangkok)
-- [Builder Nights Bangkok](https://lu.ma/80mtze59)
-- [Devcon Bangkok](https://devcon.org/en/)
-- [ETHDenver](https://www.ethdenver.com/)
diff --git a/sidebars.js b/sidebars.js
index 61c01c7c2f..2d52cb3f33 100644
--- a/sidebars.js
+++ b/sidebars.js
@@ -441,22 +441,6 @@ const sidebars = {
},
],
},
- {
- type: "category",
- label: "Community",
- link: {
- type: "doc",
- id: "developers/community/hackathons",
- },
- items: [
- "developers/community/hackathons",
- {
- type: "link",
- label: "Bug bounty program",
- href: "https://immunefi.com/bounty/linea/",
- },
- ],
- },
],
architectureSidebar: [
"architecture/index",
From 30408da50df18632cffde081ff2619cb3dcf1c09 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Thu, 17 Oct 2024 10:55:36 +0100
Subject: [PATCH 02/18] Relocate glossary and add redirects
---
.../zero-knowledge-glossary/index.mdx | 0
docusaurus.config.js | 56 +++++++++++++------
2 files changed, 40 insertions(+), 16 deletions(-)
rename docs/{users => }/zero-knowledge-glossary/index.mdx (100%)
diff --git a/docs/users/zero-knowledge-glossary/index.mdx b/docs/zero-knowledge-glossary/index.mdx
similarity index 100%
rename from docs/users/zero-knowledge-glossary/index.mdx
rename to docs/zero-knowledge-glossary/index.mdx
diff --git a/docusaurus.config.js b/docusaurus.config.js
index a4b5c98cd3..74a099d84a 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -295,11 +295,15 @@ const config = {
from: "/developers/deploy-smart-contracts",
},
{
- to: "/users/zero-knowledge-glossary",
- from: ["/reference/glossary", "/zero-knowledge-glossary"],
+ to: "/zero-knowledge-glossary",
+ from: [
+ "/reference/glossary",
+ "/zero-knowledge-glossary",
+ "/users/zero-knowledge-glossary"
+ ],
},
{
- to: "/users",
+ to: "/",
from: [
"/get-started",
"/get-started/fund",
@@ -307,15 +311,23 @@ const config = {
"/get-started/quickstart",
"/use-zkevm",
"/use-linea/index.md",
+ "/users",
+ "/users/index.mdx",
],
},
{
- to: "/users/move-funds/set-up-your-wallet",
- from: "/build-on-linea/use-linea-testnet/set-up-your-wallet",
+ to: "/",
+ from: [
+ "/build-on-linea/use-linea-testnet/set-up-your-wallet",
+ "/users/move-funds/set-up-your-wallet",
+ ],
},
{
- to: "/users/move-funds/fund",
- from: "/build-on-linea/use-linea-testnet/fund",
+ to: "/",
+ from: [
+ "/build-on-linea/use-linea-testnet/fund",
+ "/users/move-funds/fund",
+ ],
},
{
to: "/developers/quickstart/info-contracts",
@@ -330,12 +342,18 @@ const config = {
from: "/build-on-linea/use-linea-testnet/bridge-funds",
},
{
- to: "/users/move-funds/bridge",
- from: "/build-on-linea/use-linea-testnet/bridge-funds/usdc-bridge",
+ to: "/",
+ from: [
+ "/build-on-linea/use-linea-testnet/bridge-funds/usdc-bridge",
+ "/users/move-funds/bridge",
+ ],
},
{
- to: "/users/move-funds/bridge",
- from: "/build-on-linea/use-linea-testnet/bridge-funds/use-etherscan",
+ to: "/",
+ from: [
+ "/build-on-linea/use-linea-testnet/bridge-funds/use-etherscan",
+ "/users/move-funds/bridge",
+ ],
},
{
to: "/developers/guides/gas/gas-fees",
@@ -370,12 +388,18 @@ const config = {
from: "/use-mainnet/bridges-of-linea",
},
{
- to: "/users/move-funds/fund",
- from: "/use-mainnet/fund",
+ to: "/",
+ from: [
+ "/use-mainnet/fund",
+ "/users/move-funds/fund",
+ ],
},
{
- to: "/users/move-funds/set-up-your-wallet",
- from: "/use-mainnet/set-up-your-wallet",
+ to: "/",
+ from: [
+ "/use-mainnet/set-up-your-wallet",
+ "/users/move-funds/set-up-your-wallet",
+ ],
},
{
to: "/developers/quickstart/info-contracts",
@@ -485,7 +509,7 @@ const config = {
from: "/build-on-linea/quickstart",
},
{
- to: "/users",
+ to: "/",
from: "/use-mainnet",
},
{
From f732c0837ae8472d32f9b815f8475fc9530dc9d3 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Thu, 17 Oct 2024 10:55:56 +0100
Subject: [PATCH 03/18] Remove /users
---
docs/users/index.mdx | 22 --
docs/users/linea-voyage/index.mdx | 8 -
docs/users/linea-voyage/linea-surge/index.mdx | 21 --
.../linea-surge/linea-surge-model.mdx | 250 ------------------
.../linea-surge/linea-surge-overview.mdx | 65 -----
docs/users/linea-voyage/lxp/index.mdx | 149 -----------
docs/users/move-funds/bridge.mdx | 42 ---
docs/users/move-funds/fund.mdx | 78 ------
docs/users/move-funds/index.mdx | 8 -
docs/users/move-funds/set-up-your-wallet.mdx | 70 -----
10 files changed, 713 deletions(-)
delete mode 100644 docs/users/index.mdx
delete mode 100644 docs/users/linea-voyage/index.mdx
delete mode 100644 docs/users/linea-voyage/linea-surge/index.mdx
delete mode 100644 docs/users/linea-voyage/linea-surge/linea-surge-model.mdx
delete mode 100644 docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx
delete mode 100644 docs/users/linea-voyage/lxp/index.mdx
delete mode 100644 docs/users/move-funds/bridge.mdx
delete mode 100644 docs/users/move-funds/fund.mdx
delete mode 100644 docs/users/move-funds/index.mdx
delete mode 100644 docs/users/move-funds/set-up-your-wallet.mdx
diff --git a/docs/users/index.mdx b/docs/users/index.mdx
deleted file mode 100644
index 49f016d1fa..0000000000
--- a/docs/users/index.mdx
+++ /dev/null
@@ -1,22 +0,0 @@
----
-title: About Linea
-sidebar_position: 2
-image: /img/socialCards/about-linea.jpg
----
-
-Linea is an Ethereum layer 2 (L2) network that provides access to innovative Web3
-projects at significantly lower costs compared to Ethereum. It's compatible with the
-Ethereum Virtual Machine (EVM), allowing users to deploy existing Ethereum applications and
-develop new ones that would be too costly on Mainnet. It also enables the community to
-use those dapps, **at a fraction of the cost**, and at **multiples the speed** of Mainnet.
-
-Linea delivers unrivaled network security with its cryptographically secure zk-rollup infrastructure,
-comprehensive security partnerships, and security-oriented ecosystem culture. View the
-[Linea architecture](../architecture/index.mdx) for more information.
-
-You can get started by [funding your Linea account](./move-funds/index.mdx) using the
-fiat onramp in MetaMask Portfolio or by bridging over funds.
-
-:::tip
-If you run into a problem, view the [Linea Support page](https://support.linea.build/hc/en-us) and let us know.
-:::
diff --git a/docs/users/linea-voyage/index.mdx b/docs/users/linea-voyage/index.mdx
deleted file mode 100644
index 52435982e1..0000000000
--- a/docs/users/linea-voyage/index.mdx
+++ /dev/null
@@ -1,8 +0,0 @@
----
-title: Linea Voyage
-image: /img/socialCards/linea-voyage.jpg
----
-
-import DocCardList from '@theme/DocCardList';
-
-
diff --git a/docs/users/linea-voyage/linea-surge/index.mdx b/docs/users/linea-voyage/linea-surge/index.mdx
deleted file mode 100644
index 53c93645b0..0000000000
--- a/docs/users/linea-voyage/linea-surge/index.mdx
+++ /dev/null
@@ -1,21 +0,0 @@
----
-title: 'Linea Voyage: The Surge'
-image: /img/socialCards/linea-voyage-the-surge.jpg
----
-
-Linea Surge is an LXP-driven program that enables people to collect LXP-L in return for having
-assets on Linea and deploying those assets into protocols.
-
-The goal for The Surge is to allow users that provide liquidity on the network to collect LXP-L.
-LXP-L is similar to the system we have in place today for LXP, but is collected by contributing
-liquidity to Linea.
-
-A core focus is on the expansion of available assets through new applications
-and DeFi use cases built on Linea. Additional liquidity brought by new applications sustainably
-supports additional volume, in turn impacting on the sustainability of the liquidity through
-increased fees for liquidity providers and increasing the percentage of ecosystem trading
-activity compared to other venues. This constitutes something of a flywheel network effect for
-the ecosystem.
-
-The following sections provide further detail. In the overview page, we will explore the program,
-before explaining the math behind it in _Point incentive design_.
diff --git a/docs/users/linea-voyage/linea-surge/linea-surge-model.mdx b/docs/users/linea-voyage/linea-surge/linea-surge-model.mdx
deleted file mode 100644
index b9d93726b8..0000000000
--- a/docs/users/linea-voyage/linea-surge/linea-surge-model.mdx
+++ /dev/null
@@ -1,250 +0,0 @@
----
-title: Point incentive design
-sidebar_position: 2
-image: /img/socialCards/point-incentive-design.jpg
----
-
-:::note
-
-This allocation methodology is subject to minimal change.
-
-:::
-
-
-## LXP-L function
-
-LXP-L is intended to recognize and incentivize meaningful contributors within the Linea ecosystem.
-These points encompass a variety of actions, such as being an early adopter, owning assets on Linea,
-engaging with different protocols within the ecosystem, demonstrating past involvement across
-other blockchain networks, and more.
-
-The overarching function is as follows:
-
-
-$$
-P_{u} = DF \left[ EA \cdot \int_{0}^{T} \left( m_{pl} PL_{t} + \sum_{v \in V} m_{v,t} AP_{v,t} \right) dt + m_{rp} RP + m_{vet} P_{v} \right]
-$$
-
-
-
-This point formula can be extracted into three terms:
-
-$$
-P_{u} = DF \cdot \left( P_{E} + P_{R} + P_{V} \right)
-$$
-
-$P_{u}$ represents the LXP-L user _u_ earns. There are three ways users can earn points:
-
-- Ecosystem Points $\left(P_{E} \right)$
-- Referral Points $\left(P_{R} \right)$
-- Veteran Points $\left(P_{V} \right)$
-
-## Formula explanation
-
-### Decay function (DF)
-
-To gradually adapt the number of points and incentivize early participation in the program,
-we're employing a decay function that decreases at every Volt (1 month). At the start of the
-program, this function will be 1, and will be reduced by a factor of 10% after every Epoch,
-so the overall number of points will be 10% lower every month.
-
-### Ecosystem Points
-
-Ecosystem points incentivize onboarding assets onto Linea, along with user activity across
-various ecosystem protocols. It is calculated as follows:
-
-$$
-P_{E} = EA \cdot \int_{0}^{T} \left( m_{pl} PL_{t} + \sum_{v \in V} m_{v,t} AP_{v,t} \right) dt
-$$
-
-Where:
-
-- _EA_ is the [early adopter modifier](#early-adopter-modifier) that serves as a decay function
-across time
-- $m_{pl}$ is the multiplier for passive liquidity
-- $PL_{t}$ is the amount of passive liquidity held in wallet
-- _$V$_ is the set of DeFi verticals participating in the program
-- $m_{v,t}$ is the multiplier for vertical _v_ at time _t_
-- $AP_{v,t}$ is the amount of activity points earned in vertical _v_ at time _t_ weighted by the
-specific asset class that is in use across the different verticals. Asset classes will come with
-a different multiplier $\left(m_{a,t} \right)$ that will change the value of individual
-$AP_{v,t}$ to ensure a healthy ecosystem that is not concentrated in few asset classes
-(usually ETH/stables).
-
-
-
-
-
-
-
-In this specific example—which will apply to Volt 1 at the beginning of the program—we're using the
-$m_{a,t}$ multiplier to maximize the points for ETH and LRT liquidity on DEXs and lending
-platforms, with a lower weight on stables and LST and a minor weight for RWA and others. We are
-also maximizing liquidity on third party bridges pools (AMM) for ETH and stables to provide a better
-bridging experience to users.
-
-### Early adopter modifier
-
-_EA_ is the early adopter modifier, a multiplier that recognizes early activity on Linea. Early
-activity is defined as activity occurring before the start of the program.
-
-This multiplier will be constant within the time period of a single Volt (1 month) and will
-reduce over successive Volts. This is used to recognize the contributions of users that have
-provided liquidity on Linea since mainnet went live and users bridging active liquidity to
-Linea after the announcement but before The Surge program starts.
-
-The way it works is by looking at historical activity of each address that is eligible to get
-$P_{E}$.
-
-The _EA_ multiplier will be applied to your account if:
-
-- The address had at least one active liquidity event across any smart contract on Linea (also
-ones not included in the program), AND;
-- At least one active liquidity event was $\geq$ 0.1 ETH or WETH.
-
-Since the Surge has started, it is no longer possible to obtain early adopter status. This was only
-possible if your address had active liquidity events before the Surge was announced or before it
-started.
-
-The _EA_ multiplier will start at 1.5 at the beginning of the program and will be reduced at
-the end of each Volt, before reaching the value of 1 for the rest of the program:
-
-| Volt | EA multiplier |
-| :-------- | -------- |
-| Volt 1 | 1.5 |
-| Volt 2 | 1.3 |
-| Volt 3 | 1.2 |
-| Volt 4 | 1 |
-| Volt 5 | 1 |
-| Volt 6 | 1 |
-
-### DEX objective functions
-
-For Linea's DEXs, we've implemented a points incentive program tailored to recognize active
-liquidity providers for their crucial role. In this program, user points are calculated
-from the market depth of their liquidity positions and factoring in the respective pools'
-realized volatility. This methodology ensures that points are accrued per block at a rate
-proportional to the effectiveness of the liquidity provided. In essence, the deeper the market
-depth from your liquidity position, the greater the accumulation of points.
-
-Market depth for some percentage X% is calculated for a given user, pool, and block as the USD
-value of the liquidity in range X% above and X% below the active price of the pool. This function
-is formulated for various AMM structures to use the appropriate price impact mechanism for each.
-With this definition of market depth, we define the market depth score as a weighted average of
-market depth at several realized volatility levels (RV30, 2RV30, and 3RV30), with weights that
-reflect the likelihood of the given price being reached. It is the measure of liquidity across
-a certain price range, adjusted for the past volatility of the token pair. At each block,
-users will gain points according to this market depth score.
-
-This system is designed to fine-tune liquidity provision across different asset types: in a
-concentrated liquidity market maker for example, the methodology requires tighter allocations
-for stablecoin pools to reflect their lower volatility, while allowing for broader allocations
-in more volatile pools. Our aim is to optimize liquidity throughout the ecosystem, thereby
-minimizing price impact for all DEX users. By participating, liquidity providers not only
-boost the tokens they receive by allocating assets more strategically, but also contribute
-to the overall health and efficiency of the market.
-
-## Lending objective functions
-
-For lending protocols, our objective function prioritizes tokens supplied and the total revenue
-to suppliers from lending interest.
-
-$$
-O_{{Lending}} = {Value of Non Recursive Tokens Supplied} + \beta_{R} \left({Supplier Revenue from Non Recursive Interest} \right)
-$$
-
-$ \beta_{R}$ is a parameter that sets the value of income relative to value supplied. To handle
-income in a symmetric way across verticals, it is the same $\beta_{R}$ used in the DEX objective
-function.
-
-We distinguish supplier revenue from interest to exclude supplier revenue from Linea incentives.
-We also exclude any and all recursive borrowing, both for its impact on supply and its impact
-on interest payments.
-
-Recursive borrowing is borrowing a token using the same token as collateral. Although lending
-protocols allow this, it is not an intended use case. The user will always pay a higher interest
-rate on their borrowed tokens than they receive on their supplied tokens, essentially gifting
-money to the protocol for no gain.
-
-However, when incentive programs pay users for the value they supply, it can make recursive
-borrowing profitable. In many past incentive programs, users have opened recursive borrow
-positions to farm incentives, removing them all when the incentive program ends.
-
-To avoid this, we simply exclude all recursive borrowing, counting only the net value of each
-token supplied by a given account. We also subtract the share of interest paid by recursive
-borrowers from the supplier revenue. This makes the recursive strategy unappealing, and we do
-not expect any users to attempt it.
-
-### Decentralized trading objective functions
-
-#### Taker incentives
-
-Trading incentives are set with the following equation:
-
-
-$$
-\text{Trader Incentives}_{i} = \min \left( \text{Total Trader Incentives} \times \frac{\text{Trade volume}_{i}}{\text{Total trade volume}}, \text{fees}_{i} \right)
-$$
-
-
-The trader incentives allocated to user _i_ are weighted by the user’s share of total trade volume.
-However, each user cannot receive more incentives than the total amount of trading fees they paid
-during the grant period. Incentives that would exceed fees are redistributed to the rest of the
-trader pool. If total trading fees are less than the total trader incentives, extra incentives
-will be rolled into the next grant period.
-
-#### Maker incentives
-
-We define the market depth score in the same way as the [DEX liquidity section](#dex-objective-functions).
-
-### Bridge liquidity objective functions
-
-Third-party bridges typically operate by facilitating the exchange of wrapped versions of
-assets like ETH and stablecoins, transitioning them onto Linea where they are exchanged for the
-original assets. This process relies on substantial liquidity pools within automated market
-makers (AMMs) to ensure efficient swaps with minimal slippage.
-
-Similar to the [DEX section](#dex-objective-functions), points will be allocated based on a
-market depth score to improve liquidity and minimize slippage for meaningful pairs.
-
-### Objective functions for other verticals
-
-For all other types of protocols, we leverage TVL as the primary metric to allocate points.
-
-### Referral points
-
-Referral points incentivize cooperative onboarding activities. These points are calculated by
-the formula:
-
-$$
-P_{R}=m_{rp}RP_{u}
-$$
-
-where:
-
-- $RP_{u}$ is the total referral points earned by user _u_
-- $m_{rp}$ is the multiplier for referral activity
-
-To obtain the total referral points earned by user _u_, we sum over eligible points
- $\hat{P}_{r}$ generated by _r_ wallets that have activated user _u_'s referral code.
-
-$$
-RP_{u} = \sum_{r \in R_u} \hat{P}_{r}
-$$
-
-Eligible points $\hat{P}_{r}$ are points generated through on-chain wallet activities and, to
-prevent second-order referral effects, do not include referral points. The referral multiplier
-$m_{rp}$ is optimized throughout the program to incentivize early onboarding efforts and adjust
-for network growth.
-
-### Veteran points
-
-Veteran points $P_{V}$ and the multiplier $m_{vet}$ provide additional points to users who have
-demonstrated notable activity and partnership in the past, inviting active blockchain participants
-to join the Linea network.
-
-This is a recurring function of ecosystem points, acting as an additional multiplier only for a
-specific list of addresses provided by the Linea team.
diff --git a/docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx b/docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx
deleted file mode 100644
index 426189f1da..0000000000
--- a/docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx
+++ /dev/null
@@ -1,65 +0,0 @@
----
-title: Overview
-sidebar_position: 1
-image: /img/socialCards/overview.jpg
----
-
-Once it starts, the program will last for 6 months, or until the network TVL reaches $3B, whichever
-happens first. The Surge is structured into six Volts (epochs), each one month long. Why Volts?
-Because if we reach the target we will let the epoch run till the end of the Volt. And we can play
-with themes: every Volt will have narratives and featured partners, and provide educational
-content — each Volt a distinct experience.
-
-## Early adopters
-
-The points system will start when the program goes live but we already have users and early
-adopters who have provided liquidity on the network. It's important to acknowledge what
-has been done so far. For this reason, the formula that defines points has an early adopter
-modifier that provides more points to users that started contributing earlier than others.
-
-## Dashboard
-
-After go-live, OpenBlock Labs will provide a dashboard where anyone can verify the number
-of LXP-L collected within The Surge. This will feature all necessary information for a user to
-observe their activity and points received.
-
-## Sybil
-
-While in previous campaigns we tied the minting of LXP to addresses that hold Proof Of Humanity
-to specifically protect the LXP points from bot farms and reduce sybils, in this case there's
-no such need. Providing a unit of points per $ locked is an action that does not incentivize bot
-activity: a user will get the same amount of points regardless of whether they concentrate all
-the liquidity in a single wallet or split it among thousands of addresses. This makes the
-experience even easier and more enjoyable for users who bridge liquidity to Linea.
-
-## Security and UX
-
-Dapps that participate in the program will have a great opportunity to grow, but our main
-priorities at Linea are security and UX. We can't afford to assign LXP-L points to dapps that
-put users' funds at risk, so this is the right time to raise the bar for security at an ecosystem
-level. Every dapp that is on the ecosystem portal today is audited by one of the Linea security
-partners, and in order to be eligible for inclusion in the program, a dapp must satisfy the
-following criteria:
-
-- Meet UX requirements from an established framework
-- Satisfy at least one of the two following conditions:
- - Has been live for at least one year on any other EVM chain with a TVL peak of more than $50M
- - Provide an audit report associated with the version of the contract that is deployed on
- Linea and has implemented at least one real-time exploit detection solution provided by
- Linea Partners
-
-## Relationship between LXP and LXP-L
-
-The goal for The Surge is to attract more liquidity by tracking the contribution of each user,
-leveraging a similar system that we have in place today: LXP-L will be a different token with
-the same non-transferable characteristic of LXP. Both of these points systems recognize involvement
-from two distinctly different user bases while providing greater transparency for each group.
-
-This approach ensures a balanced alignment between LXP and LXP-L. Considering the complexity
-of the Surge points model, it is challenging to establish precise alignment for these two types
-of points. Implementing parallel points systems allows us to assess the alignment retrospectively
-and make necessary adjustments to maintain fairness between users who contribute liquidity
-and those who contribute through activity.
-
-Moreover, we will continue to provide opportunities for users to contribute to the growth of
-the ecosystem by performing activity-based activations on Linea dapps.
diff --git a/docs/users/linea-voyage/lxp/index.mdx b/docs/users/linea-voyage/lxp/index.mdx
deleted file mode 100644
index 504e02b0d1..0000000000
--- a/docs/users/linea-voyage/lxp/index.mdx
+++ /dev/null
@@ -1,149 +0,0 @@
----
-title: Linea Voyage LXP
-sidebar_position: 5
-image: /img/socialCards/linea-voyage-lxp.jpg
----
-
-## What is Linea Voyage XP?
-
-Similar to video and role-playing games, wherein your character can gain Experience Points (XP) as
-you go through the game, Linea Voyage LXP represents your journey and experience in the Linea
-ecosystem.
-The Voyage LXP tokens will be a custom
-[ERC-20 token](https://ethereum.org/en/developers/docs/standards/tokens/erc-20/), and will be
-visible by default in your MetaMask wallet.
-
-**Voyage LXP tokens are non-transferable, soulbound tokens that are distributed to recognize the
-community's extraordinary contribution toward the growth of the Linea ecosystem. They do not have
-any monetary value!**
-
-Apart from being a measure of contribution to building Linea into a robust and secure L2 network,
-Voyage LXP will also make owners eligible for benefits such as receiving official community roles,
-exclusive Linea swag, and more!
-
-To learn more about the Linea Voyage program, click [here](https://support.linea.build/linea-voyage).
-
-:::note
-Voyage LXP are non-transferable, and cannot be bridged to other networks. You cannot buy, sell, or
-swap them, nor can you accumulate them by transferring LXP from another account.
-
-However, you can use multiple accounts to earn LXP; more on that below.
-:::
-
-## Contract address
-
-| Voyage LXP contract address |
-| --- |
-| [0xd83af4fbD77f3AB65C3B1Dc4B38D7e67AEcf599A](https://lineascan.build/address/0xd83af4fbD77f3AB65C3B1Dc4B38D7e67AEcf599A) |
-
-## Account binding
-
-
-
-Account binding allows you to aggregate your Voyage LXP tokens to a single primary account.
-If you're navigating the Linea ecosystem with multiple accounts, choose one as your main hub to
-effortlessly accumulate all the Voyage LXP you've received.
-This ensures that every adventure is accurately recorded across your interconnected accounts,
-providing a seamless and comprehensive representation of your Linea experience.
-
-**Account binding is not retroactive. If you bind your account address after Voyage XP is received,
-then those won't be linked to the primary account!**
-
-:::caution
-
-**Account binding is permanent and irreversible, so make sure you are choosing the correct account address when going through the process!**
-
-- Using account binding is only necessary for those who want to bind two or more accounts.
-
-- To receive LXP, the Primary account set must pass Proof of Humanity. Accounts set as secondary do not need to pass PoH.
-
-- All LXP will be sent to your Primary account when using Account Binding.
-
-- You will receive LXP once per task. The exception to this is the Linea Voyage Testnet NFT, holders will receive LXP for each NFT owned.
-:::
-
-To start the Account binding process, follow the steps below:
-
-1. Go [here](https://linea.build/activations)
-2. Connect your wallet in the top-right corner of the page
-
-
-
-
-
-
-
-3. Click on the address of your currently selected account to open a dropdown menu. Here, click
-"Manage Wallet(s)"
-
-
-
-
-
-
-
-4. Sign the signature request
-
-
-
-
-
-
-
-5. Select "Set as Primary Account"
-
-
-
-
-
-
-
-6. Select "Add secondary Account"
-
-
-
-
-
-
-
-7. Follow the prompts to connect the account you want to bind and sign the signature request.
-8. Read through the disclaimer, check the box, and hit confirm to finish the binding process
-
-
-
-
-
-
-
-:::info[What if I want to bind an account from a different Secret Recovery Phrase/seed phrase?]
-
-Refer to the [support guide](https://support.linea.build/linea-voyage/lxp-binding-an-account-from-a-different-secret-recovery-phrase-).
-
-:::
diff --git a/docs/users/move-funds/bridge.mdx b/docs/users/move-funds/bridge.mdx
deleted file mode 100644
index 28274e7679..0000000000
--- a/docs/users/move-funds/bridge.mdx
+++ /dev/null
@@ -1,42 +0,0 @@
----
-title: Bridge your funds
-image: /img/socialCards/bridge-your-funds.jpg
----
-
-The [official Linea bridge](https://bridge.linea.build/) provides multiple options to bridge
-your funds to Linea.
-
-You can select the option most appropriate to you:
-
-- **MetaMask bridge for users** - The bridge feature in MetaMask Portfolio, which we recommend as
- the simplest option for most users.
-- **Third-party bridges for users** - Use alternative third-party bridges.
-- **Linea Native Bridge** - Best suited for tech operators, dapp teams, and liquidity
-providers. For more guidance on the native bridge, see [here](../../developers/guides/bridge/how-to-bridge-eth.mdx).
-
-:::info
-The Linea Native Bridge is a slower option that should not be used for time-sensitive transfers.
-Additionally, you will need to manually claim ERC-20 tokens that are transferred across using this bridge.
-:::
-
-## Use the MetaMask Portfolio bridge
-
-The [MetaMask Portfolio's bridge](https://portfolio.metamask.io/bridge) surveys bridges across Linea to
-source its routes and rates and provides you with the best price.
-
-MetaMask Portfolio's bridge also allows you to bridge and swap tokens as part of the same transaction.
-
-[View the MetaMask Portfolio's bridge documentation](https://support.metamask.io/metamask-portfolio/bridge/)
-for more information.
-
-## Third-party bridges
-
-You can find third-party bridges on the [ecosystem portal](https://linea.build/apps). Use the
-filter to find the available third-party bridges.
-
-:::caution
-
-These are permissionless bridges, and, you should do your own research before interacting
-with dapps in order to keep your funds safe.
-
-:::
diff --git a/docs/users/move-funds/fund.mdx b/docs/users/move-funds/fund.mdx
deleted file mode 100644
index 24071fce13..0000000000
--- a/docs/users/move-funds/fund.mdx
+++ /dev/null
@@ -1,78 +0,0 @@
----
-title: Fund your accounts
-description: Get tokens in your accounts
-sidebar_position: 2
-image: /img/socialCards/fund-your-accounts.jpg
----
-
-Linea uses ETH for network transaction fees. You can fund your account on either [Linea Mainnet](#linea-mainnet) for
-real transactions or [Linea Sepolia](#linea-sepolia) for testing purposes.
-
-## Linea Mainnet
-
-You can buy tokens directly on Linea using [MetaMask Portfolio](https://portfolio.metamask.io/).
-Alternatively, if you already have tokens on another network, you can [bridge them to Linea](./bridge.mdx).
-For example you can bridge ETH on the Ethereum network over to the Linea network.
-
-:::info
-The [MetaMask Portfolio](https://portfolio.metamask.io/) dapp allows you to buy, sell, swap, stake, bridge, and
-manage your cryptoassets, among other features.
-
-Linea purchases in MetaMask Portfolio are available worldwide.
-:::
-
-
-
-### Buy tokens on Linea Mainnet
-
-To buy tokens using MetaMask Portfolio:
-
-1. Access [MetaMask Portfolio](https://portfolio.metamask.io), and connect the account that will
- receive your purchased tokens.
-1. Select the option to buy tokens:
- - On a mobile device, select **Buy** from the hamburger icon menu located in the top left
- of the screen.
- - On a desktop, select **Buy** on screen.
-
- :::info
- If you've never used the **Buy** option previously, you'll first need to
- select your region because payment methods and provider availability vary based on your bank's location.
- :::
-
-1. Set the payment method, if you've bought tokens before on your current device, your
- previous choice is loaded by default.
-1. In the **Buy** menu, select the token, and locate and select **Linea** from the networks list.
-1. In the list of tokens available to buy on Linea, select the one you want to buy.
-1. On the main screen, input the amount you wish to spend.
-1. View your quotes:
- - On a desktop browser, one or more quotes appear on the right.
- - On mobile devices, select **Get Quotes**.
-1. Pick a quote by selecting it.
-
-Selecting a quote redirects you to the provider's site to complete the transaction. You may need
-to complete KYC ("Know Your Customer"; essentially, identifying yourself) with the provider.
-
-After you've completed the steps with the provider, you'll be routed back to MetaMask Portfolio.
-Timescales for receiving your funds vary based on the provider and token route.
-
-## Linea Sepolia
-
-You can use one of the following Linea Sepolia faucets to drip testnet ETH directly to your
-Linea Sepolia address:
-
-
-- [Covalent](https://www.covalenthq.com/faucet/)
-- [Infura](https://www.infura.io/faucet/linea)
-- [GetBlock](https://getblock.io/faucet/linea-sepolia/)
-- [HackQuest](https://www.hackquest.io/en/faucets/59141) (and check out their [Linea Learning Track](https://www.hackquest.io/en/learning-track/9be129e7-575b-49bd-a64e-1bbe32427ace))
-
-Alternatively, [use the Linea Native Bridge to bridge tokens between Sepolia and Linea Sepolia](../../developers/guides/bridge/how-to-bridge-eth.mdx).
diff --git a/docs/users/move-funds/index.mdx b/docs/users/move-funds/index.mdx
deleted file mode 100644
index b37b6aa214..0000000000
--- a/docs/users/move-funds/index.mdx
+++ /dev/null
@@ -1,8 +0,0 @@
----
-title: Move funds to Linea
-image: /img/socialCards/move-funds-to-linea.jpg
----
-
-import DocCardList from '@theme/DocCardList';
-
-
diff --git a/docs/users/move-funds/set-up-your-wallet.mdx b/docs/users/move-funds/set-up-your-wallet.mdx
deleted file mode 100644
index 67d12cfd60..0000000000
--- a/docs/users/move-funds/set-up-your-wallet.mdx
+++ /dev/null
@@ -1,70 +0,0 @@
----
-title: Set up your wallet
-description: Set up your wallet to start using Linea
-sidebar_position: 1
-image: /img/socialCards/set-up-your-wallet.jpg
----
-
-Use a wallet such as MetaMask to manage your digital assets and interact with dapps on the Linea network.
-
-:::info
-
-Linea is designed to be completely compatible with Ethereum and works with
-MetaMask out of the box.
-
-[View the MetaMask support site](https://support.metamask.io/getting-started/getting-started-with-metamask/)
-if you're not familiar with the MetaMask wallet.
-
-:::
-
-## Install MetaMask
-
-The MetaMask browser extension and mobile app provide built-in connections to Linea.
-
-You can [install MetaMask as a browser extension or mobile app](https://metamask.io/download/).
-
-## Access Linea on MetaMask
-
-### Linea Mainnet
-
-Linea Mainnet is included in the available networks in the MetaMask browser extension and mobile
-app by default.
-
-Select **Linea Mainnet** from the network dropdown to connect to the network.
-[View the MetaMask instructions](https://support.metamask.io/networks-and-sidechains/managing-networks/how-to-connect-to-linea-on-metamask/)
-for more information.
-
-### Linea Sepolia
-
-To connect to Linea Sepolia testnet, select **Show test networks**, as indicated in the image
-below, and then select **Linea Sepolia**.
-
-
-
-
-
-
-
-## Next steps
-
-View [the ecosystem portal](https://linea.build/apps) to see list of Web3 dapps available on Linea.
-
-Regardless of what you're doing on Linea, you'll likely need some tokens to transact on the network.
-To do this, you can [fund your Linea account](./fund.mdx).
-
-## Troubleshooting tips
-
-If you're interacting with a dapp on Linea, try that dapp's documentation and resources first.
-If you can't find your answer there, take a look at the [Linea Support Help Center](https://support.linea.build),
-and search on the [Linea Community Forums](https://community.linea.build) or [Discord](https://discord.com/invite/linea)
-for related issues. If it seems like a MetaMask issue at that point, jump over to
-[MetaMask's Help Center](https://support.metamask.io), where you can explore their forums, and
-start a conversation with support.
-
-## Other wallets
-
-Linea is compatible with any EVM-compatible wallet. If you want to add the Linea network, then
-[view the relevant network information](../../developers/quickstart/info-contracts.mdx).
From 88a4cd679c2472867c774f3a7c1896ccb209bfc4 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Thu, 17 Oct 2024 11:13:01 +0100
Subject: [PATCH 04/18] Adjust navbar
---
docusaurus.config.js | 24 ++++++++++++------------
1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/docusaurus.config.js b/docusaurus.config.js
index 74a099d84a..0e12f95a50 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -116,23 +116,17 @@ const config = {
srcDark: "img/Linea_logo_white.svg",
},
items: [
- {
- type: "doc",
- docId: "users/index",
- position: "left",
- label: "Users",
- },
{
type: "doc",
docId: "developers/quickstart/index",
position: "left",
- label: "Developers",
+ label: "Quickstart",
},
{
type: "doc",
- docId: "architecture/index",
+ docId: "developers/guides/index",
position: "left",
- label: "Architecture",
+ label: "Guides",
},
// { can add this section back if we want it
// type: "dropdown",
@@ -154,6 +148,12 @@ const config = {
position: "left",
label: "Run a node",
},
+ {
+ type: "doc",
+ docId: "architecture/index",
+ position: "left",
+ label: "Architecture",
+ },
{
to: "/developers/linea-version",
position: "right",
@@ -178,11 +178,11 @@ const config = {
title: "Links",
items: [
{
- label: "Linea homepage",
+ label: "Home",
href: "https://linea.build/",
},
{
- label: "Network status",
+ label: "Status",
href: "https://linea.statuspage.io/",
},
{
@@ -216,7 +216,7 @@ const config = {
title: "Contribute",
items: [
{
- label: "Contribute to our documentation",
+ label: "Documentation",
href: "https://github.com/Consensys/doc.linea",
},
],
From 4b7fcc8325a2f32e44bb9947b01802b8e65ac9c4 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Thu, 17 Oct 2024 11:20:39 +0100
Subject: [PATCH 05/18] Adjust sidebar and footer
---
docusaurus.config.js | 4 +-
sidebars.js | 94 ++++++++++++--------------------------------
2 files changed, 28 insertions(+), 70 deletions(-)
diff --git a/docusaurus.config.js b/docusaurus.config.js
index 0e12f95a50..6eddf36dba 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -190,8 +190,8 @@ const config = {
href: "https://lineascan.build",
},
{
- label: "Linea Sepolia block explorer",
- href: "https://sepolia.lineascan.build",
+ label: "Risk disclosures",
+ href: "risk-disclosures/index",
},
],
},
diff --git a/sidebars.js b/sidebars.js
index 2d52cb3f33..d15b32eae9 100644
--- a/sidebars.js
+++ b/sidebars.js
@@ -1,74 +1,6 @@
/** @type {import('@docusaurus/plugin-content-docs').SidebarsConfig} */
const sidebars = {
docSidebar: [
- "users/index",
- {
- type: "category",
- collapsed: true,
- label: "Move funds to Linea",
- link: {
- type: "doc",
- id: "users/move-funds/index",
- },
- items: [
- "users/move-funds/set-up-your-wallet",
- "users/move-funds/fund",
- "users/move-funds/bridge",
- ],
- },
- {
- type: "category",
- label: "Linea Voyage",
- link: {
- type: "doc",
- id: "users/linea-voyage/index",
- },
- items: [
- "users/linea-voyage/lxp/index",
- {
- type: "category",
- label: "The Surge",
- link: {
- type: "doc",
- id: "users/linea-voyage/linea-surge/index",
- },
- items: [
- "users/linea-voyage/linea-surge/linea-surge-model",
- "users/linea-voyage/linea-surge/linea-surge-overview",
- ],
- },
- ],
- },
- "users/zero-knowledge-glossary/index",
- "risk-disclosures/index",
- {
- type: "category",
- label: "Contact us",
- items: [
- {
- type: "link",
- label: "Get help",
- href: "https://support.linea.build/",
- },
- {
- type: "link",
- label: "Provide feedback",
- href: "https://community.linea.build/c/feedback",
- },
- {
- type: "link",
- label: "Report an issue",
- href: "https://community.linea.build/c/bug-reports/",
- },
- {
- type: "link",
- label: "Join our Discord",
- href: "https://discord.gg/linea",
- },
- ],
- },
- ],
- developersSidebar: [
{
type: "category",
label: "Getting started",
@@ -441,6 +373,32 @@ const sidebars = {
},
],
},
+ {
+ type: "category",
+ label: "Contact",
+ items: [
+ {
+ type: "link",
+ label: "Support",
+ href: "https://support.linea.build/",
+ },
+ {
+ type: "link",
+ label: "Feedback",
+ href: "https://community.linea.build/c/feedback",
+ },
+ {
+ type: "link",
+ label: "Report an issue",
+ href: "https://community.linea.build/c/bug-reports/",
+ },
+ {
+ type: "link",
+ label: "Discord",
+ href: "https://discord.gg/linea",
+ },
+ ],
+ },
],
architectureSidebar: [
"architecture/index",
From 0df8f8c14c57be4d60546d2945dc1597a7263df6 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Fri, 18 Oct 2024 16:21:36 +0100
Subject: [PATCH 06/18] Address broken links
---
.../developers/quickstart/deploy-smart-contract/atlas.mdx | 7 -------
.../deploy-smart-contract/{cookbook.md => cookbook.mdx} | 7 -------
.../deploy-smart-contract/{foundry.md => foundry.mdx} | 8 ++------
.../quickstart/deploy-smart-contract/hardhat.mdx | 6 +-----
.../deploy-smart-contract/{remix.md => remix.mdx} | 7 -------
docs/developers/quickstart/index.mdx | 5 +++--
6 files changed, 6 insertions(+), 34 deletions(-)
rename docs/developers/quickstart/deploy-smart-contract/{cookbook.md => cookbook.mdx} (97%)
rename docs/developers/quickstart/deploy-smart-contract/{foundry.md => foundry.mdx} (91%)
rename docs/developers/quickstart/deploy-smart-contract/{remix.md => remix.mdx} (90%)
diff --git a/docs/developers/quickstart/deploy-smart-contract/atlas.mdx b/docs/developers/quickstart/deploy-smart-contract/atlas.mdx
index be16f7c45f..eceebf420f 100644
--- a/docs/developers/quickstart/deploy-smart-contract/atlas.mdx
+++ b/docs/developers/quickstart/deploy-smart-contract/atlas.mdx
@@ -6,13 +6,6 @@ image: /img/socialCards/atlas.jpg
Atlas is a browser-based IDE with an integrated AI assistant that allows you to write, test and deploy smart contracts directly from your browser.
-## Prerequisites
-
-Before you begin, ensure you:
-
-1. [Set up your wallet](../../../users/move-funds/set-up-your-wallet.mdx).
-1. [Fund your wallet with Linea ETH](../../../users/move-funds/fund.mdx) on either the testnet or mainnet.
-
## Deploy a contract
1. Go to `https://app.atlaszk.com`.
diff --git a/docs/developers/quickstart/deploy-smart-contract/cookbook.md b/docs/developers/quickstart/deploy-smart-contract/cookbook.mdx
similarity index 97%
rename from docs/developers/quickstart/deploy-smart-contract/cookbook.md
rename to docs/developers/quickstart/deploy-smart-contract/cookbook.mdx
index 158dec5319..83083926a5 100644
--- a/docs/developers/quickstart/deploy-smart-contract/cookbook.md
+++ b/docs/developers/quickstart/deploy-smart-contract/cookbook.mdx
@@ -13,13 +13,6 @@ fast way to develop smart contracts by integrating with a variety of blockchain-
Here, we'll walk through searching for a protocol on Cookbook and deploying it to Linea using
Cookbook's no-code deploy and using Cookbook with Remix, Hardhat and Foundry.
-## Prerequisites
-
-Before you begin, ensure you:
-
-1. [Set up your wallet](../../../users/move-funds/set-up-your-wallet.mdx)
-2. [Fund your wallet with Linea ETH](../../../users/move-funds/fund.mdx) on either the testnet or mainnet
-
## Search Cookbook's smart contract registry
Navigate to [cookbook.dev/chains/Linea](https://www.cookbook.dev/chains/Linea?utm=lineadocs) and explore **Protocols** on Linea, or search for specific smart contracts in the search bar.
diff --git a/docs/developers/quickstart/deploy-smart-contract/foundry.md b/docs/developers/quickstart/deploy-smart-contract/foundry.mdx
similarity index 91%
rename from docs/developers/quickstart/deploy-smart-contract/foundry.md
rename to docs/developers/quickstart/deploy-smart-contract/foundry.mdx
index 76b74d5a48..2a4092a036 100644
--- a/docs/developers/quickstart/deploy-smart-contract/foundry.md
+++ b/docs/developers/quickstart/deploy-smart-contract/foundry.mdx
@@ -21,17 +21,13 @@ In this quickstart, we'll create a basic [Foundry](https://book.getfoundry.sh/)
## Prerequisites
-Before you begin, ensure you:
-
-1. [Set up your wallet](../../../users/move-funds/set-up-your-wallet.mdx)
-1. [Fund your wallet with Linea ETH](../../../users/move-funds/fund.mdx) on either the testnet, or mainnet
-1. Download and install Foundry:
+Before you begin, ensure you download and install Foundry:
```bash
curl -L https://foundry.paradigm.xyz | bash
```
- Then, open a new terminal, and call `foundryup` to install the latest release.
+Then, open a new terminal, and call `foundryup` to install the latest release.
## Create a Foundry project
diff --git a/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx b/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx
index f649f838d9..75eed142b4 100644
--- a/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx
+++ b/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx
@@ -11,11 +11,7 @@ In this quickstart, we'll create a basic [Hardhat](https://hardhat.org/) project
## Prerequisites
-Before you begin, ensure you:
-
-1. [Set up your wallet](../../../users/move-funds/set-up-your-wallet.mdx).
-2. [Fund your wallet with Linea ETH](../../../users/move-funds/fund.mdx) on either testnet, or mainnet.
-3. [Set up your environment using Hardhat's recommended instructions](https://hardhat.org/tutorial/setting-up-the-environment#2.-setting-up-the-environment).
+Before you begin, ensure you set up your environment using Hardhat's recommended instructions](https://hardhat.org/tutorial/setting-up-the-environment#2.-setting-up-the-environment).
## Create a Hardhat project
diff --git a/docs/developers/quickstart/deploy-smart-contract/remix.md b/docs/developers/quickstart/deploy-smart-contract/remix.mdx
similarity index 90%
rename from docs/developers/quickstart/deploy-smart-contract/remix.md
rename to docs/developers/quickstart/deploy-smart-contract/remix.mdx
index 173cfbd5d0..e9a58620f7 100644
--- a/docs/developers/quickstart/deploy-smart-contract/remix.md
+++ b/docs/developers/quickstart/deploy-smart-contract/remix.mdx
@@ -8,13 +8,6 @@ import Tabs from '@theme/Tabs'; import TabItem from '@theme/TabItem';
In this tutorial, we'll walk through creating a basic Remix project and deploying a sample contract.
-## Prerequisites
-
-Before you begin, ensure you:
-
-1. [Set up your wallet](../../../users/move-funds/set-up-your-wallet.mdx)
-2. [Fund your wallet with Linea ETH](../../../users/move-funds/fund.mdx) on either the testnet, or mainnet
-
## Explore the Remix workspace
To start using Remix, navigate to their [website](https://remix.ethereum.org/). The default project includes a
diff --git a/docs/developers/quickstart/index.mdx b/docs/developers/quickstart/index.mdx
index 53033a4cc9..ae05d127eb 100644
--- a/docs/developers/quickstart/index.mdx
+++ b/docs/developers/quickstart/index.mdx
@@ -12,8 +12,9 @@ It's always best practice to work on a test network before deploying a contract
Before you begin, ensure you've:
-1. [Set up your wallet](../../users/move-funds/set-up-your-wallet.mdx).
-2. [Funded your wallet with Linea ETH](../../users/move-funds/fund.mdx) on either the testnet or mainnet.
+1. [Set up your wallet](https://support.metamask.io/getting-started/getting-started-with-metamask/).
+2. Funded your wallet with Linea ETH, either through [bridging](../guides/bridge/index.mdx) or using
+an on-ramp such as [MetaMask Portfolio](https://portfolio.metamask.io/buy).
## Resources
From ccbf1db9a32ef27ac035dcf1ba3ada3c98024764 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Mon, 21 Oct 2024 09:25:55 +0100
Subject: [PATCH 07/18] Update links and file types
---
docs/developers/guides/community/irys/irys-dynamic-nfts.mdx | 2 +-
docs/developers/guides/community/irys/irys-nfts.mdx | 2 +-
docs/developers/quickstart/deploy-smart-contract/cookbook.mdx | 4 ++--
docs/developers/quickstart/deploy-smart-contract/foundry.mdx | 2 +-
docs/developers/quickstart/deploy-smart-contract/hardhat.mdx | 2 +-
.../quickstart/verify-smart-contract/{atlas.md => atlas.mdx} | 0
.../verify-smart-contract/{foundry.md => foundry.mdx} | 2 +-
.../verify-smart-contract/{hardhat.md => hardhat.mdx} | 0
8 files changed, 7 insertions(+), 7 deletions(-)
rename docs/developers/quickstart/verify-smart-contract/{atlas.md => atlas.mdx} (100%)
rename docs/developers/quickstart/verify-smart-contract/{foundry.md => foundry.mdx} (98%)
rename docs/developers/quickstart/verify-smart-contract/{hardhat.md => hardhat.mdx} (100%)
diff --git a/docs/developers/guides/community/irys/irys-dynamic-nfts.mdx b/docs/developers/guides/community/irys/irys-dynamic-nfts.mdx
index 5237f5e810..a9fbb98335 100644
--- a/docs/developers/guides/community/irys/irys-dynamic-nfts.mdx
+++ b/docs/developers/guides/community/irys/irys-dynamic-nfts.mdx
@@ -84,7 +84,7 @@ contract SuperMon is ERC721URIStorage {
```
-[Deploy the smart contract using Remix](../../../quickstart/deploy-smart-contract/remix.md), or
+[Deploy the smart contract using Remix](../../../quickstart/deploy-smart-contract/remix.mdx), or
[any other environment](https://docs.linea.build/developers/quickstart/deploy-smart-contract).
## Upload the images
diff --git a/docs/developers/guides/community/irys/irys-nfts.mdx b/docs/developers/guides/community/irys/irys-nfts.mdx
index f4db898999..6704db60d7 100644
--- a/docs/developers/guides/community/irys/irys-nfts.mdx
+++ b/docs/developers/guides/community/irys/irys-nfts.mdx
@@ -24,7 +24,7 @@ offchain actions.
If you're new to NFTs and smart contract development, consider deploying
one of [the audited ThirdWeb contracts](../../../../developers/quickstart/deploy-smart-contract/thirdweb.md) to learn more.
-You can also [deploy this minimal contract using Remix](../../../../developers/quickstart/deploy-smart-contract/remix.md).
+You can also [deploy this minimal contract using Remix](../../../../developers/quickstart/deploy-smart-contract/remix.mdx).
```solidity
// SPDX-License-Identifier: MIT
diff --git a/docs/developers/quickstart/deploy-smart-contract/cookbook.mdx b/docs/developers/quickstart/deploy-smart-contract/cookbook.mdx
index 83083926a5..fc211f490f 100644
--- a/docs/developers/quickstart/deploy-smart-contract/cookbook.mdx
+++ b/docs/developers/quickstart/deploy-smart-contract/cookbook.mdx
@@ -87,7 +87,7 @@ automatically be opened in a new Remix workspace.
Select **Compile** to compile your smart contract in Remix. Most contracts opened with Cookbook will automatically
compile within Remix.
-Refer to the [Remix instructions](./remix.md) for more information on how to compile and deploy smart
+Refer to the [Remix instructions](./remix.mdx) for more information on how to compile and deploy smart
contracts in the Remix IDE.
### Method 2 - Use the Cookbook Remix plug-in within the Remix IDE
@@ -130,7 +130,7 @@ contracts in the Remix IDE.
-1. Compile and deploy the smart contract as described in [the Remix instructions](./remix.md).
+1. Compile and deploy the smart contract as described in [the Remix instructions](./remix.mdx).
## Deploy your smart contract with Hardhat
diff --git a/docs/developers/quickstart/deploy-smart-contract/foundry.mdx b/docs/developers/quickstart/deploy-smart-contract/foundry.mdx
index 2a4092a036..346f543a5f 100644
--- a/docs/developers/quickstart/deploy-smart-contract/foundry.mdx
+++ b/docs/developers/quickstart/deploy-smart-contract/foundry.mdx
@@ -127,4 +127,4 @@ forge create --rpc-url linea-sepolia src/Counter.sol:Counter --private-key $PRIV
-Next, you can optionally [verify your contract on the network](../verify-smart-contract/foundry.md).
+Next, you can optionally [verify your contract on the network](../verify-smart-contract/foundry.mdx).
diff --git a/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx b/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx
index 75eed142b4..7766210531 100644
--- a/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx
+++ b/docs/developers/quickstart/deploy-smart-contract/hardhat.mdx
@@ -155,4 +155,4 @@ Deployed Addresses
LockModule#Lock - 0x2c73d6f093A2032D3371bFB9a29f7cE666080c4A
```
-Next, you can optionally [verify your contract on the network](../verify-smart-contract/hardhat.md).
+Next, you can optionally [verify your contract on the network](../verify-smart-contract/hardhat.mdx).
diff --git a/docs/developers/quickstart/verify-smart-contract/atlas.md b/docs/developers/quickstart/verify-smart-contract/atlas.mdx
similarity index 100%
rename from docs/developers/quickstart/verify-smart-contract/atlas.md
rename to docs/developers/quickstart/verify-smart-contract/atlas.mdx
diff --git a/docs/developers/quickstart/verify-smart-contract/foundry.md b/docs/developers/quickstart/verify-smart-contract/foundry.mdx
similarity index 98%
rename from docs/developers/quickstart/verify-smart-contract/foundry.md
rename to docs/developers/quickstart/verify-smart-contract/foundry.mdx
index 9e99d2b698..85f7c6c6c6 100644
--- a/docs/developers/quickstart/verify-smart-contract/foundry.md
+++ b/docs/developers/quickstart/verify-smart-contract/foundry.mdx
@@ -89,7 +89,7 @@ If you don't want to paste your keys inline and have multiple Etherscan API keys
the `.env` and `foundry.toml` files to set up custom configurations.
These steps assume you stored your secret keys in a `.env` file. which you can read more about
-[in the Foundry deployment instructions](../deploy-smart-contract/foundry.md#deploy-a-smart-contract-using-a-env-file).
+[in the Foundry deployment instructions](../deploy-smart-contract/foundry.mdx#deploy-a-smart-contract-using-a-env-file).
```bash
LINEASCAN_API_KEY=YOUR_LINEASCAN_API_KEY
diff --git a/docs/developers/quickstart/verify-smart-contract/hardhat.md b/docs/developers/quickstart/verify-smart-contract/hardhat.mdx
similarity index 100%
rename from docs/developers/quickstart/verify-smart-contract/hardhat.md
rename to docs/developers/quickstart/verify-smart-contract/hardhat.mdx
From cf9993d29d33994b94b3307c02e71c475cab0a1e Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Mon, 21 Oct 2024 10:24:59 +0100
Subject: [PATCH 08/18] External redirects
---
docusaurus.config.js | 52 +++++------------------------
scripts/redirects.js | 9 +++++
src/components/externalRedirects.js | 18 ++++++++++
src/pages/_redirects.js | 9 +++++
4 files changed, 44 insertions(+), 44 deletions(-)
create mode 100644 scripts/redirects.js
create mode 100644 src/components/externalRedirects.js
create mode 100644 src/pages/_redirects.js
diff --git a/docusaurus.config.js b/docusaurus.config.js
index 6eddf36dba..5902a2249f 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -191,7 +191,7 @@ const config = {
},
{
label: "Risk disclosures",
- href: "risk-disclosures/index",
+ href: "/risk-disclosures/index",
},
],
},
@@ -298,7 +298,6 @@ const config = {
to: "/zero-knowledge-glossary",
from: [
"/reference/glossary",
- "/zero-knowledge-glossary",
"/users/zero-knowledge-glossary"
],
},
@@ -315,18 +314,12 @@ const config = {
"/users/index.mdx",
],
},
- {
- to: "/",
- from: [
- "/build-on-linea/use-linea-testnet/set-up-your-wallet",
- "/users/move-funds/set-up-your-wallet",
- ],
- },
{
to: "/",
from: [
"/build-on-linea/use-linea-testnet/fund",
"/users/move-funds/fund",
+ "/use-mainnet/fund",
],
},
{
@@ -346,59 +339,27 @@ const config = {
from: [
"/build-on-linea/use-linea-testnet/bridge-funds/usdc-bridge",
"/users/move-funds/bridge",
- ],
- },
- {
- to: "/",
- from: [
"/build-on-linea/use-linea-testnet/bridge-funds/use-etherscan",
- "/users/move-funds/bridge",
],
},
{
to: "/developers/guides/gas/gas-fees",
from: "/use-mainnet/gas-import",
},
- {
- to: "/users/linea-voyage/linea-surge/linea-surge-overview",
- from: "/use-mainnet/linea-surge/linea-surge-overview",
- },
- {
- to: "/users/linea-voyage/linea-surge/linea-surge-model",
- from: "/use-mainnet/linea-surge/linea-surge-model",
- },
- {
- to: "/users/linea-voyage/linea-surge/linea-surge-model",
- from: "/use-mainnet/linea-surge-model",
- },
- {
- to: "/users/linea-voyage/linea-surge",
- from: "/use-mainnet/linea-surge",
- },
{
to: "/developers/guides/gas/gas-fees",
from: "/reference/api/linea-estimategas",
},
- {
- to: "/users/linea-voyage/lxp",
- from: "/use-mainnet/linea-xp",
- },
{
to: "/developers/guides/bridge",
from: "/use-mainnet/bridges-of-linea",
},
- {
- to: "/",
- from: [
- "/use-mainnet/fund",
- "/users/move-funds/fund",
- ],
- },
{
to: "/",
from: [
"/use-mainnet/set-up-your-wallet",
"/users/move-funds/set-up-your-wallet",
+ "/build-on-linea/use-linea-testnet/set-up-your-wallet",
],
},
{
@@ -426,8 +387,11 @@ const config = {
],
},
{
- to: "/developers/community/hackathons",
- from: "/build-on-linea/hackathons",
+ to: "/",
+ from: [
+ "/build-on-linea/hackathons",
+ "/developers/community/hackathons",
+ ],
},
{
to: "/developers/guides/linea-inscriptions",
diff --git a/scripts/redirects.js b/scripts/redirects.js
new file mode 100644
index 0000000000..d4e1eda723
--- /dev/null
+++ b/scripts/redirects.js
@@ -0,0 +1,9 @@
+const redirects = {
+ '/users/linea-voyage/linea-surge/linea-surge-overview': 'https://support.linea.build/linea-voyage/linea-surge/linea-surge-overview',
+ '/users/linea-voyage/linea-surge/linea-surge-model': 'https://support.linea.build/linea-voyage/linea-surge/linea-surge-model',
+ '/users/linea-voyage/linea-surge': 'https://support.linea.build/linea-voyage/linea-surge',
+ '/users/linea-voyage/lxp': 'https://support.linea.build/linea-voyage/lxp',
+ // Add more paths as needed
+ };
+
+ export default redirects;
diff --git a/src/components/externalRedirects.js b/src/components/externalRedirects.js
new file mode 100644
index 0000000000..0d095f7883
--- /dev/null
+++ b/src/components/externalRedirects.js
@@ -0,0 +1,18 @@
+import React, { useEffect } from 'react';
+import { useHistory } from '@docusaurus/router';
+
+const ExternalRedirect = ({ redirects }) => {
+ const history = useHistory();
+ const currentPath = history.location.pathname;
+
+ useEffect(() => {
+ const redirectUrl = redirects[currentPath];
+ if (redirectUrl) {
+ window.location.href = redirectUrl;
+ }
+ }, [currentPath, redirects]);
+
+ return null;
+};
+
+export default ExternalRedirect;
diff --git a/src/pages/_redirects.js b/src/pages/_redirects.js
new file mode 100644
index 0000000000..6b05dd7742
--- /dev/null
+++ b/src/pages/_redirects.js
@@ -0,0 +1,9 @@
+import React from 'react';
+import ExternalRedirect from '../components/externalRedirects';
+import redirects from '../../scripts/redirects';
+
+const RedirectsPage = () => {
+ return ;
+};
+
+export default RedirectsPage;
From 00bc0bc6f8c85368ab47daf1f051d345295d8f95 Mon Sep 17 00:00:00 2001
From: jlwllmr <95916148+jlwllmr@users.noreply.github.com>
Date: Mon, 21 Oct 2024 14:35:46 +0100
Subject: [PATCH 09/18] Build and reinstate paths to enable redirects
---
docs/developers/guides/run-a-node/besu.mdx | 3 +-
.../guides/run-a-node/bootnodes.mdx | 2 +-
docs/developers/guides/run-a-node/erigon.mdx | 3 +-
docs/developers/guides/run-a-node/geth.mdx | 3 +-
.../guides/run-a-node/linea-besu.mdx | 1 +
docs/users/index.mdx | 22 ++
docs/users/linea-voyage/index.mdx | 8 +
docs/users/linea-voyage/linea-surge/index.mdx | 21 ++
.../linea-surge/linea-surge-model.mdx | 250 ++++++++++++++++++
.../linea-surge/linea-surge-overview.mdx | 65 +++++
docs/users/linea-voyage/lxp/index.mdx | 149 +++++++++++
docs/users/move-funds/bridge.mdx | 42 +++
docs/users/move-funds/fund.mdx | 78 ++++++
docs/users/move-funds/index.mdx | 8 +
docs/users/move-funds/set-up-your-wallet.mdx | 70 +++++
docusaurus.config.js | 2 +-
scripts/redirects.js | 9 -
src/components/HomepageCards/index.tsx | 7 +-
src/components/RedirectPage.js | 30 +++
src/components/externalRedirects.js | 18 --
src/pages/_redirects.js | 9 -
src/theme/DocItem/Layout/index.js | 2 +
static/img/socialCards/besu.jpg | Bin 0 -> 78222 bytes
static/img/socialCards/bootnodes.jpg | Bin 0 -> 82854 bytes
static/img/socialCards/erigon.jpg | Bin 0 -> 78986 bytes
static/img/socialCards/geth.jpg | Bin 0 -> 78085 bytes
static/img/socialCards/linea-besu.jpg | Bin 0 -> 81943 bytes
27 files changed, 757 insertions(+), 45 deletions(-)
create mode 100644 docs/users/index.mdx
create mode 100644 docs/users/linea-voyage/index.mdx
create mode 100644 docs/users/linea-voyage/linea-surge/index.mdx
create mode 100644 docs/users/linea-voyage/linea-surge/linea-surge-model.mdx
create mode 100644 docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx
create mode 100644 docs/users/linea-voyage/lxp/index.mdx
create mode 100644 docs/users/move-funds/bridge.mdx
create mode 100644 docs/users/move-funds/fund.mdx
create mode 100644 docs/users/move-funds/index.mdx
create mode 100644 docs/users/move-funds/set-up-your-wallet.mdx
delete mode 100644 scripts/redirects.js
create mode 100644 src/components/RedirectPage.js
delete mode 100644 src/components/externalRedirects.js
delete mode 100644 src/pages/_redirects.js
create mode 100644 static/img/socialCards/besu.jpg
create mode 100644 static/img/socialCards/bootnodes.jpg
create mode 100644 static/img/socialCards/erigon.jpg
create mode 100644 static/img/socialCards/geth.jpg
create mode 100644 static/img/socialCards/linea-besu.jpg
diff --git a/docs/developers/guides/run-a-node/besu.mdx b/docs/developers/guides/run-a-node/besu.mdx
index 67b7ba3bf7..e3f87a7b36 100644
--- a/docs/developers/guides/run-a-node/besu.mdx
+++ b/docs/developers/guides/run-a-node/besu.mdx
@@ -1,6 +1,7 @@
---
title: Besu
description: Install the Besu client to run a Linea node.
+image: /img/socialCards/besu.jpg
---
import Tabs from "@theme/Tabs";
@@ -192,4 +193,4 @@ You should get a result similar to:
"highestBlock": "0x3cedec"
}
}
-```
\ No newline at end of file
+```
diff --git a/docs/developers/guides/run-a-node/bootnodes.mdx b/docs/developers/guides/run-a-node/bootnodes.mdx
index acb1d31421..8c6edfbfda 100644
--- a/docs/developers/guides/run-a-node/bootnodes.mdx
+++ b/docs/developers/guides/run-a-node/bootnodes.mdx
@@ -1,7 +1,7 @@
---
title: Bootnodes
description: Bootnodes available for Linea Mainnet
-image: /img/socialCards/edge-nodes.jpg
+image: /img/socialCards/bootnodes.jpg
---
The following bootnodes enable your node to find a peer node when initializing. To
diff --git a/docs/developers/guides/run-a-node/erigon.mdx b/docs/developers/guides/run-a-node/erigon.mdx
index fe694694d5..15fee814ab 100644
--- a/docs/developers/guides/run-a-node/erigon.mdx
+++ b/docs/developers/guides/run-a-node/erigon.mdx
@@ -1,6 +1,7 @@
---
title: Erigon
description: Install the Erigon client to run a Linea node.
+image: /img/socialCards/erigon.jpg
---
import Tabs from "@theme/Tabs";
@@ -211,4 +212,4 @@ You should get a result similar to:
"highestBlock": "0x3cedec"
}
}
-```
\ No newline at end of file
+```
diff --git a/docs/developers/guides/run-a-node/geth.mdx b/docs/developers/guides/run-a-node/geth.mdx
index e70d5206ad..cb3e1c5935 100644
--- a/docs/developers/guides/run-a-node/geth.mdx
+++ b/docs/developers/guides/run-a-node/geth.mdx
@@ -1,6 +1,7 @@
---
title: Geth
description: Install the Geth client to run a Linea node.
+image: /img/socialCards/geth.jpg
---
import Tabs from "@theme/Tabs";
@@ -222,4 +223,4 @@ You should get a result similar to:
"highestBlock": "0x3cedec"
}
}
-```
\ No newline at end of file
+```
diff --git a/docs/developers/guides/run-a-node/linea-besu.mdx b/docs/developers/guides/run-a-node/linea-besu.mdx
index 977d339574..04389c7cac 100644
--- a/docs/developers/guides/run-a-node/linea-besu.mdx
+++ b/docs/developers/guides/run-a-node/linea-besu.mdx
@@ -1,6 +1,7 @@
---
title: Linea Besu
description: Install the Besu client to run a Linea node.
+image: /img/socialCards/linea-besu.jpg
---
import Tabs from "@theme/Tabs";
diff --git a/docs/users/index.mdx b/docs/users/index.mdx
new file mode 100644
index 0000000000..49f016d1fa
--- /dev/null
+++ b/docs/users/index.mdx
@@ -0,0 +1,22 @@
+---
+title: About Linea
+sidebar_position: 2
+image: /img/socialCards/about-linea.jpg
+---
+
+Linea is an Ethereum layer 2 (L2) network that provides access to innovative Web3
+projects at significantly lower costs compared to Ethereum. It's compatible with the
+Ethereum Virtual Machine (EVM), allowing users to deploy existing Ethereum applications and
+develop new ones that would be too costly on Mainnet. It also enables the community to
+use those dapps, **at a fraction of the cost**, and at **multiples the speed** of Mainnet.
+
+Linea delivers unrivaled network security with its cryptographically secure zk-rollup infrastructure,
+comprehensive security partnerships, and security-oriented ecosystem culture. View the
+[Linea architecture](../architecture/index.mdx) for more information.
+
+You can get started by [funding your Linea account](./move-funds/index.mdx) using the
+fiat onramp in MetaMask Portfolio or by bridging over funds.
+
+:::tip
+If you run into a problem, view the [Linea Support page](https://support.linea.build/hc/en-us) and let us know.
+:::
diff --git a/docs/users/linea-voyage/index.mdx b/docs/users/linea-voyage/index.mdx
new file mode 100644
index 0000000000..52435982e1
--- /dev/null
+++ b/docs/users/linea-voyage/index.mdx
@@ -0,0 +1,8 @@
+---
+title: Linea Voyage
+image: /img/socialCards/linea-voyage.jpg
+---
+
+import DocCardList from '@theme/DocCardList';
+
+
diff --git a/docs/users/linea-voyage/linea-surge/index.mdx b/docs/users/linea-voyage/linea-surge/index.mdx
new file mode 100644
index 0000000000..53c93645b0
--- /dev/null
+++ b/docs/users/linea-voyage/linea-surge/index.mdx
@@ -0,0 +1,21 @@
+---
+title: 'Linea Voyage: The Surge'
+image: /img/socialCards/linea-voyage-the-surge.jpg
+---
+
+Linea Surge is an LXP-driven program that enables people to collect LXP-L in return for having
+assets on Linea and deploying those assets into protocols.
+
+The goal for The Surge is to allow users that provide liquidity on the network to collect LXP-L.
+LXP-L is similar to the system we have in place today for LXP, but is collected by contributing
+liquidity to Linea.
+
+A core focus is on the expansion of available assets through new applications
+and DeFi use cases built on Linea. Additional liquidity brought by new applications sustainably
+supports additional volume, in turn impacting on the sustainability of the liquidity through
+increased fees for liquidity providers and increasing the percentage of ecosystem trading
+activity compared to other venues. This constitutes something of a flywheel network effect for
+the ecosystem.
+
+The following sections provide further detail. In the overview page, we will explore the program,
+before explaining the math behind it in _Point incentive design_.
diff --git a/docs/users/linea-voyage/linea-surge/linea-surge-model.mdx b/docs/users/linea-voyage/linea-surge/linea-surge-model.mdx
new file mode 100644
index 0000000000..b9d93726b8
--- /dev/null
+++ b/docs/users/linea-voyage/linea-surge/linea-surge-model.mdx
@@ -0,0 +1,250 @@
+---
+title: Point incentive design
+sidebar_position: 2
+image: /img/socialCards/point-incentive-design.jpg
+---
+
+:::note
+
+This allocation methodology is subject to minimal change.
+
+:::
+
+
+## LXP-L function
+
+LXP-L is intended to recognize and incentivize meaningful contributors within the Linea ecosystem.
+These points encompass a variety of actions, such as being an early adopter, owning assets on Linea,
+engaging with different protocols within the ecosystem, demonstrating past involvement across
+other blockchain networks, and more.
+
+The overarching function is as follows:
+
+
+$$
+P_{u} = DF \left[ EA \cdot \int_{0}^{T} \left( m_{pl} PL_{t} + \sum_{v \in V} m_{v,t} AP_{v,t} \right) dt + m_{rp} RP + m_{vet} P_{v} \right]
+$$
+
+
+
+This point formula can be extracted into three terms:
+
+$$
+P_{u} = DF \cdot \left( P_{E} + P_{R} + P_{V} \right)
+$$
+
+$P_{u}$ represents the LXP-L user _u_ earns. There are three ways users can earn points:
+
+- Ecosystem Points $\left(P_{E} \right)$
+- Referral Points $\left(P_{R} \right)$
+- Veteran Points $\left(P_{V} \right)$
+
+## Formula explanation
+
+### Decay function (DF)
+
+To gradually adapt the number of points and incentivize early participation in the program,
+we're employing a decay function that decreases at every Volt (1 month). At the start of the
+program, this function will be 1, and will be reduced by a factor of 10% after every Epoch,
+so the overall number of points will be 10% lower every month.
+
+### Ecosystem Points
+
+Ecosystem points incentivize onboarding assets onto Linea, along with user activity across
+various ecosystem protocols. It is calculated as follows:
+
+$$
+P_{E} = EA \cdot \int_{0}^{T} \left( m_{pl} PL_{t} + \sum_{v \in V} m_{v,t} AP_{v,t} \right) dt
+$$
+
+Where:
+
+- _EA_ is the [early adopter modifier](#early-adopter-modifier) that serves as a decay function
+across time
+- $m_{pl}$ is the multiplier for passive liquidity
+- $PL_{t}$ is the amount of passive liquidity held in wallet
+- _$V$_ is the set of DeFi verticals participating in the program
+- $m_{v,t}$ is the multiplier for vertical _v_ at time _t_
+- $AP_{v,t}$ is the amount of activity points earned in vertical _v_ at time _t_ weighted by the
+specific asset class that is in use across the different verticals. Asset classes will come with
+a different multiplier $\left(m_{a,t} \right)$ that will change the value of individual
+$AP_{v,t}$ to ensure a healthy ecosystem that is not concentrated in few asset classes
+(usually ETH/stables).
+
+
+
+
+
+
+
+In this specific example—which will apply to Volt 1 at the beginning of the program—we're using the
+$m_{a,t}$ multiplier to maximize the points for ETH and LRT liquidity on DEXs and lending
+platforms, with a lower weight on stables and LST and a minor weight for RWA and others. We are
+also maximizing liquidity on third party bridges pools (AMM) for ETH and stables to provide a better
+bridging experience to users.
+
+### Early adopter modifier
+
+_EA_ is the early adopter modifier, a multiplier that recognizes early activity on Linea. Early
+activity is defined as activity occurring before the start of the program.
+
+This multiplier will be constant within the time period of a single Volt (1 month) and will
+reduce over successive Volts. This is used to recognize the contributions of users that have
+provided liquidity on Linea since mainnet went live and users bridging active liquidity to
+Linea after the announcement but before The Surge program starts.
+
+The way it works is by looking at historical activity of each address that is eligible to get
+$P_{E}$.
+
+The _EA_ multiplier will be applied to your account if:
+
+- The address had at least one active liquidity event across any smart contract on Linea (also
+ones not included in the program), AND;
+- At least one active liquidity event was $\geq$ 0.1 ETH or WETH.
+
+Since the Surge has started, it is no longer possible to obtain early adopter status. This was only
+possible if your address had active liquidity events before the Surge was announced or before it
+started.
+
+The _EA_ multiplier will start at 1.5 at the beginning of the program and will be reduced at
+the end of each Volt, before reaching the value of 1 for the rest of the program:
+
+| Volt | EA multiplier |
+| :-------- | -------- |
+| Volt 1 | 1.5 |
+| Volt 2 | 1.3 |
+| Volt 3 | 1.2 |
+| Volt 4 | 1 |
+| Volt 5 | 1 |
+| Volt 6 | 1 |
+
+### DEX objective functions
+
+For Linea's DEXs, we've implemented a points incentive program tailored to recognize active
+liquidity providers for their crucial role. In this program, user points are calculated
+from the market depth of their liquidity positions and factoring in the respective pools'
+realized volatility. This methodology ensures that points are accrued per block at a rate
+proportional to the effectiveness of the liquidity provided. In essence, the deeper the market
+depth from your liquidity position, the greater the accumulation of points.
+
+Market depth for some percentage X% is calculated for a given user, pool, and block as the USD
+value of the liquidity in range X% above and X% below the active price of the pool. This function
+is formulated for various AMM structures to use the appropriate price impact mechanism for each.
+With this definition of market depth, we define the market depth score as a weighted average of
+market depth at several realized volatility levels (RV30, 2RV30, and 3RV30), with weights that
+reflect the likelihood of the given price being reached. It is the measure of liquidity across
+a certain price range, adjusted for the past volatility of the token pair. At each block,
+users will gain points according to this market depth score.
+
+This system is designed to fine-tune liquidity provision across different asset types: in a
+concentrated liquidity market maker for example, the methodology requires tighter allocations
+for stablecoin pools to reflect their lower volatility, while allowing for broader allocations
+in more volatile pools. Our aim is to optimize liquidity throughout the ecosystem, thereby
+minimizing price impact for all DEX users. By participating, liquidity providers not only
+boost the tokens they receive by allocating assets more strategically, but also contribute
+to the overall health and efficiency of the market.
+
+## Lending objective functions
+
+For lending protocols, our objective function prioritizes tokens supplied and the total revenue
+to suppliers from lending interest.
+
+$$
+O_{{Lending}} = {Value of Non Recursive Tokens Supplied} + \beta_{R} \left({Supplier Revenue from Non Recursive Interest} \right)
+$$
+
+$ \beta_{R}$ is a parameter that sets the value of income relative to value supplied. To handle
+income in a symmetric way across verticals, it is the same $\beta_{R}$ used in the DEX objective
+function.
+
+We distinguish supplier revenue from interest to exclude supplier revenue from Linea incentives.
+We also exclude any and all recursive borrowing, both for its impact on supply and its impact
+on interest payments.
+
+Recursive borrowing is borrowing a token using the same token as collateral. Although lending
+protocols allow this, it is not an intended use case. The user will always pay a higher interest
+rate on their borrowed tokens than they receive on their supplied tokens, essentially gifting
+money to the protocol for no gain.
+
+However, when incentive programs pay users for the value they supply, it can make recursive
+borrowing profitable. In many past incentive programs, users have opened recursive borrow
+positions to farm incentives, removing them all when the incentive program ends.
+
+To avoid this, we simply exclude all recursive borrowing, counting only the net value of each
+token supplied by a given account. We also subtract the share of interest paid by recursive
+borrowers from the supplier revenue. This makes the recursive strategy unappealing, and we do
+not expect any users to attempt it.
+
+### Decentralized trading objective functions
+
+#### Taker incentives
+
+Trading incentives are set with the following equation:
+
+
+$$
+\text{Trader Incentives}_{i} = \min \left( \text{Total Trader Incentives} \times \frac{\text{Trade volume}_{i}}{\text{Total trade volume}}, \text{fees}_{i} \right)
+$$
+
+
+The trader incentives allocated to user _i_ are weighted by the user’s share of total trade volume.
+However, each user cannot receive more incentives than the total amount of trading fees they paid
+during the grant period. Incentives that would exceed fees are redistributed to the rest of the
+trader pool. If total trading fees are less than the total trader incentives, extra incentives
+will be rolled into the next grant period.
+
+#### Maker incentives
+
+We define the market depth score in the same way as the [DEX liquidity section](#dex-objective-functions).
+
+### Bridge liquidity objective functions
+
+Third-party bridges typically operate by facilitating the exchange of wrapped versions of
+assets like ETH and stablecoins, transitioning them onto Linea where they are exchanged for the
+original assets. This process relies on substantial liquidity pools within automated market
+makers (AMMs) to ensure efficient swaps with minimal slippage.
+
+Similar to the [DEX section](#dex-objective-functions), points will be allocated based on a
+market depth score to improve liquidity and minimize slippage for meaningful pairs.
+
+### Objective functions for other verticals
+
+For all other types of protocols, we leverage TVL as the primary metric to allocate points.
+
+### Referral points
+
+Referral points incentivize cooperative onboarding activities. These points are calculated by
+the formula:
+
+$$
+P_{R}=m_{rp}RP_{u}
+$$
+
+where:
+
+- $RP_{u}$ is the total referral points earned by user _u_
+- $m_{rp}$ is the multiplier for referral activity
+
+To obtain the total referral points earned by user _u_, we sum over eligible points
+ $\hat{P}_{r}$ generated by _r_ wallets that have activated user _u_'s referral code.
+
+$$
+RP_{u} = \sum_{r \in R_u} \hat{P}_{r}
+$$
+
+Eligible points $\hat{P}_{r}$ are points generated through on-chain wallet activities and, to
+prevent second-order referral effects, do not include referral points. The referral multiplier
+$m_{rp}$ is optimized throughout the program to incentivize early onboarding efforts and adjust
+for network growth.
+
+### Veteran points
+
+Veteran points $P_{V}$ and the multiplier $m_{vet}$ provide additional points to users who have
+demonstrated notable activity and partnership in the past, inviting active blockchain participants
+to join the Linea network.
+
+This is a recurring function of ecosystem points, acting as an additional multiplier only for a
+specific list of addresses provided by the Linea team.
diff --git a/docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx b/docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx
new file mode 100644
index 0000000000..426189f1da
--- /dev/null
+++ b/docs/users/linea-voyage/linea-surge/linea-surge-overview.mdx
@@ -0,0 +1,65 @@
+---
+title: Overview
+sidebar_position: 1
+image: /img/socialCards/overview.jpg
+---
+
+Once it starts, the program will last for 6 months, or until the network TVL reaches $3B, whichever
+happens first. The Surge is structured into six Volts (epochs), each one month long. Why Volts?
+Because if we reach the target we will let the epoch run till the end of the Volt. And we can play
+with themes: every Volt will have narratives and featured partners, and provide educational
+content — each Volt a distinct experience.
+
+## Early adopters
+
+The points system will start when the program goes live but we already have users and early
+adopters who have provided liquidity on the network. It's important to acknowledge what
+has been done so far. For this reason, the formula that defines points has an early adopter
+modifier that provides more points to users that started contributing earlier than others.
+
+## Dashboard
+
+After go-live, OpenBlock Labs will provide a dashboard where anyone can verify the number
+of LXP-L collected within The Surge. This will feature all necessary information for a user to
+observe their activity and points received.
+
+## Sybil
+
+While in previous campaigns we tied the minting of LXP to addresses that hold Proof Of Humanity
+to specifically protect the LXP points from bot farms and reduce sybils, in this case there's
+no such need. Providing a unit of points per $ locked is an action that does not incentivize bot
+activity: a user will get the same amount of points regardless of whether they concentrate all
+the liquidity in a single wallet or split it among thousands of addresses. This makes the
+experience even easier and more enjoyable for users who bridge liquidity to Linea.
+
+## Security and UX
+
+Dapps that participate in the program will have a great opportunity to grow, but our main
+priorities at Linea are security and UX. We can't afford to assign LXP-L points to dapps that
+put users' funds at risk, so this is the right time to raise the bar for security at an ecosystem
+level. Every dapp that is on the ecosystem portal today is audited by one of the Linea security
+partners, and in order to be eligible for inclusion in the program, a dapp must satisfy the
+following criteria:
+
+- Meet UX requirements from an established framework
+- Satisfy at least one of the two following conditions:
+ - Has been live for at least one year on any other EVM chain with a TVL peak of more than $50M
+ - Provide an audit report associated with the version of the contract that is deployed on
+ Linea and has implemented at least one real-time exploit detection solution provided by
+ Linea Partners
+
+## Relationship between LXP and LXP-L
+
+The goal for The Surge is to attract more liquidity by tracking the contribution of each user,
+leveraging a similar system that we have in place today: LXP-L will be a different token with
+the same non-transferable characteristic of LXP. Both of these points systems recognize involvement
+from two distinctly different user bases while providing greater transparency for each group.
+
+This approach ensures a balanced alignment between LXP and LXP-L. Considering the complexity
+of the Surge points model, it is challenging to establish precise alignment for these two types
+of points. Implementing parallel points systems allows us to assess the alignment retrospectively
+and make necessary adjustments to maintain fairness between users who contribute liquidity
+and those who contribute through activity.
+
+Moreover, we will continue to provide opportunities for users to contribute to the growth of
+the ecosystem by performing activity-based activations on Linea dapps.
diff --git a/docs/users/linea-voyage/lxp/index.mdx b/docs/users/linea-voyage/lxp/index.mdx
new file mode 100644
index 0000000000..504e02b0d1
--- /dev/null
+++ b/docs/users/linea-voyage/lxp/index.mdx
@@ -0,0 +1,149 @@
+---
+title: Linea Voyage LXP
+sidebar_position: 5
+image: /img/socialCards/linea-voyage-lxp.jpg
+---
+
+## What is Linea Voyage XP?
+
+Similar to video and role-playing games, wherein your character can gain Experience Points (XP) as
+you go through the game, Linea Voyage LXP represents your journey and experience in the Linea
+ecosystem.
+The Voyage LXP tokens will be a custom
+[ERC-20 token](https://ethereum.org/en/developers/docs/standards/tokens/erc-20/), and will be
+visible by default in your MetaMask wallet.
+
+**Voyage LXP tokens are non-transferable, soulbound tokens that are distributed to recognize the
+community's extraordinary contribution toward the growth of the Linea ecosystem. They do not have
+any monetary value!**
+
+Apart from being a measure of contribution to building Linea into a robust and secure L2 network,
+Voyage LXP will also make owners eligible for benefits such as receiving official community roles,
+exclusive Linea swag, and more!
+
+To learn more about the Linea Voyage program, click [here](https://support.linea.build/linea-voyage).
+
+:::note
+Voyage LXP are non-transferable, and cannot be bridged to other networks. You cannot buy, sell, or
+swap them, nor can you accumulate them by transferring LXP from another account.
+
+However, you can use multiple accounts to earn LXP; more on that below.
+:::
+
+## Contract address
+
+| Voyage LXP contract address |
+| --- |
+| [0xd83af4fbD77f3AB65C3B1Dc4B38D7e67AEcf599A](https://lineascan.build/address/0xd83af4fbD77f3AB65C3B1Dc4B38D7e67AEcf599A) |
+
+## Account binding
+
+
+
+Account binding allows you to aggregate your Voyage LXP tokens to a single primary account.
+If you're navigating the Linea ecosystem with multiple accounts, choose one as your main hub to
+effortlessly accumulate all the Voyage LXP you've received.
+This ensures that every adventure is accurately recorded across your interconnected accounts,
+providing a seamless and comprehensive representation of your Linea experience.
+
+**Account binding is not retroactive. If you bind your account address after Voyage XP is received,
+then those won't be linked to the primary account!**
+
+:::caution
+
+**Account binding is permanent and irreversible, so make sure you are choosing the correct account address when going through the process!**
+
+- Using account binding is only necessary for those who want to bind two or more accounts.
+
+- To receive LXP, the Primary account set must pass Proof of Humanity. Accounts set as secondary do not need to pass PoH.
+
+- All LXP will be sent to your Primary account when using Account Binding.
+
+- You will receive LXP once per task. The exception to this is the Linea Voyage Testnet NFT, holders will receive LXP for each NFT owned.
+:::
+
+To start the Account binding process, follow the steps below:
+
+1. Go [here](https://linea.build/activations)
+2. Connect your wallet in the top-right corner of the page
+
+
+
+
+
+
+
+3. Click on the address of your currently selected account to open a dropdown menu. Here, click
+"Manage Wallet(s)"
+
+
+
+
+
+
+
+4. Sign the signature request
+
+
+
+
+
+
+
+5. Select "Set as Primary Account"
+
+
+
+
+
+
+
+6. Select "Add secondary Account"
+
+
+
+
+
+
+
+7. Follow the prompts to connect the account you want to bind and sign the signature request.
+8. Read through the disclaimer, check the box, and hit confirm to finish the binding process
+
+
+
+
+
+
+
+:::info[What if I want to bind an account from a different Secret Recovery Phrase/seed phrase?]
+
+Refer to the [support guide](https://support.linea.build/linea-voyage/lxp-binding-an-account-from-a-different-secret-recovery-phrase-).
+
+:::
diff --git a/docs/users/move-funds/bridge.mdx b/docs/users/move-funds/bridge.mdx
new file mode 100644
index 0000000000..28274e7679
--- /dev/null
+++ b/docs/users/move-funds/bridge.mdx
@@ -0,0 +1,42 @@
+---
+title: Bridge your funds
+image: /img/socialCards/bridge-your-funds.jpg
+---
+
+The [official Linea bridge](https://bridge.linea.build/) provides multiple options to bridge
+your funds to Linea.
+
+You can select the option most appropriate to you:
+
+- **MetaMask bridge for users** - The bridge feature in MetaMask Portfolio, which we recommend as
+ the simplest option for most users.
+- **Third-party bridges for users** - Use alternative third-party bridges.
+- **Linea Native Bridge** - Best suited for tech operators, dapp teams, and liquidity
+providers. For more guidance on the native bridge, see [here](../../developers/guides/bridge/how-to-bridge-eth.mdx).
+
+:::info
+The Linea Native Bridge is a slower option that should not be used for time-sensitive transfers.
+Additionally, you will need to manually claim ERC-20 tokens that are transferred across using this bridge.
+:::
+
+## Use the MetaMask Portfolio bridge
+
+The [MetaMask Portfolio's bridge](https://portfolio.metamask.io/bridge) surveys bridges across Linea to
+source its routes and rates and provides you with the best price.
+
+MetaMask Portfolio's bridge also allows you to bridge and swap tokens as part of the same transaction.
+
+[View the MetaMask Portfolio's bridge documentation](https://support.metamask.io/metamask-portfolio/bridge/)
+for more information.
+
+## Third-party bridges
+
+You can find third-party bridges on the [ecosystem portal](https://linea.build/apps). Use the
+filter to find the available third-party bridges.
+
+:::caution
+
+These are permissionless bridges, and, you should do your own research before interacting
+with dapps in order to keep your funds safe.
+
+:::
diff --git a/docs/users/move-funds/fund.mdx b/docs/users/move-funds/fund.mdx
new file mode 100644
index 0000000000..24071fce13
--- /dev/null
+++ b/docs/users/move-funds/fund.mdx
@@ -0,0 +1,78 @@
+---
+title: Fund your accounts
+description: Get tokens in your accounts
+sidebar_position: 2
+image: /img/socialCards/fund-your-accounts.jpg
+---
+
+Linea uses ETH for network transaction fees. You can fund your account on either [Linea Mainnet](#linea-mainnet) for
+real transactions or [Linea Sepolia](#linea-sepolia) for testing purposes.
+
+## Linea Mainnet
+
+You can buy tokens directly on Linea using [MetaMask Portfolio](https://portfolio.metamask.io/).
+Alternatively, if you already have tokens on another network, you can [bridge them to Linea](./bridge.mdx).
+For example you can bridge ETH on the Ethereum network over to the Linea network.
+
+:::info
+The [MetaMask Portfolio](https://portfolio.metamask.io/) dapp allows you to buy, sell, swap, stake, bridge, and
+manage your cryptoassets, among other features.
+
+Linea purchases in MetaMask Portfolio are available worldwide.
+:::
+
+
+
+### Buy tokens on Linea Mainnet
+
+To buy tokens using MetaMask Portfolio:
+
+1. Access [MetaMask Portfolio](https://portfolio.metamask.io), and connect the account that will
+ receive your purchased tokens.
+1. Select the option to buy tokens:
+ - On a mobile device, select **Buy** from the hamburger icon menu located in the top left
+ of the screen.
+ - On a desktop, select **Buy** on screen.
+
+ :::info
+ If you've never used the **Buy** option previously, you'll first need to
+ select your region because payment methods and provider availability vary based on your bank's location.
+ :::
+
+1. Set the payment method, if you've bought tokens before on your current device, your
+ previous choice is loaded by default.
+1. In the **Buy** menu, select the token, and locate and select **Linea** from the networks list.
+1. In the list of tokens available to buy on Linea, select the one you want to buy.
+1. On the main screen, input the amount you wish to spend.
+1. View your quotes:
+ - On a desktop browser, one or more quotes appear on the right.
+ - On mobile devices, select **Get Quotes**.
+1. Pick a quote by selecting it.
+
+Selecting a quote redirects you to the provider's site to complete the transaction. You may need
+to complete KYC ("Know Your Customer"; essentially, identifying yourself) with the provider.
+
+After you've completed the steps with the provider, you'll be routed back to MetaMask Portfolio.
+Timescales for receiving your funds vary based on the provider and token route.
+
+## Linea Sepolia
+
+You can use one of the following Linea Sepolia faucets to drip testnet ETH directly to your
+Linea Sepolia address:
+
+
+- [Covalent](https://www.covalenthq.com/faucet/)
+- [Infura](https://www.infura.io/faucet/linea)
+- [GetBlock](https://getblock.io/faucet/linea-sepolia/)
+- [HackQuest](https://www.hackquest.io/en/faucets/59141) (and check out their [Linea Learning Track](https://www.hackquest.io/en/learning-track/9be129e7-575b-49bd-a64e-1bbe32427ace))
+
+Alternatively, [use the Linea Native Bridge to bridge tokens between Sepolia and Linea Sepolia](../../developers/guides/bridge/how-to-bridge-eth.mdx).
diff --git a/docs/users/move-funds/index.mdx b/docs/users/move-funds/index.mdx
new file mode 100644
index 0000000000..b37b6aa214
--- /dev/null
+++ b/docs/users/move-funds/index.mdx
@@ -0,0 +1,8 @@
+---
+title: Move funds to Linea
+image: /img/socialCards/move-funds-to-linea.jpg
+---
+
+import DocCardList from '@theme/DocCardList';
+
+
diff --git a/docs/users/move-funds/set-up-your-wallet.mdx b/docs/users/move-funds/set-up-your-wallet.mdx
new file mode 100644
index 0000000000..67d12cfd60
--- /dev/null
+++ b/docs/users/move-funds/set-up-your-wallet.mdx
@@ -0,0 +1,70 @@
+---
+title: Set up your wallet
+description: Set up your wallet to start using Linea
+sidebar_position: 1
+image: /img/socialCards/set-up-your-wallet.jpg
+---
+
+Use a wallet such as MetaMask to manage your digital assets and interact with dapps on the Linea network.
+
+:::info
+
+Linea is designed to be completely compatible with Ethereum and works with
+MetaMask out of the box.
+
+[View the MetaMask support site](https://support.metamask.io/getting-started/getting-started-with-metamask/)
+if you're not familiar with the MetaMask wallet.
+
+:::
+
+## Install MetaMask
+
+The MetaMask browser extension and mobile app provide built-in connections to Linea.
+
+You can [install MetaMask as a browser extension or mobile app](https://metamask.io/download/).
+
+## Access Linea on MetaMask
+
+### Linea Mainnet
+
+Linea Mainnet is included in the available networks in the MetaMask browser extension and mobile
+app by default.
+
+Select **Linea Mainnet** from the network dropdown to connect to the network.
+[View the MetaMask instructions](https://support.metamask.io/networks-and-sidechains/managing-networks/how-to-connect-to-linea-on-metamask/)
+for more information.
+
+### Linea Sepolia
+
+To connect to Linea Sepolia testnet, select **Show test networks**, as indicated in the image
+below, and then select **Linea Sepolia**.
+
+
+
+
+
+
+
+## Next steps
+
+View [the ecosystem portal](https://linea.build/apps) to see list of Web3 dapps available on Linea.
+
+Regardless of what you're doing on Linea, you'll likely need some tokens to transact on the network.
+To do this, you can [fund your Linea account](./fund.mdx).
+
+## Troubleshooting tips
+
+If you're interacting with a dapp on Linea, try that dapp's documentation and resources first.
+If you can't find your answer there, take a look at the [Linea Support Help Center](https://support.linea.build),
+and search on the [Linea Community Forums](https://community.linea.build) or [Discord](https://discord.com/invite/linea)
+for related issues. If it seems like a MetaMask issue at that point, jump over to
+[MetaMask's Help Center](https://support.metamask.io), where you can explore their forums, and
+start a conversation with support.
+
+## Other wallets
+
+Linea is compatible with any EVM-compatible wallet. If you want to add the Linea network, then
+[view the relevant network information](../../developers/quickstart/info-contracts.mdx).
diff --git a/docusaurus.config.js b/docusaurus.config.js
index f1d818ba3e..50192b102e 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -191,7 +191,7 @@ const config = {
},
{
label: "Risk disclosures",
- href: "/risk-disclosures/index",
+ href: "/risk-disclosures",
},
],
},
diff --git a/scripts/redirects.js b/scripts/redirects.js
deleted file mode 100644
index d4e1eda723..0000000000
--- a/scripts/redirects.js
+++ /dev/null
@@ -1,9 +0,0 @@
-const redirects = {
- '/users/linea-voyage/linea-surge/linea-surge-overview': 'https://support.linea.build/linea-voyage/linea-surge/linea-surge-overview',
- '/users/linea-voyage/linea-surge/linea-surge-model': 'https://support.linea.build/linea-voyage/linea-surge/linea-surge-model',
- '/users/linea-voyage/linea-surge': 'https://support.linea.build/linea-voyage/linea-surge',
- '/users/linea-voyage/lxp': 'https://support.linea.build/linea-voyage/lxp',
- // Add more paths as needed
- };
-
- export default redirects;
diff --git a/src/components/HomepageCards/index.tsx b/src/components/HomepageCards/index.tsx
index fca8c2f7f1..5b62fee81e 100644
--- a/src/components/HomepageCards/index.tsx
+++ b/src/components/HomepageCards/index.tsx
@@ -25,12 +25,11 @@ type CardItem = {
const CardList: CardItem[] = [
{
- title: "Bridge your funds",
- link: "/users/move-funds/bridge",
+ title: "Guides",
+ link: "/developers/guides",
description: (
<>
- Learn how to safely bridge your tokens over to Linea via MetaMask and
- ecosystem bridges
+ Learn how to get the most out of Linea with our developer-focused guides
>
),
buttonName: "Bridge",
diff --git a/src/components/RedirectPage.js b/src/components/RedirectPage.js
new file mode 100644
index 0000000000..804541e460
--- /dev/null
+++ b/src/components/RedirectPage.js
@@ -0,0 +1,30 @@
+import React, { useEffect } from 'react';
+import { useLocation } from 'react-router-dom';
+
+const redirects = {
+ '/users': 'https://support.linea.build/',
+ '/users/move-funds': 'https://support.linea.build/bridging/how-to-bridge-to-linea',
+ '/users/move-funds/bridge': 'https://support.linea.build/bridging/how-to-bridge-to-linea',
+ '/users/move-funds/set-up-your-wallet': 'https://support.linea.build/getting-started/can-you-use-linea-with-metamask',
+ '/users/move-funds/fund': 'https://support.linea.build/getting-started/how-to-buy-tokens-on-linea-using-metamask-portfolio',
+ '/users/linea-voyage': 'https://support.linea.build/linea-voyage',
+ '/users/linea-voyage/linea-surge/linea-surge-overview': 'https://support.linea.build/linea-voyage/linea-surge/linea-surge-overview',
+ '/users/linea-voyage/linea-surge/linea-surge-model': 'https://support.linea.build/linea-voyage/linea-surge/linea-surge-model',
+ '/users/linea-voyage/linea-surge': 'https://support.linea.build/linea-voyage/linea-surge',
+ '/users/linea-voyage/lxp': 'https://support.linea.build/linea-voyage/lxp',
+ // Add more paths as needed
+};
+
+export default function RedirectPage() {
+ const location = useLocation();
+ const currentPath = location.pathname;
+ const redirectUrl = redirects[currentPath];
+
+ useEffect(() => {
+ if (redirectUrl) {
+ setTimeout(() => {
+ window.location.href = redirectUrl;
+ }, 0); // Redirect immediately.
+ }
+ }, [redirectUrl]);
+}
\ No newline at end of file
diff --git a/src/components/externalRedirects.js b/src/components/externalRedirects.js
deleted file mode 100644
index 0d095f7883..0000000000
--- a/src/components/externalRedirects.js
+++ /dev/null
@@ -1,18 +0,0 @@
-import React, { useEffect } from 'react';
-import { useHistory } from '@docusaurus/router';
-
-const ExternalRedirect = ({ redirects }) => {
- const history = useHistory();
- const currentPath = history.location.pathname;
-
- useEffect(() => {
- const redirectUrl = redirects[currentPath];
- if (redirectUrl) {
- window.location.href = redirectUrl;
- }
- }, [currentPath, redirects]);
-
- return null;
-};
-
-export default ExternalRedirect;
diff --git a/src/pages/_redirects.js b/src/pages/_redirects.js
deleted file mode 100644
index 6b05dd7742..0000000000
--- a/src/pages/_redirects.js
+++ /dev/null
@@ -1,9 +0,0 @@
-import React from 'react';
-import ExternalRedirect from '../components/externalRedirects';
-import redirects from '../../scripts/redirects';
-
-const RedirectsPage = () => {
- return ;
-};
-
-export default RedirectsPage;
diff --git a/src/theme/DocItem/Layout/index.js b/src/theme/DocItem/Layout/index.js
index 92bd1353ca..0e8d22684d 100644
--- a/src/theme/DocItem/Layout/index.js
+++ b/src/theme/DocItem/Layout/index.js
@@ -13,6 +13,7 @@ import DocBreadcrumbs from '@theme/DocBreadcrumbs';
import ContentVisibility from '@theme/ContentVisibility';
import styles from './styles.module.css';
import GetFeedback from './GetFeedback';
+import RedirectPage from '../../../components/RedirectPage';
/**
* Decide if the toc should be rendered, on mobile or desktop viewports
@@ -41,6 +42,7 @@ export default function DocItemLayout({children}) {