Skip to content
A cross platform computer management client
C# Objective-C Shell PowerShell Batchfile
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
.nuget Cleanup all code Aug 10, 2015
BootStrap This commit adds the Mono URL Oct 13, 2015
BuildTools Switch to new signing cert Sep 27, 2016
Debugger Remove a bunch of auto generated files from the repo Jul 29, 2019
MSI Add Portuguese language - closing issue #105 Jul 8, 2019
Modules Set default code page to prevent from error on systems with mixed cod… Sep 9, 2019
PrinterManagerHelper Update copyrights Apr 15, 2017
Service Remove a bunch of auto generated files from the repo Jul 29, 2019
SetupHelper Allow installer to work when port 80 is blocked and up version Feb 14, 2018
ShutdownGUI Add Portuguese language - closing issue #105 Jul 8, 2019
Tray Remove a bunch of auto generated files from the repo Jul 29, 2019
UniversalInstaller Update libraries: Zazzles, Newtonsoft.Json to 12.0.2, WebSocket4Net to Jul 28, 2019
UpdateHelper Remove a bunch of auto generated files from the repo Jul 29, 2019
UpdateWaiter Remove a bunch of auto generated files from the repo Jul 29, 2019
UserService Remove a bunch of auto generated files from the repo Jul 29, 2019
libs Update libraries: Zazzles, Newtonsoft.Json to 12.0.2, WebSocket4Net to Jul 28, 2019
packages Completely remove unused PowerCLI as disabled in 594b952 Jul 29, 2019
resources Remove spinner image Oct 10, 2015
.gitignore Update .gitignore May 2, 2017
.travis.yml Update .travis.yml Oct 14, 2015
FOGService.sln Update Newtonsoft.Json library version to 10.0.3 Oct 3, 2017
FOGService.sln.DotSettings Increment to 0.11.0 Jun 19, 2016
FOGService.v12.suo Add ProcessCore to Debugger Aug 1, 2015 Add nicer code syntax and registry keys for SDK installer. Jul 25, 2017
build.ps1 Update libraries: Zazzles, Newtonsoft.Json to 12.0.2, WebSocket4Net to Jul 28, 2019
license.txt Add license Jan 24, 2015
themes.xml Make shutdown prompt look nicer with styling Dec 5, 2016

FOG Client


FOG Client is a cross platform computer management software. With it, Linux, Mac, and Windows machines can easily be managed by a remote server.


Stories in progress

Windows Linux OSX
Windows [![Linux] (] ( [![OSX] (] (

Cross Platform Compatibility

Feature Windows Linux OSX
Auto Logout
Auto Updating
Join Active Directory
Join Samba Directory
Join Open Directory
Snapin Packs
Task Reboot
User Tracker
TCP/IP Printers
Network Printers
CUPS Printers



To checkout and build the entire client (including the Installer) Windows is required. This is due to the MSI for network deployment and the Universal Installer. The following dependencies must be installed and included in PATH

  • Git for Windows
    • Default install settings are fine.
  • WiX Toolset
    • Download installer wix???.exe from github repo linked on that website.
  • Powershell / WMF 4.0+ (Windows 7 ships with 3.0)
    • See Install Instructions on that page to find the correct package for your system
  • .NET v4.6
  • MSBuild Tools 2015
    • Included with Visual Studios 2015 if you have that already
    • Add to PATH - for instructions see below
  • Windows SDK 7, .NET 4
    • Before running the installer note down and then adjust some registry keys or the installer will fail (details see here)
      • 32 bit: HKLM\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Client\Version and HKLM\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full\Version
      • 64 bit: HKLM\SOFTWARE\Wow6432Node\Microsoft\NET Framework Setup\NDP\v4\Client\Version and HKLM\SOFTWARE\Wow6432Node\Microsoft\NET Framework Setup\NDP\v4\Full\Version
    • Default setup is ok if you have enough disk space left but you can savely go with only selecting '.NET Development' and the two submodules
    • After installation change back the registry keys to what they were before

In case you want to build the Universal Installer you need to add ILMerge as well:

  • ILMerge
    • (Add to PATH - for instructions see below)

Adding PATH variables:

  • Win+R key -> rundll32.exe sysdm.cpl,EditEnvironmentVariables
  • New... -> Variable name: PATH, Variable value: C:\Program Files\MSBuild\14.0\Bin;C:\Program Files\Microsoft\ILMerge

Now, restart your system!

Repository and powershell setting

Open Git Bash and clone the repository:

IEUser@WIN7 MINGW32 ~/Desktop
$ git clone
Cloning into 'fog-client'...

Powershell must be configured to allow scripts to be run on the machine. Open CMD as adminstrator and run

powershell "Set-ExecutionPolicy RemoteSigned"

Build Command

powershell "C:\path\to\fog-client\build.ps1"

The binaries will be in C:\path\to\fog-client\bin


The client's functionality derives from modules. Each module has 1 specific goal, and is isolated from every other module. Each module is executed in a sandbox-like environment, preventing bad code from crashing the service. Since each module is isolated, the client's server can choose which modules to enable or disable.


AutoLogOut is responsible for automatically logging out users after a set inactivity period. Once that time period is reached, the user is notified that if they remain inactive they will be logged out.

  • On Linux AutoLogOut is only possible if xprintidle is installed.
  • On Windows one user must be logged in for other users to log out. This is a security measure put in place by Windows. For example, if 5 users are 'logged in', but all hit the 'Switch User' button, non will be logged out. But once someone logs into the machine they will be. GPO is recommened to handle auto log outs on Windows because of this restriction.


PowerManagement is a cron-style power management module. A computer can be configured to restart / shutdown at specific times / days. On-demand shutdown / restarts can also be issued with this module.


HostnameChanger is one of the core, and most used, modules of the client. It will:

  • Rename a computer
  • Join a domain
  • Leave a domain
  • Activate a windows installation with a product key

This module also handles renaming in a domain-friendly fashion. If a computer is joined to a domain, it will first leave the domain, then rename the host, and then join back. This ensures that there are no remenants in the domain.


PrinterManager is aimed to replace the difficult GPO printer systems. Due to the complexity of printers in general, this module has one of the steepest learning curves.

There are three printer management modes

  1. None No printers will be added or removed, this is identical to disabling the module
  2. FOG Managed Printers The module will only remove printers from a computer if FOG is set to manage it. For example, if a person has personal printer attached to their computer, this module will not touch it.
  3. Only Assigned Printers This mode should be used with caution. If selected, this module will only allow assigned printers to be added to a computer. For example, if a person has a personal printer, this module will prevent the user from adding it, unless a FOG administrator adds the printer to the list of managed.


Snapins are executables push out via the FOG server. A snapin can also be set to reboot after finishing. With this module you can push out MSIs, EXEs, batch scripts, shell scripts, or any other file capable of being executed.


TaskReboot will automatically restart a computer if the client's server has task waiting for the computer. Example tasks include image deployment, image capturing and hardware inventory.


UserTracker will automatically report to the FOG server any logins or logouts that occur on the computer.

You can’t perform that action at this time.