1
0
mirror of https://gitlab.com/simple-stock-bots/simple-stock-bot.git synced 2026-06-03 21:00:26 +00:00

Compare commits

..

14 Commits

Author SHA1 Message Date
Anson 77165d802d prettier applied 2023-10-15 22:59:05 +00:00
Anson 769290528d add prettier 2023-10-15 22:58:15 +00:00
Anson 57967cde47 add prettier 2023-10-15 21:52:28 +00:00
Anson d352131b2e run ruff 2023-10-15 21:43:34 +00:00
Anson 91cf799327 fix last link 2023-10-15 21:41:12 +00:00
Anson e513386376 update urls 2023-10-15 15:32:24 -06:00
Anson 4f7a674f50 Merge branch '110-add-options' into 'master'
Resolve "Add Options from MarketData.app"

Closes #110

See merge request simple-stock-bots/simple-telegram-stock-bot!56
2023-10-13 05:37:48 +00:00
Anson 04abd15fcc Resolve "Add Options from MarketData.app" 2023-10-13 05:37:48 +00:00
Anson 10f8460cae Merge branch 'bug-smashing-extravaganza' into 'master'
Add list of stocks to bot

Closes #105

See merge request simple-stock-bots/simple-telegram-stock-bot!55
2023-10-12 02:42:53 +00:00
Anson 66f233918e Add list of stocks to bot 2023-10-12 02:42:52 +00:00
Anson 4a556597df Merge branch 'fix-admonitions' into 'master'
Fix admonitions

See merge request simple-stock-bots/simple-telegram-stock-bot!54
2023-10-10 04:28:22 +00:00
Anson ad1ec94c6b Fix admonitions 2023-10-10 04:28:22 +00:00
Anson 133675616a Merge branch '109-add-a-blog-to-the-website' into 'master'
Resolve "Add a blog to the website"

Closes #109

See merge request simple-stock-bots/simple-telegram-stock-bot!53
2023-10-10 04:19:47 +00:00
Anson 33550f1519 Resolve "Add a blog to the website" 2023-10-10 04:19:46 +00:00
35 changed files with 925 additions and 679 deletions
-2
View File
@@ -1,5 +1,3 @@
FROM python:3.11
COPY . .
# RUN pip install -r requirements.txt
+6 -4
View File
@@ -5,7 +5,8 @@
// Or use a Dockerfile or Docker Compose file. More info: https://containers.dev/guide/dockerfile
// "image": "mcr.microsoft.com/devcontainers/python:1-3-bookworm",
"build": {
"dockerfile": "Dockerfile"
"dockerfile": "Dockerfile",
"context": ".."
},
"features": {
"ghcr.io/devcontainers-contrib/features/black:2": {},
@@ -18,14 +19,15 @@
"extensions": [
"ms-python.python",
"ms-python.black-formatter",
"ms-python.flake8",
"ms-python.vscode-pylance",
"ms-python.isort",
"charliermarsh.ruff"
"charliermarsh.ruff",
"ms-toolsai.jupyter",
"esbenp.prettier-vscode"
]
}
},
"postCreateCommand": "pip3 install --user -r dev-reqs.txt"
"postCreateCommand": "pip3 install --user -r dev-reqs.txt && apt-get update && apt-get install -y nodejs npm && npm install"
// Features to add to the dev container. More info: https://containers.dev/features.
// "features": {},
// Use 'forwardPorts' to make a list of ports inside the container available locally.
+1
View File
@@ -1,2 +1,3 @@
__pycache__
.env
node_modules
+6 -1
View File
@@ -13,12 +13,17 @@ black:
ruff:
stage: lint
# image: registry.gitlab.com/pipeline-components/ruff:latest
image: python:3.11-slim
script:
- pip3 install ruff
- ruff --output-format gitlab .
prettier:
stage: lint
image: node:16-slim # Use Node.js image since prettier is a Node.js tool
script:
- npm install prettier
- npx prettier --check . # Adjust the path as needed
include:
- local: /site/.gitlab-ci.yml
+2
View File
@@ -4,5 +4,7 @@
"editor.formatOnSaveMode": "modificationsIfAvailable",
"[python]": {
"editor.defaultFormatter": "ms-python.black-formatter",
"editor.formatOnSave": true,
"editor.formatOnSaveMode": "file"
}
}
+9 -5
View File
@@ -9,14 +9,16 @@ Enhance your group chats on Telegram and Discord with real-time stock and crypto
## Documentation
Comprehensive documentation is available to help you understand the features and capabilities of Simple Stock Bots:
- [Official Documentation](https://docs.simplestockbot.com/)
- [Command Reference](https://docs.simplestockbot.com/commands/)
- [Official Documentation](https://simplestockbot.com/)
- [Command Reference](https://simplestockbot.com/commands/)
## Support the Project
Simple Stock Bots is sustained entirely through donations, with an annual expense of about $420 for server and premium market data subscriptions from [marketdata.app](https://dashboard.marketdata.app/marketdata/aff/go/misterbiggs?keyword=repo).
You can contribute by:
- Donating through [Buy Me A Coffee](https://www.buymeacoffee.com/Anson) (PayPal or Credit Card accepted).
- Using the `/donate` [command](commands.md#donate-amount-in-usd) on Telegram.
- [Getting in touch](contact.md) for any inquiries or suggestions.
@@ -24,7 +26,7 @@ You can contribute by:
### Additional Support:
- Follow on [Twitter](https://twitter.com/AnsonBiggs)
- Contribute or star the project on [GitLab](https://gitlab.com/simple-stock-bots)
- Contribute or star the project on [GitLab](https://gitlab.com/simple-stock-bots/simple-stock-bot)
- Utilize referral links for self-hosting:
- [DigitalOcean](https://m.do.co/c/6b5df7ef55b6)
- [marketdata.app](https://dashboard.marketdata.app/marketdata/aff/go/misterbiggs?keyword=web)
@@ -32,12 +34,14 @@ You can contribute by:
## Hosting
Self-hosting instructions are provided for those interested in running the bot on their own servers:
- [Hosting Guide](https://docs.simplestockbot.com/hosting/)
- [Hosting Guide](https://simplestockbot.com/hosting/)
## Contact
Reach out for bug reports, feature requests, or other inquiries:
- [Contact Page](https://docs.simplestockbot.com/contact/)
- [Contact Page](https://simplestockbot.com/contact/)
---
+78 -2
View File
@@ -2,7 +2,9 @@ import datetime as dt
import logging
import os
from typing import Dict
from collections import OrderedDict
import humanize
import pandas as pd
import pytz
import requests as r
@@ -20,6 +22,7 @@ class MarketData:
SYMBOL_REGEX = "[$]([a-zA-Z]{1,4})"
symbol_list: Dict[str, Dict] = {}
charts: Dict[Stock, pd.DataFrame] = {}
openTime = dt.time(hour=9, minute=30, second=0)
@@ -48,6 +51,9 @@ class MarketData:
if self.MARKETDATA_TOKEN != "":
schedule.every().day.do(self.clear_charts)
self.get_symbol_list()
schedule.every().day.do(self.get_symbol_list)
def get(self, endpoint, params: dict = {}, timeout=10) -> dict:
url = "https://api.marketdata.app/v1/" + endpoint
@@ -85,6 +91,21 @@ class MarketData:
return {}
def symbol_id(self, symbol: str) -> Dict[str, Dict]:
return self.symbol_list.get(symbol.upper(), None)
def get_symbol_list(self):
sec_resp = r.get("https://www.sec.gov/files/company_tickers.json")
sec_resp.raise_for_status()
sec_data = sec_resp.json()
for rank, ticker_info in sec_data.items():
self.symbol_list[ticker_info["ticker"]] = {
"ticker": ticker_info["ticker"],
"title": ticker_info["title"],
"mkt_cap_rank": rank,
}
def clear_charts(self) -> None:
"""
Clears cache of chart data.
@@ -129,13 +150,13 @@ class MarketData:
Formatted markdown
"""
if quoteResp := self.get(f"stocks/quotes/{symbol}/"):
if quoteResp := self.get(f"stocks/quotes/{symbol.symbol}/"):
price = round(quoteResp["last"][0], 2)
try:
changePercent = round(quoteResp["changepct"][0], 2)
except TypeError:
return f"The price of {symbol} is {price}"
return f"The price of {symbol.name} is ${price}"
message = f"The current price of {symbol.name} is ${price} and "
@@ -267,3 +288,58 @@ class MarketData:
return df
return pd.DataFrame()
def options_reply(self, request: str) -> str:
"""Undocumented API Usage!"""
options_data = self.get(f"options/quotes/{request}")
for key in options_data.keys():
options_data[key] = options_data[key][0]
options_data["underlying"] = "$" + options_data["underlying"]
options_data["updated"] = humanize.naturaltime(dt.datetime.now() - dt.datetime.fromtimestamp(options_data["updated"]))
options_data["expiration"] = humanize.naturaltime(
dt.datetime.now() - dt.datetime.fromtimestamp(options_data["expiration"])
)
options_data["firstTraded"] = humanize.naturaltime(
dt.datetime.now() - dt.datetime.fromtimestamp(options_data["firstTraded"])
)
rename = {
"optionSymbol": "Option Symbol",
"underlying": "Underlying",
"expiration": "Expiration",
"side": "side",
"strike": "strike",
"firstTraded": "First Traded",
"updated": "Last Updated",
"bid": "bid",
"bidSize": "bidSize",
"mid": "mid",
"ask": "ask",
"askSize": "askSize",
"last": "last",
"openInterest": "Open Interest",
"volume": "Volume",
"inTheMoney": "inTheMoney",
"intrinsicValue": "Intrinsic Value",
"extrinsicValue": "Extrinsic Value",
"underlyingPrice": "Underlying Price",
"iv": "Implied Volatility",
"delta": "delta",
"gamma": "gamma",
"theta": "theta",
"vega": "vega",
"rho": "rho",
}
options_cleaned = OrderedDict()
for old, new in rename.items():
if old in options_data:
options_cleaned[new] = options_data[old]
return options_cleaned
+8 -6
View File
@@ -1,6 +1,7 @@
import pandas as pd
import logging
import pandas as pd
class Symbol:
"""
@@ -29,11 +30,12 @@ class Symbol:
class Stock(Symbol):
"""Stock Market Object. Gets data from MarketData"""
def __init__(self, symbol: str) -> None:
self.symbol = symbol
self.id = symbol
self.name = "$" + symbol.upper()
self.tag = "$" + symbol.lower()
def __init__(self, symbol_info: dict) -> None:
self.symbol = symbol_info["ticker"]
self.id = symbol_info["ticker"]
self.name = symbol_info["title"]
self.tag = "$" + symbol_info["ticker"]
self.market_cap_rank = symbol_info["mkt_cap_rank"]
class Coin(Symbol):
+6 -5
View File
@@ -1,6 +1,7 @@
requests==2.31.0
pandas==2.1.1
schedule==1.2.1
mplfinance==0.12.10b0
markdownify==0.11.6
cachetools==5.3.1
humanize==4.8.0
markdownify==0.11.6
mplfinance==0.12.10b0
pandas==2.1.1
requests==2.31.0
schedule==1.2.1
+24 -12
View File
@@ -5,6 +5,7 @@ import datetime
import logging
import random
import re
from typing import Dict
import pandas as pd
import schedule
@@ -14,8 +15,6 @@ from common.cg_Crypto import cg_Crypto
from common.MarketData import MarketData
from common.Symbol import Coin, Stock, Symbol
from typing import Dict
log = logging.getLogger(__name__)
@@ -38,7 +37,7 @@ class Router:
t_copy = self.trending_count.copy()
for key in t_copy.keys():
if t_copy[key] < 0.01:
# This just makes sure were not keeping around keys that havent been called in a very long time.
# Prune Keys
dead_keys.append(key)
else:
t_copy[key] = t_copy[key] * decay
@@ -48,7 +47,7 @@ class Router:
self.trending_count = t_copy.copy()
log.info("Decayed trending symbols.")
def find_symbols(self, text: str, *, trending_weight: int = 1) -> list[Stock | Symbol]:
def find_symbols(self, text: str, *, trending_weight: int = 1) -> list[Stock | Coin]:
"""Finds stock tickers starting with a dollar sign, and cryptocurrencies with two dollar signs
in a blob of text and returns them in a list.
@@ -65,16 +64,20 @@ class Router:
schedule.run_pending()
symbols: list[Symbol] = []
stocks = set(re.findall(self.STOCK_REGEX, text))
for stock in stocks:
# Market data lacks tools to check if a symbol is valid.
symbols.append(Stock(stock))
stock_matches = set(re.findall(self.STOCK_REGEX, text))
coin_matches = set(re.findall(self.CRYPTO_REGEX, text))
coins = set(re.findall(self.CRYPTO_REGEX, text))
for coin in coins:
sym = self.crypto.symbol_list[self.crypto.symbol_list["symbol"].str.fullmatch(coin.lower(), case=False)]
for stock_match in stock_matches:
# Market data lacks tools to check if a symbol is valid.
if stock_info := self.stock.symbol_id(stock_match):
symbols.append(Stock(stock_info))
else:
log.info(f"{stock_match} is not in list of stocks")
for coin_match in coin_matches:
sym = self.crypto.symbol_list[self.crypto.symbol_list["symbol"].str.fullmatch(coin_match.lower(), case=False)]
if sym.empty:
log.info(f"{coin} is not in list of coins")
log.info(f"{coin_match} is not in list of coins")
else:
symbols.append(Coin(sym))
if symbols:
@@ -393,3 +396,12 @@ class Router:
replies = replies + self.crypto.batch_price(coins)
return replies
def options(self, request: str, symbols: list[Symbol]) -> Dict:
request = request.lower()
if len(symbols) == 1:
symbol = symbols[0]
request = request.replace(symbol.tag.lower(), symbol.symbol.lower())
return self.stock.options_reply(request)
else:
return self.stock.options_reply(request)
+7 -5
View File
@@ -1,10 +1,12 @@
-r common/requirements.txt
-r docs/requirements.txt
black==23.7.0
flake8==6.1.0
Flake8-pyproject==1.2.3
-r site/requirements.txt
black==23.9.1
ipython==8.16.1
jupyter_client==8.4.0
jupyter_core==5.4.0
pylama==8.4.1
mypy==1.5.1
types-cachetools==5.3.0.6
types-pytz==2023.3.0.1
types-pytz==2023.3.1.1
ruff==0.0.292
isort==5.12.0
+4 -4
View File
@@ -10,7 +10,7 @@ class D_info:
license = re.sub(
r"\b\n",
" ",
r.get("https://gitlab.com/simple-stock-bots/simple-discord-stock-bot/-/raw/master/LICENSE").text,
r.get("https://gitlab.com/simple-stock-bots/simple-stock-bot/-/raw/master/LICENSE").text,
)
help_text = """
@@ -21,7 +21,7 @@ For stock data or hosting your own bot, use my link. This helps keep the bot fre
**Updates**: Join the bot's discord: https://t.me/simplestockbotnews.
**Documentation**: All details about the bot are at [docs](https://docs.simplestockbot.com).
**Documentation**: All details about the bot are at [docs](https://simplestockbot.com).
The bot reads _"Symbols"_. Use `$` for stock tickers and `$$` for cryptocurrencies. For example:
- `/chart $$eth` gives Ethereum's monthly chart.
@@ -41,7 +41,7 @@ Type @SimpleStockBot `[search]` anywhere to find and get stock/crypto prices. No
Data from: [marketdata.app](https://dashboard.marketdata.app/marketdata/aff/go/misterbiggs?keyword=discord).
Issues with the bot? Use `/status` or [contact us](https://docs.simplestockbot.com/contact).
Issues with the bot? Use `/status` or [contact us](https://simplestockbot.com/contact).
"""
donate_text = """
@@ -55,5 +55,5 @@ Every donation supports server costs and
2. Or, donate at [buymeacoffee](https://www.buymeacoffee.com/Anson).
- It's quick, doesn't need an account, and accepts Paypal or Credit card.
Questions? Visit our [website](https://docs.simplestockbot.com).
Questions? Visit our [website](https://simplestockbot.com).
"""
+58 -4
View File
@@ -5,9 +5,9 @@ import os
import mplfinance as mpf
import nextcord
from D_info import D_info
from nextcord.ext import commands
from D_info import D_info
from common.symbol_router import Router
DISCORD_TOKEN = os.environ["DISCORD"]
@@ -38,7 +38,7 @@ async def on_ready():
@bot.command()
async def status(ctx: commands):
"""Debug command for diagnosing if the bot is experiencing any issues."""
logging.warning(f"Status command ran by {ctx.message.author}")
logging.info(f"Status command ran by {ctx.message.author}")
message = ""
try:
message = "Contact MisterBiggs#0465 if you need help.\n"
@@ -183,20 +183,74 @@ async def trending(ctx: commands):
@bot.event
async def on_message(message):
# Ignore messages from the bot itself
if message.author.id == bot.user.id:
return
if message.content:
if message.content[0] == "/":
content_lower = message.content.lower()
# Process commands starting with "/"
if message.content.startswith("/"):
await bot.process_commands(message)
return
symbols = None
if "$" in message.content:
symbols = s.find_symbols(message.content)
if "call" in content_lower or "put" in content_lower:
await handle_options(message, symbols)
return
if symbols:
for reply in s.price_reply(symbols):
await message.channel.send(reply)
return
async def handle_options(message, symbols):
logging.info("Options detected")
try:
options_data = s.options(message.content.lower(), symbols)
# Create the embed directly within the function
embed = nextcord.Embed(title=options_data["Option Symbol"], description=options_data["Underlying"], color=0x3498DB)
# Key details
details = (
f"Expiration: {options_data['Expiration']}\n" f"Side: {options_data['side']}\n" f"Strike: {options_data['strike']}"
)
embed.add_field(name="Details", value=details, inline=False)
# Pricing info
pricing_info = (
f"Bid: {options_data['bid']} (Size: {options_data['bidSize']})\n"
f"Mid: {options_data['mid']}\n"
f"Ask: {options_data['ask']} (Size: {options_data['askSize']})\n"
f"Last: {options_data['last']}"
)
embed.add_field(name="Pricing", value=pricing_info, inline=False)
# Volume and open interest
volume_info = f"Open Interest: {options_data['Open Interest']}\n" f"Volume: {options_data['Volume']}"
embed.add_field(name="Activity", value=volume_info, inline=False)
# Greeks
greeks_info = (
f"IV: {options_data['Implied Volatility']}\n"
f"Delta: {options_data['delta']}\n"
f"Gamma: {options_data['gamma']}\n"
f"Theta: {options_data['theta']}\n"
f"Vega: {options_data['vega']}\n"
f"Rho: {options_data['rho']}"
)
embed.add_field(name="Greeks", value=greeks_info, inline=False)
# Send the created embed
await message.channel.send(embed=embed)
except KeyError as ex:
logging.warning(f"KeyError processing options for message {message.content}: {ex}")
bot.run(DISCORD_TOKEN)
+1 -1
View File
@@ -1,2 +1,2 @@
nextcord==2.4.2
nextcord==2.6.0
-r requirements.txt
+1 -2
View File
@@ -1,10 +1,9 @@
version: '3'
version: "3"
services:
telegram:
build:
context: .
dockerfile: telegram/Dockerfile
image: registry.gitlab.com/simple-stock-bots/simple-telegram-stock-bot
env_file: .env
discord:
build:
+27
View File
@@ -0,0 +1,27 @@
{
"name": "simple-stock-bot",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"devDependencies": {
"prettier": "3.0.3"
}
},
"node_modules/prettier": {
"version": "3.0.3",
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.0.3.tgz",
"integrity": "sha512-L/4pUDMxcNa8R/EthV08Zt42WBO4h1rarVtK0K+QJG0X187OLo7l699jWw0GKuwzkPQ//jMFA/8Xm6Fh3J/DAg==",
"dev": true,
"bin": {
"prettier": "bin/prettier.cjs"
},
"engines": {
"node": ">=14"
},
"funding": {
"url": "https://github.com/prettier/prettier?sponsor=1"
}
}
}
}
+5
View File
@@ -0,0 +1,5 @@
{
"devDependencies": {
"prettier": "3.0.3"
}
}
+1 -1
View File
@@ -20,4 +20,4 @@ deploy_site:
paths:
- public
rules:
- if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH'
- if: "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH"
-1
View File
@@ -1,2 +1 @@
# Blog
+4 -4
View File
@@ -26,6 +26,7 @@ Simple Stock Bot is a chatbot designed to enrich your financial discussions on T
</div>
With Simple Stock Bot, you can:
- **Fetch Real-time Quotes**: Obtain the latest stock and cryptocurrency prices instantly within your group chat.
- **View Charts**: Delve into intraday movements or assess a month's trading data right inside your group chat.
- **Stay Updated on Market Trends**: Discover what's buzzing in the stock and crypto spheres.
@@ -36,13 +37,12 @@ With Simple Stock Bot, you can:
[:fontawesome-brands-discord: Discord](https://discordapp.com/api/oauth2/authorize?client_id=532045200823025666&permissions=36507338752&scope=bot){ .md-button }
## Using the Bot
Embarking on your journey with Simple Stock Bot is effortless. Just add the bot to your Telegram or Discord group, and you're all set to dive into financial discussions right from your chat!
Here are some simple commands to get you started:
- `/intra` to view intraday charts.
- `/chart` for a glimpse of the last month's trading data.
- `/trending` to catch up on the latest trending stocks and cryptocurrencies.
@@ -51,11 +51,11 @@ Here are some simple commands to get you started:
Simple Stock Bot is a community-supported project, thriving on the contributions from its users. It's sustained entirely through donations to cover server costs and premium market data subscriptions, ensuring it remains free for everyone.
Feeling generous? You can support the project by [donating](https://docs.simplestockbot.com/donate/), following on [Twitter](https://twitter.com/AnsonBiggs), or contributing on [GitLab](https://gitlab.com/simple-stock-bot).
Feeling generous? You can support the project by [donating](https://simplestockbot.com/donate/), following on [Twitter](https://twitter.com/AnsonBiggs), or contributing on [GitLab](https://gitlab.com/simple-stock-bots/simple-stock-bot).
## Dive Deeper
Craving more insights and features? Explore the [official documentation](https://docs.simplestockbot.com/) to uncover all the capabilities of Simple Stock Bot.
Craving more insights and features? Explore the [official documentation](https://simplestockbot.com/) to uncover all the capabilities of Simple Stock Bot.
Get ready to elevate your financial discussions with Simple Stock Bot! Your group chats will never be the same again.
+12 -4
View File
@@ -5,13 +5,12 @@ Symbols are used in headings to denote what platforms and symbol types a command
- Bot Commands :robot:
- Cryptocurrency Support :material-currency-btc:
- Stock Market Support :bank:
- OTC Support :dollar:
## Get the Bots
[:fontawesome-brands-telegram: Telegram](https://t.me/SimpleStockBot){ .md-button } [:fontawesome-brands-discord: Discord](https://discordapp.com/api/oauth2/authorize?client_id=532045200823025666&permissions=36507338752&scope=bot){ .md-button }
## Symbol Detection :material-currency-btc: :bank: :dollar:
## Symbol Detection :material-currency-btc: :bank:
The Simple Stock Bot looks at every message it can see and tries to detect stock and cryptocurrency symbols. Stock market tickers are denoted with a single `$` and cryptocurrency coins are denoted with a double `$$`. So getting the price of Tesla is as simple as `$tsla` and Bitcoin `$$btc`. These symbols can be in any part of a message and there can be multiple of them aswell.
@@ -29,6 +28,12 @@ The Simple Stock Bot looks at every message it can see and tries to detect stock
</div>
</div>
## Options Detection :bank:
This command allows you to query real-time data for stock options. By simply inputting the stock symbol, strike price, month, and specifying either a call or a put, you can get the latest options data right at your fingertips. For example, `AAPL $220 December call` will provide the current data for Apple's call option with a $220 strike price expiring in December.
![Image of the telegram bot providing options info.](img/telegram_options.png)
## `/donate [Amount in USD]` :fontawesome-brands-telegram-plane:
The donate command is used to send money to the bot to help keep it free. The premium stock market data and server rentals add up so any amount helps. See the [Donate](donate.md) page for more information.
@@ -98,7 +103,9 @@ Gets the latest trending stocks and their change in price
━━━━━━━━━━━━━━━━━━━━━━━━━━
$GME: Gamestop Corporation - Class A, 5.06%
$MMAT: Meta Materials Inc, 4.77%
$$BTC: Bitcoin, -0.83%
$$
BTC: Bitcoin, -0.83%
$$ETH: Ethereum, 6.06%
$$DOGE: Binance-Peg Dogecoin, 0.14%
@@ -171,10 +178,11 @@ Bot Status:
</div>
## Inline Features :fontawesome-brands-telegram: :material-currency-btc: :bank: :dollar:
## Inline Features :fontawesome-brands-telegram: :material-currency-btc: :bank:
You can type @SimpleStockBot `[search]` in any chat or direct message to search for the stock bots
full list of stock symbols and return the price of the ticker. Then once you select the ticker
want the bot will send a message as you in that chat with the latest stock price.
The bot also looks at every message in any chat it is in for stock symbols.Symbols start with a
`$` followed by the stock symbol. For example:$tsla would return price information for Tesla Motors.
$$
+1 -1
View File
@@ -5,4 +5,4 @@ Your feedback and experience with Simple Stock Bot is invaluable. Whether you've
- **Telegram**: Drop me a message on [Telegram](https://t.me/MisterBiggs).
- **Discord**: Feel free to reach out on Discord at `MisterBiggs#0465`.
- **Twitter**: Send me a tweet on [Twitter](https://twitter.com/AnsonBiggs).
- **GitLab**: For technical issues or feature requests, feel free to open an issue on our [GitLab Repository](https://gitlab.com/simple-stock-bots/simple-telegram-stock-bot).
- **GitLab**: For technical issues or feature requests, feel free to open an issue on our [GitLab Repository](https://gitlab.com/simple-stock-bots/simple-stock-bot).
+3
View File
@@ -25,9 +25,11 @@ To enable donation acceptance, obtain a Stripe API key and provide a `STRIPE` ke
## Setup Instructions
1. **Download/Clone the Repository**:
- Download or clone this repository to your local machine.
2. **Configure Environment Variables**:
- Navigate to the project directory and locate the `.env` file.
- Fill in the `.env` file with your obtained API keys:
@@ -41,6 +43,7 @@ To enable donation acceptance, obtain a Stripe API key and provide a `STRIPE` ke
Alternatively, pass the variables using Docker Compose environment variables or command-line arguments.
3. **Build and Run the Bot:**
- Open a terminal in the project directory.
- Build and run both bots using Docker Compose:
Binary file not shown.

After

Width:  |  Height:  |  Size: 21 KiB

+6
View File
@@ -9,25 +9,31 @@ Discover a new level of financial discussion with Simple Stock Bot, your go-to s
## [Commands](commands.md)
### Real-Time Stock and Cryptocurrency Updates
- Get live price updates of stocks and cryptocurrencies.
- Symbol Detection: Use `$` for stocks and `$$` for cryptocurrencies, e.g., `$tsla` for Tesla and `$$btc` for Bitcoin.
### Intraday and Historical Data Visualization
- `/intra`: View a stock's movement since the last market open or a cryptocurrency's 24-hour chart.
- `/chart`: Provides a chart of the last month's trading data up till the day before.
### Trending Assets Awareness
- `/trending`: Discover the latest trending stocks and cryptocurrencies and their price changes.
### In-App Assistance and Support
- `/help`: Provides a quick summary of available commands for easy reference.
- `/donate`: Support the maintenance of the bot to ensure continued free access.
### User-Friendly Interaction
- Easy symbol and command usage for a smooth user experience.
- Engage with a community of financial enthusiasts and share insights effortlessly.
## [Contact](contact.md)
Need assistance or have inquiries? Feel free to reach out and I'll be happy to help.
## Powered by MarketData.app
+2 -9
View File
@@ -1,21 +1,19 @@
site_name: Simple Stock Bot
site_url: https://simplestockbot.com
edit_uri: /simple-stock-bots/site/tree/master/site
repo_url: https://gitlab.com/simple-stock-bots/simple-telegram-stock-bot
repo_url: https://gitlab.com/simple-stock-bots/simple-stock-bot
repo_name: Simple Stock Bots
site_description: Simple Discord and Telegram chat bots for Stock Market Data.
site_author: Anson Biggs
copyright: <a href="https://ansonbiggs.com">Anson Biggs</a> 2018 </br> Available Under an <a href="/LICENSE/">MIT LICENSE</a> </br>
nav:
- Home: index.md
- Commands: commands.md
- Self-Host: host.md
- Donate: donate.md
- Contact: contact.md
- Blog: /blog
- Blog: blog/index.md
theme:
name: material
@@ -56,19 +54,14 @@ extra:
link: https://dashboard.marketdata.app/marketdata/aff/go/misterbiggs?keyword=web
name: MarketData.app for stock data
extra_css:
- stylesheets/phone.css
plugins:
- search
- social
- blog
markdown_extensions:
- attr_list
- pymdownx.emoji:
+4 -4
View File
@@ -10,7 +10,7 @@ class T_info:
license = re.sub(
r"\b\n",
" ",
r.get("https://gitlab.com/simple-stock-bots/simple-telegram-stock-bot/-/raw/master/LICENSE").text,
r.get("https://gitlab.com/simple-stock-bots/simple-stock-bot/-/raw/master/LICENSE").text,
)
help_text = """
@@ -21,7 +21,7 @@ Want stock data or to host your own bot? Help keep this bot free by using my
📢 Stay updated on the bot's Telegram: https://t.me/simplestockbotnews.
**Guide**: All about using and setting up the bot is in the [docs](https://docs.simplestockbot.com).
**Guide**: All about using and setting up the bot is in the [docs](https://simplestockbot.com).
The bot recognizes _"Symbols"_. `$` for stocks and `$$` for cryptos. Example:
- `/chart $$eth` gets a month's Ethereum chart.
@@ -43,7 +43,7 @@ Pick a ticker, and the bot shares the current price in chat. Note: Prices can la
Data thanks to [marketdata.app](https://dashboard.marketdata.app/marketdata/aff/go/misterbiggs?keyword=telegram).
Bot issues? Use `/status` or [contact us](https://docs.simplestockbot.com/contact).
Bot issues? Use `/status` or [contact us](https://simplestockbot.com/contact).
"""
@@ -56,7 +56,7 @@ All funds help maintain servers, with data from
1. Use `/donate [amount in USD]`. E.g., `/donate 2` donates 2 USD.
2. Or, quickly donate at [buymeacoffee](https://www.buymeacoffee.com/Anson). No account needed, accepts Paypal & Credit card.
For questions, visit our [website](https://docs.simplestockbot.com).
For questions, visit our [website](https://simplestockbot.com).
"""
+60 -3
View File
@@ -178,17 +178,33 @@ async def symbol_detect(update: Update, context: ContextTypes.DEFAULT_TYPE):
message = update.message.text
chat_id = update.message.chat_id
if "$" in message:
symbols = s.find_symbols(message)
log.info("Looking for Symbols")
symbols = s.find_symbols(message)
else:
return
except AttributeError as ex:
log.info(ex)
return
if symbols:
# Let user know bot is working
# Detect Options
if ("call" in message.lower()) or ("put" in message.lower()):
log.info("Options detected")
await context.bot.send_chat_action(chat_id=chat_id, action=telegram.constants.ChatAction.TYPING)
try:
options_data = s.options(message, symbols)
await update.message.reply_text(
text=generate_options_reply(options_data),
parse_mode=telegram.constants.ParseMode.MARKDOWN,
)
return
except KeyError as ex:
logging.warning(ex)
pass
if symbols:
log.info(f"Symbols found: {symbols}")
await context.bot.send_chat_action(chat_id=chat_id, action=telegram.constants.ChatAction.TYPING)
for reply in s.price_reply(symbols):
await update.message.reply_text(
@@ -198,6 +214,47 @@ async def symbol_detect(update: Update, context: ContextTypes.DEFAULT_TYPE):
)
def generate_options_reply(options_data: dict):
# Header with Option Symbol and Underlying
message_text = f"*{options_data['Option Symbol']} ({options_data['Underlying']})*\n\n"
# Key details
details = (
f"*Expiration:* `{options_data['Expiration']}`\n"
f"*Side:* `{options_data['side']}`\n"
f"*Strike:* `{options_data['strike']}`\n"
f"*First Traded:* `{options_data['First Traded']}`\n"
f"*Last Updated:* `{options_data['Last Updated']}`\n\n"
)
message_text += details
# Pricing info
pricing_info = (
f"*Bid:* `{options_data['bid']}` (Size: `{options_data['bidSize']}`)\n"
f"*Mid:* `{options_data['mid']}`\n"
f"*Ask:* `{options_data['ask']}` (Size: `{options_data['askSize']}`)\n"
f"*Last:* `{options_data['last']}`\n\n"
)
message_text += pricing_info
# Volume and open interest
volume_info = f"*Open Interest:* `{options_data['Open Interest']}`\n" f"*Volume:* `{options_data['Volume']}`\n\n"
message_text += volume_info
# Greeks
greeks_info = (
f"*IV:* `{options_data['Implied Volatility']}`\n"
f"*Delta:* `{options_data['delta']}`\n"
f"*Gamma:* `{options_data['gamma']}`\n"
f"*Theta:* `{options_data['theta']}`\n"
f"*Vega:* `{options_data['vega']}`\n"
f"*Rho:* `{options_data['rho']}`\n"
)
message_text += greeks_info
return message_text
async def intra(update: Update, context: ContextTypes.DEFAULT_TYPE):
"""returns a chart of intraday data for a symbol"""
log.info(f"Intra command ran by {update.message.chat.username}")
+1 -1
View File
@@ -1,2 +1,2 @@
python-telegram-bot==20.5
python-telegram-bot==20.6
-r requirements.txt
+2 -12
View File
@@ -1,19 +1,9 @@
import keyboard
import time
import keyboard
tests = """$$xno
/info $tsla
/info $$btc
/news $tsla
/news $$btc
/stat $tsla
/stat $$btc
/cap $tsla
/cap $$btc
/dividend $tsla
/dividend $msft
/dividend $$btc
$tsla
/intra $tsla
/intra $$btc
/chart $tsla