upload files
|
@ -2,10 +2,12 @@ from django.contrib import admin
|
||||||
|
|
||||||
from core.models.customer import Customer
|
from core.models.customer import Customer
|
||||||
from core.models.role import Role
|
from core.models.role import Role
|
||||||
|
from core.models.image import Image
|
||||||
# from .model import user
|
# from .model import user
|
||||||
from core.models.AssignedRule import AssignedRule
|
from core.models.AssignedRule import AssignedRule
|
||||||
|
|
||||||
|
|
||||||
|
admin.site.register(Image)
|
||||||
admin.site.register(Role)
|
admin.site.register(Role)
|
||||||
admin.site.register(AssignedRule)
|
admin.site.register(AssignedRule)
|
||||||
admin.site.register(Customer)
|
admin.site.register(Customer)
|
||||||
|
|
31
core/migrations/0004_remove_customer_name_image.py
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
# Generated by Django 5.0 on 2025-04-19 10:02
|
||||||
|
|
||||||
|
import django.db.models.deletion
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('core', '0003_customer_name'),
|
||||||
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='customer',
|
||||||
|
name='name',
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Image',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('url', models.URLField(blank=True, max_length=250)),
|
||||||
|
('image', models.ImageField(blank=True, null=True, upload_to='user_images/')),
|
||||||
|
('name', models.CharField(max_length=100)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
]
|
49
core/migrations/0005_glb_pdf_video.py
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
# Generated by Django 5.0 on 2025-04-19 11:42
|
||||||
|
|
||||||
|
import django.db.models.deletion
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('core', '0004_remove_customer_name_image'),
|
||||||
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Glb',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('url', models.URLField(blank=True, max_length=250)),
|
||||||
|
('glb', models.ImageField(blank=True, null=True, upload_to='user_glbs/')),
|
||||||
|
('name', models.CharField(max_length=100)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Pdf',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('url', models.URLField(blank=True, max_length=250)),
|
||||||
|
('pdf', models.ImageField(blank=True, null=True, upload_to='user_pdfs/')),
|
||||||
|
('name', models.CharField(max_length=100)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Video',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('url', models.URLField(blank=True, max_length=250)),
|
||||||
|
('video', models.ImageField(blank=True, null=True, upload_to='user_videos/')),
|
||||||
|
('name', models.CharField(max_length=100)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
]
|
12
core/models/glb.py
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
from django.db import models
|
||||||
|
from django.conf import settings
|
||||||
|
|
||||||
|
class Glb(models.Model):
|
||||||
|
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
|
||||||
|
url = models.URLField(max_length=250, blank=True) # For storing external URLs
|
||||||
|
glb = models.ImageField(upload_to='user_glbs/', blank=True, null=True) # For file uploads
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
created_at = models.DateTimeField(auto_now_add=True)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return f"{self.name} - {self.user.username}"
|
12
core/models/image.py
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
from django.db import models
|
||||||
|
from django.conf import settings
|
||||||
|
|
||||||
|
class Image(models.Model):
|
||||||
|
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
|
||||||
|
url = models.URLField(max_length=250, blank=True) # For storing external URLs
|
||||||
|
image = models.ImageField(upload_to='user_images/', blank=True, null=True) # For file uploads
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
created_at = models.DateTimeField(auto_now_add=True)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return f"{self.name} - {self.user.username}"
|
12
core/models/pdf.py
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
from django.db import models
|
||||||
|
from django.conf import settings
|
||||||
|
|
||||||
|
class Pdf(models.Model):
|
||||||
|
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
|
||||||
|
url = models.URLField(max_length=250, blank=True) # For storing external URLs
|
||||||
|
pdf = models.ImageField(upload_to='user_pdfs/', blank=True, null=True) # For file uploads
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
created_at = models.DateTimeField(auto_now_add=True)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return f"{self.name} - {self.user.username}"
|
12
core/models/video.py
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
from django.db import models
|
||||||
|
from django.conf import settings
|
||||||
|
|
||||||
|
class Video(models.Model):
|
||||||
|
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
|
||||||
|
url = models.URLField(max_length=250, blank=True) # For storing external URLs
|
||||||
|
video = models.ImageField(upload_to='user_videos/', blank=True, null=True) # For file uploads
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
created_at = models.DateTimeField(auto_now_add=True)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return f"{self.name} - {self.user.username}"
|
33
core/serializers/GlbSerializer.py
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
from rest_framework import serializers
|
||||||
|
from ..models.glb import Glb
|
||||||
|
from ..models.customer import Customer
|
||||||
|
|
||||||
|
from rest_framework.exceptions import ValidationError
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
class GlbSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = Glb
|
||||||
|
fields = ['id', 'url', 'glb', 'name', 'created_at']
|
||||||
|
read_only_fields = ['id', 'created_at', 'user']
|
||||||
|
|
||||||
|
def validate(self, data):
|
||||||
|
# Safely get the request from context
|
||||||
|
request = self.context.get('request')
|
||||||
|
if not request:
|
||||||
|
raise serializers.ValidationError("Request context not provided")
|
||||||
|
|
||||||
|
# Check file size if image is provided
|
||||||
|
if 'glb' in request.FILES:
|
||||||
|
glb = request.FILES['glb']
|
||||||
|
if glb.size > 50 * 1024 * 1024: # 50MB limit
|
||||||
|
raise serializers.ValidationError("Glb file too large ( > 50MB )")
|
||||||
|
|
||||||
|
# Check file extension
|
||||||
|
ext = os.path.splitext(Glb.name)[1].lower()
|
||||||
|
valid_extensions = ['.glb']
|
||||||
|
if ext not in valid_extensions:
|
||||||
|
raise serializers.ValidationError(f"Unsupported file extension. Supported: {', '.join(valid_extensions)}")
|
||||||
|
|
||||||
|
return data
|
33
core/serializers/ImageSerializer.py
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
from rest_framework import serializers
|
||||||
|
from ..models.image import Image
|
||||||
|
from ..models.customer import Customer
|
||||||
|
|
||||||
|
from rest_framework.exceptions import ValidationError
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
class ImageSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = Image
|
||||||
|
fields = ['id', 'url', 'image', 'name', 'created_at']
|
||||||
|
read_only_fields = ['id', 'created_at', 'user']
|
||||||
|
|
||||||
|
def validate(self, data):
|
||||||
|
# Safely get the request from context
|
||||||
|
request = self.context.get('request')
|
||||||
|
if not request:
|
||||||
|
raise serializers.ValidationError("Request context not provided")
|
||||||
|
|
||||||
|
# Check file size if image is provided
|
||||||
|
if 'image' in request.FILES:
|
||||||
|
image = request.FILES['image']
|
||||||
|
if image.size > 5 * 1024 * 1024: # 5MB limit
|
||||||
|
raise serializers.ValidationError("Image file too large ( > 5MB )")
|
||||||
|
|
||||||
|
# Check file extension
|
||||||
|
ext = os.path.splitext(image.name)[1].lower()
|
||||||
|
valid_extensions = ['.jpg', '.jpeg', '.png', '.gif']
|
||||||
|
if ext not in valid_extensions:
|
||||||
|
raise serializers.ValidationError(f"Unsupported file extension. Supported: {', '.join(valid_extensions)}")
|
||||||
|
|
||||||
|
return data
|
33
core/serializers/PdfSerializer.py
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
from rest_framework import serializers
|
||||||
|
from ..models.pdf import Pdf
|
||||||
|
from ..models.customer import Customer
|
||||||
|
|
||||||
|
from rest_framework.exceptions import ValidationError
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
class PdfSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = Pdf
|
||||||
|
fields = ['id', 'url', 'pdf', 'name', 'created_at']
|
||||||
|
read_only_fields = ['id', 'created_at', 'user']
|
||||||
|
|
||||||
|
def validate(self, data):
|
||||||
|
# Safely get the request from context
|
||||||
|
request = self.context.get('request')
|
||||||
|
if not request:
|
||||||
|
raise serializers.ValidationError("Request context not provided")
|
||||||
|
|
||||||
|
# Check file size if image is provided
|
||||||
|
if 'pdf' in request.FILES:
|
||||||
|
pdf = request.FILES['pdf']
|
||||||
|
if pdf.size > 50 * 1024 * 1024: # 50MB limit
|
||||||
|
raise serializers.ValidationError("Pdf file too large ( > 50MB )")
|
||||||
|
|
||||||
|
# Check file extension
|
||||||
|
ext = os.path.splitext(Pdf.name)[1].lower()
|
||||||
|
valid_extensions = ['.pdf']
|
||||||
|
if ext not in valid_extensions:
|
||||||
|
raise serializers.ValidationError(f"Unsupported file extension. Supported: {', '.join(valid_extensions)}")
|
||||||
|
|
||||||
|
return data
|
33
core/serializers/VideoSerializer.py
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
from rest_framework import serializers
|
||||||
|
from ..models.video import Video
|
||||||
|
from ..models.customer import Customer
|
||||||
|
|
||||||
|
from rest_framework.exceptions import ValidationError
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
class VideoSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = Video
|
||||||
|
fields = ['id', 'url', 'video', 'name', 'created_at']
|
||||||
|
read_only_fields = ['id', 'created_at', 'user']
|
||||||
|
|
||||||
|
def validate(self, data):
|
||||||
|
# Safely get the request from context
|
||||||
|
request = self.context.get('request')
|
||||||
|
if not request:
|
||||||
|
raise serializers.ValidationError("Request context not provided")
|
||||||
|
|
||||||
|
# Check file size if image is provided
|
||||||
|
if 'video' in request.FILES:
|
||||||
|
video = request.FILES['video']
|
||||||
|
if video.size > 500 * 1024 * 1024: # 500MB limit
|
||||||
|
raise serializers.ValidationError("Video file too large ( > 500MB )")
|
||||||
|
|
||||||
|
# Check file extension
|
||||||
|
ext = os.path.splitext(Video.name)[1].lower()
|
||||||
|
valid_extensions = ['.mp4']
|
||||||
|
if ext not in valid_extensions:
|
||||||
|
raise serializers.ValidationError(f"Unsupported file extension. Supported: {', '.join(valid_extensions)}")
|
||||||
|
|
||||||
|
return data
|
|
@ -159,3 +159,6 @@ EMAIL_HOST_USER = 'mail@clinet.club'
|
||||||
EMAIL_HOST_PASSWORD = 'uzudzsd78786d7asd56gasdbsad'
|
EMAIL_HOST_PASSWORD = 'uzudzsd78786d7asd56gasdbsad'
|
||||||
DEFAULT_FROM_EMAIL = 'mail@clinet.club'
|
DEFAULT_FROM_EMAIL = 'mail@clinet.club'
|
||||||
|
|
||||||
|
# Add these to your settings
|
||||||
|
MEDIA_URL = '/media/'
|
||||||
|
MEDIA_ROOT = os.path.join(BASE_DIR, 'media/')
|
13
core/urls.py
|
@ -4,6 +4,9 @@ from django.urls import path
|
||||||
|
|
||||||
from .views import userView
|
from .views import userView
|
||||||
from django.urls import include, path
|
from django.urls import include, path
|
||||||
|
from django.conf import settings
|
||||||
|
from django.conf.urls.static import static
|
||||||
|
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
|
|
||||||
|
@ -27,5 +30,13 @@ urlpatterns = [
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
re_path('uploadImage/', userView.upload_image , name='upload_image'),
|
||||||
|
re_path('uploadGlb/', userView.upload_glb , name='upload_glb'),
|
||||||
|
re_path('uploadVideo/', userView.upload_video , name='upload_video'),
|
||||||
|
re_path('uploadPdf/', userView.upload_pdf , name='upload_pdf'),
|
||||||
|
|
||||||
|
|
||||||
|
]+ static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
]
|
|
||||||
|
|
|
@ -16,9 +16,17 @@ from django.contrib.auth.models import User
|
||||||
from core.models.customer import Customer
|
from core.models.customer import Customer
|
||||||
from core.serializers.UserSerializer import UserSerializer
|
from core.serializers.UserSerializer import UserSerializer
|
||||||
from core.serializers.CustomerSerializer import CustomerSerializer
|
from core.serializers.CustomerSerializer import CustomerSerializer
|
||||||
|
from core.serializers.ImageSerializer import ImageSerializer
|
||||||
|
from core.serializers.GlbSerializer import GlbSerializer
|
||||||
|
from core.serializers.VideoSerializer import VideoSerializer
|
||||||
|
from core.serializers.PdfSerializer import PdfSerializer
|
||||||
|
|
||||||
# utils.py
|
# utils.py
|
||||||
from core.models.AssignedRule import AssignedRule
|
from core.models.AssignedRule import AssignedRule
|
||||||
|
from core.models.image import Image
|
||||||
|
from core.models.video import Video
|
||||||
|
from core.models.pdf import Pdf
|
||||||
|
from core.models.glb import Glb
|
||||||
|
|
||||||
|
|
||||||
from django.core.mail import EmailMultiAlternatives
|
from django.core.mail import EmailMultiAlternatives
|
||||||
|
@ -28,9 +36,16 @@ from django.conf import settings
|
||||||
from django.utils.dateparse import parse_date
|
from django.utils.dateparse import parse_date
|
||||||
|
|
||||||
|
|
||||||
|
from datetime import datetime
|
||||||
|
from django.core.files.storage import default_storage
|
||||||
|
import os
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
import json
|
import json
|
||||||
|
import logging
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
def send_sms(to_number, code):
|
def send_sms(to_number, code):
|
||||||
username = "09399112092"
|
username = "09399112092"
|
||||||
|
@ -206,6 +221,7 @@ def sendSmsVerification(request):
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@api_view(['GET'])
|
@api_view(['GET'])
|
||||||
@authentication_classes([SessionAuthentication, TokenAuthentication])
|
@authentication_classes([SessionAuthentication, TokenAuthentication])
|
||||||
@permission_classes([IsAuthenticated])
|
@permission_classes([IsAuthenticated])
|
||||||
|
@ -218,10 +234,20 @@ def getInfo(request):
|
||||||
# Retrieve the associated customer object
|
# Retrieve the associated customer object
|
||||||
customer = Customer.objects.get(user=user)
|
customer = Customer.objects.get(user=user)
|
||||||
|
|
||||||
|
# Get all images uploaded by this user
|
||||||
|
user_images = Image.objects.filter(user=user).order_by('-created_at')
|
||||||
|
user_pdfs = Pdf.objects.filter(user=user).order_by('-created_at')
|
||||||
|
user_videos = Video.objects.filter(user=user).order_by('-created_at')
|
||||||
|
user_glb = Glb.objects.filter(user=user).order_by('-created_at')
|
||||||
|
|
||||||
|
image_serializer = ImageSerializer(user_images, many=True)
|
||||||
|
pdf_serializer = PdfSerializer(user_pdfs, many=True)
|
||||||
|
Video_serializer = VideoSerializer(user_videos, many=True)
|
||||||
|
glb_serializer = GlbSerializer(user_glb, many=True)
|
||||||
|
|
||||||
# Serialize the customer data
|
# Serialize the customer data
|
||||||
customer_serializer = CustomerSerializer(customer)
|
customer_serializer = CustomerSerializer(customer)
|
||||||
|
|
||||||
|
|
||||||
# Manually select user fields to return
|
# Manually select user fields to return
|
||||||
user_data = {
|
user_data = {
|
||||||
'id': user.id,
|
'id': user.id,
|
||||||
|
@ -232,14 +258,19 @@ def getInfo(request):
|
||||||
|
|
||||||
return Response({
|
return Response({
|
||||||
'customer': customer_serializer.data,
|
'customer': customer_serializer.data,
|
||||||
'user': user_data
|
'user': user_data,
|
||||||
|
'images': image_serializer.data , # Add images to response
|
||||||
|
'pdfs': pdf_serializer.data , # Add images to response
|
||||||
|
'videos': Video_serializer.data ,# Add images to response
|
||||||
|
'glbs': glb_serializer.data , # Add images to response
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
except Customer.DoesNotExist:
|
except Customer.DoesNotExist:
|
||||||
|
# If no customer object exists for the user, return an error response
|
||||||
return Response({'error': 'No customer data found for this user'}, status=404)
|
return Response({'error': 'No customer data found for this user'}, status=404)
|
||||||
|
|
||||||
# If no customer object exists for the user, return an error response
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -367,3 +398,185 @@ def test_token(request):
|
||||||
return Response({'message': 'No access'}, status=status.HTTP_403_FORBIDDEN)
|
return Response({'message': 'No access'}, status=status.HTTP_403_FORBIDDEN)
|
||||||
|
|
||||||
return Response({'message': 'User has admin role'})
|
return Response({'message': 'User has admin role'})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@api_view(['POST'])
|
||||||
|
@authentication_classes([SessionAuthentication, TokenAuthentication])
|
||||||
|
@permission_classes([IsAuthenticated])
|
||||||
|
def upload_image(request):
|
||||||
|
user = request.user
|
||||||
|
|
||||||
|
try:
|
||||||
|
customer = Customer.objects.get(user=user)
|
||||||
|
except Customer.DoesNotExist:
|
||||||
|
return Response(
|
||||||
|
{'error': 'No customer profile found.'},
|
||||||
|
status=status.HTTP_403_FORBIDDEN
|
||||||
|
)
|
||||||
|
|
||||||
|
if not request.FILES.get('image'):
|
||||||
|
return Response(
|
||||||
|
{'error': 'No image file provided.'},
|
||||||
|
status=status.HTTP_400_BAD_REQUEST
|
||||||
|
)
|
||||||
|
|
||||||
|
uploaded_file = request.FILES['image']
|
||||||
|
|
||||||
|
# Generate the new path: "2025/1/23/filename.jpg"
|
||||||
|
today = datetime.now()
|
||||||
|
year = str(today.year)
|
||||||
|
month = str(today.month)
|
||||||
|
day = str(today.day)
|
||||||
|
|
||||||
|
# New path format: "2025/1/23/original_filename.jpg"
|
||||||
|
new_path = os.path.join(year, month, day, uploaded_file.name)
|
||||||
|
|
||||||
|
# Save the file manually to the desired directory
|
||||||
|
saved_path = default_storage.save(new_path, uploaded_file)
|
||||||
|
|
||||||
|
# Now create the Image record with the new path
|
||||||
|
image = Image.objects.create(
|
||||||
|
user=user,
|
||||||
|
image=saved_path, # This will be "2025/1/23/filename.jpg"
|
||||||
|
name=request.data.get('name', uploaded_file.name),
|
||||||
|
)
|
||||||
|
|
||||||
|
serializer = ImageSerializer(image)
|
||||||
|
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@api_view(['POST'])
|
||||||
|
@authentication_classes([SessionAuthentication, TokenAuthentication])
|
||||||
|
@permission_classes([IsAuthenticated])
|
||||||
|
def upload_glb(request):
|
||||||
|
user = request.user
|
||||||
|
|
||||||
|
try:
|
||||||
|
customer = Customer.objects.get(user=user)
|
||||||
|
except Customer.DoesNotExist:
|
||||||
|
return Response(
|
||||||
|
{'error': 'No customer profile found.'},
|
||||||
|
status=status.HTTP_403_FORBIDDEN
|
||||||
|
)
|
||||||
|
|
||||||
|
if not request.FILES.get('glb'):
|
||||||
|
return Response(
|
||||||
|
{'error': 'No glb file provided.'},
|
||||||
|
status=status.HTTP_400_BAD_REQUEST
|
||||||
|
)
|
||||||
|
|
||||||
|
uploaded_file = request.FILES['glb']
|
||||||
|
|
||||||
|
# Generate the new path: "2025/1/23/filename.jpg"
|
||||||
|
today = datetime.now()
|
||||||
|
year = str(today.year)
|
||||||
|
month = str(today.month)
|
||||||
|
day = str(today.day)
|
||||||
|
|
||||||
|
# New path format: "2025/1/23/original_filename.jpg"
|
||||||
|
new_path = os.path.join(year, month, day, uploaded_file.name)
|
||||||
|
|
||||||
|
# Save the file manually to the desired directory
|
||||||
|
saved_path = default_storage.save(new_path, uploaded_file)
|
||||||
|
|
||||||
|
glb = Glb.objects.create(
|
||||||
|
user=user,
|
||||||
|
glb=saved_path, # This will be "2025/1/23/filename.jpg"
|
||||||
|
name=request.data.get('name', uploaded_file.name),
|
||||||
|
)
|
||||||
|
|
||||||
|
serializer = GlbSerializer(glb)
|
||||||
|
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
||||||
|
|
||||||
|
|
||||||
|
@api_view(['POST'])
|
||||||
|
@authentication_classes([SessionAuthentication, TokenAuthentication])
|
||||||
|
@permission_classes([IsAuthenticated])
|
||||||
|
def upload_video(request):
|
||||||
|
user = request.user
|
||||||
|
|
||||||
|
try:
|
||||||
|
customer = Customer.objects.get(user=user)
|
||||||
|
except Customer.DoesNotExist:
|
||||||
|
return Response(
|
||||||
|
{'error': 'No customer profile found.'},
|
||||||
|
status=status.HTTP_403_FORBIDDEN
|
||||||
|
)
|
||||||
|
|
||||||
|
if not request.FILES.get('video'):
|
||||||
|
return Response(
|
||||||
|
{'error': 'No video file provided.'},
|
||||||
|
status=status.HTTP_400_BAD_REQUEST
|
||||||
|
)
|
||||||
|
|
||||||
|
uploaded_file = request.FILES['video']
|
||||||
|
|
||||||
|
# Generate the new path: "2025/1/23/filename.jpg"
|
||||||
|
today = datetime.now()
|
||||||
|
year = str(today.year)
|
||||||
|
month = str(today.month)
|
||||||
|
day = str(today.day)
|
||||||
|
|
||||||
|
# New path format: "2025/1/23/original_filename.jpg"
|
||||||
|
new_path = os.path.join(year, month, day, uploaded_file.name)
|
||||||
|
|
||||||
|
# Save the file manually to the desired directory
|
||||||
|
saved_path = default_storage.save(new_path, uploaded_file)
|
||||||
|
|
||||||
|
video = Video.objects.create(
|
||||||
|
user=user,
|
||||||
|
video=saved_path, # This will be "2025/1/23/filename.jpg"
|
||||||
|
name=request.data.get('name', uploaded_file.name),
|
||||||
|
)
|
||||||
|
|
||||||
|
serializer = VideoSerializer(video)
|
||||||
|
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
||||||
|
|
||||||
|
|
||||||
|
@api_view(['POST'])
|
||||||
|
@authentication_classes([SessionAuthentication, TokenAuthentication])
|
||||||
|
@permission_classes([IsAuthenticated])
|
||||||
|
def upload_pdf(request):
|
||||||
|
user = request.user
|
||||||
|
|
||||||
|
try:
|
||||||
|
customer = Customer.objects.get(user=user)
|
||||||
|
except Customer.DoesNotExist:
|
||||||
|
return Response(
|
||||||
|
{'error': 'No customer profile found.'},
|
||||||
|
status=status.HTTP_403_FORBIDDEN
|
||||||
|
)
|
||||||
|
|
||||||
|
if not request.FILES.get('pdf'):
|
||||||
|
return Response(
|
||||||
|
{'error': 'No pdf file provided.'},
|
||||||
|
status=status.HTTP_400_BAD_REQUEST
|
||||||
|
)
|
||||||
|
|
||||||
|
uploaded_file = request.FILES['pdf']
|
||||||
|
|
||||||
|
# Generate the new path: "2025/1/23/filename.jpg"
|
||||||
|
today = datetime.now()
|
||||||
|
year = str(today.year)
|
||||||
|
month = str(today.month)
|
||||||
|
day = str(today.day)
|
||||||
|
|
||||||
|
# New path format: "2025/1/23/original_filename.jpg"
|
||||||
|
new_path = os.path.join(year, month, day, uploaded_file.name)
|
||||||
|
|
||||||
|
# Save the file manually to the desired directory
|
||||||
|
saved_path = default_storage.save(new_path, uploaded_file)
|
||||||
|
|
||||||
|
pdf = Pdf.objects.create(
|
||||||
|
user=user,
|
||||||
|
pdf=saved_path, # This will be "2025/1/23/filename.jpg"
|
||||||
|
name=request.data.get('name', uploaded_file.name),
|
||||||
|
)
|
||||||
|
|
||||||
|
serializer = GlbSerializer(pdf)
|
||||||
|
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
BIN
media/2025/4/19/67fa74cbb2eab89e59274320.glb
Normal file
BIN
media/2025/4/19/67fa74cbb2eab89e59274320_NVEdyy7.glb
Normal file
BIN
media/2025/4/19/67fa74cbb2eab89e59274320_ShzoLiL.glb
Normal file
BIN
media/2025/4/19/67fa74cbb2eab89e59274320_byJZqEu.glb
Normal file
BIN
media/2025/4/19/DOC-20241221-WA0001..pdf
Normal file
BIN
media/2025/4/19/DOC-20241221-WA0001._tdfjOpb.pdf
Normal file
BIN
media/2025/4/19/VR game (6).jpg
Normal file
After Width: | Height: | Size: 2.5 MiB |
BIN
media/2025/4/19/image_2025-04-14_12-54-49.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
media/2025/4/19/image_2025-04-14_12-54-49_In8jmAF.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
media/2025/4/19/image_2025-04-14_12-54-49_MVcPo9K.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
media/2025/4/19/image_2025-04-14_12-54-49_yLzrQ15.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
media/user_images/image_2025-04-14_12-54-49.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
media/user_images/image_2025-04-14_12-54-49_0Bgxccn.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
media/user_images/image_2025-04-14_12-54-49_gHlLf0F.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
|
@ -10,7 +10,7 @@ Content-Type: application/json
|
||||||
POST http://127.0.0.1:8000/login
|
POST http://127.0.0.1:8000/login
|
||||||
Content-Type: application/json
|
Content-Type: application/json
|
||||||
|
|
||||||
{ "mobile_number":"09140086509", "password": "Pass1234!" }
|
{ "mobile_number":"09140086509", "password": "123456" }
|
||||||
|
|
||||||
###
|
###
|
||||||
|
|
||||||
|
|