Passed
Push — master ( 27fb46...dad31c )
by rakekniven
15:02 queued 12s
created
lib/private/Files/Storage/Temporary.php 1 patch
Indentation   +13 added lines, -13 removed lines patch added patch discarded remove patch
@@ -29,20 +29,20 @@
 block discarded – undo
29 29
  * local storage backend in temporary folder for testing purpose
30 30
  */
31 31
 class Temporary extends Local {
32
-	public function __construct($arguments = null) {
33
-		parent::__construct(['datadir' => \OC::$server->getTempManager()->getTemporaryFolder()]);
34
-	}
32
+    public function __construct($arguments = null) {
33
+        parent::__construct(['datadir' => \OC::$server->getTempManager()->getTemporaryFolder()]);
34
+    }
35 35
 
36
-	public function cleanUp() {
37
-		\OC_Helper::rmdirr($this->datadir);
38
-	}
36
+    public function cleanUp() {
37
+        \OC_Helper::rmdirr($this->datadir);
38
+    }
39 39
 
40
-	public function __destruct() {
41
-		parent::__destruct();
42
-		$this->cleanUp();
43
-	}
40
+    public function __destruct() {
41
+        parent::__destruct();
42
+        $this->cleanUp();
43
+    }
44 44
 
45
-	public function getDataDir() {
46
-		return $this->datadir;
47
-	}
45
+    public function getDataDir() {
46
+        return $this->datadir;
47
+    }
48 48
 }
Please login to merge, or discard this patch.
lib/private/Files/Storage/Home.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -50,7 +50,7 @@
 block discarded – undo
50 50
 	public function __construct($arguments) {
51 51
 		$this->user = $arguments['user'];
52 52
 		$datadir = $this->user->getHome();
53
-		$this->id = 'home::' . $this->user->getUID();
53
+		$this->id = 'home::'.$this->user->getUID();
54 54
 
55 55
 		parent::__construct(['datadir' => $datadir]);
56 56
 	}
Please login to merge, or discard this patch.
Indentation   +67 added lines, -67 removed lines patch added patch discarded remove patch
@@ -33,80 +33,80 @@
 block discarded – undo
33 33
  * Specialized version of Local storage for home directory usage
34 34
  */
35 35
 class Home extends Local implements \OCP\Files\IHomeStorage {
36
-	/**
37
-	 * @var string
38
-	 */
39
-	protected $id;
36
+    /**
37
+     * @var string
38
+     */
39
+    protected $id;
40 40
 
41
-	/**
42
-	 * @var \OC\User\User $user
43
-	 */
44
-	protected $user;
41
+    /**
42
+     * @var \OC\User\User $user
43
+     */
44
+    protected $user;
45 45
 
46
-	/**
47
-	 * Construct a Home storage instance
48
-	 *
49
-	 * @param array $arguments array with "user" containing the
50
-	 * storage owner
51
-	 */
52
-	public function __construct($arguments) {
53
-		$this->user = $arguments['user'];
54
-		$datadir = $this->user->getHome();
55
-		$this->id = 'home::' . $this->user->getUID();
46
+    /**
47
+     * Construct a Home storage instance
48
+     *
49
+     * @param array $arguments array with "user" containing the
50
+     * storage owner
51
+     */
52
+    public function __construct($arguments) {
53
+        $this->user = $arguments['user'];
54
+        $datadir = $this->user->getHome();
55
+        $this->id = 'home::' . $this->user->getUID();
56 56
 
57
-		parent::__construct(['datadir' => $datadir]);
58
-	}
57
+        parent::__construct(['datadir' => $datadir]);
58
+    }
59 59
 
60
-	public function getId() {
61
-		return $this->id;
62
-	}
60
+    public function getId() {
61
+        return $this->id;
62
+    }
63 63
 
64
-	/**
65
-	 * @return \OC\Files\Cache\HomeCache
66
-	 */
67
-	public function getCache($path = '', $storage = null) {
68
-		if (!$storage) {
69
-			$storage = $this;
70
-		}
71
-		if (!isset($this->cache)) {
72
-			$this->cache = new \OC\Files\Cache\HomeCache($storage);
73
-		}
74
-		return $this->cache;
75
-	}
64
+    /**
65
+     * @return \OC\Files\Cache\HomeCache
66
+     */
67
+    public function getCache($path = '', $storage = null) {
68
+        if (!$storage) {
69
+            $storage = $this;
70
+        }
71
+        if (!isset($this->cache)) {
72
+            $this->cache = new \OC\Files\Cache\HomeCache($storage);
73
+        }
74
+        return $this->cache;
75
+    }
76 76
 
77
-	/**
78
-	 * get a propagator instance for the cache
79
-	 *
80
-	 * @param \OC\Files\Storage\Storage (optional) the storage to pass to the watcher
81
-	 * @return \OC\Files\Cache\Propagator
82
-	 */
83
-	public function getPropagator($storage = null) {
84
-		if (!$storage) {
85
-			$storage = $this;
86
-		}
87
-		if (!isset($this->propagator)) {
88
-			$this->propagator = new HomePropagator($storage, \OC::$server->getDatabaseConnection());
89
-		}
90
-		return $this->propagator;
91
-	}
77
+    /**
78
+     * get a propagator instance for the cache
79
+     *
80
+     * @param \OC\Files\Storage\Storage (optional) the storage to pass to the watcher
81
+     * @return \OC\Files\Cache\Propagator
82
+     */
83
+    public function getPropagator($storage = null) {
84
+        if (!$storage) {
85
+            $storage = $this;
86
+        }
87
+        if (!isset($this->propagator)) {
88
+            $this->propagator = new HomePropagator($storage, \OC::$server->getDatabaseConnection());
89
+        }
90
+        return $this->propagator;
91
+    }
92 92
 
93 93
 
94
-	/**
95
-	 * Returns the owner of this home storage
96
-	 *
97
-	 * @return \OC\User\User owner of this home storage
98
-	 */
99
-	public function getUser() {
100
-		return $this->user;
101
-	}
94
+    /**
95
+     * Returns the owner of this home storage
96
+     *
97
+     * @return \OC\User\User owner of this home storage
98
+     */
99
+    public function getUser() {
100
+        return $this->user;
101
+    }
102 102
 
103
-	/**
104
-	 * get the owner of a path
105
-	 *
106
-	 * @param string $path The path to get the owner
107
-	 * @return string uid or false
108
-	 */
109
-	public function getOwner($path) {
110
-		return $this->user->getUID();
111
-	}
103
+    /**
104
+     * get the owner of a path
105
+     *
106
+     * @param string $path The path to get the owner
107
+     * @return string uid or false
108
+     */
109
+    public function getOwner($path) {
110
+        return $this->user->getUID();
111
+    }
112 112
 }
Please login to merge, or discard this patch.
lib/private/Files/SimpleFS/SimpleFolder.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -49,7 +49,7 @@
 block discarded – undo
49 49
 	public function getDirectoryListing() {
50 50
 		$listing = $this->folder->getDirectoryListing();
51 51
 
52
-		$fileListing = array_map(function (Node $file) {
52
+		$fileListing = array_map(function(Node $file) {
53 53
 			if ($file instanceof File) {
54 54
 				return new SimpleFile($file);
55 55
 			}
Please login to merge, or discard this patch.
Indentation   +46 added lines, -46 removed lines patch added patch discarded remove patch
@@ -32,62 +32,62 @@
 block discarded – undo
32 32
 
33 33
 class SimpleFolder implements ISimpleFolder {
34 34
 
35
-	/** @var Folder */
36
-	private $folder;
35
+    /** @var Folder */
36
+    private $folder;
37 37
 
38
-	/**
39
-	 * Folder constructor.
40
-	 *
41
-	 * @param Folder $folder
42
-	 */
43
-	public function __construct(Folder $folder) {
44
-		$this->folder = $folder;
45
-	}
38
+    /**
39
+     * Folder constructor.
40
+     *
41
+     * @param Folder $folder
42
+     */
43
+    public function __construct(Folder $folder) {
44
+        $this->folder = $folder;
45
+    }
46 46
 
47
-	public function getName() {
48
-		return $this->folder->getName();
49
-	}
47
+    public function getName() {
48
+        return $this->folder->getName();
49
+    }
50 50
 
51
-	public function getDirectoryListing() {
52
-		$listing = $this->folder->getDirectoryListing();
51
+    public function getDirectoryListing() {
52
+        $listing = $this->folder->getDirectoryListing();
53 53
 
54
-		$fileListing = array_map(function (Node $file) {
55
-			if ($file instanceof File) {
56
-				return new SimpleFile($file);
57
-			}
58
-			return null;
59
-		}, $listing);
54
+        $fileListing = array_map(function (Node $file) {
55
+            if ($file instanceof File) {
56
+                return new SimpleFile($file);
57
+            }
58
+            return null;
59
+        }, $listing);
60 60
 
61
-		$fileListing = array_filter($fileListing);
61
+        $fileListing = array_filter($fileListing);
62 62
 
63
-		return array_values($fileListing);
64
-	}
63
+        return array_values($fileListing);
64
+    }
65 65
 
66
-	public function delete() {
67
-		$this->folder->delete();
68
-	}
66
+    public function delete() {
67
+        $this->folder->delete();
68
+    }
69 69
 
70
-	public function fileExists($name) {
71
-		return $this->folder->nodeExists($name);
72
-	}
70
+    public function fileExists($name) {
71
+        return $this->folder->nodeExists($name);
72
+    }
73 73
 
74
-	public function getFile($name) {
75
-		$file = $this->folder->get($name);
74
+    public function getFile($name) {
75
+        $file = $this->folder->get($name);
76 76
 
77
-		if (!($file instanceof File)) {
78
-			throw new NotFoundException();
79
-		}
77
+        if (!($file instanceof File)) {
78
+            throw new NotFoundException();
79
+        }
80 80
 
81
-		return new SimpleFile($file);
82
-	}
81
+        return new SimpleFile($file);
82
+    }
83 83
 
84
-	public function newFile($name, $content = null) {
85
-		if ($content === null) {
86
-			// delay creating the file until it's written to
87
-			return new NewSimpleFile($this->folder, $name);
88
-		} else {
89
-			$file = $this->folder->newFile($name, $content);
90
-			return new SimpleFile($file);
91
-		}
92
-	}
84
+    public function newFile($name, $content = null) {
85
+        if ($content === null) {
86
+            // delay creating the file until it's written to
87
+            return new NewSimpleFile($this->folder, $name);
88
+        } else {
89
+            $file = $this->folder->newFile($name, $content);
90
+            return new SimpleFile($file);
91
+        }
92
+    }
93 93
 }
Please login to merge, or discard this patch.
lib/private/Files/ObjectStore/HomeObjectStoreStorage.php 2 patches
Indentation   +33 added lines, -33 removed lines patch added patch discarded remove patch
@@ -28,40 +28,40 @@
 block discarded – undo
28 28
 
29 29
 class HomeObjectStoreStorage extends ObjectStoreStorage implements \OCP\Files\IHomeStorage {
30 30
 
31
-	/**
32
-	 * The home user storage requires a user object to create a unique storage id
33
-	 * @param array $params
34
-	 */
35
-	public function __construct($params) {
36
-		if (! isset($params['user']) || ! $params['user'] instanceof User) {
37
-			throw new \Exception('missing user object in parameters');
38
-		}
39
-		$this->user = $params['user'];
40
-		parent::__construct($params);
41
-	}
31
+    /**
32
+     * The home user storage requires a user object to create a unique storage id
33
+     * @param array $params
34
+     */
35
+    public function __construct($params) {
36
+        if (! isset($params['user']) || ! $params['user'] instanceof User) {
37
+            throw new \Exception('missing user object in parameters');
38
+        }
39
+        $this->user = $params['user'];
40
+        parent::__construct($params);
41
+    }
42 42
 
43
-	public function getId() {
44
-		return 'object::user:' . $this->user->getUID();
45
-	}
43
+    public function getId() {
44
+        return 'object::user:' . $this->user->getUID();
45
+    }
46 46
 
47
-	/**
48
-	 * get the owner of a path
49
-	 *
50
-	 * @param string $path The path to get the owner
51
-	 * @return false|string uid
52
-	 */
53
-	public function getOwner($path) {
54
-		if (is_object($this->user)) {
55
-			return $this->user->getUID();
56
-		}
57
-		return false;
58
-	}
47
+    /**
48
+     * get the owner of a path
49
+     *
50
+     * @param string $path The path to get the owner
51
+     * @return false|string uid
52
+     */
53
+    public function getOwner($path) {
54
+        if (is_object($this->user)) {
55
+            return $this->user->getUID();
56
+        }
57
+        return false;
58
+    }
59 59
 
60
-	/**
61
-	 * @param string $path, optional
62
-	 * @return \OC\User\User
63
-	 */
64
-	public function getUser($path = null) {
65
-		return $this->user;
66
-	}
60
+    /**
61
+     * @param string $path, optional
62
+     * @return \OC\User\User
63
+     */
64
+    public function getUser($path = null) {
65
+        return $this->user;
66
+    }
67 67
 }
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -33,7 +33,7 @@  discard block
 block discarded – undo
33 33
 	 * @param array $params
34 34
 	 */
35 35
 	public function __construct($params) {
36
-		if (! isset($params['user']) || ! $params['user'] instanceof User) {
36
+		if (!isset($params['user']) || !$params['user'] instanceof User) {
37 37
 			throw new \Exception('missing user object in parameters');
38 38
 		}
39 39
 		$this->user = $params['user'];
@@ -41,7 +41,7 @@  discard block
 block discarded – undo
41 41
 	}
42 42
 
43 43
 	public function getId() {
44
-		return 'object::user:' . $this->user->getUID();
44
+		return 'object::user:'.$this->user->getUID();
45 45
 	}
46 46
 
47 47
 	/**
Please login to merge, or discard this patch.
lib/private/DB/MigrationException.php 1 patch
Indentation   +11 added lines, -11 removed lines patch added patch discarded remove patch
@@ -24,17 +24,17 @@
 block discarded – undo
24 24
 namespace OC\DB;
25 25
 
26 26
 class MigrationException extends \Exception {
27
-	private $table;
27
+    private $table;
28 28
 
29
-	public function __construct($table, $message) {
30
-		$this->table = $table;
31
-		parent::__construct($message);
32
-	}
29
+    public function __construct($table, $message) {
30
+        $this->table = $table;
31
+        parent::__construct($message);
32
+    }
33 33
 
34
-	/**
35
-	 * @return string
36
-	 */
37
-	public function getTable() {
38
-		return $this->table;
39
-	}
34
+    /**
35
+     * @return string
36
+     */
37
+    public function getTable() {
38
+        return $this->table;
39
+    }
40 40
 }
Please login to merge, or discard this patch.
lib/private/DB/QueryBuilder/Literal.php 1 patch
Indentation   +11 added lines, -11 removed lines patch added patch discarded remove patch
@@ -25,17 +25,17 @@
 block discarded – undo
25 25
 use OCP\DB\QueryBuilder\ILiteral;
26 26
 
27 27
 class Literal implements ILiteral {
28
-	/** @var mixed */
29
-	protected $literal;
28
+    /** @var mixed */
29
+    protected $literal;
30 30
 
31
-	public function __construct($literal) {
32
-		$this->literal = $literal;
33
-	}
31
+    public function __construct($literal) {
32
+        $this->literal = $literal;
33
+    }
34 34
 
35
-	/**
36
-	 * @return string
37
-	 */
38
-	public function __toString() {
39
-		return (string) $this->literal;
40
-	}
35
+    /**
36
+     * @return string
37
+     */
38
+    public function __toString() {
39
+        return (string) $this->literal;
40
+    }
41 41
 }
Please login to merge, or discard this patch.
lib/private/DB/AdapterSqlite.php 2 patches
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -64,14 +64,14 @@
 block discarded – undo
64 64
 		if (empty($compare)) {
65 65
 			$compare = array_keys($input);
66 66
 		}
67
-		$fieldList = '`' . implode('`,`', array_keys($input)) . '`';
67
+		$fieldList = '`'.implode('`,`', array_keys($input)).'`';
68 68
 		$query = "INSERT INTO `$table` ($fieldList) SELECT "
69 69
 			. str_repeat('?,', count($input) - 1).'? '
70 70
 			. " WHERE NOT EXISTS (SELECT 1 FROM `$table` WHERE ";
71 71
 
72 72
 		$inserts = array_values($input);
73 73
 		foreach ($compare as $key) {
74
-			$query .= '`' . $key . '`';
74
+			$query .= '`'.$key.'`';
75 75
 			if (is_null($input[$key])) {
76 76
 				$query .= ' IS NULL AND ';
77 77
 			} else {
Please login to merge, or discard this patch.
Indentation   +61 added lines, -61 removed lines patch added patch discarded remove patch
@@ -31,70 +31,70 @@
 block discarded – undo
31 31
 
32 32
 class AdapterSqlite extends Adapter {
33 33
 
34
-	/**
35
-	 * @param string $tableName
36
-	 */
37
-	public function lockTable($tableName) {
38
-		$this->conn->executeUpdate('BEGIN EXCLUSIVE TRANSACTION');
39
-	}
34
+    /**
35
+     * @param string $tableName
36
+     */
37
+    public function lockTable($tableName) {
38
+        $this->conn->executeUpdate('BEGIN EXCLUSIVE TRANSACTION');
39
+    }
40 40
 
41
-	public function unlockTable() {
42
-		$this->conn->executeUpdate('COMMIT TRANSACTION');
43
-	}
41
+    public function unlockTable() {
42
+        $this->conn->executeUpdate('COMMIT TRANSACTION');
43
+    }
44 44
 
45
-	public function fixupStatement($statement) {
46
-		$statement = preg_replace('/`(\w+)` ILIKE \?/', 'LOWER($1) LIKE LOWER(?)', $statement);
47
-		$statement = str_replace('`', '"', $statement);
48
-		$statement = str_ireplace('NOW()', 'datetime(\'now\')', $statement);
49
-		$statement = str_ireplace('GREATEST(', 'MAX(', $statement);
50
-		$statement = str_ireplace('UNIX_TIMESTAMP()', 'strftime(\'%s\',\'now\')', $statement);
51
-		return $statement;
52
-	}
45
+    public function fixupStatement($statement) {
46
+        $statement = preg_replace('/`(\w+)` ILIKE \?/', 'LOWER($1) LIKE LOWER(?)', $statement);
47
+        $statement = str_replace('`', '"', $statement);
48
+        $statement = str_ireplace('NOW()', 'datetime(\'now\')', $statement);
49
+        $statement = str_ireplace('GREATEST(', 'MAX(', $statement);
50
+        $statement = str_ireplace('UNIX_TIMESTAMP()', 'strftime(\'%s\',\'now\')', $statement);
51
+        return $statement;
52
+    }
53 53
 
54
-	/**
55
-	 * Insert a row if the matching row does not exists. To accomplish proper race condition avoidance
56
-	 * it is needed that there is also a unique constraint on the values. Then this method will
57
-	 * catch the exception and return 0.
58
-	 *
59
-	 * @param string $table The table name (will replace *PREFIX* with the actual prefix)
60
-	 * @param array $input data that should be inserted into the table  (column name => value)
61
-	 * @param array|null $compare List of values that should be checked for "if not exists"
62
-	 *				If this is null or an empty array, all keys of $input will be compared
63
-	 *				Please note: text fields (clob) must not be used in the compare array
64
-	 * @return int number of inserted rows
65
-	 * @throws \Doctrine\DBAL\Exception
66
-	 * @deprecated 15.0.0 - use unique index and "try { $db->insert() } catch (UniqueConstraintViolationException $e) {}" instead, because it is more reliable and does not have the risk for deadlocks - see https://github.com/nextcloud/server/pull/12371
67
-	 */
68
-	public function insertIfNotExist($table, $input, array $compare = null) {
69
-		if (empty($compare)) {
70
-			$compare = array_keys($input);
71
-		}
72
-		$fieldList = '`' . implode('`,`', array_keys($input)) . '`';
73
-		$query = "INSERT INTO `$table` ($fieldList) SELECT "
74
-			. str_repeat('?,', count($input) - 1).'? '
75
-			. " WHERE NOT EXISTS (SELECT 1 FROM `$table` WHERE ";
54
+    /**
55
+     * Insert a row if the matching row does not exists. To accomplish proper race condition avoidance
56
+     * it is needed that there is also a unique constraint on the values. Then this method will
57
+     * catch the exception and return 0.
58
+     *
59
+     * @param string $table The table name (will replace *PREFIX* with the actual prefix)
60
+     * @param array $input data that should be inserted into the table  (column name => value)
61
+     * @param array|null $compare List of values that should be checked for "if not exists"
62
+     *				If this is null or an empty array, all keys of $input will be compared
63
+     *				Please note: text fields (clob) must not be used in the compare array
64
+     * @return int number of inserted rows
65
+     * @throws \Doctrine\DBAL\Exception
66
+     * @deprecated 15.0.0 - use unique index and "try { $db->insert() } catch (UniqueConstraintViolationException $e) {}" instead, because it is more reliable and does not have the risk for deadlocks - see https://github.com/nextcloud/server/pull/12371
67
+     */
68
+    public function insertIfNotExist($table, $input, array $compare = null) {
69
+        if (empty($compare)) {
70
+            $compare = array_keys($input);
71
+        }
72
+        $fieldList = '`' . implode('`,`', array_keys($input)) . '`';
73
+        $query = "INSERT INTO `$table` ($fieldList) SELECT "
74
+            . str_repeat('?,', count($input) - 1).'? '
75
+            . " WHERE NOT EXISTS (SELECT 1 FROM `$table` WHERE ";
76 76
 
77
-		$inserts = array_values($input);
78
-		foreach ($compare as $key) {
79
-			$query .= '`' . $key . '`';
80
-			if (is_null($input[$key])) {
81
-				$query .= ' IS NULL AND ';
82
-			} else {
83
-				$inserts[] = $input[$key];
84
-				$query .= ' = ? AND ';
85
-			}
86
-		}
87
-		$query = substr($query, 0, -5);
88
-		$query .= ')';
77
+        $inserts = array_values($input);
78
+        foreach ($compare as $key) {
79
+            $query .= '`' . $key . '`';
80
+            if (is_null($input[$key])) {
81
+                $query .= ' IS NULL AND ';
82
+            } else {
83
+                $inserts[] = $input[$key];
84
+                $query .= ' = ? AND ';
85
+            }
86
+        }
87
+        $query = substr($query, 0, -5);
88
+        $query .= ')';
89 89
 
90
-		try {
91
-			return $this->conn->executeUpdate($query, $inserts);
92
-		} catch (UniqueConstraintViolationException $e) {
93
-			// if this is thrown then a concurrent insert happened between the insert and the sub-select in the insert, that should have avoided it
94
-			// it's fine to ignore this then
95
-			//
96
-			// more discussions about this can be found at https://github.com/nextcloud/server/pull/12315
97
-			return 0;
98
-		}
99
-	}
90
+        try {
91
+            return $this->conn->executeUpdate($query, $inserts);
92
+        } catch (UniqueConstraintViolationException $e) {
93
+            // if this is thrown then a concurrent insert happened between the insert and the sub-select in the insert, that should have avoided it
94
+            // it's fine to ignore this then
95
+            //
96
+            // more discussions about this can be found at https://github.com/nextcloud/server/pull/12315
97
+            return 0;
98
+        }
99
+    }
100 100
 }
Please login to merge, or discard this patch.
lib/private/DB/OracleConnection.php 2 patches
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -82,7 +82,7 @@  discard block
 block discarded – undo
82 82
 	 * @param string $table table name without the prefix
83 83
 	 */
84 84
 	public function dropTable($table) {
85
-		$table = $this->tablePrefix . trim($table);
85
+		$table = $this->tablePrefix.trim($table);
86 86
 		$table = $this->quoteIdentifier($table);
87 87
 		$schema = $this->getSchemaManager();
88 88
 		if ($schema->tablesExist([$table])) {
@@ -97,7 +97,7 @@  discard block
 block discarded – undo
97 97
 	 * @return bool
98 98
 	 */
99 99
 	public function tableExists($table) {
100
-		$table = $this->tablePrefix . trim($table);
100
+		$table = $this->tablePrefix.trim($table);
101 101
 		$table = $this->quoteIdentifier($table);
102 102
 		$schema = $this->getSchemaManager();
103 103
 		return $schema->tablesExist([$table]);
Please login to merge, or discard this patch.
Indentation   +71 added lines, -71 removed lines patch added patch discarded remove patch
@@ -28,80 +28,80 @@
 block discarded – undo
28 28
 namespace OC\DB;
29 29
 
30 30
 class OracleConnection extends Connection {
31
-	/**
32
-	 * Quote the keys of the array
33
-	 */
34
-	private function quoteKeys(array $data) {
35
-		$return = [];
36
-		$c = $this->getDatabasePlatform()->getIdentifierQuoteCharacter();
37
-		foreach ($data as $key => $value) {
38
-			if ($key[0] !== $c) {
39
-				$return[$this->quoteIdentifier($key)] = $value;
40
-			} else {
41
-				$return[$key] = $value;
42
-			}
43
-		}
44
-		return $return;
45
-	}
31
+    /**
32
+     * Quote the keys of the array
33
+     */
34
+    private function quoteKeys(array $data) {
35
+        $return = [];
36
+        $c = $this->getDatabasePlatform()->getIdentifierQuoteCharacter();
37
+        foreach ($data as $key => $value) {
38
+            if ($key[0] !== $c) {
39
+                $return[$this->quoteIdentifier($key)] = $value;
40
+            } else {
41
+                $return[$key] = $value;
42
+            }
43
+        }
44
+        return $return;
45
+    }
46 46
 
47
-	/**
48
-	 * {@inheritDoc}
49
-	 */
50
-	public function insert($table, array $data, array $types = []) {
51
-		if ($table[0] !== $this->getDatabasePlatform()->getIdentifierQuoteCharacter()) {
52
-			$table = $this->quoteIdentifier($table);
53
-		}
54
-		$data = $this->quoteKeys($data);
55
-		return parent::insert($table, $data, $types);
56
-	}
47
+    /**
48
+     * {@inheritDoc}
49
+     */
50
+    public function insert($table, array $data, array $types = []) {
51
+        if ($table[0] !== $this->getDatabasePlatform()->getIdentifierQuoteCharacter()) {
52
+            $table = $this->quoteIdentifier($table);
53
+        }
54
+        $data = $this->quoteKeys($data);
55
+        return parent::insert($table, $data, $types);
56
+    }
57 57
 
58
-	/**
59
-	 * {@inheritDoc}
60
-	 */
61
-	public function update($table, array $data, array $criteria, array $types = []) {
62
-		if ($table[0] !== $this->getDatabasePlatform()->getIdentifierQuoteCharacter()) {
63
-			$table = $this->quoteIdentifier($table);
64
-		}
65
-		$data = $this->quoteKeys($data);
66
-		$criteria = $this->quoteKeys($criteria);
67
-		return parent::update($table, $data, $criteria, $types);
68
-	}
58
+    /**
59
+     * {@inheritDoc}
60
+     */
61
+    public function update($table, array $data, array $criteria, array $types = []) {
62
+        if ($table[0] !== $this->getDatabasePlatform()->getIdentifierQuoteCharacter()) {
63
+            $table = $this->quoteIdentifier($table);
64
+        }
65
+        $data = $this->quoteKeys($data);
66
+        $criteria = $this->quoteKeys($criteria);
67
+        return parent::update($table, $data, $criteria, $types);
68
+    }
69 69
 
70
-	/**
71
-	 * {@inheritDoc}
72
-	 */
73
-	public function delete($table, array $criteria, array $types = []) {
74
-		if ($table[0] !== $this->getDatabasePlatform()->getIdentifierQuoteCharacter()) {
75
-			$table = $this->quoteIdentifier($table);
76
-		}
77
-		$criteria = $this->quoteKeys($criteria);
78
-		return parent::delete($table, $criteria);
79
-	}
70
+    /**
71
+     * {@inheritDoc}
72
+     */
73
+    public function delete($table, array $criteria, array $types = []) {
74
+        if ($table[0] !== $this->getDatabasePlatform()->getIdentifierQuoteCharacter()) {
75
+            $table = $this->quoteIdentifier($table);
76
+        }
77
+        $criteria = $this->quoteKeys($criteria);
78
+        return parent::delete($table, $criteria);
79
+    }
80 80
 
81
-	/**
82
-	 * Drop a table from the database if it exists
83
-	 *
84
-	 * @param string $table table name without the prefix
85
-	 */
86
-	public function dropTable($table) {
87
-		$table = $this->tablePrefix . trim($table);
88
-		$table = $this->quoteIdentifier($table);
89
-		$schema = $this->getSchemaManager();
90
-		if ($schema->tablesExist([$table])) {
91
-			$schema->dropTable($table);
92
-		}
93
-	}
81
+    /**
82
+     * Drop a table from the database if it exists
83
+     *
84
+     * @param string $table table name without the prefix
85
+     */
86
+    public function dropTable($table) {
87
+        $table = $this->tablePrefix . trim($table);
88
+        $table = $this->quoteIdentifier($table);
89
+        $schema = $this->getSchemaManager();
90
+        if ($schema->tablesExist([$table])) {
91
+            $schema->dropTable($table);
92
+        }
93
+    }
94 94
 
95
-	/**
96
-	 * Check if a table exists
97
-	 *
98
-	 * @param string $table table name without the prefix
99
-	 * @return bool
100
-	 */
101
-	public function tableExists($table) {
102
-		$table = $this->tablePrefix . trim($table);
103
-		$table = $this->quoteIdentifier($table);
104
-		$schema = $this->getSchemaManager();
105
-		return $schema->tablesExist([$table]);
106
-	}
95
+    /**
96
+     * Check if a table exists
97
+     *
98
+     * @param string $table table name without the prefix
99
+     * @return bool
100
+     */
101
+    public function tableExists($table) {
102
+        $table = $this->tablePrefix . trim($table);
103
+        $table = $this->quoteIdentifier($table);
104
+        $schema = $this->getSchemaManager();
105
+        return $schema->tablesExist([$table]);
106
+    }
107 107
 }
Please login to merge, or discard this patch.
lib/private/PreviewManager.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -333,7 +333,7 @@
 block discarded – undo
333 333
 	 */
334 334
 	protected function registerCoreProvider($class, $mimeType, $options = []) {
335 335
 		if (in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
336
-			$this->registerProvider($mimeType, function () use ($class, $options) {
336
+			$this->registerProvider($mimeType, function() use ($class, $options) {
337 337
 				return new $class($options);
338 338
 			});
339 339
 		}
Please login to merge, or discard this patch.
Indentation   +389 added lines, -389 removed lines patch added patch discarded remove patch
@@ -44,393 +44,393 @@
 block discarded – undo
44 44
 use Symfony\Component\EventDispatcher\EventDispatcherInterface;
45 45
 
46 46
 class PreviewManager implements IPreview {
47
-	/** @var IConfig */
48
-	protected $config;
49
-
50
-	/** @var IRootFolder */
51
-	protected $rootFolder;
52
-
53
-	/** @var IAppData */
54
-	protected $appData;
55
-
56
-	/** @var EventDispatcherInterface */
57
-	protected $eventDispatcher;
58
-
59
-	/** @var Generator */
60
-	private $generator;
61
-
62
-	/** @var GeneratorHelper */
63
-	private $helper;
64
-
65
-	/** @var bool */
66
-	protected $providerListDirty = false;
67
-
68
-	/** @var bool */
69
-	protected $registeredCoreProviders = false;
70
-
71
-	/** @var array */
72
-	protected $providers = [];
73
-
74
-	/** @var array mime type => support status */
75
-	protected $mimeTypeSupportMap = [];
76
-
77
-	/** @var array */
78
-	protected $defaultProviders;
79
-
80
-	/** @var string */
81
-	protected $userId;
82
-
83
-	/**
84
-	 * PreviewManager constructor.
85
-	 *
86
-	 * @param IConfig $config
87
-	 * @param IRootFolder $rootFolder
88
-	 * @param IAppData $appData
89
-	 * @param EventDispatcherInterface $eventDispatcher
90
-	 * @param string $userId
91
-	 */
92
-	public function __construct(IConfig $config,
93
-								IRootFolder $rootFolder,
94
-								IAppData $appData,
95
-								EventDispatcherInterface $eventDispatcher,
96
-								GeneratorHelper $helper,
97
-								$userId) {
98
-		$this->config = $config;
99
-		$this->rootFolder = $rootFolder;
100
-		$this->appData = $appData;
101
-		$this->eventDispatcher = $eventDispatcher;
102
-		$this->helper = $helper;
103
-		$this->userId = $userId;
104
-	}
105
-
106
-	/**
107
-	 * In order to improve lazy loading a closure can be registered which will be
108
-	 * called in case preview providers are actually requested
109
-	 *
110
-	 * $callable has to return an instance of \OCP\Preview\IProvider or \OCP\Preview\IProviderV2
111
-	 *
112
-	 * @param string $mimeTypeRegex Regex with the mime types that are supported by this provider
113
-	 * @param \Closure $callable
114
-	 * @return void
115
-	 */
116
-	public function registerProvider($mimeTypeRegex, \Closure $callable) {
117
-		if (!$this->config->getSystemValue('enable_previews', true)) {
118
-			return;
119
-		}
120
-
121
-		if (!isset($this->providers[$mimeTypeRegex])) {
122
-			$this->providers[$mimeTypeRegex] = [];
123
-		}
124
-		$this->providers[$mimeTypeRegex][] = $callable;
125
-		$this->providerListDirty = true;
126
-	}
127
-
128
-	/**
129
-	 * Get all providers
130
-	 * @return array
131
-	 */
132
-	public function getProviders() {
133
-		if (!$this->config->getSystemValue('enable_previews', true)) {
134
-			return [];
135
-		}
136
-
137
-		$this->registerCoreProviders();
138
-		if ($this->providerListDirty) {
139
-			$keys = array_map('strlen', array_keys($this->providers));
140
-			array_multisort($keys, SORT_DESC, $this->providers);
141
-			$this->providerListDirty = false;
142
-		}
143
-
144
-		return $this->providers;
145
-	}
146
-
147
-	/**
148
-	 * Does the manager have any providers
149
-	 * @return bool
150
-	 */
151
-	public function hasProviders() {
152
-		$this->registerCoreProviders();
153
-		return !empty($this->providers);
154
-	}
155
-
156
-	private function getGenerator(): Generator {
157
-		if ($this->generator === null) {
158
-			$this->generator = new Generator(
159
-				$this->config,
160
-				$this,
161
-				$this->appData,
162
-				new GeneratorHelper(
163
-					$this->rootFolder,
164
-					$this->config
165
-				),
166
-				$this->eventDispatcher
167
-			);
168
-		}
169
-		return $this->generator;
170
-	}
171
-
172
-	/**
173
-	 * Returns a preview of a file
174
-	 *
175
-	 * The cache is searched first and if nothing usable was found then a preview is
176
-	 * generated by one of the providers
177
-	 *
178
-	 * @param File $file
179
-	 * @param int $width
180
-	 * @param int $height
181
-	 * @param bool $crop
182
-	 * @param string $mode
183
-	 * @param string $mimeType
184
-	 * @return ISimpleFile
185
-	 * @throws NotFoundException
186
-	 * @throws \InvalidArgumentException if the preview would be invalid (in case the original image is invalid)
187
-	 * @since 11.0.0 - \InvalidArgumentException was added in 12.0.0
188
-	 */
189
-	public function getPreview(File $file, $width = -1, $height = -1, $crop = false, $mode = IPreview::MODE_FILL, $mimeType = null) {
190
-		return $this->getGenerator()->getPreview($file, $width, $height, $crop, $mode, $mimeType);
191
-	}
192
-
193
-	/**
194
-	 * Generates previews of a file
195
-	 *
196
-	 * @param File $file
197
-	 * @param array $specifications
198
-	 * @param string $mimeType
199
-	 * @return ISimpleFile the last preview that was generated
200
-	 * @throws NotFoundException
201
-	 * @throws \InvalidArgumentException if the preview would be invalid (in case the original image is invalid)
202
-	 * @since 19.0.0
203
-	 */
204
-	public function generatePreviews(File $file, array $specifications, $mimeType = null) {
205
-		return $this->getGenerator()->generatePreviews($file, $specifications, $mimeType);
206
-	}
207
-
208
-	/**
209
-	 * returns true if the passed mime type is supported
210
-	 *
211
-	 * @param string $mimeType
212
-	 * @return boolean
213
-	 */
214
-	public function isMimeSupported($mimeType = '*') {
215
-		if (!$this->config->getSystemValue('enable_previews', true)) {
216
-			return false;
217
-		}
218
-
219
-		if (isset($this->mimeTypeSupportMap[$mimeType])) {
220
-			return $this->mimeTypeSupportMap[$mimeType];
221
-		}
222
-
223
-		$this->registerCoreProviders();
224
-		$providerMimeTypes = array_keys($this->providers);
225
-		foreach ($providerMimeTypes as $supportedMimeType) {
226
-			if (preg_match($supportedMimeType, $mimeType)) {
227
-				$this->mimeTypeSupportMap[$mimeType] = true;
228
-				return true;
229
-			}
230
-		}
231
-		$this->mimeTypeSupportMap[$mimeType] = false;
232
-		return false;
233
-	}
234
-
235
-	/**
236
-	 * Check if a preview can be generated for a file
237
-	 *
238
-	 * @param \OCP\Files\FileInfo $file
239
-	 * @return bool
240
-	 */
241
-	public function isAvailable(\OCP\Files\FileInfo $file) {
242
-		if (!$this->config->getSystemValue('enable_previews', true)) {
243
-			return false;
244
-		}
245
-
246
-		$this->registerCoreProviders();
247
-		if (!$this->isMimeSupported($file->getMimetype())) {
248
-			return false;
249
-		}
250
-
251
-		$mount = $file->getMountPoint();
252
-		if ($mount and !$mount->getOption('previews', true)) {
253
-			return false;
254
-		}
255
-
256
-		foreach ($this->providers as $supportedMimeType => $providers) {
257
-			if (preg_match($supportedMimeType, $file->getMimetype())) {
258
-				foreach ($providers as $providerClosure) {
259
-					$provider = $this->helper->getProvider($providerClosure);
260
-					if (!($provider instanceof IProviderV2)) {
261
-						continue;
262
-					}
263
-
264
-					if ($provider->isAvailable($file)) {
265
-						return true;
266
-					}
267
-				}
268
-			}
269
-		}
270
-		return false;
271
-	}
272
-
273
-	/**
274
-	 * List of enabled default providers
275
-	 *
276
-	 * The following providers are enabled by default:
277
-	 *  - OC\Preview\PNG
278
-	 *  - OC\Preview\JPEG
279
-	 *  - OC\Preview\GIF
280
-	 *  - OC\Preview\BMP
281
-	 *  - OC\Preview\HEIC
282
-	 *  - OC\Preview\XBitmap
283
-	 *  - OC\Preview\MarkDown
284
-	 *  - OC\Preview\MP3
285
-	 *  - OC\Preview\TXT
286
-	 *
287
-	 * The following providers are disabled by default due to performance or privacy concerns:
288
-	 *  - OC\Preview\Font
289
-	 *  - OC\Preview\Illustrator
290
-	 *  - OC\Preview\Movie
291
-	 *  - OC\Preview\MSOfficeDoc
292
-	 *  - OC\Preview\MSOffice2003
293
-	 *  - OC\Preview\MSOffice2007
294
-	 *  - OC\Preview\OpenDocument
295
-	 *  - OC\Preview\PDF
296
-	 *  - OC\Preview\Photoshop
297
-	 *  - OC\Preview\Postscript
298
-	 *  - OC\Preview\StarOffice
299
-	 *  - OC\Preview\SVG
300
-	 *  - OC\Preview\TIFF
301
-	 *
302
-	 * @return array
303
-	 */
304
-	protected function getEnabledDefaultProvider() {
305
-		if ($this->defaultProviders !== null) {
306
-			return $this->defaultProviders;
307
-		}
308
-
309
-		$imageProviders = [
310
-			Preview\PNG::class,
311
-			Preview\JPEG::class,
312
-			Preview\GIF::class,
313
-			Preview\BMP::class,
314
-			Preview\HEIC::class,
315
-			Preview\XBitmap::class,
316
-			Preview\Krita::class,
317
-			Preview\WebP::class,
318
-		];
319
-
320
-		$this->defaultProviders = $this->config->getSystemValue('enabledPreviewProviders', array_merge([
321
-			Preview\MarkDown::class,
322
-			Preview\MP3::class,
323
-			Preview\TXT::class,
324
-			Preview\OpenDocument::class,
325
-		], $imageProviders));
326
-
327
-		if (in_array(Preview\Image::class, $this->defaultProviders)) {
328
-			$this->defaultProviders = array_merge($this->defaultProviders, $imageProviders);
329
-		}
330
-		$this->defaultProviders = array_unique($this->defaultProviders);
331
-		return $this->defaultProviders;
332
-	}
333
-
334
-	/**
335
-	 * Register the default providers (if enabled)
336
-	 *
337
-	 * @param string $class
338
-	 * @param string $mimeType
339
-	 */
340
-	protected function registerCoreProvider($class, $mimeType, $options = []) {
341
-		if (in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
342
-			$this->registerProvider($mimeType, function () use ($class, $options) {
343
-				return new $class($options);
344
-			});
345
-		}
346
-	}
347
-
348
-	/**
349
-	 * Register the default providers (if enabled)
350
-	 */
351
-	protected function registerCoreProviders() {
352
-		if ($this->registeredCoreProviders) {
353
-			return;
354
-		}
355
-		$this->registeredCoreProviders = true;
356
-
357
-		$this->registerCoreProvider(Preview\TXT::class, '/text\/plain/');
358
-		$this->registerCoreProvider(Preview\MarkDown::class, '/text\/(x-)?markdown/');
359
-		$this->registerCoreProvider(Preview\PNG::class, '/image\/png/');
360
-		$this->registerCoreProvider(Preview\JPEG::class, '/image\/jpeg/');
361
-		$this->registerCoreProvider(Preview\GIF::class, '/image\/gif/');
362
-		$this->registerCoreProvider(Preview\BMP::class, '/image\/bmp/');
363
-		$this->registerCoreProvider(Preview\XBitmap::class, '/image\/x-xbitmap/');
364
-		$this->registerCoreProvider(Preview\WebP::class, '/image\/webp/');
365
-		$this->registerCoreProvider(Preview\Krita::class, '/application\/x-krita/');
366
-		$this->registerCoreProvider(Preview\MP3::class, '/audio\/mpeg/');
367
-		$this->registerCoreProvider(Preview\OpenDocument::class, '/application\/vnd.oasis.opendocument.*/');
368
-
369
-		// SVG, Office and Bitmap require imagick
370
-		if (extension_loaded('imagick')) {
371
-			$checkImagick = new \Imagick();
372
-
373
-			$imagickProviders = [
374
-				'SVG' => ['mimetype' => '/image\/svg\+xml/', 'class' => Preview\SVG::class],
375
-				'TIFF' => ['mimetype' => '/image\/tiff/', 'class' => Preview\TIFF::class],
376
-				'PDF' => ['mimetype' => '/application\/pdf/', 'class' => Preview\PDF::class],
377
-				'AI' => ['mimetype' => '/application\/illustrator/', 'class' => Preview\Illustrator::class],
378
-				'PSD' => ['mimetype' => '/application\/x-photoshop/', 'class' => Preview\Photoshop::class],
379
-				'EPS' => ['mimetype' => '/application\/postscript/', 'class' => Preview\Postscript::class],
380
-				'TTF' => ['mimetype' => '/application\/(?:font-sfnt|x-font$)/', 'class' => Preview\Font::class],
381
-				'HEIC' => ['mimetype' => '/image\/hei(f|c)/', 'class' => Preview\HEIC::class],
382
-				'TGA' => ['mimetype' => '/image\/t(ar)?ga/', 'class' => Preview\TGA::class],
383
-				'SGI' => ['mimetype' => '/image\/sgi/', 'class' => Preview\SGI::class],
384
-			];
385
-
386
-			foreach ($imagickProviders as $queryFormat => $provider) {
387
-				$class = $provider['class'];
388
-				if (!in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
389
-					continue;
390
-				}
391
-
392
-				if (count($checkImagick->queryFormats($queryFormat)) === 1) {
393
-					$this->registerCoreProvider($class, $provider['mimetype']);
394
-				}
395
-			}
396
-
397
-			if (count($checkImagick->queryFormats('PDF')) === 1) {
398
-				if (\OC_Helper::is_function_enabled('shell_exec')) {
399
-					$officeFound = is_string($this->config->getSystemValue('preview_libreoffice_path', null));
400
-
401
-					if (!$officeFound) {
402
-						//let's see if there is libreoffice or openoffice on this machine
403
-						$whichLibreOffice = shell_exec('command -v libreoffice');
404
-						$officeFound = !empty($whichLibreOffice);
405
-						if (!$officeFound) {
406
-							$whichOpenOffice = shell_exec('command -v openoffice');
407
-							$officeFound = !empty($whichOpenOffice);
408
-						}
409
-					}
410
-
411
-					if ($officeFound) {
412
-						$this->registerCoreProvider(Preview\MSOfficeDoc::class, '/application\/msword/');
413
-						$this->registerCoreProvider(Preview\MSOffice2003::class, '/application\/vnd.ms-.*/');
414
-						$this->registerCoreProvider(Preview\MSOffice2007::class, '/application\/vnd.openxmlformats-officedocument.*/');
415
-						$this->registerCoreProvider(Preview\OpenDocument::class, '/application\/vnd.oasis.opendocument.*/');
416
-						$this->registerCoreProvider(Preview\StarOffice::class, '/application\/vnd.sun.xml.*/');
417
-					}
418
-				}
419
-			}
420
-		}
421
-
422
-		// Video requires avconv or ffmpeg
423
-		if (in_array(Preview\Movie::class, $this->getEnabledDefaultProvider())) {
424
-			$avconvBinary = \OC_Helper::findBinaryPath('avconv');
425
-			$ffmpegBinary = $avconvBinary ? null : \OC_Helper::findBinaryPath('ffmpeg');
426
-
427
-			if ($avconvBinary || $ffmpegBinary) {
428
-				// FIXME // a bit hacky but didn't want to use subclasses
429
-				\OC\Preview\Movie::$avconvBinary = $avconvBinary;
430
-				\OC\Preview\Movie::$ffmpegBinary = $ffmpegBinary;
431
-
432
-				$this->registerCoreProvider(Preview\Movie::class, '/video\/.*/');
433
-			}
434
-		}
435
-	}
47
+    /** @var IConfig */
48
+    protected $config;
49
+
50
+    /** @var IRootFolder */
51
+    protected $rootFolder;
52
+
53
+    /** @var IAppData */
54
+    protected $appData;
55
+
56
+    /** @var EventDispatcherInterface */
57
+    protected $eventDispatcher;
58
+
59
+    /** @var Generator */
60
+    private $generator;
61
+
62
+    /** @var GeneratorHelper */
63
+    private $helper;
64
+
65
+    /** @var bool */
66
+    protected $providerListDirty = false;
67
+
68
+    /** @var bool */
69
+    protected $registeredCoreProviders = false;
70
+
71
+    /** @var array */
72
+    protected $providers = [];
73
+
74
+    /** @var array mime type => support status */
75
+    protected $mimeTypeSupportMap = [];
76
+
77
+    /** @var array */
78
+    protected $defaultProviders;
79
+
80
+    /** @var string */
81
+    protected $userId;
82
+
83
+    /**
84
+     * PreviewManager constructor.
85
+     *
86
+     * @param IConfig $config
87
+     * @param IRootFolder $rootFolder
88
+     * @param IAppData $appData
89
+     * @param EventDispatcherInterface $eventDispatcher
90
+     * @param string $userId
91
+     */
92
+    public function __construct(IConfig $config,
93
+                                IRootFolder $rootFolder,
94
+                                IAppData $appData,
95
+                                EventDispatcherInterface $eventDispatcher,
96
+                                GeneratorHelper $helper,
97
+                                $userId) {
98
+        $this->config = $config;
99
+        $this->rootFolder = $rootFolder;
100
+        $this->appData = $appData;
101
+        $this->eventDispatcher = $eventDispatcher;
102
+        $this->helper = $helper;
103
+        $this->userId = $userId;
104
+    }
105
+
106
+    /**
107
+     * In order to improve lazy loading a closure can be registered which will be
108
+     * called in case preview providers are actually requested
109
+     *
110
+     * $callable has to return an instance of \OCP\Preview\IProvider or \OCP\Preview\IProviderV2
111
+     *
112
+     * @param string $mimeTypeRegex Regex with the mime types that are supported by this provider
113
+     * @param \Closure $callable
114
+     * @return void
115
+     */
116
+    public function registerProvider($mimeTypeRegex, \Closure $callable) {
117
+        if (!$this->config->getSystemValue('enable_previews', true)) {
118
+            return;
119
+        }
120
+
121
+        if (!isset($this->providers[$mimeTypeRegex])) {
122
+            $this->providers[$mimeTypeRegex] = [];
123
+        }
124
+        $this->providers[$mimeTypeRegex][] = $callable;
125
+        $this->providerListDirty = true;
126
+    }
127
+
128
+    /**
129
+     * Get all providers
130
+     * @return array
131
+     */
132
+    public function getProviders() {
133
+        if (!$this->config->getSystemValue('enable_previews', true)) {
134
+            return [];
135
+        }
136
+
137
+        $this->registerCoreProviders();
138
+        if ($this->providerListDirty) {
139
+            $keys = array_map('strlen', array_keys($this->providers));
140
+            array_multisort($keys, SORT_DESC, $this->providers);
141
+            $this->providerListDirty = false;
142
+        }
143
+
144
+        return $this->providers;
145
+    }
146
+
147
+    /**
148
+     * Does the manager have any providers
149
+     * @return bool
150
+     */
151
+    public function hasProviders() {
152
+        $this->registerCoreProviders();
153
+        return !empty($this->providers);
154
+    }
155
+
156
+    private function getGenerator(): Generator {
157
+        if ($this->generator === null) {
158
+            $this->generator = new Generator(
159
+                $this->config,
160
+                $this,
161
+                $this->appData,
162
+                new GeneratorHelper(
163
+                    $this->rootFolder,
164
+                    $this->config
165
+                ),
166
+                $this->eventDispatcher
167
+            );
168
+        }
169
+        return $this->generator;
170
+    }
171
+
172
+    /**
173
+     * Returns a preview of a file
174
+     *
175
+     * The cache is searched first and if nothing usable was found then a preview is
176
+     * generated by one of the providers
177
+     *
178
+     * @param File $file
179
+     * @param int $width
180
+     * @param int $height
181
+     * @param bool $crop
182
+     * @param string $mode
183
+     * @param string $mimeType
184
+     * @return ISimpleFile
185
+     * @throws NotFoundException
186
+     * @throws \InvalidArgumentException if the preview would be invalid (in case the original image is invalid)
187
+     * @since 11.0.0 - \InvalidArgumentException was added in 12.0.0
188
+     */
189
+    public function getPreview(File $file, $width = -1, $height = -1, $crop = false, $mode = IPreview::MODE_FILL, $mimeType = null) {
190
+        return $this->getGenerator()->getPreview($file, $width, $height, $crop, $mode, $mimeType);
191
+    }
192
+
193
+    /**
194
+     * Generates previews of a file
195
+     *
196
+     * @param File $file
197
+     * @param array $specifications
198
+     * @param string $mimeType
199
+     * @return ISimpleFile the last preview that was generated
200
+     * @throws NotFoundException
201
+     * @throws \InvalidArgumentException if the preview would be invalid (in case the original image is invalid)
202
+     * @since 19.0.0
203
+     */
204
+    public function generatePreviews(File $file, array $specifications, $mimeType = null) {
205
+        return $this->getGenerator()->generatePreviews($file, $specifications, $mimeType);
206
+    }
207
+
208
+    /**
209
+     * returns true if the passed mime type is supported
210
+     *
211
+     * @param string $mimeType
212
+     * @return boolean
213
+     */
214
+    public function isMimeSupported($mimeType = '*') {
215
+        if (!$this->config->getSystemValue('enable_previews', true)) {
216
+            return false;
217
+        }
218
+
219
+        if (isset($this->mimeTypeSupportMap[$mimeType])) {
220
+            return $this->mimeTypeSupportMap[$mimeType];
221
+        }
222
+
223
+        $this->registerCoreProviders();
224
+        $providerMimeTypes = array_keys($this->providers);
225
+        foreach ($providerMimeTypes as $supportedMimeType) {
226
+            if (preg_match($supportedMimeType, $mimeType)) {
227
+                $this->mimeTypeSupportMap[$mimeType] = true;
228
+                return true;
229
+            }
230
+        }
231
+        $this->mimeTypeSupportMap[$mimeType] = false;
232
+        return false;
233
+    }
234
+
235
+    /**
236
+     * Check if a preview can be generated for a file
237
+     *
238
+     * @param \OCP\Files\FileInfo $file
239
+     * @return bool
240
+     */
241
+    public function isAvailable(\OCP\Files\FileInfo $file) {
242
+        if (!$this->config->getSystemValue('enable_previews', true)) {
243
+            return false;
244
+        }
245
+
246
+        $this->registerCoreProviders();
247
+        if (!$this->isMimeSupported($file->getMimetype())) {
248
+            return false;
249
+        }
250
+
251
+        $mount = $file->getMountPoint();
252
+        if ($mount and !$mount->getOption('previews', true)) {
253
+            return false;
254
+        }
255
+
256
+        foreach ($this->providers as $supportedMimeType => $providers) {
257
+            if (preg_match($supportedMimeType, $file->getMimetype())) {
258
+                foreach ($providers as $providerClosure) {
259
+                    $provider = $this->helper->getProvider($providerClosure);
260
+                    if (!($provider instanceof IProviderV2)) {
261
+                        continue;
262
+                    }
263
+
264
+                    if ($provider->isAvailable($file)) {
265
+                        return true;
266
+                    }
267
+                }
268
+            }
269
+        }
270
+        return false;
271
+    }
272
+
273
+    /**
274
+     * List of enabled default providers
275
+     *
276
+     * The following providers are enabled by default:
277
+     *  - OC\Preview\PNG
278
+     *  - OC\Preview\JPEG
279
+     *  - OC\Preview\GIF
280
+     *  - OC\Preview\BMP
281
+     *  - OC\Preview\HEIC
282
+     *  - OC\Preview\XBitmap
283
+     *  - OC\Preview\MarkDown
284
+     *  - OC\Preview\MP3
285
+     *  - OC\Preview\TXT
286
+     *
287
+     * The following providers are disabled by default due to performance or privacy concerns:
288
+     *  - OC\Preview\Font
289
+     *  - OC\Preview\Illustrator
290
+     *  - OC\Preview\Movie
291
+     *  - OC\Preview\MSOfficeDoc
292
+     *  - OC\Preview\MSOffice2003
293
+     *  - OC\Preview\MSOffice2007
294
+     *  - OC\Preview\OpenDocument
295
+     *  - OC\Preview\PDF
296
+     *  - OC\Preview\Photoshop
297
+     *  - OC\Preview\Postscript
298
+     *  - OC\Preview\StarOffice
299
+     *  - OC\Preview\SVG
300
+     *  - OC\Preview\TIFF
301
+     *
302
+     * @return array
303
+     */
304
+    protected function getEnabledDefaultProvider() {
305
+        if ($this->defaultProviders !== null) {
306
+            return $this->defaultProviders;
307
+        }
308
+
309
+        $imageProviders = [
310
+            Preview\PNG::class,
311
+            Preview\JPEG::class,
312
+            Preview\GIF::class,
313
+            Preview\BMP::class,
314
+            Preview\HEIC::class,
315
+            Preview\XBitmap::class,
316
+            Preview\Krita::class,
317
+            Preview\WebP::class,
318
+        ];
319
+
320
+        $this->defaultProviders = $this->config->getSystemValue('enabledPreviewProviders', array_merge([
321
+            Preview\MarkDown::class,
322
+            Preview\MP3::class,
323
+            Preview\TXT::class,
324
+            Preview\OpenDocument::class,
325
+        ], $imageProviders));
326
+
327
+        if (in_array(Preview\Image::class, $this->defaultProviders)) {
328
+            $this->defaultProviders = array_merge($this->defaultProviders, $imageProviders);
329
+        }
330
+        $this->defaultProviders = array_unique($this->defaultProviders);
331
+        return $this->defaultProviders;
332
+    }
333
+
334
+    /**
335
+     * Register the default providers (if enabled)
336
+     *
337
+     * @param string $class
338
+     * @param string $mimeType
339
+     */
340
+    protected function registerCoreProvider($class, $mimeType, $options = []) {
341
+        if (in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
342
+            $this->registerProvider($mimeType, function () use ($class, $options) {
343
+                return new $class($options);
344
+            });
345
+        }
346
+    }
347
+
348
+    /**
349
+     * Register the default providers (if enabled)
350
+     */
351
+    protected function registerCoreProviders() {
352
+        if ($this->registeredCoreProviders) {
353
+            return;
354
+        }
355
+        $this->registeredCoreProviders = true;
356
+
357
+        $this->registerCoreProvider(Preview\TXT::class, '/text\/plain/');
358
+        $this->registerCoreProvider(Preview\MarkDown::class, '/text\/(x-)?markdown/');
359
+        $this->registerCoreProvider(Preview\PNG::class, '/image\/png/');
360
+        $this->registerCoreProvider(Preview\JPEG::class, '/image\/jpeg/');
361
+        $this->registerCoreProvider(Preview\GIF::class, '/image\/gif/');
362
+        $this->registerCoreProvider(Preview\BMP::class, '/image\/bmp/');
363
+        $this->registerCoreProvider(Preview\XBitmap::class, '/image\/x-xbitmap/');
364
+        $this->registerCoreProvider(Preview\WebP::class, '/image\/webp/');
365
+        $this->registerCoreProvider(Preview\Krita::class, '/application\/x-krita/');
366
+        $this->registerCoreProvider(Preview\MP3::class, '/audio\/mpeg/');
367
+        $this->registerCoreProvider(Preview\OpenDocument::class, '/application\/vnd.oasis.opendocument.*/');
368
+
369
+        // SVG, Office and Bitmap require imagick
370
+        if (extension_loaded('imagick')) {
371
+            $checkImagick = new \Imagick();
372
+
373
+            $imagickProviders = [
374
+                'SVG' => ['mimetype' => '/image\/svg\+xml/', 'class' => Preview\SVG::class],
375
+                'TIFF' => ['mimetype' => '/image\/tiff/', 'class' => Preview\TIFF::class],
376
+                'PDF' => ['mimetype' => '/application\/pdf/', 'class' => Preview\PDF::class],
377
+                'AI' => ['mimetype' => '/application\/illustrator/', 'class' => Preview\Illustrator::class],
378
+                'PSD' => ['mimetype' => '/application\/x-photoshop/', 'class' => Preview\Photoshop::class],
379
+                'EPS' => ['mimetype' => '/application\/postscript/', 'class' => Preview\Postscript::class],
380
+                'TTF' => ['mimetype' => '/application\/(?:font-sfnt|x-font$)/', 'class' => Preview\Font::class],
381
+                'HEIC' => ['mimetype' => '/image\/hei(f|c)/', 'class' => Preview\HEIC::class],
382
+                'TGA' => ['mimetype' => '/image\/t(ar)?ga/', 'class' => Preview\TGA::class],
383
+                'SGI' => ['mimetype' => '/image\/sgi/', 'class' => Preview\SGI::class],
384
+            ];
385
+
386
+            foreach ($imagickProviders as $queryFormat => $provider) {
387
+                $class = $provider['class'];
388
+                if (!in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
389
+                    continue;
390
+                }
391
+
392
+                if (count($checkImagick->queryFormats($queryFormat)) === 1) {
393
+                    $this->registerCoreProvider($class, $provider['mimetype']);
394
+                }
395
+            }
396
+
397
+            if (count($checkImagick->queryFormats('PDF')) === 1) {
398
+                if (\OC_Helper::is_function_enabled('shell_exec')) {
399
+                    $officeFound = is_string($this->config->getSystemValue('preview_libreoffice_path', null));
400
+
401
+                    if (!$officeFound) {
402
+                        //let's see if there is libreoffice or openoffice on this machine
403
+                        $whichLibreOffice = shell_exec('command -v libreoffice');
404
+                        $officeFound = !empty($whichLibreOffice);
405
+                        if (!$officeFound) {
406
+                            $whichOpenOffice = shell_exec('command -v openoffice');
407
+                            $officeFound = !empty($whichOpenOffice);
408
+                        }
409
+                    }
410
+
411
+                    if ($officeFound) {
412
+                        $this->registerCoreProvider(Preview\MSOfficeDoc::class, '/application\/msword/');
413
+                        $this->registerCoreProvider(Preview\MSOffice2003::class, '/application\/vnd.ms-.*/');
414
+                        $this->registerCoreProvider(Preview\MSOffice2007::class, '/application\/vnd.openxmlformats-officedocument.*/');
415
+                        $this->registerCoreProvider(Preview\OpenDocument::class, '/application\/vnd.oasis.opendocument.*/');
416
+                        $this->registerCoreProvider(Preview\StarOffice::class, '/application\/vnd.sun.xml.*/');
417
+                    }
418
+                }
419
+            }
420
+        }
421
+
422
+        // Video requires avconv or ffmpeg
423
+        if (in_array(Preview\Movie::class, $this->getEnabledDefaultProvider())) {
424
+            $avconvBinary = \OC_Helper::findBinaryPath('avconv');
425
+            $ffmpegBinary = $avconvBinary ? null : \OC_Helper::findBinaryPath('ffmpeg');
426
+
427
+            if ($avconvBinary || $ffmpegBinary) {
428
+                // FIXME // a bit hacky but didn't want to use subclasses
429
+                \OC\Preview\Movie::$avconvBinary = $avconvBinary;
430
+                \OC\Preview\Movie::$ffmpegBinary = $ffmpegBinary;
431
+
432
+                $this->registerCoreProvider(Preview\Movie::class, '/video\/.*/');
433
+            }
434
+        }
435
+    }
436 436
 }
Please login to merge, or discard this patch.