* 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
191 lines
5.1 KiB
Markdown
191 lines
5.1 KiB
Markdown
# 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:
|
|
1. Imports of local files require explicit file extensions
|
|
2. 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:
|
|
|
|
```bash
|
|
# 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:
|
|
|
|
```bash
|
|
# 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
|
|
|
|
1. Recursively scans all JavaScript and TypeScript files in the specified directory
|
|
2. Identifies import statements with relative paths (starting with `./` or `../`) that don't have extensions and adds `.js` extensions
|
|
3. Identifies JSON imports that are missing the required assertion and adds `assert { type: 'json' }`
|
|
4. Provides a summary of files modified and any errors encountered
|
|
|
|
### Examples
|
|
|
|
Before:
|
|
```javascript
|
|
import { bigMath } from "./bigmath";
|
|
import data from "./data.json";
|
|
```
|
|
|
|
After:
|
|
```javascript
|
|
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 `.js` extensions 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:
|
|
1. Some newer environments require the `assert { type: 'json' }` assertion
|
|
2. 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:
|
|
|
|
```bash
|
|
# 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:
|
|
|
|
```bash
|
|
node scripts/remove-json-assertions.mjs
|
|
```
|
|
|
|
### What This Script Does
|
|
|
|
1. Recursively scans all JavaScript and TypeScript files in the project
|
|
2. Identifies JSON imports with `assert { type: 'json' }` assertions
|
|
3. Removes the assertions while preserving the import statements
|
|
4. Provides a summary of files modified
|
|
|
|
### Examples
|
|
|
|
Before:
|
|
```javascript
|
|
import data from "./data.json" assert { type: 'json' };
|
|
```
|
|
|
|
After:
|
|
```javascript
|
|
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:
|
|
1. Older environments used `assert { type: 'json' }` for JSON imports
|
|
2. 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:
|
|
|
|
```bash
|
|
# 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:
|
|
|
|
```bash
|
|
node scripts/update-json-imports.mjs
|
|
```
|
|
|
|
### What This Script Does
|
|
|
|
1. Recursively scans all JavaScript and TypeScript files in the project
|
|
2. 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" }`)
|
|
3. Updates them to use the modern `with { type: "json" }` syntax
|
|
4. Provides a summary of files modified
|
|
|
|
### Examples
|
|
|
|
Before (old assert syntax):
|
|
```javascript
|
|
import data from "./data.json" assert { type: 'json' };
|
|
```
|
|
|
|
Before (no type assertion):
|
|
```javascript
|
|
import data from "./data.json";
|
|
```
|
|
|
|
Before (erroneous dual syntax):
|
|
```javascript
|
|
import data from "./data.json" assert { type: 'json' } with { type: "json" };
|
|
```
|
|
|
|
After (in all cases):
|
|
```javascript
|
|
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 |