> ## Documentation Index
> Fetch the complete documentation index at: https://developers.chatwoot.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Windows Development Setup

> Complete guide to setting up your Windows development environment for Chatwoot contribution using WSL2.

# Windows Development Setup

This guide will walk you through setting up your Windows development environment for contributing to Chatwoot. We'll use Windows Subsystem for Linux 2 (WSL2) which provides the best development experience on Windows.

## Requirements

You need to install the Windows Subsystem for Linux 2 (WSL2) on your Windows machine.

### Prerequisites

* Windows 10 version 2004 and higher (Build 19041 and higher) or Windows 11
* Administrator privileges on your Windows machine

## Step 1: Enable Developer Mode

The first step is to enable "Developer mode" in Windows. You can do this by opening up Settings and navigating to "Update & Security". In there, choose the tab on the left that reads "For Developers". Turn the "Developer mode" toggle on to enable it.

<img src="https://mintcdn.com/chatwoot-447c5a93/0ZKii1AePO4f9gzo/contributing-guide/project-setup/img/developer-mode.jpg?fit=max&auto=format&n=0ZKii1AePO4f9gzo&q=85&s=c5c411bd16ca04cd654b2de9228af266" width="500" alt="Enable Developer Mode" data-path="contributing-guide/project-setup/img/developer-mode.jpg" />

## Step 2: Enable Windows Subsystem for Linux

Next you have to enable the Windows Subsystem for Linux. Open the "Control Panel" and go to "Programs and Features". Click on the link on the left "Turn Windows features on or off". Look for the "Windows Subsystem for Linux" option and select the checkbox next to it.

<img src="https://mintcdn.com/chatwoot-447c5a93/0ZKii1AePO4f9gzo/contributing-guide/project-setup/img/enable-wsl.jpg?fit=max&auto=format&n=0ZKii1AePO4f9gzo&q=85&s=98181c88b33719a59dae918366dd5606" width="500" alt="Enable WSL" data-path="contributing-guide/project-setup/img/enable-wsl.jpg" />

You'll also need to enable "Virtual Machine Platform" for WSL2. Make sure both checkboxes are selected:

* ✅ Windows Subsystem for Linux
* ✅ Virtual Machine Platform

After enabling these features, restart your computer.

## Step 3: Install WSL2 and Ubuntu

### Option 1: Using Microsoft Store (Recommended)

1. **Open Microsoft Store** and search for "Ubuntu"
2. **Install Ubuntu 22.04 LTS** (or latest LTS version)
3. **Launch Ubuntu** from the Start Menu

### Option 2: Using Command Line

Open PowerShell as Administrator and run:

```powershell theme={null}
# Install WSL2 with Ubuntu
wsl --install -d Ubuntu-22.04

# Set WSL2 as default version
wsl --set-default-version 2
```

## Step 4: Initial Ubuntu Setup

When you first launch Ubuntu, you'll be prompted to create a user account:

```bash theme={null}
# Create a username and password when prompted
# This will be your Linux user account
```

Update the system packages:

```bash theme={null}
sudo apt update && sudo apt upgrade -y
```

## Step 5: Install Core Dependencies

You need core Linux dependencies installed in order to install Ruby and other tools.

```bash theme={null}
sudo apt-get update
sudo apt-get install -y git-core curl zlib1g-dev build-essential libssl-dev libreadline-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt1-dev libcurl4-openssl-dev software-properties-common libffi-dev
```

## Installing RVM & Ruby

Install additional dependencies required for RVM:

```bash theme={null}
sudo apt-get install -y libgdbm-dev libncurses5-dev automake libtool bison libffi-dev
```

Install RVM & Ruby version 3.2.2:

```bash theme={null}
# Add RVM GPG keys
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB

# Install RVM
curl -sSL https://get.rvm.io | bash -s stable

# Load RVM into current session
source ~/.rvm/scripts/rvm

# Install Ruby 3.2.2
rvm install 3.2.2
rvm use 3.2.2 --default

# Verify installation
ruby -v
```

## Install Node.js

Chatwoot requires Node.js version 20. Install Node.js from NodeSource using the following commands:

```bash theme={null}
curl -sL https://deb.nodesource.com/setup_20.x | sudo -E bash -
sudo apt-get install -y nodejs
```

Verify Node.js installation:

```bash theme={null}
node --version
# Should output: v20.x.x
```

## Install pnpm

We use `pnpm` as the package manager for better performance:

```bash theme={null}
# Install pnpm globally
npm install -g pnpm

# Verify installation
pnpm --version
```

## Install PostgreSQL

The database used in Chatwoot is PostgreSQL. Use the following commands to install PostgreSQL:

```bash theme={null}
sudo apt install -y postgresql postgresql-contrib
```

The installation procedure created a user account called postgres that is associated with the default Postgres role. In order to use PostgreSQL, you can log into that account:

```bash theme={null}
sudo -u postgres psql
```

Install `libpq-dev` dependencies for Ubuntu:

```bash theme={null}
sudo apt-get install -y libpq-dev
```

Start PostgreSQL service:

```bash theme={null}
sudo service postgresql start
```

Configure PostgreSQL to start automatically:

```bash theme={null}
echo 'sudo service postgresql start' >> ~/.bashrc
```

Create a database user:

```bash theme={null}
# Switch to postgres user and create a superuser
sudo -u postgres createuser --superuser $USER

# Set password for your user
sudo -u postgres psql -c "ALTER USER $USER PASSWORD 'password';"
```

## Install Redis Server

Chatwoot uses Redis server for agent assignments and reporting. To install `redis-server`:

```bash theme={null}
sudo apt-get install -y redis-server
```

Start Redis service:

```bash theme={null}
sudo service redis-server start
```

Configure Redis to start automatically:

```bash theme={null}
echo 'sudo service redis-server start' >> ~/.bashrc
```

Enable Redis to start on system boot:

```bash theme={null}
sudo systemctl enable redis-server.service
```

## Install ImageMagick

Chatwoot uses ImageMagick for image processing:

```bash theme={null}
sudo apt-get install -y imagemagick libmagickwand-dev
```

## Configure Git

Set up Git with your information:

```bash theme={null}
git config --global user.name "Your Name"
git config --global user.email "your.email@example.com"
```

## Windows-Specific Configuration

### Install VS Code with WSL Extension

1. **Install Visual Studio Code** on Windows from [https://code.visualstudio.com/](https://code.visualstudio.com/)
2. **Install Remote - WSL extension** from the Extensions marketplace
3. **Open your project in WSL** by running `code .` from your WSL terminal

### Configure File Permissions

WSL2 may have file permission issues. Fix them:

```bash theme={null}
# Add to ~/.bashrc for better file permissions
echo 'umask 022' >> ~/.bashrc

# Configure Git to ignore file mode changes
git config --global core.filemode false
```

## Environment Verification

Verify all installations are working correctly:

```bash theme={null}
# Check all versions
ruby --version        # Should be 3.2.2
node --version         # Should be v20.x.x
pnpm --version        # Should show pnpm version
psql --version        # Should show PostgreSQL version
redis-cli ping        # Should output: PONG
convert --version     # Should show ImageMagick version
git --version         # Should show Git version
```

## Troubleshooting Common Issues

<Accordion title="WSL installation fails">
  **Solution**: Ensure virtualization is enabled in BIOS and Windows features are properly enabled:

  1. Restart computer and enter BIOS settings
  2. Enable Intel VT-x or AMD-V virtualization
  3. Enable Hyper-V in Windows Features
  4. Restart and try installation again
</Accordion>

<Accordion title="Ubuntu terminal won't open">
  **Solution**: Reset WSL or reinstall Ubuntu:

  ```powershell theme={null}
  # Reset Ubuntu (will delete all data)
  wsl --unregister Ubuntu-22.04
  wsl --install -d Ubuntu-22.04
  ```
</Accordion>

<Accordion title="PostgreSQL fails to start">
  **Solution**: Check if Windows PostgreSQL service is conflicting:

  ```bash theme={null}
  # Stop Windows PostgreSQL service first (run in Windows Command Prompt as Admin)
  net stop postgresql-x64-14

  # Then start WSL2 PostgreSQL
  sudo service postgresql start
  ```
</Accordion>

<Accordion title="Permission denied errors">
  **Solution**: Fix file permissions:

  ```bash theme={null}
  # For the entire project
  find . -type f -exec chmod 644 {} \;
  find . -type d -exec chmod 755 {} \;

  # For executable files
  chmod +x bin/*
  ```
</Accordion>

<Accordion title="Slow performance">
  **Solution**: Ensure code is stored in WSL2 filesystem:

  ```bash theme={null}
  # Good: Store code here (fast)
  /home/username/projects/chatwoot

  # Avoid: Storing code here (slow)
  /mnt/c/Users/Username/projects/chatwoot
  ```
</Accordion>

If you encounter issues during setup:

* **Common Errors**: Check [Common Errors](/contributing-guide/common-errors)
* **WSL2 Documentation**: [Microsoft WSL Documentation](https://docs.microsoft.com/en-us/windows/wsl/)
* **Discord Community**: Join our [Discord](https://discord.com/invite/cJXdrwS)
* **GitHub Issues**: [Create an issue](https://github.com/chatwoot/chatwoot/issues)

***

Your Windows development environment with WSL2 is now ready for Chatwoot development! 🪟🐧
