Unofficial library to interact with websockets on Tradingview.
P.S. Check out this awesome trading journal app https://tradinglog.app.
- Realtime data from Tradingview
- Authorization with session id from cookies
- Fetching candlesticks for any symbol with any available timeframe
import { connect, getCandles } from 'tradingview-ws'
(async function() {
const connection = await connect()
const candles = await getCandles({
connection,
symbols: ['FX:AUDCAD', 'FX:AUDCHF'],
amount: 10_000,
timeframe: 60
})
await connection.close()
console.log(`Candles for AUDCAD:`, candles[0])
console.log(`Candles for AUDCHF:`, candles[1])
}());
Creates new connection to tradingview websockets. Returns TradingviewConnection
.
Options:
sessionId?: string
- authorize connection if present. Can be received from cookies.
Fetches all available candles for symbols. The maximum amount is around 13_000 candles for the hourly timeframe. Returns an array where each element is an array of candles for one symbol in the order it passed to the function.
Options:
connection: TradingviewConnection
- connection objectsymbols: string[]
- array of symbols. Symbol name can be found on Symbol info modal(click three dots after symbol name on the top left corner of the chart).timeframe?: number | '1D' | '1W' | '1M'
- candlestick timeframe, default is60
amount?: number
- amount of candles to fetch. If not present, it will try to fetch as much as possible.
Connection object. Can be used directly to receive and send data to websockets.
Methods:
subscribe: (handler: Subscriber) => Unsubscriber
- subscribe to websockets eventssend: (name: string, params: any[]) => void
- send command to websocketsclose: () => Promise<void>
- close the connection