* 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
Scripts
This directory contains utility scripts for the project.
Add JS Extensions Script
The add-js-extensions.mjs script adds .js extensions to import statements in JavaScript and TypeScript files, and also adds the required JSON import assertions.
Why This Script?
When working with ES Modules in Node.js:
- Imports of local files require explicit file extensions
- JSON imports require an
assert { type: 'json' }assertion
This script automates both processes to ensure your code is ESM-compatible.
Usage
Run the script with npm:
# Fix imports in the src directory (default)
npm run fix-imports
# Fix imports in a specific directory
npm run fix-imports-dir -- path/to/directory
Or run the script directly:
# Fix imports in the src directory (default)
node scripts/add-js-extensions.mjs
# Fix imports in a specific directory
node scripts/add-js-extensions.mjs path/to/directory
What This Script Does
- Recursively scans all JavaScript and TypeScript files in the specified directory
- Identifies import statements with relative paths (starting with
./or../) that don't have extensions and adds.jsextensions - Identifies JSON imports that are missing the required assertion and adds
assert { type: 'json' } - Provides a summary of files modified and any errors encountered
Examples
Before:
import { bigMath } from "./bigmath";
import data from "./data.json";
After:
import { bigMath } from "./bigmath.js";
import data from "./data.json" assert { type: 'json' };
Important Notes
- The script only modifies imports with relative paths (starting with
./or../) - It skips imports that already have a file extension (except for JSON files)
- It adds
.jsextensions to extensionless imports - It adds
assert { type: 'json' }to JSON imports that don't already have it - It handles regular imports, dynamic imports, and exports
Remove JSON Assertions Script
The remove-json-assertions.mjs script removes assert { type: 'json' } assertions from JSON imports.
Why This Script?
Different JavaScript environments have different requirements for JSON imports:
- Some newer environments require the
assert { type: 'json' }assertion - Others don't support or need these assertions
This script removes these assertions to improve compatibility with environments that don't need them.
Usage
Run the script with npm:
# Remove JSON assertions
npm run remove-json-assertions
# Run both import fixes and assertion removal in one command
npm run prepare-code
Or run the script directly:
node scripts/remove-json-assertions.mjs
What This Script Does
- Recursively scans all JavaScript and TypeScript files in the project
- Identifies JSON imports with
assert { type: 'json' }assertions - Removes the assertions while preserving the import statements
- Provides a summary of files modified
Examples
Before:
import data from "./data.json" assert { type: 'json' };
After:
import data from "./data.json";
Important Notes
- The script only modifies JSON imports with assertions
- It preserves all other import statements
- It works in conjunction with the add-js-extensions script
- These scripts can be run in sequence to first fix imports then remove assertions
Update JSON Imports Script
The update-json-imports.mjs script updates JSON imports to use the modern with { type: "json" } syntax.
Why This Script?
Different JavaScript environments have different requirements for JSON imports:
- Older environments used
assert { type: 'json' }for JSON imports - Modern JavaScript environments now use the
with { type: "json" }syntax
This script updates your codebase to use the newer, more standardized approach.
Usage
Run the script with npm:
# Update JSON import syntax
npm run update-json-imports
# Run both import fixing and JSON import updating in one command
npm run prepare-code
Or run the script directly:
node scripts/update-json-imports.mjs
What This Script Does
- Recursively scans all JavaScript and TypeScript files in the project
- Identifies JSON imports using either:
- The older
assert { type: 'json' }syntax - No type assertion at all
- Erroneous dual syntax (
assert { type: 'json' } with { type: "json" })
- The older
- Updates them to use the modern
with { type: "json" }syntax - Provides a summary of files modified
Examples
Before (old assert syntax):
import data from "./data.json" assert { type: 'json' };
Before (no type assertion):
import data from "./data.json";
Before (erroneous dual syntax):
import data from "./data.json" assert { type: 'json' } with { type: "json" };
After (in all cases):
import data from "./data.json" with { type: "json" };
Important Notes
- The script updates all JSON imports to use the modern syntax
- It properly fixes cases where both old and new syntax are present
- It preserves all other import statements
- Files with properly formatted imports are not modified