
- Complete FastAPI backend with SQLite database
- AI-powered resume parsing and job matching using OpenAI
- JWT authentication with role-based access control
- Resume upload, job management, and matching endpoints
- Recruiter dashboard with candidate ranking
- Analytics and skill gap analysis features
- Comprehensive API documentation with OpenAPI
- Alembic database migrations
- File upload support for PDF, DOCX, and TXT resumes
- CORS enabled for frontend integration
🤖 Generated with BackendIM
Co-Authored-By: Claude <noreply@anthropic.com>
41 lines
990 B
Python
41 lines
990 B
Python
from typing import Optional, List, Dict, Any
|
|
from pydantic import BaseModel
|
|
from datetime import datetime
|
|
|
|
|
|
class ResumeBase(BaseModel):
|
|
title: str
|
|
extracted_text: Optional[str] = None
|
|
parsed_data: Optional[Dict[str, Any]] = None
|
|
skills: Optional[List[str]] = None
|
|
experience_years: Optional[int] = None
|
|
education_level: Optional[str] = None
|
|
|
|
|
|
class ResumeCreate(ResumeBase):
|
|
pass
|
|
|
|
|
|
class ResumeUpdate(BaseModel):
|
|
title: Optional[str] = None
|
|
extracted_text: Optional[str] = None
|
|
parsed_data: Optional[Dict[str, Any]] = None
|
|
skills: Optional[List[str]] = None
|
|
experience_years: Optional[int] = None
|
|
education_level: Optional[str] = None
|
|
|
|
|
|
class ResumeResponse(ResumeBase):
|
|
id: int
|
|
user_id: int
|
|
file_path: Optional[str] = None
|
|
original_filename: Optional[str] = None
|
|
created_at: datetime
|
|
updated_at: Optional[datetime] = None
|
|
|
|
class Config:
|
|
from_attributes = True
|
|
|
|
|
|
class Resume(ResumeResponse):
|
|
pass |