Job App Tracker
An MCP (Model Context Protocol) server that automates your job application process using AI.
Ask AI about Job App Tracker
Powered by Claude Β· Grounded in docs
I know everything about Job App Tracker. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
π§ MCP Job Application Tracker & Resume Customizer
An MCP (Model Context Protocol) server that automates your job application process using AI. It connects with Google Drive, Notion, and Gmail to help you track applications, generate tailored resumes and cover letters, and send follow-up reminders.
β¨ Features
- AI-Powered Resume & Cover Letter Generation: Uses Claude to create tailored documents for each job
- Google Drive Integration: Automatically saves generated documents to your Drive
- Notion Database Tracking: Logs all job applications with status tracking
- Follow-up Email Automation: Sends reminder emails for applications that need attention
- MCP Protocol: Works seamlessly with MCP-compatible AI assistants
π Quick Start
1. Install Dependencies
npm install
2. Set Up Environment Variables
Copy the example environment file and fill in your API keys:
cp env.example .env
For Windows users: You can also use the provided setup-env.bat or setup-env-windows.bat scripts.
β οΈ IMPORTANT: Edit these files first to replace placeholder values with your actual API keys before running them. Never commit files containing real API keys!
You'll need to set up:
- Anthropic API Key: Get from Anthropic Console
- Google OAuth Credentials: Set up a project in Google Cloud Console
- Notion Integration: Create an integration in Notion Developers
3. Build the Project
npm run build
4. Run the MCP Server
npm start
π§ Setup Instructions
Google APIs Setup
- Go to Google Cloud Console
- Create a new project or select existing one
- Enable the following APIs:
- Google Drive API
- Gmail API
- Create OAuth 2.0 credentials:
- Application type: Web application
- Authorized redirect URIs:
http://localhost:3000/auth/google/callback
- Copy the Client ID and Client Secret to your
.envfile
Notion Setup
- Go to Notion Developers
- Create a new integration
- Copy the Internal Integration Token to your
.envfile - Create a database in Notion with the following properties:
- Job Title (Title)
- Company (Text)
- Status (Select: drafted, applied, interviewing, offer, rejected, withdrawn)
- Applied Date (Date)
- Follow-up Date (Date)
- Resume URL (URL)
- Cover Letter URL (URL)
- Notes (Text)
- Created (Date)
- Last Updated (Date)
- Share the database with your integration
- Copy the database ID to your
.envfile
π Usage
Available Tools
The MCP server provides the following tools:
process_job_application
Process a new job application by generating tailored resume and cover letter.
Parameters:
jobTitle(string): The title of the job positioncompanyName(string): The name of the companyjobDescription(string): The full job description textresumeData(object): Your resume information
Example:
{
"jobTitle": "Senior Software Engineer",
"companyName": "Tech Corp",
"jobDescription": "We are looking for a senior software engineer...",
"resumeData": {
"name": "John Doe",
"email": "john@example.com",
"phone": "+1-555-0123",
"location": "San Francisco, CA",
"summary": "Experienced software engineer...",
"experience": [...],
"education": [...],
"skills": ["JavaScript", "Python", "React"],
"projects": [...]
}
}
get_job_applications
Retrieve all job applications from your Notion database.
update_job_status
Update the status of a job application.
Parameters:
pageId(string): The Notion page IDstatus(string): New status (drafted, applied, interviewing, offer, rejected, withdrawn)notes(string, optional): Additional notes
send_follow_up_emails
Send follow-up emails for applications that need attention.
Parameters:
recipientEmail(string): Email address to send follow-ups to
get_google_auth_url
Get the Google OAuth URL for setting up access.
π Workflow
- Find a Job: When you find a job you want to apply for
- Process Application: Use
process_job_applicationwith the job details and your resume data - Review Documents: Check the generated resume and cover letter in Google Drive
- Submit Application: When you submit, update the status to "applied"
- Track Progress: Monitor your applications in Notion
- Follow Up: Use
send_follow_up_emailsto send reminders
π οΈ Development
Project Structure
src/
βββ config/ # Configuration management
βββ services/ # External service integrations
β βββ openai.ts # OpenAI GPT integration
β βββ google.ts # Google Drive & Gmail
β βββ notion.ts # Notion database
βββ types/ # TypeScript type definitions
βββ index.ts # Main MCP server
Available Scripts
npm run dev: Run in development mode with hot reloadnpm run build: Build the TypeScript projectnpm start: Run the built servernpm run watch: Watch for changes and rebuild
π Security
- All API keys are stored in environment variables
- Google OAuth uses secure token exchange
- No sensitive data is logged or stored in plain text
β οΈ Important Security Practices
NEVER commit API keys to version control!
- Always use
.envfiles for your API keys (already in.gitignore) - If using
setup-env.batorsetup-env-windows.batscripts, replace placeholders with your actual keys locally - Keep your API keys private and rotate them immediately if exposed
- For Windows users: Copy the setup script templates, add your keys, but do NOT commit them back to the repository
π€ Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
π License
MIT License - see LICENSE file for details
π Support
If you encounter any issues:
- Check that all environment variables are set correctly
- Verify your API keys have the necessary permissions
- Ensure your Notion database has the correct structure
- Check the console for error messages
For more help, please open an issue on GitHub.
