defined('ABSPATH') || die('No direct access.');
use Extendify\Shared\Services\Sanitizer;
* Controller for handling various app data
public static $slug = 'extendify';
* The JS/CSS asset manifest (with hashes)
public static $assetManifest = [];
public static $version = '';
* Plugin API REST version
public static $apiVersion = 'v1';
public static $partnerId = null;
public static $showLaunch = false;
public static $environment = '';
public static $requiredCapability = EXTENDIFY_REQUIRED_CAPABILITY;
public static $config = [];
* Whether Launch was finished
public static $launchCompleted = false;
* Enabled preview features.
public static $previewFeatures = [];
public static $enablePreviewFeatures = false;
* Process the readme file to get version and name
public function __construct()
self::$partnerId = defined('EXTENDIFY_PARTNER_ID') ? constant('EXTENDIFY_PARTNER_ID') : null;
$partnerData = PartnerData::getPartnerData();
// phpcs:ignore WordPress.WP.AlternativeFunctions.file_get_contents_file_get_contents
$readme = file_get_contents(EXTENDIFY_PATH . 'readme.txt');
preg_match('/Stable tag: ([0-9.:]+)/', $readme, $matches);
self::$version = $matches[1];
self::$assetManifest = wp_json_file_decode(
EXTENDIFY_PATH . 'public/build/manifest.json',
if (!get_option('extendify_first_installed_version')) {
update_option('extendify_first_installed_version', Sanitizer::sanitizeText(self::$version));
// Set up the Preview features
// phpcs:ignore WordPress.Security.NonceVerification
self::handlePreviewUrlOptIn($_GET);
// An easy way to check if we are in dev mode is to look for a dev specific file.
$isDev = is_readable(EXTENDIFY_PATH . '.devbuild');
self::$environment = $isDev ? 'DEVELOPMENT' : 'PRODUCTION';
self::$launchCompleted = (bool) get_option('extendify_onboarding_completed', false);
self::$showLaunch = $isDev ? true : ((bool) ($partnerData['showLaunch'] ?? false));
* Retrieves the value of a preview setting.
* This method first checks if the preview setting exists as a static property of the class.
* If it does, it returns the value of that property. Otherwise, it looks for the
* preview setting in the saved setting and returns its value if found.
* @param string $previewKey The key of the preview setting to retrieve.
* @return boolean The value of the setting if found or false if not found.
public static function preview(string $previewKey)
if (self::$environment === 'DEVELOPMENT') {
if (property_exists(self::class, $previewKey)) {
return self::$previewFeatures[$previewKey];
$previewFeatures = get_option('extendify_enable_preview_features_v1', []);
return (bool) ($previewFeatures[$previewKey] ?? false);
* Processes preview features from URL parameters and enables them.
* This method checks for 'extendify-preview' parameters in the GET request
* and enables the specified preview features. It supports both single feature
* format (extendify-preview=feature1) and array format (extendify-preview[]=feature1).
* All specified features are enabled and saved to the database.
* @param array $getParams The GET parameters that may contain 'extendify-preview' settings.
protected static function handlePreviewUrlOptIn(array $getParams = [])
if (!isset($getParams['extendify-preview'])) {
$previewParam = $getParams['extendify-preview'];
$features = is_array($previewParam) ? $previewParam : [$previewParam];
self::$previewFeatures = get_option('extendify_enable_preview_features_v1', []);
foreach ($features as $feature) {
self::$previewFeatures[$feature] = true;
update_option('extendify_enable_preview_features_v1', Sanitizer::sanitizeArray(self::$previewFeatures));