Spaces:
Building
Building
File size: 8,919 Bytes
8067274 be70292 2d8a78b be70292 6b076a3 be70292 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 |
import discord
from discord import app_commands
import aiohttp
import asyncio
from datetime import datetime, timezone, timedelta
user_cash = {}
user_bets = {}
def save_database():
with open("database.txt", "w") as f:
for user_id, cash in user_cash.items():
f.write(f"{user_id} cash({cash})\n")
def load_database():
global user_cash
try:
with open("database.txt", "r") as f:
for line in f:
parts = line.strip().split()
if len(parts) == 2 and parts[1].startswith("cash(") and parts[1].endswith(")"):
user_id = int(parts[0])
cash = int(parts[1][5:-1])
user_cash[user_id] = cash
except FileNotFoundError:
print("No database found. Creating a new one.")
load_database()
async def fetch_nhl_scores():
async with aiohttp.ClientSession() as session:
async with session.get("https://nhl-score-api.herokuapp.com/api/scores/latest") as response:
return await response.json()
def format_time_difference(start_time):
now = datetime.now(timezone.utc)
start = datetime.fromisoformat(start_time.replace('Z', '+00:00'))
diff = start - now
if diff < timedelta(0):
return "Game has already started"
elif diff < timedelta(hours=1):
return f"{diff.seconds // 60} minutes from now"
elif diff < timedelta(days=1):
return f"{diff.seconds // 3600} hours from now"
else:
return f"{diff.days} days from now"
class GameSelect(discord.ui.Select):
def __init__(self, games):
options = [
discord.SelectOption(
label=f"{game['teams']['away']['teamName']} vs {game['teams']['home']['teamName']}",
value=f"{game['teams']['away']['abbreviation']}_{game['teams']['home']['abbreviation']}",
description=f"Start: {format_time_difference(game['startTime'])}"
) for game in games
]
super().__init__(placeholder="Select a game", options=options)
class TeamSelect(discord.ui.Select):
def __init__(self, away_team, home_team):
options = [
discord.SelectOption(label=away_team['teamName'], value=away_team['abbreviation']),
discord.SelectOption(label=home_team['teamName'], value=home_team['abbreviation'])
]
super().__init__(placeholder="Select a team to bet on", options=options)
class BetModal(discord.ui.Modal, title="Place Your Bet"):
bet_amount = discord.ui.TextInput(label="Bet Amount", placeholder="Enter bet amount")
def __init__(self, team, user_id, game_data):
super().__init__()
self.team = team
self.user_id = user_id
self.game_data = game_data
async def on_submit(self, interaction: discord.Interaction):
try:
bet_amount = int(self.bet_amount.value)
if bet_amount <= 0:
raise ValueError("Bet more than 0 dollars")
if bet_amount > user_cash.get(self.user_id, 0):
raise ValueError(f"Insufficient funds. Your balance is ${user_cash.get(self.user_id, 0)}")
user_cash[self.user_id] -= bet_amount
save_database()
await interaction.response.send_message(f"Bet placed on {self.team} for ${bet_amount}")
user = await interaction.client.fetch_user(self.user_id)
embed = discord.Embed(title="Bet Placed", color=0x787878)
embed.add_field(name="Team", value=self.team, inline=False)
embed.add_field(name="Amount", value=f"${bet_amount}", inline=False)
embed.add_field(name="Game", value=f"{self.game_data['teams']['away']['teamName']} vs {self.game_data['teams']['home']['teamName']}", inline=False)
embed.add_field(name="Start Time", value=format_time_difference(self.game_data['startTime']), inline=False)
await user.send(embed=embed)
if self.user_id not in user_bets:
user_bets[self.user_id] = []
user_bets[self.user_id].append({
"team": self.team,
"amount": bet_amount,
"game_data": self.game_data
})
asyncio.create_task(self.monitor_game(interaction, bet_amount))
except ValueError as e:
await interaction.response.send_message(str(e), ephemeral=True)
async def monitor_game(self, interaction, bet_amount):
game_start = datetime.fromisoformat(self.game_data['startTime'].replace('Z', '+00:00'))
await asyncio.sleep((game_start - datetime.now(timezone.utc)).total_seconds())
while True:
scores = await fetch_nhl_scores()
game = next((g for g in scores['games'] if g['teams']['away']['abbreviation'] == self.game_data['teams']['away']['abbreviation'] and
g['teams']['home']['abbreviation'] == self.game_data['teams']['home']['abbreviation']), None)
if game['status']['state'] == 'FINAL':
winner = 'away' if game['scores']['away'] > game['scores']['home'] else 'home'
if game['teams'][winner]['abbreviation'] == self.team:
winnings = bet_amount * 2
user_cash[self.user_id] += winnings
save_database()
await interaction.user.send(f"WOO YOUR TEAM WON you won ${winnings}!")
else:
await interaction.user.send(f"Sorry, your team lost booo!")
user_bets[self.user_id] = [bet for bet in user_bets[self.user_id] if bet['game_data'] != self.game_data]
break
await asyncio.sleep(300)
@app_commands.command(name="sportbet", description="bet on sports game")
async def sportbet(interaction: discord.Interaction):
scores = await fetch_nhl_scores()
upcoming_games = [game for game in scores['games'] if game['status']['state'] == 'PREVIEW']
if not upcoming_games:
await interaction.response.send_message("No games for betting.")
return
view = discord.ui.View()
game_select = GameSelect(upcoming_games)
view.add_item(game_select)
await interaction.response.send_message("game to bet on:", view=view)
async def game_callback(interaction: discord.Interaction):
selected_game = next(game for game in upcoming_games if f"{game['teams']['away']['abbreviation']}_{game['teams']['home']['abbreviation']}" == game_select.values[0])
team_view = discord.ui.View()
team_select = TeamSelect(selected_game['teams']['away'], selected_game['teams']['home'])
team_view.add_item(team_select)
await interaction.response.edit_message(content="team to bet on:", view=team_view)
async def team_callback(interaction: discord.Interaction):
selected_team = team_select.values[0]
await interaction.response.send_modal(BetModal(selected_team, interaction.user.id, selected_game))
team_select.callback = team_callback
game_select.callback = game_callback
@app_commands.command(name="currentbets", description="view your bets")
async def currentbets(interaction: discord.Interaction):
user_id = interaction.user.id
if user_id not in user_bets or not user_bets[user_id]:
await interaction.response.send_message("You have no bets.")
return
embed = discord.Embed(title="Your Current Bets", color=0x787878)
for i, bet in enumerate(user_bets[user_id]):
scores = await fetch_nhl_scores()
game = next((g for g in scores['games'] if g['teams']['away']['abbreviation'] == bet['game_data']['teams']['away']['abbreviation'] and
g['teams']['home']['abbreviation'] == bet['game_data']['teams']['home']['abbreviation']), None)
embed.add_field(name=f"Bet {i+1}", value=f"Team: {bet['team']}\nAmount: ${bet['amount']}\nGame: {bet['game_data']['teams']['away']['teamName']} vs {bet['game_data']['teams']['home']['teamName']}\nCurrent Score: {game['scores']['away']} - {game['scores']['home']}", inline=False)
view = discord.ui.View()
cancel_select = discord.ui.Select(placeholder="Select a bet to cancel", options=[
discord.SelectOption(label=f"Bet {i+1}", value=str(i)) for i in range(len(user_bets[user_id]))
])
view.add_item(cancel_select)
async def cancel_callback(interaction: discord.Interaction):
bet_index = int(cancel_select.values[0])
cancelled_bet = user_bets[user_id].pop(bet_index)
user_cash[user_id] += cancelled_bet['amount']
save_database()
await interaction.response.send_message(f"Bet cancelled. ${cancelled_bet['amount']} has been refunded.")
cancel_select.callback = cancel_callback
await interaction.response.send_message(embed=embed, view=view) |