Skip to content

GodsScion/Auto_job_applier_linkedIn

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LinkedIn AI Auto Job Applier 🤖

This is an web scraping bot that automates the process of job applications on LinkedIn. It searches for jobs relevant to you, answers all questions in application form, customizes your resume based on the collected job information, such as skills required, description, about company, etc. and applies to the job. Can apply 100+ jobs in less than 1 hour.

📽️ See it in Action

Auto Job Applier demo video Click on above image to watch the demo or use this link https://youtu.be/gMbB1fWZDHw

✨ Content


⚙️ How to install

  1. Python 3.10 or above. Visit https://www.python.org/downloads/ to download and install Python, or for windows you could visit Microsoft Store and search for "Python". Please make sure Python is added to Path in System Environment Variables.
  2. Install necessary Undetected Chromedriver, PyAutoGUI and Setuptools packages. After Python is installed, OPEN a console/terminal or shell, Use below command that uses the pip command-line tool to install these 3 package.
pip install undetected-chromedriver pyautogui setuptools openai
  1. Download and install latest version of Google Chrome in it's default location, visit https://www.google.com/chrome to download it's installer.
  2. Clone the current git repo or download it as a zip file, url to the latest update https://github.com/GodsScion/Auto_job_applier_linkedIn.
  3. (Not needed if you set stealth_mode = True in config/settings.py ) Download and install the appropriate Chrome Driver for Google Chrome and paste it in the location Chrome was installed, visit https://googlechromelabs.github.io/chrome-for-testing/ to download.

    OR

    If you are using Windows, click on windows-setup.bat available in the /setup folder, this will install the latest chromedriver automatically.
  4. If you have questions or need help setting it up or to talk in general, join the github server: https://discord.gg/fFp7uUzWCY

back to index


🔧 How to configure

  1. Open personals.py file in /config folder and enter your details like name, phone number, address, etc. Whatever you want to fill in your applications.
  2. Open questions.py file in /config folder and enter your answers for application questions, configure wether you want the bot to pause before submission or pause if it can't answer unknown questions.
  3. Open search.py file in /config folder and enter your search preferences, job filters, configure the bot as per your needs (these settings decide which jobs to apply for or skip).
  4. Open secrets.py file in /config folder and enter your LinkedIn username, password to login and OpenAI API Key for generation of job tailored resumes and cover letters (This entire step is optional). If you do not provide username or password or leave them as default, it will login with saved profile in browser, if failed will ask you to login manually.
  5. Open settings.py file in /config folder to configure the bot settings like, keep screen awake, click intervals (click intervals are randomized to seem like human behavior), run in background, stealth mode (to avoid bot detection), etc. as per your needs.
  6. (Optional) Don't forget to add you default resume in the location you mentioned in default_resume_path = "all resumes/default/resume.pdf" given in /config/questions.py. If one is not provided, it will use your previous resume submitted in LinkedIn or (In Development) generate custom resume if OpenAI APT key is provided!
  7. Run runAiBot.py and see the magic happen.
  8. If you have questions or need help setting it up or to talk in general, join the github server: https://discord.gg/fFp7uUzWCY

back to index


🧑‍💻 Contributor Guidelines

Thank you for your efforts and being a part of the community. All contributions are appreciated no matter how small or big. Once you contribute to the code base, your work will be remembered forever.

NOTE: Only Pull request to community-version branch will be accepted. Any other requests will be declined by default, especially to main branch. Once your code is tested, your changes will be merged to the main branch in next cycle.

Code Guidelines

Functions:

  1. All functions or methods are named lower case and snake case
  2. Must have explanation of their purpose. Write explanation surrounded in ''' Explanation ''' under the definition def function() -> None:. Example:
    def function() -> None:
      '''
      This function does nothing, it's just an example for explanation placement!
      '''
  3. The Types (str, list, int, list[str], int | float) for the parameters and returns must be given. Example:
    def function(param1: str, param2: list[str], param3: int) -> str:
  4. Putting all that together some valid examples for function or method declarations would be as follows.
    def function_name_in_camel_case(parameter1: driver, parameter2: str) -> list[str] | ValueError:
      '''
      This function is an example for code guidelines
      '''
      return [parameter2, parameter2.lower()]
  5. The hashtag comments on top of functions are optional, which are intended for developers # Comments for developers.
    # Enter input text function
    def text_input_by_ID(driver: WebDriver, id: str, value: str, time: float=5.0) -> None | Exception:
        '''
        Enters `value` into the input field with the given `id` if found, else throws NotFoundException.
        - `time` is the max time to wait for the element to be found.
        '''
        username_field = WebDriverWait(driver, time).until(EC.presence_of_element_located((By.ID, id)))
        username_field.send_keys(Keys.CONTROL + "a")
        username_field.send_keys(value)

Variables

  1. All variables must start with lower case, must be in explainable full words. If someone reads the variable name, it should be easy to understand what the variable stores.
  2. All local variables are camel case. Examples:
    jobListingsElement = None
    localBufferTime = 5.5
  3. All global variables are snake case. Example:
    total_runs = 1
    
  4. Mentioning types are optional.
    localBufferTime: float | int = 5.5

Configuration variables

  1. All config variables are treated as global variables. They have some extra guidelines.
  2. Must have variable setting explanation, and examples of valid values. Examples:
    # Explanation of what this setting will do, and instructions to enter it correctly
    config_variable = "value1"    #  <Valid values examples, and NOTES> "value1", "value2", etc. Don't forget quotes ("")
    # Do you want to randomize the search order for search_terms?
    randomize_search_order = False     # True of False, Note: True or False are case-sensitive
    # Avoid applying to jobs if their required experience is above your current_experience. (Set value as -1 if you want to apply to all ignoring their required experience...)
    current_experience = 5             # Integers > -2 (Ex: -1, 0, 1, 2, 3, 4...)
    # Search location, this will be filled in "City, state, or zip code" search box. If left empty as "", tool will not fill it.
    search_location = "United States"               # Some valid examples: "", "United States", "India", "Chicago, Illinois, United States", "90001, Los Angeles, California, United States", "Bengaluru, Karnataka, India", etc.
  3. Add the config variable in appropriate /config/file.
  4. Every config variable must be validated. Go to /modules/validator.py and add it over there. Example: For config variable search_location = "" found in /config/search.py, string validation is added in file /modules/validator.py under the method def validate_search().
    def validate_search() -> None | ValueError | TypeError:
        '''
        Validates all variables in the `/config/search.py` file.
        '''
        check_string(search_location, "search_location")

back to index

Attestation

  1. All contributions require proper attestion. Format for attestation:
##> ------ <Your full name> : <github id> OR <email> - <Type of change> ------
    print("My contributions 😍") # Your code
##<
  1. Examples for proper attestation: New feature example
##> ------ Sai Vignesh Golla : godsscion - Feature ------
def alert_box(title: str, message: str) -> None:
  '''
  Shows an alert box with the given `title` and `message`.
  '''
  from pyautogui import alert
  return alert(title, message)

##<

Bug fix example

def alert_box(title: str, message: str) -> None:
  '''
  Shows an alert box with the given `title` and `message`.
  '''
  from pyautogui import alert

##> ------ Sai Vignesh Golla : saivigneshgolla@outlook.com - Bug fix ------
  return alert(message, title)
##<

back to index


🤩 Feature List

(I'm yet to complete the documentation, I'm adding in more features, still in development)

General Features 🚀:

  • Opens browser with default logged in google account (Yet to test with browsers having multiple profiles)
  • Auto Login: If configured or already saved in browser (not saved passwords)
  • Apply filters (Salary, Companies, Experience Level,... ) Must config
  • Region specific searches
  • Opens job search and searches key words
  • Easy applies
  • Auto Answers questions answered in config
  • Collects urls of career page if have to Apply externally
  • Collects HR Info
  • Collects skills required (In Development)
  • Collects experience required and skips if not applicable to you, must be configured
  • Auto Filters jobs based on your experience and black list key words
  • Skips blacklisted jobs
  • Can be configured to skip jobs requiring Security Clearance
  • You can add exceptions to blacklist key words
  • Only applies to filtered jobs
  • Auto selects next pages until it hits the quota you configured
  • Selects your default resume
  • Auto Submits
  • Saves all the info of applied jobs, failed to apply jobs in excels and logs
  • Takes screenshot of questions answered to fail, for future debugging
  • Saves info of all questions, it's options, previous answer and current answer in application
  • Option to overwrite previous answers
  • Continuous applications non stop (beta)
  • No need for fear of missing out, Goes through all possible filters and sorts combinations with each cycle if configured (Most Recent, Most Relevant, Newest First, Past 24 Hrs, Past Month, Past Week etc)
  • Option to randomize the search order
  • Run in background, headless browser
  • Auto collects a looooooooooooooooooot of info about your jobs, check applied-jobs.excel and failed_jobs.excel for info after each run.
  • Optional pause before submit application.
  • Optional pause if stuck at a question.

Stealth features 🥸🤫:

  • Undetected Chromedriver to bypass anti-bot scripts (Browser, Undetected ChromeDriver versions must be compatible) (Beta) {If problem occurs uninstall and install undetected chromedriver, update browser, selenium and chromedriver}
  • Click intervals can be randomized and increased to avoid suspicions
  • Smooth Scrolls the elements into view before click

Upcoming Features or currently in development 🤖🛠️:

  • Answer questions with help of chatGpt or other LLMs
  • Humanize clicks and mouse movements for stealth
  • Auto send personalized messages to HR that accept messages
  • Custom resume generator based on Skills required gathering (In Development)
  • Customize resume for every job using LLMs ChatGPT (In Development). (Halted decision pending, will probably implement api or utilize other LLMs or Web Scrape)

Currently Broken 🥲😭:

  • All ChatGPT features:
    • ChatGPT Login
    • ChatGPT resume chat window opener

back to index


✉️ My Heartfelt letter to you ❤️...

My Dear User,

Thank you for using the job application tool! Your support means everything to me.

As you continue your job search, I hope this tool has provided you with valuable assistance and streamlined your efforts.

To continue improving and maintaining this tool, I rely on the support of users like you. If you believe in its mission and want to contribute, you can support me by sharing about this project with your peers and network.

If you need a post to communicate about it: https://www.linkedin.com/posts/saivigneshgolla_jobsearch-jobapplication-careerdevelopment-activity-7166416367628341249-WE_8

By doing so, you can empower others in their job hunt, just as you've been empowered.. Every contribution, big or small, makes a significant impact!

As an independent developer, I pour my heart and soul into creating tools like this, driven by the genuine desire to make a positive impact. Your support, whether through donations or simply spreading the word, means the world to me and helps keep this project alive and thriving.

You can connect and reach me out at:


Thank you for being part of this journey, and remember that together, we can make a real difference in the lives of job seekers worldwide.

With heartfelt appreciation,
Sai Vignesh Golla



back to index


🗓️ Major Updates History:

Nov 28, 2024

  • Patched to work for latest changes in Linkedin.
  • Users can now select to follow or not follow companies when submitting application.
  • Frameworks for future AI Developments have been added.
  • AI can now be used to extract skills from job description.

Oct 16, 2024

  • Framework for OpenAI API and Local LLMs
  • Framework for RAG

Sep 09, 2024

  • Smarter Auto-fill for salaries and notice periods
  • Robust Search location filter, will work in window mode (No need for full screen)
  • Better logic for Select and Radio type questions
  • Proper functioning of Decline to answer questions in Equal Employment opportunity questions
  • Checkbox questions select fail bug fixed
  • Annotations are clearer in instructions for setup

Sep 07, 2024

  • Annotations for developers
  • Robust input validations
  • Restructured config file
  • Fixed pagination bug

Aug 21, 2024

  • Performance improvements (skip clicking on applied jobs and blacklisted companies)
  • Stop when easy apply application limit is reached
  • Added ability to discard from pause at submission dialogue box
  • Added support for address input
  • Bug fixed radio questions, added support for physical disability questions
  • Added framework for future config file updates

June 19, 2024

  • Major Bug fixes (Text Area type questions)
  • Made uploading default resume as not required

May 15, 2024

  • Added functionality for textarea type questions summary, cover_letter(Summary, Cover letter); checkbox type questions (acknowledgements)
  • Added feature to skip irrelevant jobs based on bad_words
  • Improved performance for answering questions
  • Logic change for masters students skipping
  • Change variable names blacklist_exceptions -> about_company_good_words and blacklist_words -> about_company_bad_words
  • Added session summary for logs
  • Added option to turn off "Pause before Submit" until next run

May 05, 2024

  • For questions similar to "What is your current location?", City posted in Job description will be posted as the answer if current_city is left empty in the configuration
  • Added option to over write previously saved answers for a question overwrite_previous_answers
  • Tool will now save previous answer of a question
  • Tool will now collect all available options for a Radio type or Select type question
  • Major update in answering logic for Easy Apply Application questions
  • Added Safe mode option for quick stable launches safe_mode

May 04, 2024

  • Added option to fill in "City, state, or zip code" search box search_location
  • Bug fixes in answering City or location question

back to index


📜 Disclaimer

This program is for educational purposes only. By downloading, using, copying, replicating, or interacting with this program or its code, you acknowledge and agree to abide by all the Terms, Conditions, Policies, and Licenses mentioned, which are subject to modification without prior notice. The responsibility of staying informed of any changes or updates bears upon yourself. For the latest Terms & Conditions, Licenses, or Policies, please refer to Auto Job Applier. Additionally, kindly adhere to and comply with LinkedIn's terms of service and policies pertaining to web scraping. Usage is at your own risk. The creators and contributors of this program emphasize that they bear no responsibility or liability for any misuse, damages, or legal consequences resulting from its usage.

🏛️ Terms and Conditions

Please consider the following:

  • LinkedIn Policies: LinkedIn has specific policies regarding web scraping and data collection. The responsibility to review and comply with these policies before engaging, interacting, or undertaking any actions with this program bears upon yourself. Be aware of the limitations and restrictions imposed by LinkedIn to avoid any potential violation(s).

  • No Warranties or Guarantees: This program is provided as-is, without any warranties or guarantees of any kind. The accuracy, reliability, and effectiveness of the program cannot be guaranteed. Use it at your own risk.

  • Disclaimer of Liability: The creators and contributors of this program shall not be held responsible or liable for any damages or consequences arising from the direct or indirect use, interaction, or actions performed with this program. This includes but is not limited to any legal issues, loss of data, or other damages incurred.

  • Use at Your Own Risk: It is important to exercise caution and ensure that your usage, interactions, and actions with this program comply with the applicable laws and regulations. Understand the potential risks and consequences associated with web scraping and data collection activities.

  • Chrome Driver: This program utilizes the Chrome Driver for web scraping. Please review and comply with the terms and conditions specified for Chrome Driver.

⚖️ License

Copyright (C) 2024 Sai Vignesh Golla saivigneshgolla@outlook.com

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.

See AGPLv3 LICENSE for more info.


back to index


🐧 Socials

🙌 Community Support and Discussions

ℹ️ Version: 24.12.29.12.30 Stable Preview


back to the top