JobSphere is a web application that helps users find job opportunities based on their resumes. It uses a combination of resume parsing, job scraping from multiple platforms, and MongoDB to store user data and job listings. The application allows users to upload their resumes, extract relevant skills and experience, and automatically generate job recommendations based on their profile.
- User Authentication: Users can sign up, log in, and securely store their information.
- Resume Upload: Users can upload their resumes, which will be parsed to extract relevant details (skills, experience, etc.).
- Job Scraping: Automatically fetch jobs from platforms like Indeed, Glassdoor, and ZipRecruiter using parsed resume data.
- Job Dashboard: Displays a list of relevant job opportunities tailored to the user based on their resume.
- Profile Management: Users can view and manage their profile information.
- Responsive Design: The application is designed to be responsive and works well on various screen sizes.
Landing Page
Sign-Up/Signin Pages
Dashboard with Job Recommendations
Profile Page
Modal for Uploading a Resume
Modal for Deleting Your Account
- Frontend: HTML5, CSS3, Bootstrap, EJS, fetch-API
- Backend: Node.js, Express.js
- Database: MongoDB
- Resume Parsing: Integrated with the Resume Parser API
- Job Scraping: Python-based web scraping using the
jobspy
module - Authentication: JSON Web Tokens (JWT), Bcrypt.js for password hashing
- APIs/ Middleware: Multer, Axios, Connect-Flash, Cookie-Parser, Express-Session
Make sure you have the following installed:
- Node.js (v14 or higher)
- MongoDB (or use a MongoDB cloud service like Atlas)
- Python 3.x (for running the job scraper script)
-
Clone the repository:
git clone https://github.com/curiousityDrives/JobSphere.git cd jobsphere
-
Install Node.js dependencies:
npm install
-
Set up MongoDB:
- If you’re using a local MongoDB instance, make sure MongoDB is running.
- If you prefer to use MongoDB Atlas, update the
mongoose.connect()
URI inapp.js
with your MongoDB Atlas credentials.
-
Add the
jobspy
module and any other necessary Python packages for web scraping. -
Set up environment variables:
- Create a
.env
file in the root directory and add the following:JWT_SECRET=your_jwt_secret API_KEY=your_resume_parser_api_key
- Create a
-
Run the server:
npm start
-
Navigate to
http://localhost:3000
in your browser to access the application.
- Create an account by clicking the "Sign Up" link and filling out the registration form with your username, email, and password.
- After signing up, you can log in using your credentials.
- Once logged in, you can upload your resume by navigating to the "Upload Resume" page.
- The resume will be parsed, and relevant job recommendations will be displayed based on the extracted data.
- After uploading your resume, the dashboard will show you a list of job opportunities that match your experience and skills.
- If no jobs are found, you will be prompted to upload a resume.
- When you click on the any of the jobs on your dashboard, you are redirected to a page where that specific job post's details are displayed, from which you can decide either to apply from the site of the post or directly from the company's site.
- In this page, you can also find information on the company and links to their profile, if available.
- The profile page allows you to view and manage your user details. You can edit your username, your password, add a second email, add a phone number, upload another resume, or delete your account.
- Enhanced job filtering and sorting based on salary, location, and job type.
- Integrate additional job platforms for more comprehensive job scraping.
- Add the ability for users to save job postings and receive notifications.
- Improve the UI with modern design trends and better responsiveness.
Contributions are welcome! If you find any bugs or have ideas for new features, feel free to open an issue or submit a pull request.
- Fork the repository.
- Create a new branch (
git checkout -b feature/your-feature-name
). - Make your changes.
- Commit your changes (
git commit -am 'Add new feature'
). - Push to the branch (
git push origin feature/your-feature-name
). - Create a new pull request.
This project is licensed under the MIT License - see the LICENSE file for details.
- Thanks to JobSpy for the web scraping module.
- Thanks to Resume Parser API for resume parsing.
Note: This project is still a work in progress, and many features and improvements are in the pipeline. Feel free to contribute or suggest enhancements!
Created and maintained by Natnael Haile.