An unofficial API to fetch job listings from LinkedIn. This API allows you to search for jobs using keywords, location, and date filters.
Created by: Atharv Hatwar
- 🔍 Search jobs by keywords
- 📍 Filter by location
- 📅 Filter by posting date
- 🧹 Clean and formatted job data
- 🌐 CORS enabled
⚠️ Error handling- 🛡️ Rate limiting protection
npm install @atharvh01/linkedin-jobs-api
import express from 'express';
import { searchJobs } from '@atharvh01/linkedin-jobs-api';
const app = express();
const PORT = 3000;
app.get('/api/search', searchJobs);
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
});
GET /api/search
Parameter | Type | Required | Description |
---|---|---|---|
keywords | string | Yes | Search terms (e.g., "react developer") |
location | string | Yes | Job location (e.g., "remote", "Pune") |
dateSincePosted | string | No | Filter by post date (past_24h, past_week, past_month) |
GET /api/search?keywords=react&location=remote&dateSincePosted=past_24h
{
"success": true,
"count": 2,
"jobs": [
{
"title": "Senior React Developer",
"company": "Example Corp",
"location": "Remote",
"link": "https://www.linkedin.com/jobs/view/123456789",
"postedDate": "2023-12-20T10:00:00.000Z",
"description": "We are looking for a Senior React Developer..."
}
]
}
The API returns appropriate error messages and status codes:
{
"success": false,
"error": {
"message": "Keywords parameter is required",
"status": 400
}
}
To prevent abuse, the API implements rate limiting:
- 100 requests per hour per IP
- Customizable limits through configuration
# Run the test suite
npm test
# Test specific endpoints
npm run test:api
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
Atharv Hatwar
- GitHub: atharvhatwar
This package is for educational purposes only. Please review LinkedIn's terms of service before using this API in production.