mirror of https://github.com/Bunsly/JobSpy
chore: postman
parent
4d04bb63e2
commit
369b1cffd6
|
@ -1,7 +1,4 @@
|
|||
{
|
||||
// Use IntelliSense to learn about possible attributes.
|
||||
// Hover to view descriptions of existing attributes.
|
||||
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
|
||||
"version": "0.2.0",
|
||||
"configurations": [
|
||||
{
|
||||
|
|
98
README.md
98
README.md
|
@ -1,62 +1,67 @@
|
|||
# JobSpy Scraper
|
||||
# JobSpy AIO Scraper
|
||||
|
||||
## Features
|
||||
|
||||
- Scrapes job postings from **LinkedIn**, **Indeed**, **ZipRecruiter**
|
||||
- Returns jobs with title, location, company, and other data
|
||||
- JWT authorization
|
||||
|
||||
data:image/s3,"s3://crabby-images/0d4f9/0d4f941913ea23338ac8fc1763ddb58af2f3ceeb" alt="jobspy"
|
||||
|
||||
## Endpoints
|
||||
data:image/s3,"s3://crabby-images/51e14/51e14cba671091675f05cbb149b6edfb9a988391" alt="image"
|
||||
- Scrapes job postings from **LinkedIn**, **Indeed** & **ZipRecruiter** simultaneously
|
||||
- Returns jobs with title, location, company, description & other data
|
||||
- Optional JWT authorization
|
||||
|
||||
|
||||
### Jobs Endpoint
|
||||
### API
|
||||
|
||||
**Endpoint**: `/api/v1/jobs/`
|
||||
POST `/api/v1/jobs/`
|
||||
### Request Schema
|
||||
#### Example
|
||||
<pre>
|
||||
{
|
||||
"site_type": ["linkedin", "indeed"],
|
||||
"search_term": "software engineer",
|
||||
"location": "austin, tx",
|
||||
"distance": 10,
|
||||
"job_type": "fulltime",
|
||||
"results_wanted": 10
|
||||
}
|
||||
</pre>
|
||||
|
||||
#### Parameters:
|
||||
- **site_type**: List[str] (Required) - Options: `linkedin`, `zip_recruiter`, `indeed`
|
||||
- **search_term**: str (Required)
|
||||
- **location**: int
|
||||
- **distance**: int
|
||||
- **job_type**: str - Options: `fulltime`, `parttime`, `internship`, `contract`
|
||||
- **is_remote**: bool
|
||||
- **results_wanted**: int (per `site_type`)
|
||||
- **easy_apply**: bool (Only for LinkedIn)
|
||||
##### Required
|
||||
- **site_type**: _List[str]_ - `linkedin`, `zip_recruiter`, `indeed`
|
||||
- **search_term**: _str_
|
||||
|
||||
##### Optional
|
||||
- **location**: _int_
|
||||
- **distance**: _int_
|
||||
- **job_type**: _str_ - `fulltime`, `parttime`, `internship`, `contract`
|
||||
- **is_remote**: _bool_
|
||||
- **results_wanted**: _int_ (per `site_type`)
|
||||
- **easy_apply**: _bool_ (only for `linkedIn`)
|
||||
|
||||
|
||||
## Response Schema
|
||||
### Example
|
||||
data:image/s3,"s3://crabby-images/888fd/888fd24ee547521476f50d4a6b03937de871421f" alt="image"
|
||||
|
||||
|
||||
## Response
|
||||
|
||||
### Schema
|
||||
data:image/s3,"s3://crabby-images/54a8a/54a8a136933624b2fb54c3bb71db929205f6d1f8" alt="image"
|
||||
|
||||
#### JobResponse
|
||||
- **success**: bool - Indicates if the request was successful
|
||||
- **error**: str - Any error messages, null if no error
|
||||
- **jobs**: list[JobPost] - A list of job postings
|
||||
- **total_results**: int - Total number of results found
|
||||
- **returned_results**: int - Number of results returned in this request
|
||||
- **success**: _bool_ - Indicates if the request was successful
|
||||
- **error**: _str_
|
||||
- **jobs**: _list[JobPost]_
|
||||
- #### JobPost
|
||||
- **title**: _str_
|
||||
- **company_name**: _str_
|
||||
- **job_url**: _str_
|
||||
- **location**: _object_ - (country, city, state, postal_code, address)
|
||||
- **description**: _str_
|
||||
- **job_type**: _str_ - `fulltime`, `parttime`, `internship`, `contract`
|
||||
- **compensation**: _object_ - Contains: `interval`, `min_amount`, `max_amount`, `currency`
|
||||
- **date_posted**: _str_
|
||||
|
||||
- **total_results**: _int_
|
||||
- **returned_results**: _int_
|
||||
|
||||
#### JobPost
|
||||
- **title**: str
|
||||
- **company_name**: str
|
||||
- **job_url**: str
|
||||
- **location**: object - (country, city, state, postal_code, address)
|
||||
- **description**: str
|
||||
- **job_type**: str - Options: `fulltime`, `parttime`, `internship`, `contract`
|
||||
- **compensation**: object - Contains: `interval`, `min_amount`, `max_amount`, `currency`
|
||||
- **date_posted**: str
|
||||
|
||||
### Example
|
||||
data:image/s3,"s3://crabby-images/ae068/ae068a7f4799d9171947ad2695bdd5572843f87c" alt="image"
|
||||
|
||||
## Installation
|
||||
_Python >= 3.10 required_
|
||||
1. Clone this repository
|
||||
1. Clone this repository `git clone https://github.com/cullenwatson/jobspy`
|
||||
2. Install the dependencies with `pip install -r requirements.txt`
|
||||
4. Run the server with `uvicorn main:app --reload`
|
||||
|
||||
|
@ -65,7 +70,7 @@ _Python >= 3.10 required_
|
|||
To see the interactive API documentation, visit [localhost:8000/docs](http://localhost:8000/docs).
|
||||
|
||||
For Postman integration:
|
||||
- Import the Postman collection and environment JSON files from the `postman` folder.
|
||||
- Import the Postman collection and environment JSON files from the `/postman/` folder.
|
||||
|
||||
|
||||
## FAQ
|
||||
|
@ -89,3 +94,8 @@ Add these three environment variables:
|
|||
- `SUPABASE_URL`: go to project settings -> API -> Project URL
|
||||
- `SUPABASE_KEY`: go to project settings -> API -> service_role secret
|
||||
- `JWT_SECRET_KEY` - type `openssl rand -hex 32` in terminal to create a 32 byte secret key
|
||||
|
||||
Use these endpoints to register and get an access token:
|
||||
|
||||
data:image/s3,"s3://crabby-images/98d28/98d28d0ac210d1ab668a82bdb14f2a8f1147530c" alt="image"
|
||||
|
||||
|
|
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue