# /pong/game/views.py from django.shortcuts import render from django.core.exceptions import ObjectDoesNotExist from .models import Player, Tournoi, Match from .utils import create_player, create_tournoi, create_match from django.http import JsonResponse from django.contrib.auth.models import User from django.contrib.auth import authenticate from django.views.decorators.csrf import csrf_exempt import json import uuid def index(request): return render(request, 'index.html') @csrf_exempt def register_user(request): if request.method == 'POST': data = json.loads(request.body) username = data.get('username') password = data.get('password') if not User.objects.filter(username=username).exists(): user = User.objects.create_user(username=username, password=password) token = get_or_create_token(user) return JsonResponse({'registered': True, 'token': token}) return JsonResponse({'registered': False, 'error': 'User already exists'}) return JsonResponse({'error': 'Invalid request method'}, status=400) @csrf_exempt def check_user_exists(request): if request.method == 'POST': data = json.loads(request.body) username = data.get('username') if User.objects.filter(username=username).exists(): return JsonResponse({'exists': True}) return JsonResponse({'exists': False}) return JsonResponse({'error': 'Invalid request method'}, status=400) @csrf_exempt def authenticate_user(request): if request.method == 'POST': try: data = json.loads(request.body) username = data.get('username', '') password = data.get('password', '') user = authenticate(username=username, password=password) if user is not None: token = get_or_create_token(user) return JsonResponse({'authenticated': True, 'token': token, 'user_id': user.id}) else: return JsonResponse({'authenticated': False}, status=401) except Exception as e: return JsonResponse({'error': str(e)}, status=500) else: return JsonResponse({'error': 'Method not allowed'}, status=405) def get_or_create_token(user): if not user.auth_token: while True: token = str(uuid.uuid4()) if not User.objects.filter(auth_token=token).exists(): user.auth_token = token user.save() break return user.auth_token ####################### THEOUCHE PART ############################ @csrf_exempt def create_player_view(request): if request.method == 'POST': try: data = json.loads(request.body) name = data.get('name') # Vérifier que le nom est présent if not name: return JsonResponse({'error': 'Name is required'}, status=400) # Appeler la fonction create_player et traiter les exceptions player = create_player( name=name, total_match=data.get('total_match', 0), total_win=data.get('total_win', 0), p_win=data.get('p_win'), m_score_match=data.get('m_score_match'), m_score_adv_match=data.get('m_score_adv_match'), best_score=data.get('best_score', 0), m_nbr_ball_touch=data.get('m_nbr_ball_touch'), total_duration=data.get('total_duration'), m_duration=data.get('m_duration'), num_participated_tournaments=data.get('num_participated_tournaments', 0), num_won_tournaments=data.get('num_won_tournaments', 0) ) return JsonResponse({'id': player.id, 'name': player.name}) except ValueError as e: # Erreur spécifique à la validation return JsonResponse({'error': str(e)}, status=400) except json.JSONDecodeError: # Erreur de décodage JSON return JsonResponse({'error': 'Invalid JSON format'}, status=400) except Exception as e: # Erreur générale return JsonResponse({'error': 'An unexpected error occurred', 'details': str(e)}, status=500) # Méthode HTTP non supportée return JsonResponse({'error': 'Invalid HTTP method'}, status=405) @csrf_exempt def create_tournoi_view(request): if request.method == 'POST': data = json.loads(request.body) name = data.get('name') nbr_player = data.get('nbr_player') date = data.get('date') winner_id = data.get('winner_id') if not (name and nbr_player and date): return JsonResponse({'error': 'Name, number of players, and date are required'}, status=400) winner = None if winner_id: try: winner = Player.objects.get(id=winner_id) except Player.DoesNotExist: return JsonResponse({'error': 'Winner not found'}, status=404) tournoi = create_tournoi(name, nbr_player, date, winner) return JsonResponse({ 'id': tournoi.id, 'name': tournoi.name, 'nbr_player': tournoi.nbr_player, 'date': tournoi.date.isoformat(), 'winner': winner.id if winner else None }) return JsonResponse({'error': 'Invalid HTTP method'}, status=405) @csrf_exempt def create_match_view(request): if request.method == 'POST': data = json.loads(request.body) player1_id = data.get('player1_id') player2_id = data.get('player2_id') score_player1 = data.get('score_player1', 0) score_player2 = data.get('score_player2', 0) nbr_ball_touch_p1 = data.get('nbr_ball_touch_p1', 0) nbr_ball_touch_p2 = data.get('nbr_ball_touch_p2', 0) duration = data.get('duration') is_tournoi = data.get('is_tournoi', False) tournoi_id = data.get('tournoi_id') if not (player1_id and player2_id and duration): return JsonResponse({'error': 'Player IDs and duration are required'}, status=400) try: player1 = Player.objects.get(id=player1_id) player2 = Player.objects.get(id=player2_id) except Player.DoesNotExist: return JsonResponse({'error': 'One or both players not found'}, status=404) tournoi = None if tournoi_id: try: tournoi = Tournoi.objects.get(id=tournoi_id) except Tournoi.DoesNotExist: return JsonResponse({'error': 'Tournoi not found'}, status=404) match = create_match(player1, player2, score_player1, score_player2, nbr_ball_touch_p1, nbr_ball_touch_p2, duration, is_tournoi, tournoi) return JsonResponse({ 'id': match.id, 'player1': match.player1.id, 'player2': match.player2.id, 'score_player1': match.score_player1, 'score_player2': match.score_player2, 'nbr_ball_touch_p1': match.nbr_ball_touch_p1, 'nbr_ball_touch_p2': match.nbr_ball_touch_p2, 'duration': str(match.duration), 'is_tournoi': match.is_tournoi, 'tournoi': match.tournoi.id if match.tournoi else None }) return JsonResponse({'error': 'Invalid HTTP method'}, status=405) def player_list(request): players = Player.objects.all() return render(request, 'pong/player_list.html', {'players': players}) def match_list(request): matches = Match.objects.select_related('player1', 'player2', 'winner', 'tournoi').all() return render(request, 'pong/match_list.html', {'matches': matches}) def tournoi_list(request): tournois = Tournoi.objects.select_related('winner').all() return render(request, 'pong/tournoi_list.html', {'tournois': tournois}) ####################### THEOUCHE PART ############################ ####################### jcheca PART ############################ from web3 import Web3 provider = Web3.HTTPProvider("https://sepolia.infura.io/v3/60e51df7c97c4f4c8ab41605a4eb9907") web3 = Web3(provider) eth_gas_price = web3.eth.gas_price/1000000000 print(eth_gas_price) contract_address = "0x078D04Eb6fb97Cd863361FC86000647DC876441B" contract_abi = [{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"uint256","name":"_timecode","type":"uint256"},{"internalType":"uint256","name":"_participantCount","type":"uint256"},{"internalType":"string[]","name":"_playerPseudonyms","type":"string[]"},{"internalType":"string[]","name":"_finalOrder","type":"string[]"}],"name":"addTournament","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getAllTournaments","outputs":[{"components":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"string","name":"name","type":"string"},{"internalType":"uint256","name":"timecode","type":"uint256"},{"internalType":"uint256","name":"participantCount","type":"uint256"},{"internalType":"string[]","name":"playerPseudonyms","type":"string[]"},{"internalType":"string[]","name":"finalOrder","type":"string[]"}],"internalType":"struct PongTournament.Tournament[]","name":"","type":"tuple[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getTournament","outputs":[{"components":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"string","name":"name","type":"string"},{"internalType":"uint256","name":"timecode","type":"uint256"},{"internalType":"uint256","name":"participantCount","type":"uint256"},{"internalType":"string[]","name":"playerPseudonyms","type":"string[]"},{"internalType":"string[]","name":"finalOrder","type":"string[]"}],"internalType":"struct PongTournament.Tournament","name":"","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tournamentCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"tournaments","outputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"string","name":"name","type":"string"},{"internalType":"uint256","name":"timecode","type":"uint256"},{"internalType":"uint256","name":"participantCount","type":"uint256"}],"stateMutability":"view","type":"function"}] contract = web3.eth.contract(address=contract_address, abi=contract_abi) def read_data(request): # Créer une instance du contrat # Appeler une fonction du contrat pour obtenir tous les tournois tournaments = contract.functions.getAllTournaments().call() # Afficher les résultats json_data = [] for tournament in tournaments: tournament_data = [] for item in tournament: print(f"{item}") tournament_data.append(item) json_data.append(tournament_data) # Retourner le JSON comme réponse HTTP # print(f"Tournament ID: {tournament[0]}") # print(f"Name: {tournament[1]}") # print(f"Timecode: {tournament[2]}") # print(f"Participant Count: {tournament[3]}") # print(f"Player Pseudonyms: {', '.join(tournament[4])}") # print(f"Final Order: {', '.join(tournament[5])}") print("-----------------------------") return JsonResponse(json_data, safe=False) def write_data(request): # addTournament(string,uint256,uint256,string[],string[]) # # Configuration de la transaction pour la fonction store # account = "0x66CeBE2A1F7dae0F6AdBAad2c15A56A9121abfEf" # private_key = "beb16ee3434ec5abec8b799549846cc04443c967b8d3643b943e2e969e7d25be" # nonce = web3.eth.get_transaction_count(account) # transaction = contract.functions.addTournament("test",1721830559,6,["aaudeber", "tlorne", "ocassany", "yestello", "jcheca", "toto"],["toto", "jcheca", "yestello", "tlorne", "ocassany", "aaudeber"]).build_transaction({ # 'chainId': 11155111, # ID de la chaîne Sepolia # 'gas': 2000000, # 'gasPrice': web3.to_wei(eth_gas_price, 'gwei'), # 'nonce': nonce # }) # # Signature de la transaction # signed_txn = web3.eth.account.sign_transaction(transaction, private_key) # # Envoi de la transaction # tx_hash = web3.eth.send_raw_transaction(signed_txn.rawTransaction) # print("Transaction hash:", web3.to_hex(tx_hash)) # # Attente de la confirmation de la transaction # tx_receipt = web3.eth.wait_for_transaction_receipt(tx_hash) # print("Transaction receipt:", tx_receipt) print("-----------------------------")