* 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
130 lines
4.3 KiB
JavaScript
Executable File
130 lines
4.3 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
|
|
import fs from 'fs/promises';
|
|
import path from 'path';
|
|
import { fileURLToPath } from 'url';
|
|
|
|
// Get the current file path and directory
|
|
const __filename = fileURLToPath(import.meta.url);
|
|
const __dirname = path.dirname(__filename);
|
|
const gmxsdkDir = path.resolve(__dirname, '../src/Managing.Fastify/src/generated/gmxsdk');
|
|
|
|
// Regex to match import statements with relative paths without extensions
|
|
// This regex captures: import statements, export statements, and dynamic imports
|
|
const importRegex = /((?:import|export)(?:\s+(?:[\w*\s{},]*)\s+from\s+)?['"]|import\(['"])(\.[^'")\s]*)(['"]|\))/g;
|
|
|
|
// Regex to match JSON imports that don't have the assert { type: 'json' }
|
|
const jsonImportRegex = /((?:import|export)(?:\s+(?:[\w*\s{},]*)\s+from\s+)?['"]|import\(['"])(\.[^'")\s]*\.json)(['"])(?!\s+assert\s*{\s*type\s*:\s*['"]json['"]\s*})/g;
|
|
|
|
async function processFile(filePath) {
|
|
try {
|
|
// Read file content
|
|
const content = await fs.readFile(filePath, 'utf8');
|
|
|
|
// Skip files that are already processed or don't need processing
|
|
if (!content.match(importRegex) && !content.match(jsonImportRegex)) {
|
|
return { filePath, changed: false };
|
|
}
|
|
|
|
// First: Handle normal imports - add .js extensions
|
|
let modifiedContent = content.replace(importRegex, (match, prefix, importPath, suffix) => {
|
|
// Skip if already has an extension
|
|
if (path.extname(importPath)) {
|
|
return match;
|
|
}
|
|
|
|
// Add .js extension
|
|
return `${prefix}${importPath}.js${suffix}`;
|
|
});
|
|
|
|
// Second: Handle JSON imports - add assert { type: 'json' }
|
|
modifiedContent = modifiedContent.replace(jsonImportRegex, (match, prefix, importPath, suffix) => {
|
|
// Add the JSON assertion
|
|
return `${prefix}${importPath}${suffix} assert { type: 'json' }`;
|
|
});
|
|
|
|
// Only write if content changed
|
|
if (content !== modifiedContent) {
|
|
await fs.writeFile(filePath, modifiedContent, 'utf8');
|
|
return { filePath, changed: true };
|
|
}
|
|
|
|
return { filePath, changed: false };
|
|
} catch (error) {
|
|
return { filePath, error: error.message };
|
|
}
|
|
}
|
|
|
|
async function walkDir(dir, fileTypes = ['.ts', '.tsx', '.js', '.jsx', '.mjs']) {
|
|
const entries = await fs.readdir(dir, { withFileTypes: true });
|
|
const files = [];
|
|
|
|
for (const entry of entries) {
|
|
const fullPath = path.join(dir, entry.name);
|
|
|
|
if (entry.isDirectory()) {
|
|
// Skip node_modules, .git, build, and dist directories
|
|
const skipDirs = ['node_modules', '.git', 'build', 'dist', '.next'];
|
|
if (!skipDirs.includes(entry.name)) {
|
|
files.push(...await walkDir(fullPath, fileTypes));
|
|
}
|
|
} else if (entry.isFile()) {
|
|
const ext = path.extname(entry.name);
|
|
if (fileTypes.includes(ext)) {
|
|
files.push(fullPath);
|
|
}
|
|
}
|
|
}
|
|
|
|
return files;
|
|
}
|
|
|
|
async function main() {
|
|
console.log(`Scanning @gmxsdk directory: ${gmxsdkDir}`);
|
|
|
|
try {
|
|
const files = await walkDir(gmxsdkDir);
|
|
console.log(`Found ${files.length} files to process in @gmxsdk`);
|
|
|
|
// Process files in chunks to avoid memory issues with large projects
|
|
const chunkSize = 100;
|
|
const results = [];
|
|
|
|
for (let i = 0; i < files.length; i += chunkSize) {
|
|
const chunk = files.slice(i, i + chunkSize);
|
|
const chunkResults = await Promise.all(chunk.map(processFile));
|
|
results.push(...chunkResults);
|
|
|
|
// Progress update
|
|
console.log(`Processed ${Math.min(i + chunkSize, files.length)}/${files.length} files...`);
|
|
}
|
|
|
|
// Collect statistics
|
|
const changed = results.filter(r => r.changed);
|
|
const errors = results.filter(r => r.error);
|
|
|
|
console.log('\nSummary:');
|
|
console.log(`- Total files scanned: ${files.length}`);
|
|
console.log(`- Files modified: ${changed.length}`);
|
|
console.log(`- Errors encountered: ${errors.length}`);
|
|
|
|
if (changed.length > 0) {
|
|
console.log('\nModified files:');
|
|
changed.forEach(({ filePath }) => {
|
|
console.log(`- ${path.relative(process.cwd(), filePath)}`);
|
|
});
|
|
}
|
|
|
|
if (errors.length > 0) {
|
|
console.log('\nErrors:');
|
|
errors.forEach(({ filePath, error }) => {
|
|
console.log(`- ${path.relative(process.cwd(), filePath)}: ${error}`);
|
|
});
|
|
}
|
|
} catch (error) {
|
|
console.error('Error:', error.message);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
main().catch(console.error); |