mirror of https://github.com/Bunsly/JobSpy
27 lines
879 B
Python
27 lines
879 B
Python
from fastapi import APIRouter, Depends
|
|
|
|
from api.core.scrapers.indeed import IndeedScraper
|
|
from api.core.scrapers.ziprecruiter import ZipRecruiterScraper
|
|
from api.core.scrapers.linkedin import LinkedInScraper
|
|
from api.core.scrapers import ScraperInput, Site
|
|
from ...v1.token.auth import get_active_current_user
|
|
|
|
router = APIRouter(prefix="/jobs", dependencies=[Depends(get_active_current_user)])
|
|
|
|
SCRAPER_MAPPING = {
|
|
Site.LINKEDIN: LinkedInScraper,
|
|
Site.INDEED: IndeedScraper,
|
|
Site.ZIP_RECRUITER: ZipRecruiterScraper,
|
|
}
|
|
|
|
|
|
@router.get("/")
|
|
async def scrape_jobs(site_type: Site, search_term: str, location: str, page: int = 1):
|
|
scraper_class = SCRAPER_MAPPING[site_type]
|
|
scraper = scraper_class()
|
|
|
|
scraper_input = ScraperInput(search_term=search_term, location=location, page=page)
|
|
job_response = scraper.scrape(scraper_input)
|
|
|
|
return job_response
|