Filter everything with users (#16)

* Filter everything with users

* Fix backtests and user management

* Add cursor rules

* Fix backtest and bots

* Update configs names

* Sign until unauth

* Setup delegate

* Setup delegate and sign

* refact

* Enhance Privy signature generation with improved cryptographic methods

* Add Fastify backend

* Add Fastify backend routes for privy

* fix privy signing

* fix privy client

* Fix tests

* add gmx core

* fix merging sdk

* Fix tests

* add gmx core

* add gmx core

* add privy to boilerplate

* clean

* fix

* add fastify

* Remove Managing.Fastify submodule

* Add Managing.Fastify as regular directory instead of submodule

* Update .gitignore to exclude Managing.Fastify dist and node_modules directories

* Add token approval functionality to Privy plugin

- Introduced a new endpoint `/approve-token` for approving ERC20 tokens.
- Added `approveToken` method to the Privy plugin for handling token approvals.
- Updated `signPrivyMessage` to differentiate between message signing and token approval requests.
- Enhanced the plugin with additional schemas for input validation.
- Included new utility functions for token data retrieval and message construction.
- Updated tests to verify the new functionality and ensure proper request decoration.

* Add PrivyApproveTokenResponse model for token approval response

- Created a new class `PrivyApproveTokenResponse` to encapsulate the response structure for token approval requests.
- The class includes properties for `Success` status and a transaction `Hash`.

* Refactor trading commands and enhance API routes

- Updated `OpenPositionCommandHandler` to use asynchronous methods for opening trades and canceling orders.
- Introduced new Fastify routes for opening positions and canceling orders with appropriate request validation.
- Modified `EvmManager` to handle both Privy and non-Privy wallet operations, utilizing the Fastify API for Privy wallets.
- Adjusted test configurations to reflect changes in account types and added helper methods for testing Web3 proxy services.

* Enhance GMX trading functionality and update dependencies

- Updated `dev:start` script in `package.json` to include the `-d` flag for Fastify.
- Upgraded `fastify-cli` dependency to version 7.3.0.
- Added `sourceMap` option to `tsconfig.json`.
- Refactored GMX plugin to improve position opening logic, including enhanced error handling and validation.
- Introduced a new method `getMarketInfoFromTicker` for better market data retrieval.
- Updated account type in `PrivateKeys.cs` to use `Privy`.
- Adjusted `EvmManager` to utilize the `direction` enum directly for trade direction handling.

* Refactor GMX plugin for improved trading logic and market data retrieval

- Enhanced the `openGmxPositionImpl` function to utilize the `TradeDirection` enum for trade direction handling.
- Introduced `getTokenDataFromTicker` and `getMarketByIndexToken` functions for better market and token data retrieval.
- Updated collateral calculation and logging for clarity.
- Adjusted `EvmManager` to ensure proper handling of price values in trade requests.

* Refactor GMX plugin and enhance testing for position opening

- Updated `test:single` script in `package.json` to include TypeScript compilation before running tests.
- Removed `this` context from `getClientForAddress` function and replaced logging with `console.error`.
- Improved collateral calculation in `openGmxPositionImpl` for better precision.
- Adjusted type casting for `direction` in the API route to utilize `TradeDirection` enum.
- Added a new test for opening a long position in GMX, ensuring functionality and correctness.

* Update sdk

* Update

* update fastify

* Refactor start script in package.json to simplify command execution

- Removed the build step from the start script, allowing for a more direct launch of the Fastify server.

* Update package.json for Web3Proxy

- Changed the name from "Web3Proxy" to "web3-proxy".
- Updated version from "0.0.0" to "1.0.0".
- Modified the description to "The official Managing Web3 Proxy".

* Update Dockerfile for Web3Proxy

- Upgraded Node.js base image from 18-alpine to 22.14.0-alpine.
- Added NODE_ENV environment variable set to production.

* Refactor Dockerfile and package.json for Web3Proxy

- Removed the build step from the Dockerfile to streamline the image creation process.
- Updated the start script in package.json to include the build step, ensuring the application is built before starting the server.

* Add fastify-tsconfig as a development dependency in Dockerfile-web3proxy

* Remove fastify-tsconfig extension from tsconfig.json for Web3Proxy

* Add PrivyInitAddressResponse model for handling initialization responses

- Introduced a new class `PrivyInitAddressResponse` to encapsulate the response structure for Privy initialization, including properties for success status, USDC hash, order vault hash, and error message.

* Update

* Update

* Remove fastify-tsconfig installation from Dockerfile-web3proxy

* Add build step to Dockerfile-web3proxy

- Included `npm run build` in the Dockerfile to ensure the application is built during the image creation process.

* Update

* approvals

* Open position from front embedded wallet

* Open position from front embedded wallet

* Open position from front embedded wallet

* Fix call contracts

* Fix limit price

* Close position

* Fix close position

* Fix close position

* add pinky

* Refactor position handling logic

* Update Dockerfile-pinky to copy package.json and source code from the correct directory

* Implement password protection modal and enhance UI with new styles; remove unused audio elements and update package dependencies.

* add cancel orders

* Update callContract function to explicitly cast account address as Address type

* Update callContract function to cast transaction parameters as any type for compatibility

* Cast transaction parameters as any type in approveTokenImpl for compatibility

* Cast wallet address and transaction parameters as Address type in approveTokenImpl for type safety

* Add .env configuration file for production setup including database and server settings

* Refactor home route to update welcome message and remove unused SDK configuration code

* add referral code

* fix referral

* Add sltp

* Fix typo

* Fix typo

* setup sltp on backtend

* get orders

* get positions with slp

* fixes

* fixes close position

* fixes

* Remove MongoDB project references from Dockerfiles for managing and worker APIs

* Comment out BotManagerWorker service registration and remove MongoDB project reference from Dockerfile

* fixes
This commit is contained in:
Oda
2025-04-20 22:18:27 +07:00
committed by GitHub
parent 0ae96a3278
commit 528c62a0a1
400 changed files with 94446 additions and 1635 deletions

View File

@@ -4,7 +4,9 @@ using Managing.Common;
using Managing.Domain.Evm;
using Managing.Infrastructure.Evm;
using Managing.Infrastructure.Evm.Abstractions;
using Managing.Infrastructure.Evm.Models.Privy;
using Managing.Infrastructure.Evm.Services;
using Microsoft.Extensions.Options;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using Nethereum.Contracts;
using Nethereum.Contracts.Standards.ERC721.ContractDefinition;
@@ -21,19 +23,23 @@ public class EvmManagerTests
private readonly List<Chain> _chains;
public List<ISubgraphPrices> Subgraphs;
public readonly string PublicAddress = "";
public readonly IWeb3ProxyService _web3Proxy;
public readonly string PublicAddress = "0x932167388dd9aad41149b3ca23ebd489e2e2dd78";
public EvmManagerTests()
{
_manager = new EvmManager(Subgraphs);
// Use the helper method to create Web3ProxyService
_web3Proxy = CreateWebProxyService();
_manager = new EvmManager(Subgraphs, _web3Proxy);
_chains = ChainService.GetChains();
}
[Fact]
public void Should_construct_manager()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
Assert.IsType<EvmManager>(manager);
}
@@ -63,7 +69,7 @@ public class EvmManagerTests
[InlineData("0xa435530d50d7D17Fd9fc6E1c897Dbf7C08E12d35", "0x17f4BAa9D35Ee54fFbCb2608e20786473c7aa49f")]
public async Task Should_return_event_transfer_nft(string owner, string contract)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var holders = await manager.GetNftEvent(owner, contract);
Assert.IsType<List<EventLog<TransferEventDTO>>>(holders);
Assert.True(holders.Any());
@@ -74,7 +80,7 @@ public class EvmManagerTests
[Fact]
public async Task Should_return_date_of_block()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var date = await manager.GetBlockDate(38793245);
Assert.Equal(new DateTime(2022, 11, 17, 11, 15, 33), date);
}
@@ -86,7 +92,7 @@ public class EvmManagerTests
var address = "0x94618601FE6cb8912b274E5a00453949A57f8C1e";
var privateKey = "0x7580e7fb49df1c861f0050fae31c2224c6aba908e116b8da44ee8cd927b990b0";
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var signature = manager.SignMessage(message, privateKey);
var addressRecovered = manager.VerifySignature(signature, message);
@@ -97,7 +103,7 @@ public class EvmManagerTests
[Fact]
public void Shoud_return_generated_evm_address()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var keys = manager.GenerateAddress();
Assert.IsType<(string Key, string Secret)>(keys);
@@ -109,7 +115,7 @@ public class EvmManagerTests
public void Should_return_correct_account_for_mnemo()
{
var mnemo = "twist enemy flame exchange summer roast beyond friend image pyramid topple need";
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var publicAddress = "0x3aBAD913A70554f416944F1a4C0EAbF3BCAFB959";
var address = manager.GetAddressFromMnemo(mnemo);
Assert.NotNull(address);
@@ -123,7 +129,7 @@ public class EvmManagerTests
// [InlineData("0x7002AE0Bae7fC67416230F025A32EfE086C0934E", Constants.Chains.Arbitrum)]
public async Task Should_return_balances(string publicAddress, string chainName)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var chain = _chains.First(c => c.Name == chainName);
var balances = await manager.GetBalances(chain, 0, 500, publicAddress);
@@ -137,7 +143,7 @@ public class EvmManagerTests
[InlineData("0xc62F5499789b716Aa94a421A60c76c8c13A31ab6", Constants.Chains.Ethereum)]
public async Task Should_return_all_balance(string publicAddress, string chainName)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var chain = _chains.First(c => c.Name == chainName);
var balances = await manager.GetAllBalances(chain, publicAddress);
@@ -150,7 +156,7 @@ public class EvmManagerTests
[InlineData("", Constants.Chains.Arbitrum, Ticker.GMX)]
public async void Should_return_token_balance(string publicAddress, string chainName, Ticker ticker)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var balance = await manager.GetTokenBalance(chainName, ticker, publicAddress);
Assert.IsType<EvmBalance>(balance);
@@ -162,7 +168,7 @@ public class EvmManagerTests
[InlineData("")]
public async Task Should_return_balance_of_ethers(string publicAddress)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var chain = _chains.First(c => c.Name == Constants.Chains.Ethereum);
var balance = await manager.GetEtherBalance(chain, publicAddress);
@@ -174,7 +180,7 @@ public class EvmManagerTests
[InlineData("")]
public async Task Should_return_all_balance_for_all_chain(string publicAddress)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var balances = await manager.GetAllBalancesOnAllChain(publicAddress);
Assert.IsType<List<EvmBalance>>(balances);
@@ -186,7 +192,7 @@ public class EvmManagerTests
[InlineData(Ticker.BTC, Timeframe.FiveMinutes)]
public async Task Get_Prices(Ticker ticker, Timeframe timeframe)
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var candles = await manager.GetCandles(SubgraphProvider.ChainlinkPrice, ticker, DateTime.UtcNow, timeframe);
if (!candles.Any())
@@ -202,7 +208,7 @@ public class EvmManagerTests
[Fact]
public async Task Get_Available_Tickers()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var tickers = await manager.GetAvailableTicker();
Assert.NotEmpty(tickers);
@@ -212,7 +218,7 @@ public class EvmManagerTests
[Fact]
public async Task GetLastCandle()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var candle = await manager.GetCandle(SubgraphProvider.Gbc, Ticker.BTC);
Assert.NotNull(candle);
@@ -222,8 +228,8 @@ public class EvmManagerTests
[Fact]
public async Task Should_Init_Address_For_Trading()
{
var manager = new EvmManager(Subgraphs);
var accountInitilized = await manager.InitAddress(Constants.Chains.Arbitrum, PublicAddress, "PrivateKey");
var manager = new EvmManager(Subgraphs, _web3Proxy);
var accountInitilized = await manager.InitAddress(PublicAddress);
Assert.True(accountInitilized);
}
@@ -232,7 +238,7 @@ public class EvmManagerTests
[Fact]
public async Task Should_send_eth_from_account()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var chain = _chains.First(c => c.Name == Constants.Chains.Arbitrum);
var balance = await manager.GetEtherBalance(chain, PublicAddress);
// Update receiver
@@ -252,7 +258,7 @@ public class EvmManagerTests
[Fact]
public async Task Should_send_Gmx_from_account()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var chain = _chains.First(c => c.Name == Constants.Chains.Arbitrum);
var receiverAddress = "";
var balance = await manager.GetTokenBalance(chain.Name, Ticker.GMX, PublicAddress);
@@ -272,7 +278,7 @@ public class EvmManagerTests
[Fact]
public async Task Should_return_allowance()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var account = PrivateKeys.GetAccount();
var allowance = await manager.GetAllowance(account.Key, Ticker.USDC);
@@ -283,13 +289,13 @@ public class EvmManagerTests
[Fact]
public async Task Should_set_allowance()
{
var manager = new EvmManager(Subgraphs);
var manager = new EvmManager(Subgraphs, _web3Proxy);
var account = PrivateKeys.GetAccount();
// Get amount from balance
var balance = await manager.GetTokenBalance(Constants.Chains.Arbitrum, Ticker.USDC, account.Key);
var result = await manager.SetAllowance(account, Ticker.USDC, new BigInteger(balance.Balance));
var result = await manager.SetAllowance(account, Ticker.USDC, new BigInteger(10));
Assert.True(result);
}
@@ -300,4 +306,25 @@ public class EvmManagerTests
await EvmBase.GetGasPrice(new Web3(_chains.First(c => c.Name == Constants.Chains.Arbitrum).RpcUrl));
Assert.True(result > 0);
}
[Fact]
public async Task Should_Sign_Message_Embedded_Account()
{
var message = "Hello eth";
var walletId = "cm7vxs99f0007blcl8cmzv74t";
var address = "0x932167388dD9aad41149b3cA23eBD489E2E2DD78";
var manager = new EvmManager(Subgraphs, _web3Proxy);
var signature = await manager.SignMessageAsync(walletId, address, message);
Assert.NotNull(signature);
}
// Helper method to create Web3ProxyService for tests
public static IWeb3ProxyService CreateWebProxyService(string baseUrl = "http://localhost:4111/api/")
{
var settings = new Web3ProxySettings { BaseUrl = baseUrl };
var options = Options.Create(settings);
return new Web3ProxyService(options);
}
}