mirror of
https://github.com/kristoferssolo/FOSSDB.git
synced 2025-10-21 17:50:35 +00:00
Added Tag model
This commit is contained in:
parent
4b97d321bc
commit
89143d6d43
@ -1,7 +1,7 @@
|
|||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
|
|
||||||
from .models import (HostingPlatform, License, ProgrammingLanguage, Project,
|
from .models import (HostingPlatform, License, ProgrammingLanguage, Project,
|
||||||
ProjectHostingPlatform, ProjectProgrammingLanguage)
|
ProjectHostingPlatform, ProjectProgrammingLanguage, Tag)
|
||||||
|
|
||||||
|
|
||||||
class ProjectProgrammingLanguageInline(admin.TabularInline):
|
class ProjectProgrammingLanguageInline(admin.TabularInline):
|
||||||
@ -29,3 +29,4 @@ admin.site.register(License)
|
|||||||
admin.site.register(ProgrammingLanguage)
|
admin.site.register(ProgrammingLanguage)
|
||||||
admin.site.register(HostingPlatform)
|
admin.site.register(HostingPlatform)
|
||||||
admin.site.register(Project, ProjectAdmin)
|
admin.site.register(Project, ProjectAdmin)
|
||||||
|
admin.site.register(Tag)
|
||||||
|
|||||||
@ -1,12 +1,14 @@
|
|||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
from django.contrib.auth.models import User
|
from django.conf import settings
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
|
User = settings.AUTH_USER_MODEL
|
||||||
|
|
||||||
|
|
||||||
class License(models.Model):
|
class License(models.Model):
|
||||||
short_name = models.CharField(max_length=50)
|
short_name = models.CharField(max_length=50)
|
||||||
full_name = models.CharField(max_length=100, null=True, blank=True)
|
full_name = models.CharField(max_length=100, blank=True)
|
||||||
url = models.URLField(null=True, blank=True)
|
url = models.URLField(null=True, blank=True)
|
||||||
description = models.TextField(null=True, blank=True)
|
description = models.TextField(null=True, blank=True)
|
||||||
|
|
||||||
@ -24,7 +26,7 @@ class ProgrammingLanguage(models.Model):
|
|||||||
class ProjectProgrammingLanguage(models.Model):
|
class ProjectProgrammingLanguage(models.Model):
|
||||||
project = models.ForeignKey("Project", on_delete=models.CASCADE)
|
project = models.ForeignKey("Project", on_delete=models.CASCADE)
|
||||||
language = models.ForeignKey(ProgrammingLanguage, on_delete=models.CASCADE)
|
language = models.ForeignKey(ProgrammingLanguage, on_delete=models.CASCADE)
|
||||||
percentage = models.PositiveIntegerField()
|
percentage = models.PositiveIntegerField(default=0)
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return f"{self.project} | {self.language} | {self.percentage}%"
|
return f"{self.project} | {self.language} | {self.percentage}%"
|
||||||
@ -46,6 +48,12 @@ class ProjectHostingPlatform(models.Model):
|
|||||||
return f"{self.project} | {self.hosting_platform}"
|
return f"{self.project} | {self.hosting_platform}"
|
||||||
|
|
||||||
|
|
||||||
|
class Tag(models.Model):
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
description = models.TextField(null=True, blank=True)
|
||||||
|
icon = models.ImageField(upload_to="types/icons/", null=True, blank=True)
|
||||||
|
|
||||||
|
|
||||||
class Project(models.Model):
|
class Project(models.Model):
|
||||||
uuid = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
uuid = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
||||||
author = models.ForeignKey(User, on_delete=models.CASCADE)
|
author = models.ForeignKey(User, on_delete=models.CASCADE)
|
||||||
@ -54,6 +62,7 @@ class Project(models.Model):
|
|||||||
licenses = models.ManyToManyField(License)
|
licenses = models.ManyToManyField(License)
|
||||||
programming_languages = models.ManyToManyField(ProgrammingLanguage, through="ProjectProgrammingLanguage", related_name="projects")
|
programming_languages = models.ManyToManyField(ProgrammingLanguage, through="ProjectProgrammingLanguage", related_name="projects")
|
||||||
hosting_platform = models.ManyToManyField(HostingPlatform, through="ProjectHostingPlatform", related_name="projects")
|
hosting_platform = models.ManyToManyField(HostingPlatform, through="ProjectHostingPlatform", related_name="projects")
|
||||||
|
project_type = models.ForeignKey(Tag, on_delete=models.CASCADE, blank=True, null=True)
|
||||||
date_created = models.DateTimeField(auto_now_add=True)
|
date_created = models.DateTimeField(auto_now_add=True)
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
|
|||||||
@ -82,7 +82,7 @@ WSGI_APPLICATION = "FOSSDB_web.wsgi.application"
|
|||||||
|
|
||||||
DATABASES = {
|
DATABASES = {
|
||||||
"default": {
|
"default": {
|
||||||
"ENGINE": "django.db.backends.mysql",
|
"ENGINE": f"django.db.backends.{config['DATABASE']['ENGINE']}",
|
||||||
"NAME": config["DATABASE"]["NAME"],
|
"NAME": config["DATABASE"]["NAME"],
|
||||||
"USER": config["DATABASE"]["USER"],
|
"USER": config["DATABASE"]["USER"],
|
||||||
"PASSWORD": config["DATABASE"]["PASSWORD"],
|
"PASSWORD": config["DATABASE"]["PASSWORD"],
|
||||||
@ -128,6 +128,7 @@ USE_TZ = True
|
|||||||
|
|
||||||
STATIC_URL = "/static/"
|
STATIC_URL = "/static/"
|
||||||
STATIC_ROOT = BASE_PATH.joinpath("static")
|
STATIC_ROOT = BASE_PATH.joinpath("static")
|
||||||
|
MEDIA_URL = "/media/"
|
||||||
MEDIA_ROOT = BASE_PATH.joinpath("media")
|
MEDIA_ROOT = BASE_PATH.joinpath("media")
|
||||||
|
|
||||||
# Default primary key field type
|
# Default primary key field type
|
||||||
@ -136,3 +137,14 @@ MEDIA_ROOT = BASE_PATH.joinpath("media")
|
|||||||
DEFAULT_AUTO_FIELD = "django.db.models.BigAutoField"
|
DEFAULT_AUTO_FIELD = "django.db.models.BigAutoField"
|
||||||
LOGIN_REDIRECT_URL = "/"
|
LOGIN_REDIRECT_URL = "/"
|
||||||
LOGOUT_REDIRECT_URL = "/"
|
LOGOUT_REDIRECT_URL = "/"
|
||||||
|
|
||||||
|
# HTTPS settings
|
||||||
|
# SESSION_COOKIE_SECURE = True
|
||||||
|
# CSRF_COOKIE_SECURE = True
|
||||||
|
# SECURE_SSL_REDIRECT = True
|
||||||
|
|
||||||
|
# HSTS settings
|
||||||
|
# SECURE_HSTS_SECONDS = 31536000 # 1 year
|
||||||
|
# SECURE_HSTS_SECONDS = 1 # 1 year
|
||||||
|
# SECURE_HSTS_PRELOAD = True
|
||||||
|
# SECURE_HSTS_INCLUDE_SUBDOMAINS = True
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user