// Copyright 2005-2019 The Mumble Developers. All rights reserved. // Use of this source code is governed by a BSD-style license // that can be found in the LICENSE file at the root of the // Mumble source tree or at . #include "olsettings.h" #include "lib.h" // include lib.h for Windows headers... #include "util.h" #include #include #include #include #include "overlay_blacklist.h" #include "overlay_whitelist.h" #include "overlay_launchers.h" // Get the default blacklist (from overlay_blacklist.h) as a string vector. static std::vector defaultBlacklistVector() { std::vector out; size_t i = 0; while (overlayBlacklist[i] != NULL) { out.push_back(std::string(overlayBlacklist[i])); i++; } return out; } // Get the default whitelist (from overlay_whitelist.h) as a string vector. static std::vector defaultWhitelistVector() { std::vector out; size_t i = 0; while (overlayWhitelist[i] != NULL) { out.push_back(std::string(overlayWhitelist[i])); i++; } return out; } // Get the default launcher list (from overlay_launchers.h) as a string vector. static std::vector defaultLaunchersVector() { std::vector out; size_t i = 0; while (overlayLaunchers[i] != NULL) { out.push_back(std::string(overlayLaunchers[i])); i++; } return out; } // Read a REG_MULTI_SZ value from the Windows registry and return it as a string vector. // Returns an empty vector on failure. static std::vector regReadMultiString(HKEY key, const std::string &subKey, const std::string &valueName) { LONG err = 0; std::vector out; char *buf = NULL; HKEY subKeyHandle = 0; err = RegOpenKeyExA(key, subKey.c_str(), NULL, KEY_READ, &subKeyHandle); if (err != ERROR_SUCCESS) { goto err; } DWORD sz = 0; DWORD type = 0; err = RegQueryValueExA(subKeyHandle, valueName.c_str(), NULL, &type, NULL, &sz); if (err != ERROR_SUCCESS) { goto err; } if (type != REG_MULTI_SZ) { goto err; } // If the size is longer than 4MB, treat it as an error. if (sz > 4*1024*1024) { goto err; } buf = reinterpret_cast(malloc(sz)); if (buf == NULL) { goto err; } err = RegQueryValueExA(subKeyHandle, valueName.c_str(), NULL, &type, reinterpret_cast(buf), &sz); if (err != ERROR_SUCCESS) { goto err; } size_t begin = 0; for (size_t i = 0; i < sz; i++) { if (buf[i] == 0) { size_t len = i - begin; if (len > 0) { std::string s(&buf[begin], len); out.push_back(s); } begin = i + 1; } } err: free(buf); return out; } // Get the Mumble client's configured overlay exclusion mode as an integer. // Returns -1 if the function could not read the value from the Windows registry. static int getModeInternal() { LONG err = 0; HKEY key = NULL; DWORD mode = -1; err = RegOpenKeyExA(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", NULL, KEY_READ, &key); if (err != ERROR_SUCCESS) { return -1; } DWORD sz = sizeof(mode); err = RegQueryValueExA(key, "mode", NULL, NULL, reinterpret_cast(&mode), &sz); if (err != ERROR_SUCCESS) { return -1; } if (sz != sizeof(mode)) { return -1; } return static_cast(mode); } OverlayExclusionMode SettingsGetExclusionMode() { int mode = getModeInternal(); if (mode == -1) { // If no exclusion mode is set in the registry, // use the launcher filter. return LauncherFilterExclusionMode; } return static_cast(mode); } std::vector SettingsGetLaunchers() { std::vector defaultLaunchers = vlowercase(defaultLaunchersVector()); std::vector userLaunchers = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "launchers")); std::vector userExcludedLaunchers = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "launchersexclude")); std::vector actualExcludedLaunchers = vintersect(defaultLaunchers, userExcludedLaunchers); return vexclude(vmerge(defaultLaunchers, userLaunchers), actualExcludedLaunchers); } std::vector SettingsGetWhitelist() { std::vector defaultWhitelist = vlowercase(defaultWhitelistVector()); // We don't consider Mumble's built-in whitelist when in WhitelistExclusionMode. // The built-in whitelist is only used in LauncherFilterExclusionMode. if (SettingsGetExclusionMode() == WhitelistExclusionMode) { defaultWhitelist = std::vector(); } std::vector userWhitelist = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "whitelist")); std::vector userExcludedWhitelistEntries = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "whitelistexclude")); std::vector actualExcludedWhitelistEntries = vintersect(defaultWhitelist, userExcludedWhitelistEntries); return vexclude(vmerge(defaultWhitelist, userWhitelist), actualExcludedWhitelistEntries); } std::vector SettingsGetPaths() { std::vector defaultPaths; std::vector userPaths = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "paths")); std::vector userExcludedPaths = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "pathsexclude")); std::vector actualExcludedPaths = vintersect(defaultPaths, userExcludedPaths); return vexclude(vmerge(defaultPaths, userPaths), actualExcludedPaths); } std::vector SettingsGetBlacklist() { std::vector defaultBlacklist = vlowercase(defaultBlacklistVector()); std::vector userBlacklist = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "blacklist")); std::vector userExcludedBlacklistEntries = vlowercase(regReadMultiString(HKEY_CURRENT_USER, "Software\\Mumble\\Mumble\\overlay", "blacklistexclude")); std::vector actualExcludedPaths = vintersect(defaultBlacklist, userExcludedBlacklistEntries); return vexclude(vmerge(defaultBlacklist, userBlacklist), actualExcludedPaths); }