I am trying to do something simple with Django and Ajax.
My goal is to make a kind of lobby website, where each client knows the names of everybody currently in the lobby.
The way I'm doing it (bear with me even if it's the most awful method you've ever heard of) is to have the client send a message every second that says "I'm still here!". If the server doesn't here from a client for five seconds, that client is removed from the list of people in the lobby. I have this working.
What I can't figure out is how to send the list of players names that I have in by Django view back to the client. I've been trying to use JsonResponse and then receiving that in the success function of the $.ajax()
call, but I can't seem to get it to work.
Here is my $.ajax()
call:
$.ajax({
url: apiUpdateUrl,
method: "post",
data: {
csrfmiddlewaretoken: Cookies.get("csrftoken")
},
dataType: "json",
success: function(data) {
console.log(data.player_list)
}
});
Here is my Django view:
def update(request):
if Player.objects.filter(nickname=request.user.username).count() == 0:
player = Player(nickname=request.user.username, time_joined=datetime.datetime.now())
player.save()
else:
player = Player.objects.get(nickname=request.user.username)
player.save()
curr_time = datetime.datetime.now()
for player in Player.objects.all():
if (curr_time - player.last_update).total_seconds() >= 5:
Player.objects.filter(pk=player.pk).delete()
player_list = [p.nickname for p in Player.objects.all()]
print(player_list)
return JsonResponse({"player_list": player_list})