Skip to content
Draft
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
3 changes: 3 additions & 0 deletions .flake8
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[flake8]
exclude = .git,__pycache__,venv,finalvenv, venv,migrations
max-line-length = 79
10 changes: 10 additions & 0 deletions finalvenv/bin/black
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from black import patched_main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(patched_main())
10 changes: 10 additions & 0 deletions finalvenv/bin/blackd
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from blackd import patched_main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(patched_main())
2 changes: 2 additions & 0 deletions finalvenv/bin/django-admin
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
# -*- coding: utf-8 -*-
import re
import sys

from django.core.management import execute_from_command_line

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(execute_from_command_line())
10 changes: 10 additions & 0 deletions finalvenv/bin/flake8
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from flake8.main.cli import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
10 changes: 10 additions & 0 deletions finalvenv/bin/isort
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from isort.main import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
10 changes: 10 additions & 0 deletions finalvenv/bin/isort-identify-imports
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from isort.main import identify_imports_main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(identify_imports_main())
2 changes: 2 additions & 0 deletions finalvenv/bin/pip
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
# -*- coding: utf-8 -*-
import re
import sys

from pip._internal.cli.main import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
2 changes: 2 additions & 0 deletions finalvenv/bin/pip3
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
# -*- coding: utf-8 -*-
import re
import sys

from pip._internal.cli.main import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
2 changes: 2 additions & 0 deletions finalvenv/bin/pip3.12
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
# -*- coding: utf-8 -*-
import re
import sys

from pip._internal.cli.main import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
10 changes: 10 additions & 0 deletions finalvenv/bin/pycodestyle
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from pycodestyle import _main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(_main())
10 changes: 10 additions & 0 deletions finalvenv/bin/pyflakes
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/home/pasokon/Projects/backend-final-assignment-arvid-edvinsson/finalvenv/bin/python
# -*- coding: utf-8 -*-
import re
import sys

from pyflakes.api import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
2 changes: 2 additions & 0 deletions finalvenv/bin/sqlformat
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
# -*- coding: utf-8 -*-
import re
import sys

from sqlparse.__main__ import main

if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(main())
1 change: 1 addition & 0 deletions followers/admin.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
from django.contrib import admin

from .models import Follow

admin.site.register(Follow)
4 changes: 2 additions & 2 deletions followers/apps.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,5 @@


class FollowersConfig(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
name = 'followers'
default_auto_field = "django.db.models.BigAutoField"
name = "followers"
17 changes: 12 additions & 5 deletions followers/migrations/0001_initial.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,22 @@ class Migration(migrations.Migration):

initial = True

dependencies = [
]
dependencies = []

operations = [
migrations.CreateModel(
name='Follow',
name="Follow",
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("created_at", models.DateTimeField(auto_now_add=True)),
],
),
]
26 changes: 17 additions & 9 deletions followers/migrations/0002_initial.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,23 +10,31 @@ class Migration(migrations.Migration):
initial = True

dependencies = [
('followers', '0001_initial'),
("followers", "0001_initial"),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]

operations = [
migrations.AddField(
model_name='follow',
name='followed',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='followers', to=settings.AUTH_USER_MODEL),
model_name="follow",
name="followed",
field=models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="followers",
to=settings.AUTH_USER_MODEL,
),
),
migrations.AddField(
model_name='follow',
name='follower',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='following', to=settings.AUTH_USER_MODEL),
model_name="follow",
name="follower",
field=models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="following",
to=settings.AUTH_USER_MODEL,
),
),
migrations.AlterUniqueTogether(
name='follow',
unique_together={('follower', 'followed')},
name="follow",
unique_together={("follower", "followed")},
),
]
17 changes: 13 additions & 4 deletions followers/models.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,23 @@
from django.db import models
from django.conf import settings
from django.db import models


class Follow(models.Model):
follower = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, related_name='following')
followed = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, related_name='followers')
follower = models.ForeignKey(
settings.AUTH_USER_MODEL,
on_delete=models.CASCADE,
related_name="following",
)

followed = models.ForeignKey(
settings.AUTH_USER_MODEL,
on_delete=models.CASCADE,
related_name="followers",
)
created_at = models.DateTimeField(auto_now_add=True)

class Meta:
unique_together = ('follower', 'followed')
unique_together = ("follower", "followed")

def __str__(self):
return f"{self.follower.username} follows {self.followed.username}"
3 changes: 0 additions & 3 deletions followers/tests.py
Original file line number Diff line number Diff line change
@@ -1,3 +0,0 @@
from django.test import TestCase

# Create your tests here.
7 changes: 5 additions & 2 deletions followers/urls.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
from django.urls import path

from . import views

urlpatterns = [
path('follow/<str:username>/', views.follow_user, name='follow_user'),
path('unfollow/<str:username>/', views.unfollow_user, name='unfollow_user')
path("follow/<str:username>/", views.follow_user, name="follow_user"),
path(
"unfollow/<str:username>/", views.unfollow_user, name="unfollow_user"
),
]
9 changes: 3 additions & 6 deletions followers/views.py
Original file line number Diff line number Diff line change
@@ -1,15 +1,12 @@
from django.shortcuts import redirect, get_object_or_404
from django.contrib.auth.decorators import login_required
from django.contrib import messages
from users.models import CustomUser
from .models import Follow
from django.shortcuts import redirect


@login_required
def follow_user(request, username):
return redirect('home')
return redirect("home")


@login_required
def unfollow_user(request, username):
return redirect('home')
return redirect("home")
4 changes: 2 additions & 2 deletions manage.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

def main():
"""Run administrative tasks."""
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'twittercopy.settings')
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "twittercopy.settings")
try:
from django.core.management import execute_from_command_line
except ImportError as exc:
Expand All @@ -18,5 +18,5 @@ def main():
execute_from_command_line(sys.argv)


if __name__ == '__main__':
if __name__ == "__main__":
main()
2 changes: 2 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
[tool.black]
line-length = 79
Loading