LucasAguetai commited on
Commit
e0724f2
·
1 Parent(s): 2974ccd

fix post url

Browse files
Files changed (2) hide show
  1. app.py +20 -21
  2. requirements.txt +2 -1
app.py CHANGED
@@ -1,4 +1,4 @@
1
- from fastapi import FastAPI, HTTPException, UploadFile
2
  from fastapi.middleware.cors import CORSMiddleware
3
  from fastapi import FastAPI, UploadFile
4
  from typing import Union
@@ -8,6 +8,7 @@ from modeles import bert, squeezebert, deberta, loadSqueeze
8
  from uploadFile import file_to_text
9
  from typing import List
10
  from transformers import pipeline
 
11
 
12
 
13
 
@@ -21,7 +22,17 @@ app.add_middleware(
21
  allow_headers=["*"],
22
  )
23
 
 
 
 
24
 
 
 
 
 
 
 
 
25
 
26
  pipBert = pipeline('question-answering', model="ALOQAS/bert-large-uncased-finetuned-squad-v2", tokenizer="ALOQAS/bert-large-uncased-finetuned-squad-v2")
27
  pipDeberta = pipeline('question-answering', model="ALOQAS/deberta-large-finetuned-squad-v2", tokenizer="ALOQAS/deberta-large-finetuned-squad-v2")
@@ -33,12 +44,12 @@ async def root():
33
 
34
 
35
  @app.post("/uploadfile/")
36
- async def create_upload_file(files: List[UploadFile], texte: str, model: str):
37
  res = []
38
  for file in files:
39
  fileToText = await file_to_text(file)
40
 
41
- res.append({"model": model, "texte": texte, "filename": file.filename, "file_to_text": fileToText})
42
 
43
  return res
44
 
@@ -54,14 +65,10 @@ async def create_upload_file(texte: str, model: str):
54
 
55
  return {"model": model, "texte": texte}
56
 
57
- # # Modèle Pydantic pour les requêtes SqueezeBERT
58
- # class SqueezeBERTRequest(BaseModel):
59
- # context: str
60
- # question: str
61
  @app.post("/squeezebert/")
62
- async def qasqueezebert(context: str, question: str):
63
  try:
64
- squeezebert_answer = squeezebert(context, question, model, tokenizer)
65
  if squeezebert_answer:
66
  return squeezebert_answer
67
  else:
@@ -69,14 +76,10 @@ async def qasqueezebert(context: str, question: str):
69
  except Exception as e:
70
  raise HTTPException(status_code=500, detail=f"An error occurred: {str(e)}")
71
 
72
- # # Modèle Pydantic pour les requêtes BERT
73
- # class BERTRequest(BaseModel):
74
- # context: str
75
- # question: str
76
  @app.post("/bert/")
77
- async def qabert(context: str, question: str):
78
  try:
79
- bert_answer = bert(context, question, pipBert)
80
  if bert_answer:
81
  return bert_answer
82
  else:
@@ -84,14 +87,10 @@ async def qabert(context: str, question: str):
84
  except Exception as e:
85
  raise HTTPException(status_code=500, detail=f"An error occurred: {str(e)}")
86
 
87
- # # Modèle Pydantic pour les requêtes DeBERTa
88
- # class DeBERTaRequest(BaseModel):
89
- # context: str
90
- # question: str
91
  @app.post("/deberta-v2/")
92
- async def qadeberta(context: str, question: str):
93
  try:
94
- deberta_answer = deberta(context, question, pipDeberta)
95
  if deberta_answer:
96
  return deberta_answer
97
  else:
 
1
+ from fastapi import FastAPI, HTTPException, UploadFile, File, Form, Depends
2
  from fastapi.middleware.cors import CORSMiddleware
3
  from fastapi import FastAPI, UploadFile
4
  from typing import Union
 
8
  from uploadFile import file_to_text
9
  from typing import List
10
  from transformers import pipeline
11
+ from pydantic import BaseModel
12
 
13
 
14
 
 
22
  allow_headers=["*"],
23
  )
24
 
25
+ class SqueezeBERTRequest(BaseModel):
26
+ context: str
27
+ question: str
28
 
29
+ class BERTRequest(BaseModel):
30
+ context: str
31
+ question: str
32
+
33
+ class DeBERTaRequest(BaseModel):
34
+ context: str
35
+ question: str
36
 
37
  pipBert = pipeline('question-answering', model="ALOQAS/bert-large-uncased-finetuned-squad-v2", tokenizer="ALOQAS/bert-large-uncased-finetuned-squad-v2")
38
  pipDeberta = pipeline('question-answering', model="ALOQAS/deberta-large-finetuned-squad-v2", tokenizer="ALOQAS/deberta-large-finetuned-squad-v2")
 
44
 
45
 
46
  @app.post("/uploadfile/")
47
+ async def create_upload_file(files: List[UploadFile], question: str, model: str):
48
  res = []
49
  for file in files:
50
  fileToText = await file_to_text(file)
51
 
52
+ res.append({"model": model, "texte": question, "filename": file.filename, "file_to_text": fileToText})
53
 
54
  return res
55
 
 
65
 
66
  return {"model": model, "texte": texte}
67
 
 
 
 
 
68
  @app.post("/squeezebert/")
69
+ async def qasqueezebert(request: SqueezeBERTRequest):
70
  try:
71
+ squeezebert_answer = squeezebert(request.context, request.question, model, tokenizer)
72
  if squeezebert_answer:
73
  return squeezebert_answer
74
  else:
 
76
  except Exception as e:
77
  raise HTTPException(status_code=500, detail=f"An error occurred: {str(e)}")
78
 
 
 
 
 
79
  @app.post("/bert/")
80
+ async def qabert(request: BERTRequest):
81
  try:
82
+ bert_answer = bert(request.context, request.question, pipBert)
83
  if bert_answer:
84
  return bert_answer
85
  else:
 
87
  except Exception as e:
88
  raise HTTPException(status_code=500, detail=f"An error occurred: {str(e)}")
89
 
 
 
 
 
90
  @app.post("/deberta-v2/")
91
+ async def qadeberta(request: DeBERTaRequest):
92
  try:
93
+ deberta_answer = deberta(request.context, request.question, pipDeberta)
94
  if deberta_answer:
95
  return deberta_answer
96
  else:
requirements.txt CHANGED
@@ -12,4 +12,5 @@ PyMuPDF
12
  chardet
13
  frontend
14
  typing
15
- torch
 
 
12
  chardet
13
  frontend
14
  typing
15
+ torch
16
+ pydantic