12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- <?php
- namespace OCA\WorkflowEngine\Check;
- use OCP\IL10N;
- use OCP\IRequest;
- class RequestURL extends AbstractStringCheck {
- public const CLI = 'cli';
-
- protected $url;
-
- public function __construct(
- IL10N $l,
- protected IRequest $request,
- ) {
- parent::__construct($l);
- }
-
- public function executeCheck($operator, $value) {
- if (\OC::$CLI) {
- $actualValue = $this->url = RequestURL::CLI;
- } else {
- $actualValue = $this->getActualValue();
- }
- if (in_array($operator, ['is', '!is'])) {
- switch ($value) {
- case 'webdav':
- if ($operator === 'is') {
- return $this->isWebDAVRequest();
- } else {
- return !$this->isWebDAVRequest();
- }
- }
- }
- return $this->executeStringCheck($operator, $value, $actualValue);
- }
-
- protected function getActualValue() {
- if ($this->url !== null) {
- return $this->url;
- }
- $this->url = $this->request->getServerProtocol() . '://';
- $this->url .= $this->request->getServerHost();
- $this->url .= $this->request->getScriptName();
- $this->url .= $this->request->getPathInfo();
- return $this->url;
- }
- protected function isWebDAVRequest(): bool {
- if ($this->url === RequestURL::CLI) {
- return false;
- }
- return substr($this->request->getScriptName(), 0 - strlen('/remote.php')) === '/remote.php' && (
- $this->request->getPathInfo() === '/webdav' ||
- str_starts_with($this->request->getPathInfo() ?? '', '/webdav/') ||
- $this->request->getPathInfo() === '/dav/files' ||
- str_starts_with($this->request->getPathInfo() ?? '', '/dav/files/')
- );
- }
- }
|