npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@alleyway/add-tradingview-alerts-tool

v3.0.5

Published

Add TradingView Alerts in bulk

Downloads

2,040

Readme

Add TradingView Alerts Tool 🤖

Automatically add custom alerts to TradingView in bulk

npm version build status code coverage Npm package monthly downloads

⚠️ WARNING: Running command line software on your computer is risky! Although this software has no known malicious code in it - it does rely on 3rd-party libraries which can be vulnerable to hacking. As of late 2021, 3rd-party hacks have been on the rise - use at your own risk.

👋 NOTE: We have a service that automates this tool on secured, virtual servers. Become a beta tester at alertzmanager.io

Alertz Manager Banner

Why This Project Exists

Trading platforms (such as 3Commas and Alertatron) allow automated trades based on custom TradingView alerts which can be pinged using webhook URLs to execute trades.

When using a TradingView indicator (such as Material Indicators), you can send signals to your trading bot using TradingView alerts

So what if you want to use an indicator to trade across dozens or hundreds of pairs? Because there is no TradingView API to add alerts in bulk, you'd need to maintain those alerts by hand.

How does this tool work?

Using open source software designed for automated website testing, we can enter as many custom alerts as your TradingView account allows. It installs its very own Chrome browser (called Chromium) which is controlled by this script.

Watch as this tool enters your TradingView alerts automatically.

Requirements

MacOS/Windows/Linux

Install NodeJS (recommended version: 20.x)

Installation

Open Terminal/PowerShell and run the following:

Make sure you're running at least node version 20

node -v

Create your tradingview-alerts-home directory and/or upgrade version (it will prompt to create a subdirectory and install ATAT)

npx @alleyway/create-tradingview-alerts-home@latest

Edit your config.yml file (if you're passing signals for automated trading such as 3commas, configure those details here)

files:
  input: binance_usdt_symbols.csv
  exclude: blacklist.csv
tradingview:
  # The chart which has the indicator you'd like to use
  chartUrl: https://www.tradingview.com/chart/WS5uK1l5/
  # (optional) set the chart interval before adding symbols, otherwise interval of last saved chart is used
  # examples: 1s | 30s | 1m | 15m | 1H | 1D | 1W      # NOTE: '1H,4H' to add alerts across multiple intervals
  interval: 4h
  # Optionally supply login details or login manually once and restart script
  #username: 
  #password: 
alert:
  condition:
    primaryLeft: MTF Deviation
    primaryRight:
    secondary: Tier1 long
    tertiaryLeft:
    tertiaryRight:
    quaternaryLeft: 
    quaternaryRight:
  option: Once Per Bar Close
  actions:
    notifyOnApp: false
    showPopup: false
    sendEmail: false
    webhook:
      enabled: true
      url: "https://3commas.io/trade_signal/trading_view"
  # alert name is optional - can override in csv if desired and use {{symbol|instrument|quote_asset}}
  # name: MI dev3 for {{instrument}} {{quote_asset}}
  # indentation matters! {{quote_asset}} and {{instrument}} are swapped out for quote asset(eg. USDT) and the base token or instrument (eg. 'BTC')
  message: >
    {
        "message_type": "bot",
        "bot_id": 999999,
        "email_token": "fffffff-fffff-fffff-ffff-ffffffffff",
        "delay_seconds": 0,
        "pair": "{{quote_asset}}_{{instrument}}"
    }

Fetching Trading Pairs

Creates CSV file for use as input (see above config) for supported exchanges. Want other exchanges? File an issue!)

Download Trading Pairs From Binance/BinanceUS

This command downloads all USDT trading pairs for Binance: (NOTE: binance is now geofencing some of their endpoints)

    ./atat fetch-symbols binance -q usdt        

This command downloads all trading pairs for BinanceUS:

    ./atat fetch-symbols binanceus

Download Trading Pairs From Coinbase

    ./atat fetch-symbols coinbase -q usd

Download Trading Pairs From Bittrex

    ./atat fetch-symbols bittrex -q btc

Download Trading Pairs From Kraken

    ./atat fetch-symbols kraken -q usd

Download Trading Pairs From KuCoin

    ./atat fetch-symbols kucoin -q usdt

Download Trading Pairs From OKX (formerly OKEx)

    ./atat fetch-symbols okx_spot -q usdt

Download Trading Pairs From ByBit Inverse

    ./atat fetch-symbols bybit_inverse

Download Trading Pairs From ByBit Linear

    ./atat fetch-symbols bybit_linear

...and so on..

Adding TradingView Alerts

Before you run the script

When adding alerts TradingView uses your last settings as defaults for new alerts. If not explicitly set in the config.yml file, it will use the settings from the last alert made. So if you prefer to play a sound or not, create an alert with that setting before running the script.

You must actually create an alert once with those options, before they become defaults. (You can immediately delete the alert)

Running the script

NOTE: You'll need to log into TradingView the first time you run the script, then you'll need to close the browser and re-run the command

./atat add-alerts

You can stop the script in Terminal/PowerShell by pressing Ctrl-C

If the tool gets interrupted for some reason, you can remove the rows of already-added alert symbols (from the .csv) and re-run

Troubleshooting

  • Windows users having issues executing because of a thing downloaded off the internet (contributed by a user)

    powershell -executionpolicy ByPass -File .\atat.ps1 fetch-symbols binance -q usdt

  • Moving too fast for your connection speed? Try adjusting the delay option (default is 1000)

    ./atat --delay 1500 add-alerts

  • Selecting the wrong option? Conditions can be regular expressions. For example...

Let's say you have a conditions dropdown with multiple indicator configurations like so:

MTF Deviation - Mtrl_Scientist v0.7 (50, 530, 750, 3)
MTF Deviation - Mtrl_Scientist v0.7 (50, 530, 750, 6)
MTF Deviation - Mtrl_Scientist v0.7 (50, 530, 750, 9)

If your configuration only used the term "MTF Deviation" the tool might incorrectly select the first option containing that term.

For example, the following regular expression will match the indicator with percent deviation setting of 6 :

alert:
  condition:
    primaryLeft: /^MTF Deviation.*,\s6\)$/

Another common issue is sometimes option text for one condition can exist entirely within another.

For example:

Blue Wave Crossing Down [Sm. Red Dot]
Blue Wave Crossing UP [Sm. Green Dot]
Green Dot

A regular expression to match "Green Dot" exactly would be the following:

alert:
  condition:
    primaryLeft: /^Green Dot$/

Learn more about regular expression syntax

  • "atat" command not found? From your tradingview-alerts-home directory run the following:

    npx @alleyway/create-tradingview-alerts-home@latest

  • Any other hiccups? File an issue

Advanced Usage

Multiple Configurations

A configured TradingView Indicator that works for assets quoted in BTC may not be appropriate for USD pairs, therefore, you'll want to segment your setup as follows:

| Abstract | Concretely | |-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | List of pairs quoted only in BTC | Run "./atat fetch-symbols binance btc"input: binance_usdt_symbols.csv | | TradingView chart layout with an indicator tailored specific to BTC (eg. set 6% for deviation on MTF deviation) | chartUrl: https://www.tradingview.com/chart/WS5uK1l5/ | | 3commas trading bot to handle only BTC | { "message_type": "bot", "bot_id": 999999, "email_token": "fffffff-fffff-fffff-ffff-ffffffffff", "delay_seconds": 0, "pair": "{{quote_asset}}_{{instrument}}"} | | A dedicated configuration file for the above | ./atat add-alerts config.btc.yml |

NOTE: running "./atat add-alerts" will default to config.yml unless you specify one (eg. "./atat add-alerts config.btc.yml")

Token Replacement in Alert Settings

There are some scenarios where you may want some pairs to use different indicators or the same indicator with different settings (must be added to the chart for each setting - this script CANNOT adjust indicator settings yet)

multiple indicators

Then you could add an arbitrary column to your .csv - here we use "DSMAsetting"

symbol,quote_asset,instrument,DSMAsetting
BINANCE:1INCHUSDT,USDT,1INCH,40
BINANCE:AAVEUSDT,USDT,AAVE,20
BINANCE:ACMUSDT,USDT,ACM,40
BINANCE:ADAUSDT,USDT,ADA,20

You can then use any value from your csv by surrounding the column header name with double braces as follows:

...
alert:
  condition:
    primaryLeft: "DSMA ({{DSMAsetting}}, 50)"
...

Send a single alert to multiple 3commas bots

3commas will allow you to use an array of commands in the message, I typically send a message to two bots: one for paper trading, and another "real" account which I can choose to disable.

So you can use a JSON array for the message:

  message: >
    [{
        "message_type": "bot",
        "bot_id": 999999,
        "email_token": "fffffff-fffff-fffff-ffff-ffffffffff",
        "delay_seconds": 0,
        "pair": "{{quote_asset}}_{{instrument}}"
    },
    {
        "message_type": "bot",
        "bot_id": 999999,
        "email_token": "fffffff-fffff-fffff-ffff-ffffffffff",
        "delay_seconds": 0,
        "pair": "{{quote_asset}}_{{instrument}}"
    }]

Send an alert to Alertatron

This works in the same way as for 3Commas, but Alertatron using a different format for its messages. For example...

  message: >
    binanceKeys({{quote_asset}}_{{instrument}}) {
        market(side=buy, amount=50%);
        stopOrder(side=sell, amount=100%p, offset=2%);
        limit(side=sell, amount=100%p, offset=3%);
    }

Do You Find This Tool Helpful?

Consider one of the following:

  1. Increase awareness on GitHub: Click the ⭐ at the top of the page!

Star this project

  1. Become a FREE beta tester (limited time) of our eventual commercial service:
  • Graphical Interface: Nothing to install - alerts added by our secure, private servers
  • Multiple Alerts Per Symbol: separate buy & sell alerts
  • Faster Alert Management: intelligently keeps/updates/adds/removes alerts
  • Flexible Alert Template Assignment: Use 24h exchange data(volume,tradecount) to enable/disable alerts
  • Automation: Configure and sychronize alerts on a schedule, fetch new exchange tokens

Create a free account at https://alertzmanager.io