2025-09-02 15:51:35 +01:00
|
|
|
from datetime import datetime
|
|
|
|
|
from enum import Enum
|
2025-09-03 09:41:19 +01:00
|
|
|
from typing import List, Optional
|
|
|
|
|
|
|
|
|
|
from pydantic import BaseModel
|
2025-09-02 15:51:35 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class InvestmentStage(str, Enum):
|
2025-09-03 09:41:19 +01:00
|
|
|
SEED = "SEED"
|
|
|
|
|
SERIES_A = "SERIES_A"
|
|
|
|
|
SERIES_B = "SERIES_B"
|
|
|
|
|
SERIES_C = "SERIES_C"
|
|
|
|
|
GROWTH = "GROWTH"
|
|
|
|
|
LATE_STAGE = "LATE_STAGE"
|
2025-09-02 15:51:35 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class SectorSchema(BaseModel):
|
|
|
|
|
id: int
|
|
|
|
|
name: str
|
|
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
|
|
|
|
|
2025-09-25 17:00:38 +01:00
|
|
|
class InvestorMemberSchema(BaseModel):
|
|
|
|
|
id: int
|
|
|
|
|
name: str
|
2025-09-26 15:56:29 +01:00
|
|
|
role: str | None
|
|
|
|
|
email: str | None
|
2025-09-25 17:00:38 +01:00
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
2025-09-26 15:56:29 +01:00
|
|
|
|
2025-10-07 15:24:36 +01:00
|
|
|
class FundSchema(BaseModel):
|
|
|
|
|
id: int
|
|
|
|
|
fund_name: str | None
|
|
|
|
|
fund_size: int | None # Changed to int for numerical filtering
|
|
|
|
|
fund_size_source_url: str | None
|
|
|
|
|
check_size_lower: int | None # NEW: Lower bound of check size range
|
|
|
|
|
check_size_upper: int | None # NEW: Upper bound of check size range
|
|
|
|
|
source_url: str | None
|
|
|
|
|
source_provider: str | None
|
|
|
|
|
geographic_focus: List[str] | None
|
|
|
|
|
investment_stage_focus: List[str] | None
|
|
|
|
|
sector_focus: List[str] | None
|
|
|
|
|
created_at: Optional[datetime] = None
|
|
|
|
|
updated_at: Optional[datetime] = None
|
|
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
|
|
|
|
|
2025-09-25 17:00:38 +01:00
|
|
|
class CompanyMemberSchema(BaseModel):
|
|
|
|
|
id: int
|
2025-09-26 15:56:29 +01:00
|
|
|
name: Optional[str]
|
|
|
|
|
linkedin: Optional[str]
|
|
|
|
|
role: Optional[str]
|
2025-09-25 17:00:38 +01:00
|
|
|
company_id: int
|
|
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
2025-09-26 15:56:29 +01:00
|
|
|
|
2025-09-02 15:51:35 +01:00
|
|
|
class CompanySchema(BaseModel):
|
|
|
|
|
id: int
|
|
|
|
|
name: str
|
2025-09-26 15:56:29 +01:00
|
|
|
industry: str | None
|
|
|
|
|
location: str | None
|
2025-09-25 17:00:38 +01:00
|
|
|
description: Optional[str]
|
2025-09-02 15:51:35 +01:00
|
|
|
founded_year: Optional[int]
|
|
|
|
|
website: Optional[str]
|
2025-09-26 15:56:29 +01:00
|
|
|
created_at: Optional[datetime] = None
|
|
|
|
|
updated_at: Optional[datetime] = None
|
2025-09-02 15:51:35 +01:00
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class InvestorSchema(BaseModel):
|
|
|
|
|
id: int
|
|
|
|
|
name: str
|
|
|
|
|
description: Optional[str]
|
2025-09-26 15:56:29 +01:00
|
|
|
aum: int | None
|
|
|
|
|
check_size_lower: int | None
|
|
|
|
|
check_size_upper: int | None
|
|
|
|
|
geographic_focus: str | None
|
2025-09-02 15:51:35 +01:00
|
|
|
stage_focus: InvestmentStage
|
2025-09-26 15:56:29 +01:00
|
|
|
number_of_investments: int | None
|
|
|
|
|
created_at: Optional[datetime] = None
|
|
|
|
|
updated_at: Optional[datetime] = None
|
2025-09-02 15:51:35 +01:00
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class InvestorData(BaseModel):
|
2025-10-07 15:24:36 +01:00
|
|
|
"""Comprehensive investor data schema - used for individual investor requests"""
|
2025-09-03 09:41:19 +01:00
|
|
|
|
2025-09-02 15:51:35 +01:00
|
|
|
investor: InvestorSchema
|
2025-09-25 17:00:38 +01:00
|
|
|
portfolio_companies: List[CompanySchema]
|
|
|
|
|
team_members: List[InvestorMemberSchema]
|
|
|
|
|
sectors: List[SectorSchema]
|
2025-10-07 15:24:36 +01:00
|
|
|
funds: List[FundSchema]
|
|
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class InvestorFundData(BaseModel):
|
|
|
|
|
"""Investor-Fund combined data - used for list/filter requests
|
|
|
|
|
|
|
|
|
|
Each row represents one investor-fund combination.
|
|
|
|
|
An investor with 3 funds will appear as 3 separate entries.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
# Investor fields
|
|
|
|
|
investor_id: int
|
|
|
|
|
investor_name: str
|
|
|
|
|
investor_description: Optional[str]
|
|
|
|
|
investor_website: Optional[str]
|
|
|
|
|
investor_headquarters: Optional[str]
|
|
|
|
|
aum: int | None
|
|
|
|
|
aum_as_of_date: str | None
|
|
|
|
|
aum_source_url: str | None
|
|
|
|
|
investment_thesis: List[str] | None
|
|
|
|
|
portfolio_highlights: List[str] | None
|
|
|
|
|
number_of_investments: int | None
|
|
|
|
|
|
|
|
|
|
# Fund fields
|
|
|
|
|
fund_id: int | None
|
|
|
|
|
fund_name: str | None
|
|
|
|
|
fund_size: int | None # Changed to int for numerical filtering
|
|
|
|
|
fund_size_source_url: str | None
|
|
|
|
|
check_size_lower: int | None # NEW: Lower bound of check size range
|
|
|
|
|
check_size_upper: int | None # NEW: Upper bound of check size range
|
|
|
|
|
geographic_focus: List[str] | None
|
|
|
|
|
investment_stage_focus: List[str] | None
|
|
|
|
|
sector_focus: List[str] | None
|
|
|
|
|
|
|
|
|
|
# Related data
|
|
|
|
|
portfolio_companies: List[CompanySchema]
|
|
|
|
|
team_members: List[InvestorMemberSchema]
|
|
|
|
|
sectors: List[SectorSchema]
|
2025-09-02 15:51:35 +01:00
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
2025-09-03 09:41:19 +01:00
|
|
|
|
2025-09-02 15:51:35 +01:00
|
|
|
|
2025-09-25 17:00:38 +01:00
|
|
|
class CompanyData(BaseModel): # Renamed from CompaniesData for consistency
|
|
|
|
|
company: CompanySchema
|
|
|
|
|
sectors: List[SectorSchema]
|
|
|
|
|
members: List[CompanyMemberSchema]
|
|
|
|
|
investors: List[InvestorSchema]
|
|
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
|
from_attributes = True
|
|
|
|
|
|
2025-09-26 15:56:29 +01:00
|
|
|
|
2025-09-02 15:51:35 +01:00
|
|
|
class InvestorList(BaseModel):
|
2025-09-26 15:56:29 +01:00
|
|
|
investors: List[InvestorData]
|
2025-10-07 15:24:36 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class InvestorFundList(BaseModel):
|
|
|
|
|
"""List of investor-fund combinations"""
|
|
|
|
|
|
|
|
|
|
investor_funds: List[InvestorFundData]
|