#automation #cli #networking #job-search

bin+lib jobshell

A CLI tool for job searching and scraping job boards

13 stable releases

new 2.0.1 Jan 10, 2025
2.0.0 Jan 8, 2025
1.0.12 Dec 29, 2024

#891 in Command line utilities

Download history 348/week @ 2024-12-11 137/week @ 2024-12-18 806/week @ 2024-12-25 46/week @ 2025-01-01 320/week @ 2025-01-08

1,314 downloads per month

MIT license

695KB
4.5K SLoC

JobShell: Because Job Hunting is Hell Enough

GitHub Release GitHub Repo stars Downloads Issues Pull Requests Crates.io Total Downloads Homebrew crates.io

Are you a software engineer desperately seeking employment but done with LinkedIn’s circus of virtue-signaling posts and irrelevant job alerts? Tired of getting emails that scream “Exciting opportunities in your network!” only to find out John liked Dave’s post about on-site synergy?

Wish you could manage your job search from the comfort of your terminal cave, where corporate nonsense can’t reach you? Well, my friend, welcome to JobShell—the no-bullshit solution to staying updated on opportunities at companies you actually care about.

Say goodbye to distractions and hello to streamlined job hunting.

Table of Contents


Key Features

  1. CLI Mode

    • Interactive Navigation: Run jobshell for a terminal-based menu. Scrape jobs from individual companies, view new postings, and manage your professional network from a single interface.
    • Network-Based Discovery: Scan for new roles exclusively at companies where you have existing connections or have "followed".
    • Bookmarks & Draft Messages: Bookmark interesting jobs for later review and draft personalized opening messages to your connections.
  2. Discord Integration Mode

    • Automated Updates via Webhook: Use jobshell --discord to run a continuous background scrape for all supported companies. It will periodically post new job updates to a specified Discord channel.
    • Scheduled Execution: Configure the scraper to run at regular intervals (every 1–12 hours) to stay informed with the latest openings.

Supported Companies

1Password Airbnb Atlassian Blizzard
Chase Cisco Cloudflare Coinbase
CoStar Discord Disney DoorDash
Experian GitHub GitLab IBM
Meta Netflix Nike Norton
Palantir PayPal Reddit Robinhood
Salesforce ServiceNow Square Stripe
Toast Uber

See Full List of Companies

Want a company added to JobShell?

Submit a Company Request by opening a GitHub issue.


Prerequisites

Before running JobShell, ensure you have the following:

  1. Detectable Chrome Binary:
    JobShell uses browser automation to scrape job postings. You must have a working Chrome installation that can be detected by the underlying scraper.

    • If you're on macOS, ensure you have Google Chrome installed in the standard location.
    • On Linux, install Google Chrome via your package manager (e.g., apt, yum) or download from the official site.
    • On Windows, ensure Chrome is installed in a standard location or is available in your PATH.
  2. Desktop Environment (or Virtual Environment):
    Headless scraping may still require a display server. If running on a server, use Xvfb or similar tools to simulate a desktop environment.


Installation

🏠 Install via Homebrew (macOS)

brew tap angelplusultra/jobshell
brew install jobshell

📦 Install via Cargo (All Platforms)

cargo install jobshell

📥 Install from Release (macOS and Windows only for now)

  1. Download a Binary from Releases:
    Head to the Releases page and download the latest binary that matches your operating system.

  2. Place the Binary in Your $PATH:
    Move the binary to a directory that's included in your system’s $PATH. On most UNIX-like systems, this could be:

    mv jobshell /usr/local/bin/
    
  3. Set Executable Permissions:
    Ensure the binary is executable:

    chmod +x /usr/local/bin/jobshell
    
  4. Bypass Apple Gatekeeper on macOS (If Necessary):
    On macOS, you might need to bypass Gatekeeper’s security checks if the binary isn’t signed:

    sudo xattr -r -d com.apple.quarantine /usr/local/bin/jobshell
    

    If prompted by Gatekeeper, you can also open System Preferences > Security & Privacy and choose to "Open Anyway" for the jobshell binary.

🛠️ Build from Source

  1. Install Rust:
    If not already installed on your system, Install Rust.

  2. Clone the Repo:
    Clone the repo to your system and cd into it

    git clone https://github.com/angelplusultra/job-shell && cd job-shell
    
  3. Create a Release Build:
    Compile the JobShell binary for your platform

    cargo build --release
    
  4. Add the Binary to Your $PATH:
    Move or copy the compiled binary to a directory on your $PATH.

    An example:

    mv ./target/release/jobshell /usr/bin/jobshell 
    

Verify Installation

jobshell --version

Usage

⌨ CLI Mode

Basic Command:
Run JobShell in interactive CLI mode:

jobshell

What You Can Do in CLI Mode:

  • Scrape Individual Companies:
    Choose a company from the menu and scrape the latest postings.

  • Manage Connections: Create and manage your personal connections at the supported companies

  • Scan for New Network Jobs:
    If you’ve configured your connections, scan for new roles at companies where you have at least one connection.

  • View New Jobs Reports:
    Open generated new jobs HTML reports for clearer insights

  • Bookmark Jobs:
    Mark interesting opportunities for future reference.

  • Reach out to connections:
    Once you discover a job that interests you and have a connection at the company, JobShell lets you craft a personalized message and open your contact’s LinkedIn profile in one go. Your message, along with the job link, is automatically copied to your clipboard, ready to paste and send.

🤖 Discord Mode

jobshell --discord

When jobshell --discord is executed, a wizard will guide you through the setup process. This wizard collects the necessary information to configure the job-scraping process and ensures Discord notifications are set up correctly.

Wizard Steps

  1. Enter Discord Channel Webhook URL
    • You’ll be prompted to provide the webhook URL for the Discord channel where job notifications will be posted.
    • Example: https://discord.com/api/webhooks/someid/someid
      • How to Get a Discord Webhook URL
        1. Open your Discord server
        2. Navigate to the desired channel and click the gear icon to open the channel settings.
        3. Go to the Integrations tab.
        4. Select Webhooks and click Create Webhook.
        5. Customize the webhook settings, copy the Webhook URL, and paste it into the prompt.
  2. Set Hourly Interval
    • Enter the scraping interval in hours. This value must be an integer between 1 and 12.
    • Example Input: 6
  3. Choose Scraping Scope
    • Specify whether you want to scrape all supported companies or restrict scraping to:

      • Companies you have at least one connection with.
      • Companies you’ve chosen to “follow” via CLI mode.
    • Prompt Example:

      Scan all companies? (otherwise only followed companies or companies where you have at least 1 connection) (yes/no)
      

Once all prompts all completed, JobShell begins scraping job postings at the specified hourly interval and new job postings will be sent to the provided Discord channel webhook.

Smart Criteria (AI Feature)

What is Smart Criteria?

Smart Criteria is an optional feature powered by AI (ChatGPT) that allows you to filter newly detected jobs to match your personal preferences. Without Smart Criteria enabled, the Discord channel you set in Discord mode will receive notifications for every new job detected at a company—regardless of whether the role aligns with your search preferences or interests.

This may work well for community Discord servers where you want visibility into all job postings. However, for personal job searches, it can lead to unnecessary noise. Smart Criteria helps you focus on the jobs that matter to you by filtering out irrelevant roles.

How Does Smart Criteria Work?

Smart Criteria is simple to use. You provide plain-text instructions that tell the AI what kind of jobs you’re interested in. The AI then evaluates each job posting against your criteria and notifies you only about jobs that meet your preferences.

Example Smart Criteria:

I am interested in Software Engineer jobs based in Southern California or Remote, US.

How to Enable Smart Criteria

  1. Set your Open AI API key as an environment variable
export OPENAI_KEY=your_api_key_here

Replace your_api_key_here with your actual API key.

  1. Enable Smart Criteria:
    • Navigate to the main menu in JobShell and enable the Smart Criteria feature.
    • Set your criteria directly in the interface.
  2. Enjoy Filtered Job Notifications:
    • Scan For New Jobs Across Network and Followed Companies will now only reveal new jobs that match your smart criteria
    • JobShell in Discord mode will only deploy notifications when new jobs match your smart criteria

Suggested Workflow

To get the most out of JobShell, follow this workflow:

  1. Set Up Your Preferences in CLI Mode
    • Start by running JobShell in CLI mode. Configure your connections, "follow" companies of interest, and set up your Smart Criteria if you have an Open AI API key.
  2. Deploy JobShell in Discord Mode
    • Once set up, switch to Discord mode to receive real-time job notifications directly in your designated Discord channel.
  3. Run JobShell on a VPS (Optional)
    • If you don’t have a machine to keep JobShell running continuously, consider using a Virtual Private Server (VPS) from providers like DigitalOcean, Linode, or Vultr.

That’s it! You’re all set to simplify your job search with JobShell.

Dependencies

~21–38MB
~625K SLoC