Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: full refactor towards class-based await/async + TS + ESM #922

Merged
merged 89 commits into from
Apr 1, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
89 commits
Select commit Hold shift + click to select a range
492a87a
chore: refactor class [wip]
carlosmiei Mar 17, 2025
5601047
use different approach to request
carlosmiei Mar 18, 2025
1bfa4ec
more rest endpoints
carlosmiei Mar 19, 2025
2707c94
fix some TS errors
carlosmiei Mar 19, 2025
260ed4e
more changes
carlosmiei Mar 20, 2025
f21adc0
convert some arrow functions
carlosmiei Mar 20, 2025
e016d0d
several fixes
carlosmiei Mar 20, 2025
3d35a8e
more typescript fixes
carlosmiei Mar 21, 2025
7548f45
fix js compiling errors
carlosmiei Mar 21, 2025
0a4a502
more updates
carlosmiei Mar 24, 2025
fefadee
update tsconfig
carlosmiei Mar 24, 2025
a80a377
spot signed working
carlosmiei Mar 24, 2025
478ed8f
spot private working
carlosmiei Mar 24, 2025
5edabd9
private futures working
carlosmiei Mar 24, 2025
1e2b2c1
type params
carlosmiei Mar 24, 2025
a672844
add and type params
carlosmiei Mar 24, 2025
a515d60
update folder structure
carlosmiei Mar 24, 2025
c98d349
fix remaining ts
carlosmiei Mar 24, 2025
86a84cb
several tests fixes
carlosmiei Mar 25, 2025
8c5c31e
update command
carlosmiei Mar 25, 2025
86c84e6
add some types
carlosmiei Mar 25, 2025
7bf358d
update tests and cjs bundle
carlosmiei Mar 25, 2025
b5ea30e
update static test
carlosmiei Mar 25, 2025
7a60f04
update import
carlosmiei Mar 25, 2025
12f3402
update package
carlosmiei Mar 25, 2025
74458d2
update ts-ignore
carlosmiei Mar 25, 2025
6a81560
add more typing
carlosmiei Mar 25, 2025
3be7282
add more types
carlosmiei Mar 26, 2025
34d49d6
add binance docs
carlosmiei Mar 26, 2025
7fac213
more docs
carlosmiei Mar 26, 2025
e47c13f
more endpoints and types
carlosmiei Mar 26, 2025
75cfe64
upgrade outdated methods
carlosmiei Mar 26, 2025
a1af566
fix static tests
carlosmiei Mar 26, 2025
1969b68
proxy variable
carlosmiei Mar 26, 2025
e0b0226
update methods and docs
carlosmiei Mar 27, 2025
38e7775
update docs
carlosmiei Mar 27, 2025
ce0da0f
add tests
carlosmiei Mar 27, 2025
d22f4f0
eslint fixes
carlosmiei Mar 27, 2025
5a6c7af
add linting and more tests
carlosmiei Mar 27, 2025
d5a7deb
update package.json
carlosmiei Mar 27, 2025
0388214
move older files to folder
carlosmiei Mar 27, 2025
26106e4
tmp comment types export
carlosmiei Mar 27, 2025
57da9a1
update dist
carlosmiei Mar 27, 2025
a6ce5bc
type http method
carlosmiei Mar 27, 2025
874b4cf
dry spot url calls
carlosmiei Mar 27, 2025
35a53d5
add public/private request helpers
carlosmiei Mar 28, 2025
175631d
update deprecated endpoints and other fixes
carlosmiei Mar 28, 2025
48573e8
add params to some methods
carlosmiei Mar 28, 2025
38ee1be
update readme
carlosmiei Mar 28, 2025
aa699d9
update
carlosmiei Mar 28, 2025
6cadb33
add more types and methods
carlosmiei Mar 28, 2025
f793a17
feat(proxy): implement proxies
ttodua Mar 28, 2025
64dab2e
nodefetch package
ttodua Mar 28, 2025
182afa4
docs(example) - proxy
ttodua Mar 28, 2025
ce90cca
feat(urlProxy): added urlProxy prop
ttodua Mar 28, 2025
d5792b7
urlProxy example
ttodua Mar 28, 2025
1a7c8d7
add some all_* callbacks
carlosmiei Mar 31, 2025
5771c8c
refresh listening key
carlosmiei Mar 31, 2025
0d312ea
bind ws handlers
carlosmiei Mar 31, 2025
cfdb731
latest edits
carlosmiei Mar 31, 2025
1b38e58
Merge pull request #924 from ccxt/ts-proxy-1
carlosmiei Mar 31, 2025
6a34414
update links
carlosmiei Mar 31, 2025
966393b
Merge branch 'ts-support' of github.com:carlosmiei/node-binance-api i…
carlosmiei Mar 31, 2025
a44e091
update dependencies
carlosmiei Mar 31, 2025
1a50da8
fix syntax and rollup
carlosmiei Mar 31, 2025
5df5372
fix cjs tests
carlosmiei Mar 31, 2025
0bb928f
update dependencies
carlosmiei Mar 31, 2025
456b9f0
fix live tests
carlosmiei Mar 31, 2025
c38d366
more tests
carlosmiei Mar 31, 2025
9c6940c
update cjs test
carlosmiei Mar 31, 2025
f4cb6c2
overridable domain
carlosmiei Mar 31, 2025
895e22c
fix command
carlosmiei Mar 31, 2025
e3e7d0c
add package test
carlosmiei Mar 31, 2025
00dbc4d
sandbox test
carlosmiei Mar 31, 2025
0832ba6
fix docs
carlosmiei Mar 31, 2025
05e3fa3
use jsonbig instead
carlosmiei Mar 31, 2025
53ca47c
add export statement
carlosmiei Mar 31, 2025
e06fa00
fix readme and init ws tests
carlosmiei Mar 31, 2025
6a80fba
fix WS bindings
carlosmiei Apr 1, 2025
34f329d
use url instead
carlosmiei Apr 1, 2025
0e9acbd
complete websockets interface
carlosmiei Apr 1, 2025
528832f
rename test
carlosmiei Apr 1, 2025
964a87e
add ws tests
carlosmiei Apr 1, 2025
711418b
remove named export
carlosmiei Apr 1, 2025
bc0ea27
use url instead
carlosmiei Apr 1, 2025
559d1c1
add test stream
carlosmiei Apr 1, 2025
c16f871
fix url
carlosmiei Apr 1, 2025
d0005c1
fix live tests
carlosmiei Apr 1, 2025
af2e35a
force mocha exit
carlosmiei Apr 1, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
61 changes: 0 additions & 61 deletions .eslintrc.json

This file was deleted.

20 changes: 17 additions & 3 deletions .github/workflows/js.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,21 @@ jobs:
cache: 'npm'
- name: Install npm dependencies
run: npm i --include=dev
- name: Static Tests
- name: Lint
run: npm run lint
- name: Build
run: npm run build
- name: Static Tests (TS ESM)
run: npm run ts-test-static
- name: Static Tests (JS CJS)
run: npm run static-test
- name: Live Tests
run: npm run test
- name: Live Tests (TS ESM)
run: npm run ts-test-live
- name: Ws Live Tests (spot)
run: npm run ws-tests-spot
- name: Ws Live Tests (futures)
run: npm run ws-tests-futures
- name: CJS test
run: npm run test-cjs
- name: Package test
run: npm run package-test
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,8 @@
ehthumbs.db
Thumbs.db

dist/

# Secrets #
###########
.secret
Expand Down
4 changes: 4 additions & 0 deletions .mocharc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"$schema": "https://json.schemastore.org/mocharc.json",
"require": "tsx"
}
13 changes: 13 additions & 0 deletions .npmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# Initally ignore all files
*

# Files to include
!package.json
!package-lock.json
!LICENSE.txt
!README.md

# Folders to include
!src/**/*
!dist/**/*

76 changes: 66 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,6 @@ color=blueviolet 🔵q






# Node Binance API

[![telegram](https://patrolavia.github.io/telegram-badge/chat.png)](https://t.me/nodebinanceapi) [![Yearly Downloads](https://img.shields.io/npm/dy/node-binance-api.svg)](https://www.npmjs.com/package/node-binance-api) [![jaggedsoft on X](https://img.shields.io/twitter/follow/jaggedsoft.svg?style=social)](https://x.com/jaggedsoft)
Expand All @@ -44,7 +41,7 @@ This project is designed to help you make your own projects that interact with t
#### Installation

```
npm install -s node-binance-api
npm install node-binance-api
```
[![NPM](https://nodei.co/npm/node-binance-api.png?compact=true)](https://npmjs.org/package/node-binance-api)
<!-- [![npm install node-binance-api](https://nodei.co/npm/node-binance-api.png?mini=true)](https://npmjs.org/package/node-binance-api) -->
Expand All @@ -56,6 +53,28 @@ https://t.me/nodebinanceapi

**This project is powered by** <a href="https://github.com/ccxt/ccxt"><img src="https://avatars.githubusercontent.com/u/31901609" width=4% height=4%></a>

Actively maintained, typed, and safe SDK for the Binance REST APIs and Websockets. Supports ESM and CJS out of the box.

### Features
- Spot, Margin, Futures and Delivery API
- Portfolio Margin API *\*soon*\*
- Testnet support
- Proxy support (REST and WS)
- Customizable HTTP headers
- Customizable request parameters
- RSA/ECDSA support *\*soon*\*
- Websocket handling with automatic reconnection
- RecvWindow and automatic timestamps generation
- Ability to call any endpoint, even if not supported directly by the library
- Overridable hostnames (.us, .jp, etc)
- Verbose mode to debug http requests/responses

### Upgrading to v1.0.0+

The library was fully refactored to use modern and typed JavaScript/Typescript version, using the built-in await/async syntax and unifying some methods' signatures. Some important changes include the removal of callbacks as parameters of REST methods, adaptation of signatures to directly receive some important request values (symbol, orderId, ...), etc.

**We highly advise you to update from 0.0.X but minor adjustments might be needed.**


#### Getting started (ESM)
```javascript
Expand All @@ -70,7 +89,7 @@ async function run() {
#### Getting started (CJS)
```javascript
const Binance = require('node-binance-api');
const binance = new Binance().options({
const binance = new Binance({
APIKEY: '<key>',
APISECRET: '<secret>',
test: true, // if you want to use the sandbox/testnet
Expand All @@ -96,12 +115,12 @@ console.info( await binance.futuresBalance() );

#### Futures Limit Buy
```js
console.info( await binance.futuresBuy( 'BTCUSDT', 0.1, 8222 ) );
console.info( await binance.futuresBuy( 'LIMIT', 'BTCUSDT', 0.1, 8222 ) );
```

#### Futures Limit Sell
```js
console.info( await binance.futuresSell( 'BTCUSDT', 0.5, 11111 ) );
console.info( await binance.futuresSell( 'LIMIT', 'BTCUSDT', 0.5, 11111 ) );
```

#### Futures Market Buy
Expand Down Expand Up @@ -197,20 +216,55 @@ console.info( await binance.futuresHistoricalTrades( "XMRUSDT" ) );
console.info( await binance.futuresLeverageBracket( "LINKUSDT" ) );
console.info( await binance.futuresIncome() );
console.info( await binance.futuresCancelAll( "BTCUSDT" ) );
console.info( await binance.futuresCancel( "BTCUSDT", {orderId: "1025137386"} ) );
console.info( await binance.futuresCancel( "BTCUSDT", "1025137386" ) );
console.info( await binance.futuresCountdownCancelAll( "BTCUSDT", 45000 ) );
console.info( await binance.futuresOrderStatus( "BTCUSDT", {orderId: "1025137386"} ) );
console.info( await binance.futuresOrderStatus( "BTCUSDT", "1025137386") );
console.info( await binance.futuresOpenOrders() );
console.info( await binance.futuresOpenOrders( "BTCUSDT" ) );
console.info( await binance.futuresAllOrders() );
console.info( await binance.futuresAllOrders( "BTCUSDT" ) );
console.info( await binance.futuresUserTrades( "BTCUSDT" ) );
console.info( await binance.futuresGetDataStream() );
console.info( await binance.futuresPositionMarginHistory( "TRXUSDT" ) );
console.info( await binance.promiseRequest( 'v1/time' ) );
console.info( await binance.futuresPublicRequest( 'v1/time' ) );
console.info( await binance.spotPublicRequest( 'v1/time')); // call any method by providing the path
console.info( await binance.privateFuturesRequest('v3/account')); // custom futures private call
// Batch orders, remaining WebSocket streams, and better documentation will be come later
```

### Proxy support

In some specific cases using a proxy is required, for example:
- Exchange is not available in your location
- You need to make a large amount of requests without getting blocked
- ...

This package supports the following proxy types, `httpsProxy`, `proxyUrl` and `socksProxy`

#### httpsProxy

To set a real http(s) proxy for your scripts, you need to have an access to a remote http or https proxy, so calls will be made directly to the target exchange, tunneled through your proxy server:

```Js
client.httpsProxy = 'http://1.2.3.4:8080/';
```

#### proxyUrl

This property prepends an url to API requests. It might be useful for simple redirection or bypassing CORS browser restriction.

```Js
client.proxyUrl = 'YOUR_PROXY_URL';
```

#### socksProxy

Tou can also use socks proxy with the following format:

```Js
client.socksProxy = 'socks5://1.2.3.4:8080/';
```

#### Futures Historical Bulk Data Download API

##### Get Download ID
Expand Down Expand Up @@ -296,6 +350,8 @@ binance.futuresTerminate( 'btcusdt@kline_4h' );
console.log( binance.futuresSubscriptions() );
```



# Delivery API (Futures w/Expiration Date)
```
deliveryBuy
Expand Down
File renamed without changes.
Loading