PagerMaid_Plugins_Pyro/bc/main.py

116 lines
4.1 KiB
Python
Raw Normal View History

""" PagerMaid Plugin Coin by Pentacene """
# ______ _
# | ___ \ | |
# | |_/ /__ _ __ | |_ __ _ ___ ___ _ __ ___
# | __/ _ \ '_ \| __/ _` |/ __/ _ \ '_ \ / _ \
# | | | __/ | | | || (_| | (_| __/ | | | __/
# \_| \___|_| |_|\__\__,_|\___\___|_| |_|\___|
#
2024-03-15 12:28:49 +00:00
from datetime import datetime
from sys import executable
import urllib.request
from pyrogram import Client
2024-09-28 14:35:08 +00:00
from pagermaid.enums import Message
from pagermaid.listener import listener
2024-09-28 14:35:08 +00:00
from pagermaid.utils import pip_install
2024-03-15 12:28:49 +00:00
pip_install("binance-connector", alias="binance")
pip_install("xmltodict")
2024-03-15 12:28:49 +00:00
from binance.spot import Spot
from binance.error import ClientError
import xmltodict
API = "https://www.ecb.europa.eu/stats/eurofxref/eurofxref-daily.xml"
2024-03-15 12:28:49 +00:00
def init() -> list:
""" INIT """
with urllib.request.urlopen(API) as response:
result = response.read()
2024-03-15 12:28:49 +00:00
currencies = []
data = {}
rate_data = xmltodict.parse(result)
rate_data = rate_data['gesmes:Envelope']['Cube']['Cube']['Cube']
for i in rate_data:
currencies.append(i['@currency'])
data[i['@currency']] = float(i['@rate'])
currencies.sort()
return [currencies, data]
2023-07-01 12:18:58 +00:00
@listener(command="bc", description="coins", parameters="[num] [coin1] [coin2]")
async def coin(_: Client, message: Message) -> None:
2023-07-01 12:18:58 +00:00
"""coin change"""
2024-03-15 12:28:49 +00:00
currencies, data = init()
binanceclient = Spot()
nowtimestamp = binanceclient.time()
nowtime = datetime.fromtimestamp(float(nowtimestamp['serverTime'])/1000)
if len(message.parameter) == 0:
btc_usdt_data = binanceclient.klines("BTCUSDT", "1m")[:1][0]
eth_usdt_data = binanceclient.klines("ETHUSDT", "1m")[:1][0]
await message.edit((
f'{nowtime.strftime("%Y-%m-%d %H:%M:%S")} UTC\n'
f'**1 BTC** = {btc_usdt_data[1]} USDT '
f'\n'
f'**1 ETH** = {eth_usdt_data[1]} USDT '))
return
if len(message.parameter) < 3:
await message.edit('输入错误.\nbc 数量 币种1 币种2')
return
2024-03-15 12:28:49 +00:00
try:
number = float(message.parameter[0])
except ValueError:
await message.edit('输入错误.\nbc 数量 币种1 币种2')
return
_from = message.parameter[1].upper().strip()
_to = message.parameter[2].upper().strip()
# both are real currency
if (currencies.count(_from) != 0) and (currencies.count(_to) != 0):
await message.edit((
f'{message.parameter[0]} {message.parameter[1].upper().strip()} ='
f'{number * data[_to] / data[_from]:.2f} '
f'{message.parameter[2].upper().strip()}'))
return
# from real currency to crypto
if currencies.count(_from) != 0:
usd_number = number * data["USD"] / data[_from]
try:
2024-03-15 12:28:49 +00:00
x_usdt_data = binanceclient.klines(f"{_to}USDT", "1m")[:1][0]
except ClientError:
await message.edit(f'Cannot find coinpair {_to}USDT')
return
2024-03-15 12:28:49 +00:00
await message.edit((
f'{message.parameter[0]} **{_from}** = '
f'{1 / float(x_usdt_data[1]) * usd_number:.8f} **{_to}**\n'
f'{message.parameter[0]} **{_from}** = '
f'{usd_number:.2f} **USD**'))
return
# from crypto to real currency
if currencies.count(_to) != 0:
usd_number = number * data[_to] / data["USD"]
try:
x_usdt_data = binanceclient.klines(f"{_from}USDT", "1m")[:1][0]
except ClientError:
await message.edit(f'Cannot find coinpair {_from}USDT')
return
await message.edit((
f'{message.parameter[0]} **{_from}** = '
f'{float(x_usdt_data[1]) * usd_number:.2f} **{_to}**\n'
f'{message.parameter[0]} **{_from}** = '
f'{float(x_usdt_data[1]):.2f} **USD**'))
return
2024-03-15 12:28:49 +00:00
# both crypto
try:
from_to_data = binanceclient.klines(f"{_from}{_to}", "1m")[:1][0]
except ClientError:
await message.edit(f'Cannot find coinpair {_from}{_to}')
return
await message.edit((
f'{message.parameter[0]} **{_from}** = '
f'{float(from_to_data[1]) * number} **{_to}**\n'))