Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .github/workflows/deployment.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,11 @@ jobs:
terraform_version: 1.3.0

- name: Terraform Init
if: github.event_name == 'pull_request'
run: terraform -chdir=infra init

- name: Terraform Plan
if: github.event_name == 'pull_request'
run: terraform -chdir=infra plan -var="db_username=${{ secrets.DB_USER_PROD }}" -var="db_password=${{ secrets.DB_PASSWORD }}"

- name: Terraform Apply (for push to main)
Expand Down
19 changes: 19 additions & 0 deletions backend/projects/migrations/0006_project_tags.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Generated by Django 5.1.6 on 2025-03-25 02:56

import django.contrib.postgres.fields
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0005_rename_followers_project_followers_count_and_more'),
]

operations = [
migrations.AddField(
model_name='project',
name='tags',
field=django.contrib.postgres.fields.ArrayField(base_field=models.CharField(max_length=225), blank=True, null=True, size=None),
),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
# Generated by Django 5.1.6 on 2025-03-25 04:35

import django.contrib.postgres.fields
import django.db.models.deletion
import uuid
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0006_project_tags'),
('userauth', '0001_initial'),
]

operations = [
migrations.AddField(
model_name='project',
name='email',
field=models.EmailField(blank=True, max_length=254, null=True, unique=True),
),
migrations.AddField(
model_name='project',
name='full_description',
field=models.CharField(blank=True, max_length=1000, null=True),
),
migrations.AddField(
model_name='project',
name='members',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='member_of_projects', to='userauth.user'),
),
migrations.AddField(
model_name='project',
name='other_contact',
field=models.CharField(blank=True, max_length=225, null=True),
),
migrations.AddField(
model_name='project',
name='owner',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='owned_projects', to='userauth.user'),
),
migrations.AddField(
model_name='project',
name='project_id',
field=models.UUIDField(default=uuid.uuid4, editable=False, null=True),
),
migrations.AddField(
model_name='project',
name='updates',
field=django.contrib.postgres.fields.ArrayField(base_field=models.CharField(max_length=540), blank=True, null=True, size=None),
),
migrations.AddField(
model_name='project',
name='wanted_description',
field=models.CharField(blank=True, max_length=540, null=True),
),
]
20 changes: 20 additions & 0 deletions backend/projects/migrations/0008_populate_uuids.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# Generated by Django 5.1.6 on 2025-03-25 04:36

from django.db import migrations
import uuid

def populate_uuids(apps, schema_editor):
Project = apps.get_model('projects', 'Project')
for project in Project.objects.all():
project.project_id = uuid.uuid4()
project.save()

class Migration(migrations.Migration):

dependencies = [
('projects', '0007_project_email_project_full_description_and_more'),
]

operations = [
migrations.RunPython(populate_uuids),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Generated by Django 5.1.6 on 2025-03-25 04:38

import uuid
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0008_populate_uuids'),
]

operations = [
migrations.RemoveField(
model_name='project',
name='id',
),
migrations.AlterField(
model_name='project',
name='project_id',
field=models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False),
),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
# Generated by Django 5.1.7 on 2025-03-26 04:24

import django.contrib.postgres.fields
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0009_remove_project_id_alter_project_project_id'),
]

operations = [
migrations.RenameField(
model_name='project',
old_name='tags',
new_name='interest_tags',
),
migrations.AddField(
model_name='project',
name='location',
field=models.JSONField(blank=True, default=list),
),
migrations.AddField(
model_name='project',
name='skill_tags',
field=django.contrib.postgres.fields.ArrayField(base_field=models.CharField(max_length=225), blank=True, null=True, size=None),
),
migrations.AlterField(
model_name='project',
name='group',
field=models.CharField(blank=True, max_length=255, null=True),
),
migrations.AlterField(
model_name='project',
name='image_url',
field=models.ImageField(upload_to='projects/'),
),
migrations.AlterField(
model_name='project',
name='images',
field=models.JSONField(blank=True, default=list),
),
migrations.AlterField(
model_name='project',
name='match_percentage',
field=models.FloatField(blank=True, null=True),
),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Generated by Django 5.1.7 on 2025-03-26 04:28

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0010_rename_tags_project_interest_tags_project_location_and_more'),
('userauth', '0003_rename_tags_user_interest_tags_and_more'),
]

operations = [
migrations.RemoveField(
model_name='project',
name='members',
),
migrations.AddField(
model_name='project',
name='members',
field=models.ManyToManyField(blank=True, null=True, related_name='member_of_projects', to='userauth.user'),
),
]
19 changes: 19 additions & 0 deletions backend/projects/migrations/0012_alter_project_members.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Generated by Django 5.1.7 on 2025-03-26 04:28

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0011_remove_project_members_project_members'),
('userauth', '0003_rename_tags_user_interest_tags_and_more'),
]

operations = [
migrations.AlterField(
model_name='project',
name='members',
field=models.ManyToManyField(blank=True, related_name='member_of_projects', to='userauth.user'),
),
]
18 changes: 18 additions & 0 deletions backend/projects/migrations/0013_rename_project_id_project_id.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 5.1.7 on 2025-03-26 04:32

from django.db import migrations


class Migration(migrations.Migration):

dependencies = [
('projects', '0012_alter_project_members'),
]

operations = [
migrations.RenameField(
model_name='project',
old_name='project_id',
new_name='id',
),
]
49 changes: 40 additions & 9 deletions backend/projects/models.py
Original file line number Diff line number Diff line change
@@ -1,18 +1,49 @@
from django.db import models
from userauth.models import User

from django.contrib.postgres.fields import ArrayField
import uuid
# PROJECTS MODEL
class Project(models.Model):
group = models.CharField(max_length=255)
match_percentage = models.FloatField()
title = models.CharField(max_length=255)
institution = models.CharField(max_length=255)
description = models.TextField()
# Auto generated
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)

# REQUIRED
title = models.CharField(max_length=255, blank=False, null=False)
institution = models.CharField(max_length=255, blank=False, null=False)
description = models.TextField(blank=False, null=False)
positions = models.JSONField(default=list)
image_url = models.ImageField(upload_to="projects/", blank=False, null=False)

# Not Required
group = models.CharField(max_length=255, blank=True, null=True)
followers_count = models.IntegerField(default=0)
likes_count = models.IntegerField(default=0)
positions = models.JSONField(default=list)
image_url = models.ImageField(upload_to="projects/", blank=True, null=True)
images = models.JSONField(default=list)
match_percentage = models.FloatField(blank=True, null=True)
location = models.JSONField(default=list, blank=True)
images = models.JSONField(default=list, blank=True)
interest_tags = ArrayField(models.CharField(max_length=225), blank=True, null=True)
skill_tags = ArrayField(models.CharField(max_length=225), blank=True, null=True)
full_description = models.CharField(max_length=1000, blank=True, null=True)
email = models.EmailField(unique=True, blank=True, null=True)
other_contact = models.CharField(max_length=225, blank=True, null=True)
updates = ArrayField(models.CharField(max_length=540), blank=True, null=True)
wanted_description = models.CharField(max_length=540, blank=True, null=True)

members = models.ManyToManyField(
'userauth.User',
related_name='member_of_projects',
blank=True
)

owner = models.ForeignKey(
'userauth.User',
on_delete=models.CASCADE,
related_name='owned_projects',
null=True,
blank=True
)

#discussion = ArrayField(models.CharField(max_length=540), blank=True, null=True) - for future

def __str__(self):
return self.title
Expand Down
2 changes: 1 addition & 1 deletion backend/projects/urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
urlpatterns = [
path('', get_projects, name='get_projects'), # Fetch all projects
path('create/', ProjectCRUDView.as_view(), name='project-create'), # Create project
path('<int:pk>/', ProjectCRUDView.as_view(), name='project-detail'), # Read, Update, Delete project by ID
path('<str:pk>/', ProjectCRUDView.as_view(), name='project-detail'), # Read, Update, Delete project by ID
path('like/<int:project_id>', toggle_like, name='toggle_like'),
path('follow/<int:project_id>', toggle_follow, name='toggle_follow')
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Generated by Django 5.1.6 on 2025-03-25 04:35

import django.db.models.deletion
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('projects', '0007_project_email_project_full_description_and_more'),
('userauth', '0001_initial'),
]

operations = [
migrations.AddField(
model_name='user',
name='owned',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='owners', to='projects.project'),
),
migrations.AddField(
model_name='user',
name='projects',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='contributors', to='projects.project'),
),
migrations.AlterField(
model_name='user',
name='email',
field=models.EmailField(blank=True, max_length=254, null=True, unique=True),
),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
# Generated by Django 5.1.7 on 2025-03-26 04:24

import django.contrib.postgres.fields
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('userauth', '0002_user_owned_user_projects_alter_user_email'),
]

operations = [
migrations.RenameField(
model_name='user',
old_name='tags',
new_name='interest_tags',
),
migrations.RenameField(
model_name='user',
old_name='position',
new_name='location_preference',
),
migrations.AddField(
model_name='user',
name='positions',
field=models.JSONField(default=list),
),
migrations.AddField(
model_name='user',
name='skill_tags',
field=django.contrib.postgres.fields.ArrayField(base_field=models.CharField(max_length=225), blank=True, null=True, size=None),
),
]
Loading
Loading