namespace Friendica\App;
+use Detection\MobileDetect;
use Friendica\Core\Config\Cache\ConfigCache;
use Friendica\Database\Database;
use Friendica\Util\BasePath;
const MAINTENANCEDISABLED = 8;
/***
- * @var int the mode of this Application
+ * @var int The mode of this Application
*
*/
private $mode;
- public function __construct(int $mode = 0)
+ /**
+ * @var bool True, if the call is a backend call
+ */
+ private $isBackend;
+
+ /**
+ * @var bool True, if the call is a ajax call
+ */
+ private $isAjax;
+
+ /**
+ * @var bool True, if the call is from a mobile device
+ */
+ private $isMobile;
+
+ /**
+ * @var bool True, if the call is from a tablet device
+ */
+ private $isTablet;
+
+ public function __construct(int $mode = 0, bool $isBackend = false, bool $isAjax = false, bool $isMobile = false, bool $isTablet = false)
{
- $this->mode = $mode;
+ $this->mode = $mode;
+ $this->isBackend = $isBackend;
+ $this->isAjax = $isAjax;
+ $this->isMobile = $isMobile;
+ $this->isTablet = $isTablet;
}
/**
$mode |= Mode::MAINTENANCEDISABLED;
- return new Mode($mode);
+ return new Mode($mode, $this->isBackend, $this->isAjax, $this->isMobile, $this->isTablet);
+ }
+
+ /**
+ * Checks if the site is called via a backend process
+ *
+ * @param bool $isBackend True, if the call is from a backend script (daemon, worker, ...)
+ * @param Module $module The pre-loaded module (just name, not class!)
+ * @param array $server The $_SERVER variable
+ * @param MobileDetect $mobileDetect The mobile detection library
+ *
+ * @return Mode returns the determined mode
+ */
+ public function determineRunMode(bool $isBackend, Module $module, array $server, MobileDetect $mobileDetect)
+ {
+ $isBackend = $isBackend ||
+ $module->isBackend();
+ $isMobile = $mobileDetect->isMobile();
+ $isTablet = $mobileDetect->isTablet();
+ $isAjax = strtolower($server['HTTP_X_REQUESTED_WITH'] ?? '') == 'xmlhttprequest';
+
+ return new Mode($this->mode, $isBackend, $isAjax, $isMobile, $isTablet);
}
/**
$this->has(Mode::DBCONFIGAVAILABLE) &&
$this->has(Mode::MAINTENANCEDISABLED);
}
+
+ /**
+ * Returns true, if the call is from a backend node (f.e. from a worker)
+ *
+ * @return bool Is it a backend call
+ */
+ public function isBackend()
+ {
+ return $this->isBackend;
+ }
+
+ /**
+ * Check if request was an AJAX (xmlhttprequest) request.
+ *
+ * @return bool true if it was an AJAX request
+ */
+ public function isAjax()
+ {
+ return $this->isAjax;
+ }
+
+ /**
+ * Check if request was a mobile request.
+ *
+ * @return bool true if it was an mobile request
+ */
+ public function isMobile()
+ {
+ return $this->isMobile;
+ }
+
+ /**
+ * Check if request was a tablet request.
+ *
+ * @return bool true if it was an tablet request
+ */
+ public function isTablet()
+ {
+ return $this->isTablet;
+ }
}