This process assumes a user is using a Windows machine and has admin rights.
Visit this page and click on the SessionCounterInstall artifact.
Navigate to your Downloads folder, and extract the .zip file.
- Right click on SessionCounterInstall.exe and click "Run as Administrator"
- Follow the instructions to install Wireshark
- For npcap, check all three options
- Restrict Npcap driver's access to Administrator only
- Support raw 802.11 traffic (and monitor mode) for wireless adapters
- Install Npcap in WinPcap API-compatible mode
- Ctrl + Alt + Delete to open the Task Manager
- Scroll to the Background Processes section
- If
Windows Service Wrapper
is running theestimating-wifi
program, then it's running in the background as expected
While the service is running in the background, you may need to update session-counter.ini with new config values.
- Open your Windows start menu and search for Notepad
- Right click the Notepad app and click 'Run as administrator'
- Click 'File' > 'Open' and navigate to 'C:\Program Files (x86)\IMLS Session Counter\service\session-counter.ini'
- Update
session-counter.ini
with your desired variable(s), then save the file - Open Powershell as an admin and cd to C:\Program Files (x86)\IMLS Session Counter\service
- Run
./WinSw-x64.exe restart estimating-wifi
- Run
./WinSw-x64.exe status estimating-wifi
(just to confirm it's running) - You can check
WinSw-x64.err.log
to see if your changes were made
This process assumes a user is using a Windows machine, has admin rights, has downloaded the entire repository as a .zip, extracted all files into a folder, and is currently in the imls-windows-installer directory.
- Open Windows powershell and cd to estimating-wifi\imls-windows-installer
- Enter
./session-counter_build_prereqs.ps1
to run the script
- Downloads, installs, and adds GoLang 1.19 to your Windows Path
- If GoLang is already installed on your system, the script proceeds to the next step
- Downloads, installs, and adds the latest version of Inno Setup to your system
- If Inno Setup is already installed on your system, the script proceeds to the nexts tep
- Builds session-counter.exe from the imls-wifi-sensor directory and moves it to the imls-windows-installer directory
- If session-counter.exe is already found in imls-windows-installer, the script deletes it and builds a new one
- Builds wifi-hardware-search-windows.exe from the imls-wifi-sensor directory and moves it to the imls-windows-installer directory
- If wifi-hardware-search-windows.exe is already found in imls-windows-installer, the script deletes it and builds a new one
- Open Inno Setup and choose imls-windows-installer\setup.iss as the configuration script
- Compile the executable by clicking 'Build' at the top toolbar
- Open the newly created estimating-wifi\imls-windows-installer\Output folder
- Right click on SessionCounterInstall.exe and click "Run as Administrator"
- Follow the instructions
- Note: the WiresharkPortable app cannot be placed in any Program Files directories
- Ctrl + Alt + Delete to open the Task Manager
- Scroll to the Background Processes section
- If
Windows Service Wrapper
is running theestimating-wifi
program, then it's running in the background as expected
To run end-to-end tests on Windows requires WSL2. The basic idea is to run the backend in a Linux VM and have the Windows service "talk" to this backend. Steps:
- Install WSL2 and your favorite Linux distribution.
- Run
wsl --install
in Powershell (Run as Administrator) - Restart your machine
- Ubuntu has a good guide on how to install Ubuntu on WSL2.
- Run
- In Ubuntu, install the tools necessary to run Docker.
sudo apt-get -y install docker-compose docker.io
- You might need to run
sudo apt-get update
beforehand.
- You might need to run
- Running Docker in Ubuntu in WSL can be clunky. We'll have to start the service manually because systemd is not available (although this has changed recently):
sudo dockerd
- Now we can build the backend.
- Open up a separate Ubuntu terminal
- Clone this repository
- Change directory to the
imls-backend
directory - Run
sudo docker build -t imls:postgres -f Dockerfile.pgjwt .
- You might need to run
sudo apt-get update
again beforehand
- You might need to run
- Run
DOCKER_HOST=unix:///var/run/docker.sock docker-compose up
- Please note, if this command fails as a normal user, you can add your user to the group
sudo usermod -aG docker $USER
or you can justsudo
this command.
- Please note, if this command fails as a normal user, you can add your user to the group
- You probably also want to run migrations. Unfortunately,
dbmate
is not easily installable on Ubuntu, so we'll download the binary ourselves.- Open up a separate (third!) Ubuntu terminal (make sure you are in the
imls-backend
directory) sudo curl -fsSL -o dbmate https://github.com/amacneil/dbmate/releases/latest/download/dbmate-linux-amd64
sudo chmod +x dbmate
sudo ./dbmate -u "postgres://postgres:imlsimls@localhost:5432/imls?sslmodel=disable" up
- Open up a separate (third!) Ubuntu terminal (make sure you are in the
- To verify that all is running correctly:
- Open up a separate Powershell terminal and run
curl.exe -v 127.0.0.1:3000/presences
- Open up a separate Powershell terminal and run
- Install the Windows session-counter service as normal, if you haven't already.
- Edit your session-counter.ini:
- Under
[api]
, you should have:host=127.0.0.1:3000
- The windows session-counter should run with the default ini configuration
- But if you need to change any ini settings:
- After changing the ini file, restart session-counter by running
WinSw-x64.exe restart
in the installed IMLS Session Counter directory.
- After changing the ini file, restart session-counter by running
- Under