code-audit-api / app.py
Forrest99's picture
Create app.py
08465c2 verified
raw
history blame
1.28 kB
from fastapi import FastAPI, HTTPException
from pydantic import BaseModel
from transformers import AutoTokenizer, T5ForConditionalGeneration
import torch
app = FastAPI()
# ε…¨ε±€εŠ θ½½ζ¨‘εž‹
tokenizer = AutoTokenizer.from_pretrained("Salesforce/codet5-small")
model = T5ForConditionalGeneration.from_pretrained("Salesforce/codet5-small")
class CodeRequest(BaseModel):
code: str
max_length: int = 512
@app.post("/v1/analyze")
async def analyze_code(request: CodeRequest):
try:
# ζž„ι€ ζη€Ίθ―
prompt = f"Analyze security vulnerabilities in this code:\n{request.code}"
# η”Ÿζˆεˆ†ζžη»“ζžœ
inputs = tokenizer(prompt, return_tensors="pt",
max_length=512, truncation=True)
outputs = model.generate(
inputs.input_ids,
max_length=request.max_length,
num_beams=5,
early_stopping=True
)
# θ§£η η»“ζžœ
analysis = tokenizer.decode(outputs[0], skip_special_tokens=True)
return {
"status": "success",
"analysis": analysis,
"model": "Salesforce/codet5-small"
}
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))