Spaces:
Running
Running
sachin
commited on
Commit
·
d83c996
1
Parent(s):
d152ed5
add sarvam transalte
Browse files- accounts/__init__.py +0 -0
- accounts/admin.py +3 -0
- accounts/apps.py +6 -0
- accounts/migrations/__init__.py +0 -0
- accounts/models.py +3 -0
- accounts/tests.py +3 -0
- accounts/urls.py +6 -0
- accounts/views.py +3 -0
- inference/rag_process.py +99 -0
- inference/sarvam_inference.py +32 -0
- recipes/urls.py +2 -1
- recipes/views.py +110 -69
- requirements.txt +16 -1
- spaces/settings.py +20 -0
- spaces/urls.py +1 -0
accounts/__init__.py
ADDED
File without changes
|
accounts/admin.py
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
from django.contrib import admin
|
2 |
+
|
3 |
+
# Register your models here.
|
accounts/apps.py
ADDED
@@ -0,0 +1,6 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
from django.apps import AppConfig
|
2 |
+
|
3 |
+
|
4 |
+
class AccountsConfig(AppConfig):
|
5 |
+
default_auto_field = 'django.db.models.BigAutoField'
|
6 |
+
name = 'accounts'
|
accounts/migrations/__init__.py
ADDED
File without changes
|
accounts/models.py
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
from django.db import models
|
2 |
+
|
3 |
+
# Create your models here.
|
accounts/tests.py
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
from django.test import TestCase
|
2 |
+
|
3 |
+
# Create your tests here.
|
accounts/urls.py
ADDED
@@ -0,0 +1,6 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
from django.urls import path, include
|
2 |
+
|
3 |
+
urlpatterns = [
|
4 |
+
path('api/', include('djoser.urls')),
|
5 |
+
path('api/', include('djoser.urls.authtoken')),
|
6 |
+
]
|
accounts/views.py
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
from django.shortcuts import render
|
2 |
+
|
3 |
+
# Create your views here.
|
inference/rag_process.py
ADDED
@@ -0,0 +1,99 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
from mistralai import Mistral
|
2 |
+
import requests
|
3 |
+
import numpy as np
|
4 |
+
import faiss
|
5 |
+
import os
|
6 |
+
|
7 |
+
api_key=os.getenv("MISTRAL_API_KEY", "")
|
8 |
+
client = Mistral(api_key=api_key)
|
9 |
+
|
10 |
+
def get_data():
|
11 |
+
|
12 |
+
response = requests.get('https://raw.githubusercontent.com/run-llama/llama_index/main/docs/docs/examples/data/paul_graham/paul_graham_essay.txt')
|
13 |
+
text = response.text
|
14 |
+
|
15 |
+
f = open('essay.txt', 'w')
|
16 |
+
f.write(text)
|
17 |
+
f.close()
|
18 |
+
|
19 |
+
|
20 |
+
len(text)
|
21 |
+
return text
|
22 |
+
|
23 |
+
def create_chunks(text):
|
24 |
+
|
25 |
+
chunk_size = 2048
|
26 |
+
chunks = [text[i:i + chunk_size] for i in range(0, len(text), chunk_size)]
|
27 |
+
|
28 |
+
len(chunks)
|
29 |
+
return chunks
|
30 |
+
|
31 |
+
def get_text_embedding(input):
|
32 |
+
embeddings_batch_response = client.embeddings.create(
|
33 |
+
model="mistral-embed",
|
34 |
+
inputs=input
|
35 |
+
)
|
36 |
+
return embeddings_batch_response.data[0].embedding
|
37 |
+
|
38 |
+
|
39 |
+
def load_vectors(chunks):
|
40 |
+
text_embeddings = np.array([get_text_embedding(chunk) for chunk in chunks])
|
41 |
+
|
42 |
+
text_embeddings.shape
|
43 |
+
|
44 |
+
d = text_embeddings.shape[1]
|
45 |
+
index = faiss.IndexFlatL2(d)
|
46 |
+
index.add(text_embeddings)
|
47 |
+
return index
|
48 |
+
|
49 |
+
def create_embed_for_question(question):
|
50 |
+
|
51 |
+
question_embeddings = np.array([get_text_embedding(question)])
|
52 |
+
question_embeddings.shape
|
53 |
+
return question_embeddings
|
54 |
+
|
55 |
+
def get_similar_chunks(index, question_embeddings, chunks):
|
56 |
+
D, I = index.search(question_embeddings, k=2)
|
57 |
+
print(I)
|
58 |
+
retrieved_chunk = [chunks[i] for i in I.tolist()[0]]
|
59 |
+
print(retrieved_chunk)
|
60 |
+
return retrieved_chunk
|
61 |
+
|
62 |
+
def create_prompt(retrieved_chunk, question):
|
63 |
+
prompt = f"""
|
64 |
+
Context information is below.
|
65 |
+
---------------------
|
66 |
+
{retrieved_chunk}
|
67 |
+
---------------------
|
68 |
+
Given the context information and not prior knowledge, answer the query.
|
69 |
+
Query: {question}
|
70 |
+
Answer:
|
71 |
+
"""
|
72 |
+
return prompt
|
73 |
+
|
74 |
+
|
75 |
+
def run_mistral(user_message, model="mistral-large-latest"):
|
76 |
+
messages = [
|
77 |
+
{
|
78 |
+
"role": "user", "content": user_message
|
79 |
+
}
|
80 |
+
]
|
81 |
+
chat_response = client.chat.complete(
|
82 |
+
model=model,
|
83 |
+
messages=messages
|
84 |
+
)
|
85 |
+
return (chat_response.choices[0].message.content)
|
86 |
+
|
87 |
+
def main():
|
88 |
+
text = get_data()
|
89 |
+
chunks = create_chunks(text=text)
|
90 |
+
question = "What were the two main things the author worked on before college?"
|
91 |
+
|
92 |
+
index = load_vectors(chunks=chunks)
|
93 |
+
question_embeddings = create_embed_for_question(question=question)
|
94 |
+
retrieved_chunk = get_similar_chunks(index, question_embeddings, chunks)
|
95 |
+
prompt = create_prompt(retrieved_chunk, question)
|
96 |
+
answer = run_mistral(prompt)
|
97 |
+
print(answer)
|
98 |
+
|
99 |
+
main()
|
inference/sarvam_inference.py
ADDED
@@ -0,0 +1,32 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
|
2 |
+
import requests
|
3 |
+
import os
|
4 |
+
|
5 |
+
def translate_text(text_string, source_lang, target_lang):
|
6 |
+
|
7 |
+
api_key=os.getenv("SARVAM_API_KEY", "")
|
8 |
+
url = "https://api.sarvam.ai/translate"
|
9 |
+
payload = {
|
10 |
+
"input": text_string,
|
11 |
+
"source_language_code": source_lang,
|
12 |
+
"target_language_code": target_lang,
|
13 |
+
"speaker_gender": "Male",
|
14 |
+
"mode": "formal",
|
15 |
+
"model": "mayura:v1",
|
16 |
+
"enable_preprocessing": True
|
17 |
+
}
|
18 |
+
headers = {"Content-Type": "application/json",
|
19 |
+
'API-Subscription-Key': f"{api_key}"
|
20 |
+
}
|
21 |
+
|
22 |
+
response = requests.request("POST", url, json=payload, headers=headers)
|
23 |
+
|
24 |
+
#print(response.text)
|
25 |
+
return response.text
|
26 |
+
|
27 |
+
|
28 |
+
#text_string = "Who is the founder of Bengaluru?"
|
29 |
+
#source_lang = "en-IN"
|
30 |
+
#target_lang = "kn-IN"
|
31 |
+
#response_text = translate_text(text_string, source_lang, target_lang)
|
32 |
+
#print(response_text)
|
recipes/urls.py
CHANGED
@@ -1,10 +1,11 @@
|
|
1 |
from django.urls import path
|
2 |
from .views import recipe_generate_route
|
3 |
-
from .views import VisionLLMView, NIMVisionLLMView, TextLLMView
|
4 |
|
5 |
urlpatterns = [
|
6 |
path('recipe_generate/', recipe_generate_route, name='recipe_generate'),
|
7 |
path('vision_llm_url/', VisionLLMView.as_view()),
|
8 |
path('nim_vision_llm_url/', NIMVisionLLMView.as_view()),
|
9 |
path('text_llm_url/', TextLLMView.as_view()),
|
|
|
10 |
]
|
|
|
1 |
from django.urls import path
|
2 |
from .views import recipe_generate_route
|
3 |
+
from .views import VisionLLMView, NIMVisionLLMView, TextLLMView, TranslateLLMView
|
4 |
|
5 |
urlpatterns = [
|
6 |
path('recipe_generate/', recipe_generate_route, name='recipe_generate'),
|
7 |
path('vision_llm_url/', VisionLLMView.as_view()),
|
8 |
path('nim_vision_llm_url/', NIMVisionLLMView.as_view()),
|
9 |
path('text_llm_url/', TextLLMView.as_view()),
|
10 |
+
path('translate_llm_url/', TranslateLLMView.as_view()),
|
11 |
]
|
recipes/views.py
CHANGED
@@ -10,43 +10,80 @@ import base64
|
|
10 |
import json
|
11 |
import requests
|
12 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
13 |
|
14 |
class TextLLMView(APIView):
|
15 |
def post(self, request, format=None):
|
16 |
-
|
17 |
-
|
18 |
-
|
19 |
-
|
20 |
-
|
21 |
-
|
22 |
-
prompt = data['messages'][0]['prompt']
|
23 |
-
# Specify model
|
24 |
-
#model = "pixtral-12b-2409"
|
25 |
-
model = data['model']
|
26 |
-
# Define the messages for the chat
|
27 |
-
messages = [
|
28 |
-
{
|
29 |
-
"role": "user",
|
30 |
-
"content": [
|
31 |
-
{
|
32 |
-
"type": "text",
|
33 |
-
"text": prompt
|
34 |
-
}
|
35 |
-
]
|
36 |
-
}
|
37 |
-
]
|
38 |
|
39 |
-
|
40 |
-
|
41 |
-
model=
|
42 |
-
|
43 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
44 |
|
45 |
-
|
46 |
-
|
47 |
-
|
48 |
-
|
|
|
49 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
50 |
|
51 |
|
52 |
@api_view(['GET'])
|
@@ -69,44 +106,48 @@ def recipe_generate_route(request):
|
|
69 |
|
70 |
class VisionLLMView(APIView):
|
71 |
def post(self, request, format=None):
|
72 |
-
|
73 |
-
|
74 |
-
|
75 |
-
|
76 |
-
|
77 |
-
|
78 |
-
|
79 |
-
|
80 |
-
|
81 |
-
|
82 |
-
|
83 |
-
|
84 |
-
|
85 |
-
|
86 |
-
|
87 |
-
|
88 |
-
|
89 |
-
|
90 |
-
|
91 |
-
|
92 |
-
|
93 |
-
|
94 |
-
|
95 |
-
|
96 |
-
|
97 |
-
|
98 |
-
|
|
|
99 |
|
100 |
-
|
101 |
-
|
102 |
-
|
103 |
-
|
104 |
-
|
105 |
|
106 |
-
|
107 |
-
|
108 |
-
|
109 |
-
|
|
|
|
|
|
|
110 |
|
111 |
|
112 |
class NIMVisionLLMView(APIView):
|
@@ -155,5 +196,5 @@ class NIMVisionLLMView(APIView):
|
|
155 |
|
156 |
|
157 |
except Exception as e: # Added general exception handling
|
158 |
-
print(f"
|
159 |
-
|
|
|
10 |
import json
|
11 |
import requests
|
12 |
|
13 |
+
class TranslateLLMView(APIView):
|
14 |
+
def post(self, request, format=None):
|
15 |
+
try:
|
16 |
+
data = request.data
|
17 |
+
prompt = data['messages'][0]['prompt']
|
18 |
+
# Specify model
|
19 |
+
source_language = data['sourceLanguage']
|
20 |
+
target_language = data['targetLanguage']
|
21 |
+
#model = data['model']
|
22 |
+
# Define the messages for the chat
|
23 |
+
api_key=os.getenv("SARVAM_API_KEY", "")
|
24 |
+
url = "https://api.sarvam.ai/translate"
|
25 |
+
|
26 |
+
payload = {
|
27 |
+
"input": prompt,
|
28 |
+
"source_language_code": source_language,
|
29 |
+
"target_language_code": target_language,
|
30 |
+
"speaker_gender": "Male",
|
31 |
+
"mode": "formal",
|
32 |
+
"model": "mayura:v1",
|
33 |
+
"enable_preprocessing": True
|
34 |
+
}
|
35 |
+
headers = {"Content-Type": "application/json",
|
36 |
+
'API-Subscription-Key': f"{api_key}"
|
37 |
+
}
|
38 |
+
|
39 |
+
response = requests.request("POST", url, json=payload, headers=headers)
|
40 |
+
content = response.text
|
41 |
+
#print(chat_response.choices[0].message.content)
|
42 |
+
# Return the content of the response
|
43 |
+
return Response({"response": content})
|
44 |
+
except Exception as e:
|
45 |
+
print(f"An error occurred: {e}")
|
46 |
+
return Response({'error': 'Something went wrong'}, status=500)
|
47 |
|
48 |
class TextLLMView(APIView):
|
49 |
def post(self, request, format=None):
|
50 |
+
try:
|
51 |
+
data = request.data
|
52 |
+
api_key = os.environ["MISTRAL_API_KEY"]
|
53 |
+
|
54 |
+
# Initialize the Mistral client
|
55 |
+
client = Mistral(api_key=api_key)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
56 |
|
57 |
+
prompt = data['messages'][0]['prompt']
|
58 |
+
# Specify model
|
59 |
+
#model = "pixtral-12b-2409"
|
60 |
+
model = data['model']
|
61 |
+
# Define the messages for the chat
|
62 |
+
messages = [
|
63 |
+
{
|
64 |
+
"role": "user",
|
65 |
+
"content": [
|
66 |
+
{
|
67 |
+
"type": "text",
|
68 |
+
"text": prompt
|
69 |
+
}
|
70 |
+
]
|
71 |
+
}
|
72 |
+
]
|
73 |
|
74 |
+
# Get the chat response
|
75 |
+
chat_response = client.chat.complete(
|
76 |
+
model=model,
|
77 |
+
messages=messages
|
78 |
+
)
|
79 |
|
80 |
+
content = chat_response.choices[0].message.content
|
81 |
+
#print(chat_response.choices[0].message.content)
|
82 |
+
# Return the content of the response
|
83 |
+
return Response({"response": content})
|
84 |
+
except Exception as e:
|
85 |
+
print(f"An error occurred: {e}")
|
86 |
+
return Response({'error': 'Something went wrong'}, status=500)
|
87 |
|
88 |
|
89 |
@api_view(['GET'])
|
|
|
106 |
|
107 |
class VisionLLMView(APIView):
|
108 |
def post(self, request, format=None):
|
109 |
+
try:
|
110 |
+
data = request.data
|
111 |
+
api_key = os.environ["MISTRAL_API_KEY"]
|
112 |
+
|
113 |
+
# Initialize the Mistral client
|
114 |
+
client = Mistral(api_key=api_key)
|
115 |
+
|
116 |
+
image_data = (data['messages'][0]['image'][0])
|
117 |
+
prompt = data['messages'][0]['prompt']
|
118 |
+
# Specify model
|
119 |
+
#model = "pixtral-12b-2409"
|
120 |
+
model = data['model']
|
121 |
+
# Define the messages for the chat
|
122 |
+
messages = [
|
123 |
+
{
|
124 |
+
"role": "user",
|
125 |
+
"content": [
|
126 |
+
{
|
127 |
+
"type": "text",
|
128 |
+
"text": prompt
|
129 |
+
},
|
130 |
+
{
|
131 |
+
"type": "image_url",
|
132 |
+
"image_url": f"data:image/jpeg;base64,{image_data}"
|
133 |
+
}
|
134 |
+
]
|
135 |
+
}
|
136 |
+
]
|
137 |
|
138 |
+
# Get the chat response
|
139 |
+
chat_response = client.chat.complete(
|
140 |
+
model=model,
|
141 |
+
messages=messages
|
142 |
+
)
|
143 |
|
144 |
+
content = chat_response.choices[0].message.content
|
145 |
+
#print(chat_response.choices[0].message.content)
|
146 |
+
# Return the content of the response
|
147 |
+
return Response({"response": content})
|
148 |
+
except Exception as e:
|
149 |
+
print(f"An error occurred: {e}")
|
150 |
+
return Response({'error': 'Something went wrong'}, status=500)
|
151 |
|
152 |
|
153 |
class NIMVisionLLMView(APIView):
|
|
|
196 |
|
197 |
|
198 |
except Exception as e: # Added general exception handling
|
199 |
+
print(f"An error occurred: {e}")
|
200 |
+
return Response({'error': 'Something went wrong'}, status=500)
|
requirements.txt
CHANGED
@@ -2,35 +2,50 @@ annotated-types==0.7.0
|
|
2 |
anyio==4.5.0
|
3 |
asgiref==3.8.1
|
4 |
certifi==2024.8.30
|
|
|
5 |
charset-normalizer==3.3.2
|
6 |
click==8.1.7
|
|
|
|
|
7 |
Django==5.1.1
|
8 |
django-cors-headers==4.4.0
|
9 |
django-filter==24.3
|
|
|
10 |
django_csp==3.8
|
11 |
djangorestframework==3.15.2
|
|
|
|
|
12 |
drf-yasg==1.21.7
|
13 |
eval_type_backport==0.2.0
|
14 |
exceptiongroup==1.2.2
|
|
|
15 |
h11==0.14.0
|
16 |
httpcore==1.0.5
|
17 |
httpx==0.27.2
|
18 |
idna==3.10
|
19 |
inflection==0.5.1
|
20 |
jsonpath-python==1.0.6
|
|
|
21 |
mistralai==1.1.0
|
22 |
mypy-extensions==1.0.0
|
23 |
-
numpy==
|
|
|
24 |
packaging==24.1
|
25 |
pandas==2.2.3
|
|
|
26 |
pydantic==2.9.2
|
27 |
pydantic_core==2.23.4
|
|
|
28 |
python-dateutil==2.8.2
|
|
|
29 |
pytz==2024.2
|
30 |
PyYAML==6.0.2
|
31 |
requests==2.32.3
|
|
|
32 |
six==1.16.0
|
33 |
sniffio==1.3.1
|
|
|
|
|
34 |
sqlparse==0.5.1
|
35 |
typing-inspect==0.9.0
|
36 |
typing_extensions==4.12.2
|
|
|
2 |
anyio==4.5.0
|
3 |
asgiref==3.8.1
|
4 |
certifi==2024.8.30
|
5 |
+
cffi==1.17.1
|
6 |
charset-normalizer==3.3.2
|
7 |
click==8.1.7
|
8 |
+
cryptography==43.0.1
|
9 |
+
defusedxml==0.8.0rc2
|
10 |
Django==5.1.1
|
11 |
django-cors-headers==4.4.0
|
12 |
django-filter==24.3
|
13 |
+
django-templated-mail==1.1.1
|
14 |
django_csp==3.8
|
15 |
djangorestframework==3.15.2
|
16 |
+
djangorestframework-simplejwt==5.3.1
|
17 |
+
djoser==2.2.3
|
18 |
drf-yasg==1.21.7
|
19 |
eval_type_backport==0.2.0
|
20 |
exceptiongroup==1.2.2
|
21 |
+
faiss-cpu==1.8.0.post1
|
22 |
h11==0.14.0
|
23 |
httpcore==1.0.5
|
24 |
httpx==0.27.2
|
25 |
idna==3.10
|
26 |
inflection==0.5.1
|
27 |
jsonpath-python==1.0.6
|
28 |
+
Markdown==3.7
|
29 |
mistralai==1.1.0
|
30 |
mypy-extensions==1.0.0
|
31 |
+
numpy==1.26.4
|
32 |
+
oauthlib==3.2.2
|
33 |
packaging==24.1
|
34 |
pandas==2.2.3
|
35 |
+
pycparser==2.22
|
36 |
pydantic==2.9.2
|
37 |
pydantic_core==2.23.4
|
38 |
+
PyJWT==2.9.0
|
39 |
python-dateutil==2.8.2
|
40 |
+
python3-openid==3.2.0
|
41 |
pytz==2024.2
|
42 |
PyYAML==6.0.2
|
43 |
requests==2.32.3
|
44 |
+
requests-oauthlib==2.0.0
|
45 |
six==1.16.0
|
46 |
sniffio==1.3.1
|
47 |
+
social-auth-app-django==5.4.2
|
48 |
+
social-auth-core==4.5.4
|
49 |
sqlparse==0.5.1
|
50 |
typing-inspect==0.9.0
|
51 |
typing_extensions==4.12.2
|
spaces/settings.py
CHANGED
@@ -43,6 +43,10 @@ INSTALLED_APPS = [
|
|
43 |
'space_walks',
|
44 |
'recipes',
|
45 |
'csp',
|
|
|
|
|
|
|
|
|
46 |
]
|
47 |
|
48 |
MIDDLEWARE = [
|
@@ -71,6 +75,10 @@ CSP_FONT_SRC = ("'self'", "https:", "data:")
|
|
71 |
CORS_ORIGIN_WHITELIST = [
|
72 |
'https://gaganyatri.in',
|
73 |
]
|
|
|
|
|
|
|
|
|
74 |
|
75 |
CORS_ALLOW_CREDENTIALS = True
|
76 |
|
@@ -152,4 +160,16 @@ REST_FRAMEWORK = {
|
|
152 |
'DEFAULT_RENDERER_CLASSES': [
|
153 |
'rest_framework.renderers.JSONRenderer',
|
154 |
],
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
155 |
}
|
|
|
43 |
'space_walks',
|
44 |
'recipes',
|
45 |
'csp',
|
46 |
+
'rest_framework',
|
47 |
+
'rest_framework.authtoken',
|
48 |
+
'djoser',
|
49 |
+
'accounts'
|
50 |
]
|
51 |
|
52 |
MIDDLEWARE = [
|
|
|
75 |
CORS_ORIGIN_WHITELIST = [
|
76 |
'https://gaganyatri.in',
|
77 |
]
|
78 |
+
CORS_ALLOWED_ORIGINS = [
|
79 |
+
"http://localhost:3000",
|
80 |
+
"http://127.0.0.1:3000"
|
81 |
+
]
|
82 |
|
83 |
CORS_ALLOW_CREDENTIALS = True
|
84 |
|
|
|
160 |
'DEFAULT_RENDERER_CLASSES': [
|
161 |
'rest_framework.renderers.JSONRenderer',
|
162 |
],
|
163 |
+
'DEFAULT_AUTHENTICATION_CLASSES': (
|
164 |
+
'rest_framework.authentication.TokenAuthentication',
|
165 |
+
),
|
166 |
+
'DEFAULT_PERMISSION_CLASSES': [
|
167 |
+
# TODO - remove comment after authentication in frontend is enforced
|
168 |
+
# 'rest_framework.permissions.IsAuthenticated',
|
169 |
+
]
|
170 |
+
}
|
171 |
+
|
172 |
+
# configure Djoser
|
173 |
+
DJOSER = {
|
174 |
+
"USER_ID_FIELD": "username"
|
175 |
}
|
spaces/urls.py
CHANGED
@@ -40,4 +40,5 @@ urlpatterns = [
|
|
40 |
path('redoc/', schema_view.with_ui('redoc', cache_timeout=0), name='schema-redoc'),
|
41 |
path('api/v1/space_walks/', include('space_walks.urls')),
|
42 |
path('api/v1/recipes/', include('recipes.urls')),
|
|
|
43 |
]
|
|
|
40 |
path('redoc/', schema_view.with_ui('redoc', cache_timeout=0), name='schema-redoc'),
|
41 |
path('api/v1/space_walks/', include('space_walks.urls')),
|
42 |
path('api/v1/recipes/', include('recipes.urls')),
|
43 |
+
path('api/v1/accounts/', include('accounts.urls')),
|
44 |
]
|