Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xandao-dev/thetan-arena-sniper
Thetan Arena bot to buy NFT's quickly
https://github.com/xandao-dev/thetan-arena-sniper
arbitrage arbitrage-bot aws blockchain crypto cryptocurrency ec2 nft nftbot thetan-arena thetan-arena-bot web3js
Last synced: 3 months ago
JSON representation
Thetan Arena bot to buy NFT's quickly
- Host: GitHub
- URL: https://github.com/xandao-dev/thetan-arena-sniper
- Owner: xandao-dev
- License: mit
- Created: 2021-12-26T19:25:02.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-09-06T01:43:06.000Z (over 2 years ago)
- Last Synced: 2024-10-10T12:50:43.080Z (3 months ago)
- Topics: arbitrage, arbitrage-bot, aws, blockchain, crypto, cryptocurrency, ec2, nft, nftbot, thetan-arena, thetan-arena-bot, web3js
- Language: TypeScript
- Homepage:
- Size: 1.96 MB
- Stars: 7
- Watchers: 4
- Forks: 10
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
Thetan Arena Sniper
Thetan Arena Sniper is a tool to buy cheap thetans NFTs quickly. It interacts with BSC Blockchain to buy thetans as fast as possible.
:warning: I'ts not working, the contracts has been updated :warning:
:warning: I am not responsible for financial losses. :warning:
Explore the docs »
Report Bug
·
Request Feature
Table of Contents
## About The Project
### Introduction
There are a few things you need to know before using the bot. There are some variables that can be changed according to
your need, they are in [configs file](./src/configs.ts).First, this bot selects the cheap characters through the Expected Earn Rate which is the percentage of profit in
relation to the purchase price and the possible sale price.The sales price estimate is based on how much profit a character can generate. When the win rate is 40%, we estimate
the sale price to the same amount which would make the character generate a profit. You can adjust this value in the [configs file](./src/configs.ts) in BATTLE_WIN_RATE. You can check how much the character generates by 40% in the
[Thetan Arena Tool](https://thetanarenatool.io/).There are the more configs that I recommend tweaking, check the [configs file](./src/configs.ts) for more details.
### Tips
I recommend placing the bot on a server in the US to be closer to the game server and thus be able to see the
characters faster. I used an EC2 from Amazon AWS at the us-east-1 location.### Features
* Watch the marketplace for good opportunities
* Automatically buy and rent new and cheap thetans from marketplace
* Automatically buy BNB for gas fees when the balance is low
* Dinamically estimate gas fee for each transaction based on the possible profit
* Fast (become even faster if you put it on a US server), it does not miss a block.
* Saves a record of all transactions in a log file
* [TODO] ~~Automatically sell thetans~~
* [TODO] ~~Mempool monitoring to front run thetans~~### Built With
* [Node.js](https://nodejs.org/) - A JavaScript runtime build on Chrome's V8 JS engine
* [Web3.js](https://web3js.readthedocs.io/) - A library for interacting with blockchain networks and smart contracts## Getting Started
To get a local copy up and running follow these simple steps.
### Installation Local
1. Clone the repo
```sh
git clone https://github.com/xandao-dev/thetan-arena-sniper.git
```2. Install dependencies
```sh
cd thetan-arena-sniper
npm install # or yarn install
```3. Set environment variables. Create a ".env" file based on ".env.example".
* BSC_PROVIDER - The URL of the BSC node, use this one for mainnet: https://bsc-dataseed1.binance.org:443
* WALLET_PRIVATE_KEY - Your wallet private key, you can find it on Metamask -> Account Details -> Export Private Key
You should append the 0x to the private key.
I recommend creating a new wallet just for this project, fill with some BNB for gas and with WBNB to buy thetans.4. Install pm2 to run the application as a service
```sh
npm install pm2 -g
```### Installation EC2 (Optional)
Install Thetan Arena Sniper in EC2 Server:
1. Connect to EC2 server
```sh
ssh -i @
```2. Copy dist folder to the server
```sh
scp -i -r ./dist @:/home//thetan-arena-sniper/
```3. Copy .env file
```sh
scp -i ./.env @:/home//thetan-arena-sniper/.env
```4. Copy package.json
```sh
scp -i ./package.json @:/home//thetan-arena-sniper/package.json
```5. Update ec2: `sudo yum update -y`
6. Install git: `sudo yum install git -y`
7. Install node: `curl -L https://git.io/n-install | bash -s -- -y `8. Run inside thetan-arena-sniper folder: `npm install`
9. Install pm2: `npm install pm2 -g`
10. Run application: `pm2 start main.js -- 0.3 --stop-exit-codes 0`
11. Monitor with `pm2 monit`
## Usage
* Generate a version of the application
```sh
npm run build # or yarn build
```* Run:
```sh
pm2 start ./dist/main.js
```* Monitor:
```sh
pm2 monit
```* Stop:
```sh
pm2 stop all
```## Roadmap
See the [open issues](https://github.com/xandao-dev/thetan-arena-sniper/issues) for a list of proposed features (and known issues).
## Contributing
Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated**.
1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request## License
Distributed under the MIT License. See [LICENSE](./LICENSE.md) for more information.
Free software =)
## Contact
Alexandre Calil - [Linkedin](https://www.linkedin.com/in/xandao-dev/) - [[email protected]](mailto:[email protected])
Project Link: [https://github.com/xandao-dev/thetan-arena-sniper](https://github.com/xandao-dev/thetan-arena-sniper)
## Acknowledgements
* [typescript](https://www.typescriptlang.org/) - strongly typed JavaScript
* [ts-node-dev](https://www.npmjs.com/package/ts-node-dev) - npm run dev with typescript support
* [dotenv](https://github.com/motdotla/dotenv) - environment variables
* [beeper](https://www.npmjs.com/package/beeper) - beep sound on terminal
* [set-interval-async](https://www.npmjs.com/package/set-interval-async) - Async set interval
* [simple-node-logger](https://www.npmjs.com/package/simple-node-logger) - A simple logger for Node.js
* [undici](https://www.npmjs.com/package/undici) - The fastest HTTP client for Node.js
* [pm2](https://www.npmjs.com/package/pm2) - A Node.js process manager