simplify apps

This commit is contained in:
Matteo Rosati
2026-02-11 21:05:49 +01:00
parent 93dafb6a81
commit 9587995354
24 changed files with 67 additions and 166 deletions

View File

@@ -1,3 +0,0 @@
from django.contrib import admin
# Register your models here.

View File

@@ -1,5 +0,0 @@
from django.apps import AppConfig
class ApiConfig(AppConfig):
name = 'api'

View File

@@ -1,22 +0,0 @@
# Generated by Django 6.0.2 on 2026-02-10 18:07
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
]
operations = [
migrations.CreateModel(
name='Building',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('geojson_id', models.IntegerField()),
('health', models.FloatField()),
],
),
]

View File

@@ -1,38 +0,0 @@
# Generated by Django 6.0.2 on 2026-02-11 00:00
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
("api", "0001_initial"),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name="PlayerInfo",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("energy", models.PositiveIntegerField()),
(
"user",
models.OneToOneField(
on_delete=django.db.models.deletion.CASCADE,
related_name="player_info",
to=settings.AUTH_USER_MODEL,
),
),
],
),
]

View File

@@ -1,16 +0,0 @@
from django.conf import settings
from django.db import models
class Building(models.Model):
geojson_id = models.IntegerField()
health = models.FloatField()
class PlayerInfo(models.Model):
user = models.OneToOneField(
settings.AUTH_USER_MODEL,
on_delete=models.CASCADE,
related_name="player_info",
)
energy = models.PositiveIntegerField()

View File

@@ -1,5 +0,0 @@
from django.urls import path
from .views import prova
urlpatterns = [path("prova/", prova)]

View File

@@ -1,6 +0,0 @@
from django.http.request import HttpRequest
from django.http.response import JsonResponse
def prova(reques: HttpRequest):
return JsonResponse({"message": "OK"})

Binary file not shown.

View File

@@ -40,12 +40,11 @@ ALLOWED_HOSTS = ["127.0.0.1", "localhost"]
# Application definition # Application definition
INSTALLED_APPS = [ INSTALLED_APPS = [
"api", "game",
"frontend", "frontend",
"rest_framework", "rest_framework",
"rest_framework_simplejwt", "rest_framework_simplejwt",
"rest_framework_simplejwt.token_blacklist", "rest_framework_simplejwt.token_blacklist",
"django.contrib.admin",
"django.contrib.auth", "django.contrib.auth",
"django.contrib.contenttypes", "django.contrib.contenttypes",
"django.contrib.sessions", "django.contrib.sessions",

View File

@@ -15,11 +15,8 @@ Including another URLconf
2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) 2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
""" """
from django.contrib import admin
from django.urls import include, path from django.urls import include, path
urlpatterns = [ urlpatterns = [
path("", include("frontend.urls")), path("", include("frontend.urls")),
path("admin/", admin.site.urls),
path("api/", include("api.urls")),
] ]

View File

@@ -1,3 +0,0 @@
from django.contrib import admin
# Register your models here.

View File

@@ -1,8 +0,0 @@
from django.apps import AppConfig
class FrontendConfig(AppConfig):
name = "frontend"
def ready(self) -> None:
from . import models # noqa: F401

View File

@@ -1,37 +0,0 @@
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name="UserProfile",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("display_name", models.CharField(max_length=150)),
(
"user",
models.OneToOneField(
on_delete=django.db.models.deletion.CASCADE,
related_name="profile",
to=settings.AUTH_USER_MODEL,
),
),
],
),
]

View File

@@ -1,15 +0,0 @@
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("frontend", "0001_userprofile"),
]
operations = [
migrations.AlterField(
model_name="userprofile",
name="display_name",
field=models.CharField(max_length=150, unique=True),
),
]

View File

@@ -2,7 +2,6 @@ from django.urls import path
from . import views from . import views
urlpatterns = [ urlpatterns = [
path("", views.home, name="home"), path("", views.home, name="home"),
path("auth/register/", views.register, name="register"), path("auth/register/", views.register, name="register"),

View File

@@ -10,7 +10,7 @@ from django.shortcuts import redirect, render
from django.views.decorators.http import require_http_methods from django.views.decorators.http import require_http_methods
from django_ratelimit.decorators import ratelimit from django_ratelimit.decorators import ratelimit
from .models import UserProfile from game.models import UserProfile
def home(request): def home(request):

5
game/apps.py Normal file
View File

@@ -0,0 +1,5 @@
from django.apps import AppConfig
class GameConfig(AppConfig):
name = 'game'

View File

@@ -0,0 +1,41 @@
# Generated by Django 6.0.2 on 2026-02-11 20:00
import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name='Building',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('geojson_id', models.IntegerField()),
('health', models.FloatField()),
],
),
migrations.CreateModel(
name='PlayerInfo',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('energy', models.PositiveIntegerField()),
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='player_info', to=settings.AUTH_USER_MODEL)),
],
),
migrations.CreateModel(
name='UserProfile',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('display_name', models.CharField(max_length=150, unique=True)),
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='profile', to=settings.AUTH_USER_MODEL)),
],
),
]

View File

@@ -4,6 +4,20 @@ from django.db.models.signals import post_save
from django.dispatch import receiver from django.dispatch import receiver
class Building(models.Model):
geojson_id = models.IntegerField()
health = models.FloatField()
class PlayerInfo(models.Model):
user = models.OneToOneField(
settings.AUTH_USER_MODEL,
on_delete=models.CASCADE,
related_name="player_info",
)
energy = models.PositiveIntegerField()
class UserProfile(models.Model): class UserProfile(models.Model):
user = models.OneToOneField( user = models.OneToOneField(
settings.AUTH_USER_MODEL, settings.AUTH_USER_MODEL,
@@ -19,7 +33,8 @@ class UserProfile(models.Model):
@receiver(post_save, sender=settings.AUTH_USER_MODEL) @receiver(post_save, sender=settings.AUTH_USER_MODEL)
def create_profile_for_user(sender, instance, created, **kwargs): def create_profile_for_user(sender, instance, created, **kwargs):
if created: if created:
UserProfile.objects.create( # type: ignore[attr-defined] UserProfile.objects.create(
user=instance, user=instance,
display_name=instance.username, display_name=instance.username,
) )
PlayerInfo.objects.create(user=instance, energy=10_000)

3
game/views.py Normal file
View File

@@ -0,0 +1,3 @@
from django.shortcuts import render
# Create your views here.