Skip to content

Soroswap.Finance Frontend for Soroswap AMM, Soroswap Aggregator & Spacewalk Bridge Implementation

License

Notifications You must be signed in to change notification settings

soroswap/frontend

 
 

Repository files navigation

🌟 Soroswap Frontend @ Soroban Preview 10🌟

Welcome to Soroswap, a decentralized exchange (DEX) that draws inspiration from the Uniswap V2 protocol and is specifically tailored for the Soroban network.

Before you begin, ensure you have met the following requirements:

  • docker >= v24.0.2
  • Freighter Wallet v5.6.3 Please use this version. You can have an intependent environment following the instructios in this post

πŸ›  Setting Up Soroswap πŸ› 

1. Clone the Repository

```bash

git clone https://github.com/soroswap/frontend.git
cd frontend
```

2.Set Up Environment Variables

Copy the .env.example file to create a new .env file:

cp .env.local.example .env

Edit the .env file and provide the following variables:

NEXT_PUBLIC_BACKEND_URL=http://localhost:8010 // If you are following the instructions in `https://github.com/soroswap/core`
NEXT_PUBLIC_SOROSWAP_BACKEND_URL=http://localhost:8000// Your local soroswap backend url
NEXT_PUBLIC_SOROSWAP_BACKEND_ENABLED= false // Enables or disables the soroswap backend
NEXT_PUBLIC_DEFAULT_NETWORK= standalone // The default network to connect
NEXT_PUBLIC_AGGREGATOR_ENABLED= false // Enables or disables the aggregator
NEXT_PUBLIC_SOROSWAP_BACKEND_API_KEY= BACKEND_API_KEY // The API key to autenthicate in the soroswap backend
NEXT_PUBLIC_TRUSTLINE_WALLET_PUBLIC_KEY= STELLAR_PUBLIC_KEY// The public key of the trustline wallet
NEXT_PUBLIC_TEST_TOKENS_ADMIN_SECRET_KEY= STELLAR_SECRET_KEY // The secret key of the test tokens admin

Hints: The NEXT_PUBLIC_BACKEND_URL should serve:

  • the list of known tokens
  • the SoroswapFactory address
  • the SoroswapRouter address

The NEXT_PUBLIC_TEST_TOKENS_ADMIN_SECRET_KEY should be the same as the one that deployed the tokens in the core repository.

To enable or disable features like the Soroswap backend or the aggregator, switch the NEXT_PUBLIC_SOROSWAP_BACKEND_ENABLED and NEXT_PUBLIC_AGGREGATOR_ENABLED variables to true or false.

Then, when you are ready for production, you can take Futurenet Contracts information from https://api.soroswap.finance and use the production env file:

cp .env.production.example .env

[!IMPORTANT] Note that some Futurenet RPC's might not have the same version, so we strongly recomend you to connect to a local quickstart node following the instructions in https://github.com/soroswap/core; and setting up your Freighter Wallet as in step 6.

  1. Start Docker

    Navigate to the the run.sh script inside the docker folder

    bash docker/run.sh

    This script will set up and start the Docker containers required for Soroswap.

  2. Install the Dependencies

    After the Docker container is up, you will be inside the root folder on the container. Then, install the dependencies using Yarn:

    yarn install
  3. Run the Development Instance

    Now you are ready to start the development instance. Run the following command:

    yarn dev

    This will start the Soroswap development instance.

  4. Configure your Freigher Wallet

    For Standalone network

    Name Local Standalone
    HORIZON RPC URL http://localhost:8000
    SOROBAN RPC URL http://localhost:8000/soroban/rpc
    Passphrase Standalone Network ; February 2017
    Friendbot http://localhost:8000/friendbot
    Allow HTTP connection Enabled
    Switch to this network Enabled

    For Futurenet network

    Name Local Futurenet
    HORIZON RPC URL http://localhost:8000
    SOROBAN RPC URL http://localhost:8000/soroban/rpc
    Passphrase Test SDF Future Network ; October 2022
    Friendbot http://localhost:8000/friendbot
    Allow HTTP connection Enabled
    Switch to this network Enabled

    ** Important:** You should also do: Preferences> Allow experimental mode

  5. Last, but not least, add some lumens to your Freighter wallet!

    Do it directly on the wallet or use:

    For Standalone: http://localhost:8000/friendbot?addr=<your address> For Futurenet, visit: https://laboratory.stellar.org/#create-account

πŸš€ Congrats! πŸš€

You have successfully set up Soroswap on your local machine! Start swapping, pooling, and exploring the possibilities of decentralized finance (DeFi) on the Soroban network.

If you want to add or remove supported protocols, you can do so by editing the functions/generateRoute.ts:79-97 file and adding or removing the protocols you want to support on swap.

[!HINT] You can found the list of supported protocols in the soroswap-router-sdk repository.

πŸ§ͺπŸ”¨ Testing πŸ§ͺπŸ”¨

To execute the tests, you must first start the development container. To do this, run the following command from your host machine:

bash docker/run.sh

Once the development container is running, you can install the dependencies for the tests by running the following command:

## πŸ§ͺπŸ”¨ Testing πŸ§ͺπŸ”¨
To execute the tests, you must first start the development container. To do this, run the following command from your host machine:

```bash
bash docker/run.sh

Once the development container is running, you can install the dependencies for the tests by running the following command:

yarn install

Finally, to run the tests, run the following command from within the development container:

yarn test

This will run all of the unit and integration tests for the project.

The tests are written using Vitest & testing-library.

For more information on Vitest, please see the Vitest documentation: https://vitest.dev/.

For more information on Testing Library, please see the Testing Library documentation: https://testing-library.com/docs/react-testing-library/intro/

Contributing

If you find a bug or have a feature request, please create an issue or submit a pull request. Contributions are always welcome!

License: MIT

Acknowledgments

Special thanks to the Uniswap team for providing the base protocol on which Soroswap is built.
Thank you to the Stellar Community for the continuous support.


Made with ❀️ by the Soroswap Team.

About

Soroswap.Finance Frontend for Soroswap AMM, Soroswap Aggregator & Spacewalk Bridge Implementation

Topics

Resources

License

Stars

Watchers

Forks

Languages