Cargo.toml 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. [package]
  2. name = "extended"
  3. version = "0.1.0"
  4. edition = "2024"
  5. [dependencies]
  6. # 异步运行时,选择 tokio,并启用完整特性集(包含多线程运行时、net, time, fs, process, signal 等)
  7. # "full" 特性非常方便开发,生产环境可以根据实际需求裁剪
  8. tokio = { version = "1", features = ["full"] }
  9. # HTTP 客户端,用于 REST API 请求(获取交易对、下单等)
  10. # - "json": 启用 JSON 支持,方便发送和接收 JSON 数据
  11. # - "tokio-native-tls": 与 tokio 集成,支持 HTTPS (SSL/TLS),使用系统的 TLS 实现
  12. reqwest = { version = "0.11", features = ["json", "tokio-native-tls"] }
  13. ring = "0.16.20"
  14. base64 = "0.13"
  15. futures-channel = "0.3.28"
  16. # 解压缩
  17. flate2 = "1.0"
  18. # WebSocket 客户端,基于 tokio 构建,用于订阅 K 线和深度
  19. tokio-tungstenite= { git = "https://github.com/skyfffire/tokio-tungstenite-proxy.git" }
  20. # futures 工具库,提供一些异步编程中常用的 trait 和工具
  21. # 包含了 Stream 的一些方法,例如 split 用于分离 WebSocket stream 的读写端
  22. futures-util = "0.3"
  23. # URL 解析和构建库,在处理交易所端点或配置代理时可能会用到
  24. url = "2"
  25. # 序列化和反序列化框架,用于将 Rust 结构体与各种数据格式相互转换
  26. # - "derive": 启用 derive 宏,方便自动实现 Serialize 和 Deserialize trait
  27. serde = { version = "1", features = ["derive"] }
  28. # serde 的 JSON 实现,用于处理交易所 API 的 JSON 数据和应用配置(如果使用 JSON 格式)
  29. serde_json = "1"
  30. # 日志和诊断框架,推荐使用 tracing,功能强大且适合异步应用
  31. tracing = "0.1"
  32. # tracing 的 subscriber 实现,用于配置日志输出格式、目的地等
  33. # - "env-filter": 允许通过 RUST_LOG 环境变量控制日志级别
  34. # - "fmt": 提供格式化输出到控制台
  35. # - "json": 可选,如果需要结构化 JSON 日志
  36. tracing-subscriber = { version = "0.3", features = ["json", "fmt", "env-filter", "registry", "time"] }
  37. # 用于日志文件按日期滚动
  38. tracing-appender = "0.2"
  39. # 日期和时间处理
  40. chrono = "0.4"
  41. # 时区数据库,用于获取 Asia/Shanghai 时区
  42. chrono-tz = "0.8"
  43. # 确保 time crate 的特性被启用
  44. time = { version = "0.3", features = ["macros", "formatting", "parsing", "local-offset"] }
  45. # 简化错误处理的库,方便快速构建可链式调用的错误
  46. anyhow = "1"
  47. # 用于定义自定义错误类型的库,与 anyhow 配合使用,让错误更具语义
  48. thiserror = "1"
  49. # 异步 SQL 数据库客户端,选择支持 tokio 和 SQLite 的版本,用于存储配置等
  50. # - "runtime-tokio": 使用 tokio 作为异步运行时
  51. # - "sqlite": 启用 SQLite 驱动
  52. # - "macros": 启用宏支持,用于 compile-time query checking (强烈推荐)
  53. # - "offline": 用于离线模式下的宏检查 (与 "macros" 配合使用)
  54. sqlx = { version = "0.7", features = ["runtime-tokio", "sqlite", "macros"] }
  55. backtrace = "0.3.74"
  56. prost = "0.11"
  57. hex = "0.4.3"
  58. ##代替f64避免精度丢失
  59. rust_decimal = "1.32.0"
  60. rust_decimal_macros = "1.32.0"
  61. # 以下是rust-crtpto-lib-base的依赖
  62. num-bigint = "0.4.6"
  63. sha2 = "0.10.8"
  64. starknet = { git = "https://github.com/xJonathanLEI/starknet-rs", tag = "starknet/v0.17.0" }
  65. starknet-crypto = "0.8.1" # `starknet` crate doesn't re-export `PoseidonHasher`
  66. # =======================================================
  67. # 以下是一些在开发过程中可能会用到的devDependencies,只用于开发和测试,不包含在最终发布版本中
  68. [dev-dependencies]
  69. [build-dependencies]
  70. prost-build = "0.11" # 或者最新版本