@ -0,0 +1,102 @@ | |||||
# Byte-compiled / optimized / DLL files | |||||
__pycache__/ | |||||
*.py[cod] | |||||
*$py.class | |||||
# C extensions | |||||
*.so | |||||
# Distribution / packaging | |||||
.Python | |||||
build/ | |||||
develop-eggs/ | |||||
dist/ | |||||
downloads/ | |||||
eggs/ | |||||
.eggs/ | |||||
lib/ | |||||
lib64/ | |||||
parts/ | |||||
sdist/ | |||||
var/ | |||||
wheels/ | |||||
*.egg-info/ | |||||
.installed.cfg | |||||
*.egg | |||||
# PyInstaller | |||||
# Usually these files are written by a python script from a template | |||||
# before PyInstaller builds the exe, so as to inject date/other infos into it. | |||||
*.manifest | |||||
*.spec | |||||
# Installer logs | |||||
pip-log.txt | |||||
pip-delete-this-directory.txt | |||||
# Unit test / coverage reports | |||||
htmlcov/ | |||||
.tox/ | |||||
.coverage | |||||
.coverage.* | |||||
.cache | |||||
nosetests.xml | |||||
coverage.xml | |||||
*.cover | |||||
.hypothesis/ | |||||
# Translations | |||||
*.mo | |||||
*.pot | |||||
# Django stuff: | |||||
*.log | |||||
local_settings.py | |||||
# Flask stuff: | |||||
instance/ | |||||
.webassets-cache | |||||
# Scrapy stuff: | |||||
.scrapy | |||||
# Sphinx documentation | |||||
docs/_build/ | |||||
# PyBuilder | |||||
target/ | |||||
# Jupyter Notebook | |||||
.ipynb_checkpoints | |||||
# pyenv | |||||
.python-version | |||||
# celery beat schedule file | |||||
celerybeat-schedule | |||||
# SageMath parsed files | |||||
*.sage.py | |||||
# Environments | |||||
.env | |||||
.venv | |||||
env/ | |||||
venv/ | |||||
ENV/ | |||||
# Spyder project settings | |||||
.spyderproject | |||||
.spyproject | |||||
# Rope project settings | |||||
.ropeproject | |||||
# mkdocs documentation | |||||
/site | |||||
# mypy | |||||
.mypy_cache/ | |||||
*.sqlite3 | |||||
.vagrant |
@ -0,0 +1,3 @@ | |||||
# Tests docker django | |||||
Rest api providing basic functionnality |
@ -0,0 +1,28 @@ | |||||
Vagrant.configure("2") do |config| | |||||
config.vm.box = "gusztavvargadr/docker-linux" | |||||
config.vm.network "forwarded_port", guest: 80, host: 80 | |||||
config.vm.provision "shell", inline: <<-SHELL | |||||
# Update and upgrade the server packages. | |||||
sudo apt-get update | |||||
sudo apt-get -y upgrade | |||||
# Set Ubuntu Language | |||||
sudo locale-gen en_GB.UTF-8 | |||||
# Install Python, SQLite and pip | |||||
# sudo apt-get install -y python3-dev sqlite python3-pip | |||||
# Upgrade pip to the latest version. | |||||
#sudo pip install --upgrade pip | |||||
# Install and configure python virtualenvwrapper. | |||||
#sudo pip install virtualenvwrapper | |||||
#if ! grep -q VIRTUALENV_ALREADY_ADDED /home/vagrant/.bashrc; then | |||||
# echo "# VIRTUALENV_ALREADY_ADDED" >> /home/vagrant/.bashrc | |||||
# echo "WORKON_HOME=~/.virtualenvs" >> /home/vagrant/.bashrc | |||||
# echo "PROJECT_HOME=/vagrant" >> /home/vagrant/.bashrc | |||||
# echo "export VIRTUALENVWRAPPER_PYTHON='/usr/bin/python3'" >> /home/vagrant/.bashrc | |||||
# echo "source /usr/local/bin/virtualenvwrapper.sh" >> /home/vagrant/.bashrc | |||||
#fi | |||||
cd /vagrant | |||||
SHELL | |||||
end |
@ -0,0 +1,28 @@ | |||||
Vagrant.configure("2") do |config| | |||||
config.vm.box = "gusztavvargadr/docker-linux" | |||||
config.vm.network "forwarded_port", guest: 80, host: 80 | |||||
config.vm.provision "shell", inline: <<-SHELL | |||||
# Update and upgrade the server packages. | |||||
sudo apt-get update | |||||
sudo apt-get -y upgrade | |||||
# Set Ubuntu Language | |||||
sudo locale-gen en_GB.UTF-8 | |||||
# Install Python, SQLite and pip | |||||
# sudo apt-get install -y python3-dev sqlite python3-pip | |||||
# Upgrade pip to the latest version. | |||||
#sudo pip install --upgrade pip | |||||
# Install and configure python virtualenvwrapper. | |||||
#sudo pip install virtualenvwrapper | |||||
#if ! grep -q VIRTUALENV_ALREADY_ADDED /home/vagrant/.bashrc; then | |||||
# echo "# VIRTUALENV_ALREADY_ADDED" >> /home/vagrant/.bashrc | |||||
# echo "WORKON_HOME=~/.virtualenvs" >> /home/vagrant/.bashrc | |||||
# echo "PROJECT_HOME=/vagrant" >> /home/vagrant/.bashrc | |||||
# echo "export VIRTUALENVWRAPPER_PYTHON='/usr/bin/python3'" >> /home/vagrant/.bashrc | |||||
# echo "source /usr/local/bin/virtualenvwrapper.sh" >> /home/vagrant/.bashrc | |||||
#fi | |||||
cd /vagrant | |||||
SHELL | |||||
end |
@ -0,0 +1,13 @@ | |||||
from django.contrib import admin | |||||
from app1.models import Profile, Address, Image | |||||
# Register your models here. | |||||
class ProfileAdmin(admin.ModelAdmin): | |||||
pass | |||||
admin.site.register(Profile, ProfileAdmin) | |||||
admin.site.register(Address, ProfileAdmin) | |||||
admin.site.register(Image, ProfileAdmin) | |||||
@ -0,0 +1,6 @@ | |||||
from django.apps import AppConfig | |||||
class App1Config(AppConfig): | |||||
default_auto_field = 'django.db.models.BigAutoField' | |||||
name = 'app1' |
@ -0,0 +1,63 @@ | |||||
# Generated by Django 3.2.8 on 2021-10-15 16:56 | |||||
import datetime | |||||
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='Address', | |||||
fields=[ | |||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), | |||||
('title', models.CharField(max_length=100)), | |||||
('street1', models.CharField(max_length=50)), | |||||
('street2', models.CharField(blank=True, max_length=50)), | |||||
('postalcode', models.CharField(max_length=10)), | |||||
('city', models.CharField(max_length=100)), | |||||
('state', models.CharField(max_length=50)), | |||||
('country', models.CharField(max_length=50)), | |||||
('owner', models.ForeignKey(blank=True, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), | |||||
], | |||||
), | |||||
migrations.CreateModel( | |||||
name='Image', | |||||
fields=[ | |||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), | |||||
('photo', models.ImageField(default='avatar.png', upload_to='avatars/')), | |||||
('description', models.CharField(blank=True, max_length=100)), | |||||
('owner', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), | |||||
], | |||||
), | |||||
migrations.CreateModel( | |||||
name='Profile', | |||||
fields=[ | |||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), | |||||
('first_name', models.CharField(blank=True, max_length=50)), | |||||
('last_name', models.CharField(blank=True, max_length=50)), | |||||
('gender', models.CharField(choices=[('m', 'Male'), ('f', 'Female')], default='m', max_length=1)), | |||||
('birthdate', models.DateField(default=datetime.date(2021, 10, 15))), | |||||
('companyname', models.CharField(blank=True, max_length=200)), | |||||
('bio', models.TextField(blank=True, default='no bio ...', max_length=300)), | |||||
('country', models.CharField(blank=True, max_length=50)), | |||||
('updated', models.DateTimeField(auto_now=True)), | |||||
('created', models.DateTimeField(auto_now_add=True)), | |||||
('type', models.CharField(choices=[('pers', 'personal'), ('prof', 'professional'), ('asso', 'association')], max_length=4)), | |||||
('tel', models.CharField(blank=True, max_length=50)), | |||||
('sex', models.IntegerField(blank=True, choices=[(0, 'exclusively heterosexual'), (1, 'Heterosexual predominance'), (2, 'Predominantly heterosexual, occasionally homosexual'), (3, 'Bisexual without preference'), (4, 'Predominantly homosexual, occasionally heterosexual'), (5, 'Homosexual predominance'), (6, 'exclusively homosexual')], null=True)), | |||||
('activated', models.BooleanField(default=False)), | |||||
('avatar', models.OneToOneField(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='app1.image')), | |||||
('defaddr', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='app1.address')), | |||||
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), | |||||
], | |||||
), | |||||
] |
@ -0,0 +1,19 @@ | |||||
# Generated by Django 3.2.8 on 2021-10-16 09:19 | |||||
import datetime | |||||
from django.db import migrations, models | |||||
class Migration(migrations.Migration): | |||||
dependencies = [ | |||||
('app1', '0001_initial'), | |||||
] | |||||
operations = [ | |||||
migrations.AlterField( | |||||
model_name='profile', | |||||
name='birthdate', | |||||
field=models.DateField(default=datetime.date(2021, 10, 16)), | |||||
), | |||||
] |
@ -0,0 +1,19 @@ | |||||
# Generated by Django 3.2.8 on 2021-11-02 23:19 | |||||
import datetime | |||||
from django.db import migrations, models | |||||
class Migration(migrations.Migration): | |||||
dependencies = [ | |||||
('app1', '0002_alter_profile_birthdate'), | |||||
] | |||||
operations = [ | |||||
migrations.AlterField( | |||||
model_name='profile', | |||||
name='birthdate', | |||||
field=models.DateField(default=datetime.date(2021, 11, 2)), | |||||
), | |||||
] |
@ -0,0 +1,85 @@ | |||||
from django.db import models | |||||
from django.contrib.auth.models import User | |||||
from django.utils.translation import gettext as _ | |||||
from datetime import date | |||||
from django.template.defaultfilters import truncatechars | |||||
# Create your models here. | |||||
TYPE_CHOICES = ( | |||||
('pers', _('personal')), | |||||
('prof', _('professional')), | |||||
('asso', _('association')), | |||||
) | |||||
GENRE_CHOICES = ( | |||||
('m', _('Male')), | |||||
('f', _('Female')) | |||||
) | |||||
SEX_CHOICES = ( | |||||
(0, _('exclusively heterosexual')), | |||||
(1, _('Heterosexual predominance')), | |||||
(2, _('Predominantly heterosexual, occasionally homosexual')), | |||||
(3, _('Bisexual without preference')), | |||||
(4, _('Predominantly homosexual, occasionally heterosexual')), | |||||
(5, _('Homosexual predominance')), | |||||
(6, _('exclusively homosexual')), | |||||
) | |||||
class Profile(models.Model): | |||||
user = models.OneToOneField(User, on_delete=models.CASCADE) | |||||
first_name = models.CharField( max_length=50, blank=True) | |||||
last_name = models.CharField( max_length=50, blank=True) | |||||
gender = models.CharField(choices=GENRE_CHOICES, max_length=1, default='m') | |||||
birthdate = models.DateField(default=date.today()) | |||||
companyname = models.CharField(max_length=200, blank=True) | |||||
bio = models.TextField(default='no bio ...', max_length=300, blank=True) | |||||
avatar = models.OneToOneField( | |||||
"Image", | |||||
null=True, | |||||
blank=True, | |||||
on_delete=models.CASCADE) | |||||
#avatar = models.ImageField(default='avatar.png', upload_to='avatars/', blank=True) | |||||
country = models.CharField( max_length=50, blank=True) | |||||
#friends = models.ManyToManyField(User, default=None, blank=True, related_name='friends') | |||||
#slug = models.SlugField(unique=True, blank=True) | |||||
updated = models.DateTimeField(auto_now=True) | |||||
created = models.DateTimeField(auto_now_add=True) | |||||
type = models.CharField(max_length=4, choices=TYPE_CHOICES) | |||||
tel = models.CharField(max_length=50, blank=True) | |||||
sex = models.IntegerField(choices=SEX_CHOICES, blank=True, null=True) | |||||
activated = models.BooleanField(default=False) | |||||
defaddr = models.ForeignKey('Address', blank=True, null=True, on_delete=models.SET_NULL) | |||||
def __str__(self): | |||||
return f'{self.user.username}' | |||||
def short_bio(self): | |||||
return truncatechars(self.bio, 50) | |||||
class Address(models.Model): | |||||
title = models.CharField(max_length=100) | |||||
street1 = models.CharField(max_length=50) | |||||
street2 = models.CharField(max_length=50, blank=True) | |||||
postalcode = models.CharField(max_length=10) | |||||
city = models.CharField(max_length=100) | |||||
state = models.CharField(max_length=50) | |||||
country = models.CharField(max_length=50) | |||||
owner = models.ForeignKey(User, on_delete=models.CASCADE, blank=True) | |||||
def __str__(self): | |||||
return f'{self.title}' | |||||
class Image(models.Model): | |||||
photo = models.ImageField(default='avatar.png', upload_to='avatars/') | |||||
owner = models.ForeignKey(User, on_delete=models.CASCADE) | |||||
description = models.CharField(blank=True, max_length=100) | |||||
def __str__(self): | |||||
return str(self.description) | |||||
#avatar = models.OneToOneField("Image", on_delete=models.CASCADE) | |||||
@ -0,0 +1,3 @@ | |||||
from django.test import TestCase | |||||
# Create your tests here. |
@ -0,0 +1,3 @@ | |||||
from django.shortcuts import render | |||||
# Create your views here. |
@ -0,0 +1,12 @@ | |||||
Vagrant --> Commande Virtualbox pour lancer une vm | |||||
#Initialize a vagrant file (Create a template Vagrantfile) | |||||
vagrant init | |||||
# Démarrage de la vm en lisant le Vagrantfile | |||||
vagrant up | |||||
# Demarrer une session sur la VM | |||||
vagrant ssh | |||||
@ -0,0 +1,27 @@ | |||||
version: '3' | |||||
services: | |||||
db: | |||||
image: postgres | |||||
restart: always | |||||
volumes: | |||||
- ./pgdata:/var/lib/postgresql/data | |||||
environment: | |||||
POSTGRES_PASSWORD: c1secret2qbc | |||||
POSTGRES_DB: weontheme | |||||
ports: | |||||
- 5432:5432 | |||||
django: | |||||
build: ./docker_django | |||||
restart: always | |||||
volumes: | |||||
- /vagrant:/etc/project | |||||
ports: | |||||
- 80:8000 | |||||
depends_on: | |||||
- db | |||||
command: > | |||||
sh -c "python manage.py runserver 0.0.0.0:8000" | |||||
@ -0,0 +1,21 @@ | |||||
FROM python:3 | |||||
ENV PYTHONUNBUFFERED=1 | |||||
#WORKDIR /usr/src/app | |||||
#COPY requirements.txt ./ | |||||
#RUN pip install --no-cache-dir -r requirements.txt | |||||
#RUN pip install django djangorestframework psycopg2 | |||||
RUN mkdir /etc/project | |||||
#VOLUME [ "/vagrant","/etc/project" ] | |||||
WORKDIR /etc/project | |||||
COPY requirements.txt . | |||||
RUN pip install --upgrade pip | |||||
RUN pip install -r requirements.txt | |||||
#$ docker build -t my-python-app . | |||||
#$ docker run -it --rm --name my-running-app my-python-app |
@ -0,0 +1,7 @@ | |||||
asgiref==3.4.1 | |||||
Django==3.2.8 | |||||
djangorestframework==3.12.4 | |||||
Pillow==8.4.0 | |||||
psycopg2==2.9.1 | |||||
pytz==2021.3 | |||||
sqlparse==0.4.2 |
@ -0,0 +1,22 @@ | |||||
#!/usr/bin/env python | |||||
"""Django's command-line utility for administrative tasks.""" | |||||
import os | |||||
import sys | |||||
def main(): | |||||
"""Run administrative tasks.""" | |||||
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project1.settings') | |||||
try: | |||||
from django.core.management import execute_from_command_line | |||||
except ImportError as exc: | |||||
raise ImportError( | |||||
"Couldn't import Django. Are you sure it's installed and " | |||||
"available on your PYTHONPATH environment variable? Did you " | |||||
"forget to activate a virtual environment?" | |||||
) from exc | |||||
execute_from_command_line(sys.argv) | |||||
if __name__ == '__main__': | |||||
main() |
@ -0,0 +1,16 @@ | |||||
""" | |||||
ASGI config for project1 project. | |||||
It exposes the ASGI callable as a module-level variable named ``application``. | |||||
For more information on this file, see | |||||
https://docs.djangoproject.com/en/3.2/howto/deployment/asgi/ | |||||
""" | |||||
import os | |||||
from django.core.asgi import get_asgi_application | |||||
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project1.settings') | |||||
application = get_asgi_application() |
@ -0,0 +1,130 @@ | |||||
""" | |||||
Django settings for project1 project. | |||||
Generated by 'django-admin startproject' using Django 3.2.8. | |||||
For more information on this file, see | |||||
https://docs.djangoproject.com/en/3.2/topics/settings/ | |||||
For the full list of settings and their values, see | |||||
https://docs.djangoproject.com/en/3.2/ref/settings/ | |||||
""" | |||||
from pathlib import Path | |||||
# Build paths inside the project like this: BASE_DIR / 'subdir'. | |||||
BASE_DIR = Path(__file__).resolve().parent.parent | |||||
# Quick-start development settings - unsuitable for production | |||||
# See https://docs.djangoproject.com/en/3.2/howto/deployment/checklist/ | |||||
# SECURITY WARNING: keep the secret key used in production secret! | |||||
SECRET_KEY = 'django-insecure-^+_nr8efle)m_bv=c$b9d3p3e_tn32%tirtnwlu6(w0$t)o@w_' | |||||
# SECURITY WARNING: don't run with debug turned on in production! | |||||
DEBUG = True | |||||
ALLOWED_HOSTS = [] | |||||
# Application definition | |||||
INSTALLED_APPS = [ | |||||
'django.contrib.admin', | |||||
'django.contrib.auth', | |||||
'django.contrib.contenttypes', | |||||
'django.contrib.sessions', | |||||
'django.contrib.messages', | |||||
'django.contrib.staticfiles', | |||||
'app1', | |||||
] | |||||
MIDDLEWARE = [ | |||||
'django.middleware.security.SecurityMiddleware', | |||||
'django.contrib.sessions.middleware.SessionMiddleware', | |||||
'django.middleware.common.CommonMiddleware', | |||||
'django.middleware.csrf.CsrfViewMiddleware', | |||||
'django.contrib.auth.middleware.AuthenticationMiddleware', | |||||
'django.contrib.messages.middleware.MessageMiddleware', | |||||
'django.middleware.clickjacking.XFrameOptionsMiddleware', | |||||
] | |||||
ROOT_URLCONF = 'project1.urls' | |||||
TEMPLATES = [ | |||||
{ | |||||
'BACKEND': 'django.template.backends.django.DjangoTemplates', | |||||
'DIRS': [], | |||||
'APP_DIRS': True, | |||||
'OPTIONS': { | |||||
'context_processors': [ | |||||
'django.template.context_processors.debug', | |||||
'django.template.context_processors.request', | |||||
'django.contrib.auth.context_processors.auth', | |||||
'django.contrib.messages.context_processors.messages', | |||||
], | |||||
}, | |||||
}, | |||||
] | |||||
WSGI_APPLICATION = 'project1.wsgi.application' | |||||
# Database | |||||
# https://docs.djangoproject.com/en/3.2/ref/settings/#databases | |||||
DATABASES = { | |||||
'default': { | |||||
'ENGINE': 'django.db.backends.postgresql', | |||||
'USER': 'postgres', | |||||
'PASSWORD': 'c1secret2qbc', | |||||
'NAME': 'weontheme', | |||||
'HOST': 'db', | |||||
'PORT': 5432, | |||||
} | |||||
} | |||||
# Password validation | |||||
# https://docs.djangoproject.com/en/3.2/ref/settings/#auth-password-validators | |||||
AUTH_PASSWORD_VALIDATORS = [ | |||||
{ | |||||
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', | |||||
}, | |||||
{ | |||||
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', | |||||
}, | |||||
{ | |||||
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', | |||||
}, | |||||
{ | |||||
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', | |||||
}, | |||||
] | |||||
# Internationalization | |||||
# https://docs.djangoproject.com/en/3.2/topics/i18n/ | |||||
LANGUAGE_CODE = 'en-us' | |||||
TIME_ZONE = 'UTC' | |||||
USE_I18N = True | |||||
USE_L10N = True | |||||
USE_TZ = True | |||||
# Static files (CSS, JavaScript, Images) | |||||
# https://docs.djangoproject.com/en/3.2/howto/static-files/ | |||||
STATIC_URL = '/static/' | |||||
# Default primary key field type | |||||
# https://docs.djangoproject.com/en/3.2/ref/settings/#default-auto-field | |||||
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' |
@ -0,0 +1,21 @@ | |||||
"""project1 URL Configuration | |||||
The `urlpatterns` list routes URLs to views. For more information please see: | |||||
https://docs.djangoproject.com/en/3.2/topics/http/urls/ | |||||
Examples: | |||||
Function views | |||||
1. Add an import: from my_app import views | |||||
2. Add a URL to urlpatterns: path('', views.home, name='home') | |||||
Class-based views | |||||
1. Add an import: from other_app.views import Home | |||||
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home') | |||||
Including another URLconf | |||||
1. Import the include() function: from django.urls import include, path | |||||
2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) | |||||
""" | |||||
from django.contrib import admin | |||||
from django.urls import path | |||||
urlpatterns = [ | |||||
path('admin/', admin.site.urls), | |||||
] |
@ -0,0 +1,16 @@ | |||||
""" | |||||
WSGI config for project1 project. | |||||
It exposes the WSGI callable as a module-level variable named ``application``. | |||||
For more information on this file, see | |||||
https://docs.djangoproject.com/en/3.2/howto/deployment/wsgi/ | |||||
""" | |||||
import os | |||||
from django.core.wsgi import get_wsgi_application | |||||
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project1.settings') | |||||
application = get_wsgi_application() |
Powered by TurnKey Linux.