diff options
129 files changed, 949 insertions, 274 deletions
diff --git a/apps/encryption/l10n/el.js b/apps/encryption/l10n/el.js index d2546fff92a..078b66d6784 100644 --- a/apps/encryption/l10n/el.js +++ b/apps/encryption/l10n/el.js @@ -21,8 +21,10 @@ OC.L10N.register( "The old password was not correct, please try again." : "Το παλαιό συνθηματικό δεν είναι σωστό, παρακαλώ δοκιμάστε ξανά.", "The current log-in password was not correct, please try again." : "Το τρέχον συνθηματικό δεν είναι σωστό, παρακαλώ δοκιμάστε ξανά.", "Private key password successfully updated." : "Το Προσωπικό κλειδί πρόσβασης ενημερώθηκε επιτυχώς", + "You need to migrate your encryption keys from the old encryption (ownCloud <= 8.0) to the new one. Please run 'occ encryption:migrate' or contact your administrator" : "Πρέπει να μεταφέρετε τα κλειδιά κρυπτογράφησής σας από την παλιά κρυπτογράφηση (ownCloud <= 8.0) στην καινούρια. Παρακαλούμε εκτελέστε την εντολή 'occ encryption:migrate' ή επικοινωνήστε με το διαχειριστή σας.", "Invalid private key for Encryption App. Please update your private key password in your personal settings to recover access to your encrypted files." : "Άκυρο προσωπικό κλειδί για την εφαρμογή κρυπτογράφησης. Παρακαλώ ενημερώστε τον κωδικό του προσωπικού κλειδίου σας στις προσωπικές ρυθμίσεις για να επανακτήσετε πρόσβαση στα κρυπτογραφημένα σας αρχεία.", "Encryption App is enabled but your keys are not initialized, please log-out and log-in again" : "Η εφαρμογή κρυπτογράφησης είναι ενεργοποιημένη αλλά τα κλειδιά σας δεν έχουν καταγραφεί, παρακαλώ αποσυνδεθείτε και επανασυνδεθείτε.", + "Encryption App is enabled and ready" : "Η Εφαρμογή Κρυπτογράφησης είναι ενεργοποιημένη και έτοιμη.", "Can not decrypt this file, probably this is a shared file. Please ask the file owner to reshare the file with you." : "Δεν ήταν δυνατό να αποκρυπτογραφηθεί αυτό το αρχείο, πιθανόν πρόκειται για κοινόχρηστο αρχείο. Παρακαλώ ζητήστε από τον ιδιοκτήτη του αρχείου να το ξαναμοιραστεί μαζί σας.", "Can not read this file, probably this is a shared file. Please ask the file owner to reshare the file with you." : "Αδυναμία ανάγνωσης αυτού του αρχείου, πιθανό να είναι διαμοιραζόμενο αρχείο. Παρακαλώ ρωτήστε τον κάτοχο του αρχείου να το διαμοιράσει ξανά μαζί σας.", "Enable recovery key" : "Ενεργοποίηση κλειδιού ανάκτησης", diff --git a/apps/encryption/l10n/el.json b/apps/encryption/l10n/el.json index 8904aaa8fa3..c50f4cf938b 100644 --- a/apps/encryption/l10n/el.json +++ b/apps/encryption/l10n/el.json @@ -19,8 +19,10 @@ "The old password was not correct, please try again." : "Το παλαιό συνθηματικό δεν είναι σωστό, παρακαλώ δοκιμάστε ξανά.", "The current log-in password was not correct, please try again." : "Το τρέχον συνθηματικό δεν είναι σωστό, παρακαλώ δοκιμάστε ξανά.", "Private key password successfully updated." : "Το Προσωπικό κλειδί πρόσβασης ενημερώθηκε επιτυχώς", + "You need to migrate your encryption keys from the old encryption (ownCloud <= 8.0) to the new one. Please run 'occ encryption:migrate' or contact your administrator" : "Πρέπει να μεταφέρετε τα κλειδιά κρυπτογράφησής σας από την παλιά κρυπτογράφηση (ownCloud <= 8.0) στην καινούρια. Παρακαλούμε εκτελέστε την εντολή 'occ encryption:migrate' ή επικοινωνήστε με το διαχειριστή σας.", "Invalid private key for Encryption App. Please update your private key password in your personal settings to recover access to your encrypted files." : "Άκυρο προσωπικό κλειδί για την εφαρμογή κρυπτογράφησης. Παρακαλώ ενημερώστε τον κωδικό του προσωπικού κλειδίου σας στις προσωπικές ρυθμίσεις για να επανακτήσετε πρόσβαση στα κρυπτογραφημένα σας αρχεία.", "Encryption App is enabled but your keys are not initialized, please log-out and log-in again" : "Η εφαρμογή κρυπτογράφησης είναι ενεργοποιημένη αλλά τα κλειδιά σας δεν έχουν καταγραφεί, παρακαλώ αποσυνδεθείτε και επανασυνδεθείτε.", + "Encryption App is enabled and ready" : "Η Εφαρμογή Κρυπτογράφησης είναι ενεργοποιημένη και έτοιμη.", "Can not decrypt this file, probably this is a shared file. Please ask the file owner to reshare the file with you." : "Δεν ήταν δυνατό να αποκρυπτογραφηθεί αυτό το αρχείο, πιθανόν πρόκειται για κοινόχρηστο αρχείο. Παρακαλώ ζητήστε από τον ιδιοκτήτη του αρχείου να το ξαναμοιραστεί μαζί σας.", "Can not read this file, probably this is a shared file. Please ask the file owner to reshare the file with you." : "Αδυναμία ανάγνωσης αυτού του αρχείου, πιθανό να είναι διαμοιραζόμενο αρχείο. Παρακαλώ ρωτήστε τον κάτοχο του αρχείου να το διαμοιράσει ξανά μαζί σας.", "Enable recovery key" : "Ενεργοποίηση κλειδιού ανάκτησης", diff --git a/apps/encryption/tests/lib/HookManagerTest.php b/apps/encryption/tests/lib/HookManagerTest.php index 3da0bafb691..fb74c05546b 100644 --- a/apps/encryption/tests/lib/HookManagerTest.php +++ b/apps/encryption/tests/lib/HookManagerTest.php @@ -43,7 +43,7 @@ class HookManagerTest extends TestCase { $this->getMock('NotIHook') ]); - $hookInstances = \Test_Helper::invokePrivate(self::$instance, 'hookInstances'); + $hookInstances = self::invokePrivate(self::$instance, 'hookInstances'); // Make sure our type checking works $this->assertCount(2, $hookInstances); } @@ -66,7 +66,7 @@ class HookManagerTest extends TestCase { $mock = $this->getMockBuilder('OCA\Encryption\Hooks\Contracts\IHook')->disableOriginalConstructor()->getMock(); self::$instance->registerHook($mock); - $hookInstances = \Test_Helper::invokePrivate(self::$instance, 'hookInstances'); + $hookInstances = self::invokePrivate(self::$instance, 'hookInstances'); $this->assertCount(3, $hookInstances); } diff --git a/apps/encryption/tests/lib/KeyManagerTest.php b/apps/encryption/tests/lib/KeyManagerTest.php index 6e9c6d15818..eb43d5a843f 100644 --- a/apps/encryption/tests/lib/KeyManagerTest.php +++ b/apps/encryption/tests/lib/KeyManagerTest.php @@ -285,7 +285,7 @@ class KeyManagerTest extends TestCase { ->with('user1', 'privateKey') ->willReturn(true); - $this->assertTrue(\Test_Helper::invokePrivate($this->instance, + $this->assertTrue(self::invokePrivate($this->instance, 'deletePrivateKey', [$this->userId])); } @@ -329,8 +329,8 @@ class KeyManagerTest extends TestCase { }); // set key IDs - \Test_Helper::invokePrivate($this->instance, 'publicShareKeyId', [$publicShareKeyId]); - \Test_Helper::invokePrivate($this->instance, 'recoveryKeyId', [$recoveryKeyId]); + self::invokePrivate($this->instance, 'publicShareKeyId', [$publicShareKeyId]); + self::invokePrivate($this->instance, 'recoveryKeyId', [$recoveryKeyId]); $result = $this->instance->addSystemKeys($accessList, $publicKeys, $uid); diff --git a/apps/encryption/tests/lib/MigrationTest.php b/apps/encryption/tests/lib/MigrationTest.php index f56ff5cc2f7..c876cea05c9 100644 --- a/apps/encryption/tests/lib/MigrationTest.php +++ b/apps/encryption/tests/lib/MigrationTest.php @@ -292,7 +292,7 @@ class MigrationTest extends \Test\TestCase { public function testUpdateFileCache() { $this->prepareFileCache(); $m = new Migration(\OC::$server->getConfig(), new \OC\Files\View(), \OC::$server->getDatabaseConnection()); - \Test_Helper::invokePrivate($m, 'updateFileCache'); + self::invokePrivate($m, 'updateFileCache'); // check results diff --git a/apps/encryption/tests/lib/RecoveryTest.php b/apps/encryption/tests/lib/RecoveryTest.php index 5bfafa3a98e..0b85192690b 100644 --- a/apps/encryption/tests/lib/RecoveryTest.php +++ b/apps/encryption/tests/lib/RecoveryTest.php @@ -180,7 +180,7 @@ class RecoveryTest extends TestCase { $this->keyManagerMock->expects($this->once()) ->method('setAllFileKeys'); - $this->assertNull(\Test_Helper::invokePrivate($this->instance, + $this->assertNull(self::invokePrivate($this->instance, 'recoverFile', ['/', 'testkey', 'admin'])); } diff --git a/apps/encryption/tests/lib/crypto/cryptTest.php b/apps/encryption/tests/lib/crypto/cryptTest.php index 4114adb115a..f850725108b 100644 --- a/apps/encryption/tests/lib/crypto/cryptTest.php +++ b/apps/encryption/tests/lib/crypto/cryptTest.php @@ -70,7 +70,7 @@ class cryptTest extends TestCase { ->with($this->equalTo('openssl'), $this->equalTo([])) ->willReturn(array()); - $result = \Test_Helper::invokePrivate($this->crypt, 'getOpenSSLConfig'); + $result = self::invokePrivate($this->crypt, 'getOpenSSLConfig'); $this->assertSame(1, count($result)); $this->assertArrayHasKey('private_key_bits', $result); $this->assertSame(4096, $result['private_key_bits']); @@ -86,7 +86,7 @@ class cryptTest extends TestCase { ->with($this->equalTo('openssl'), $this->equalTo([])) ->willReturn(array('foo' => 'bar', 'private_key_bits' => 1028)); - $result = \Test_Helper::invokePrivate($this->crypt, 'getOpenSSLConfig'); + $result = self::invokePrivate($this->crypt, 'getOpenSSLConfig'); $this->assertSame(2, count($result)); $this->assertArrayHasKey('private_key_bits', $result); $this->assertArrayHasKey('foo', $result); @@ -146,7 +146,7 @@ class cryptTest extends TestCase { */ public function testConcatIV() { - $result = \Test_Helper::invokePrivate( + $result = self::invokePrivate( $this->crypt, 'concatIV', array('content', 'my_iv')); @@ -161,7 +161,7 @@ class cryptTest extends TestCase { */ public function testSplitIV() { $data = 'encryptedContent00iv001234567890123456'; - $result = \Test_Helper::invokePrivate($this->crypt, 'splitIV', array($data)); + $result = self::invokePrivate($this->crypt, 'splitIV', array($data)); $this->assertTrue(is_array($result)); $this->assertSame(2, count($result)); $this->assertArrayHasKey('encrypted', $result); @@ -174,7 +174,7 @@ class cryptTest extends TestCase { * test addPadding() */ public function testAddPadding() { - $result = \Test_Helper::invokePrivate($this->crypt, 'addPadding', array('data')); + $result = self::invokePrivate($this->crypt, 'addPadding', array('data')); $this->assertSame('dataxx', $result); } @@ -186,7 +186,7 @@ class cryptTest extends TestCase { * @param $expected */ public function testRemovePadding($data, $expected) { - $result = \Test_Helper::invokePrivate($this->crypt, 'removePadding', array($data)); + $result = self::invokePrivate($this->crypt, 'removePadding', array($data)); $this->assertSame($expected, $result); } @@ -208,7 +208,7 @@ class cryptTest extends TestCase { public function testParseHeader() { $header= 'HBEGIN:foo:bar:cipher:AES-256-CFB:HEND'; - $result = \Test_Helper::invokePrivate($this->crypt, 'parseHeader', array($header)); + $result = self::invokePrivate($this->crypt, 'parseHeader', array($header)); $this->assertTrue(is_array($result)); $this->assertSame(2, count($result)); @@ -227,12 +227,12 @@ class cryptTest extends TestCase { $decrypted = 'content'; $password = 'password'; - $iv = \Test_Helper::invokePrivate($this->crypt, 'generateIv'); + $iv = self::invokePrivate($this->crypt, 'generateIv'); $this->assertTrue(is_string($iv)); $this->assertSame(16, strlen($iv)); - $result = \Test_Helper::invokePrivate($this->crypt, 'encrypt', array($decrypted, $iv, $password)); + $result = self::invokePrivate($this->crypt, 'encrypt', array($decrypted, $iv, $password)); $this->assertTrue(is_string($result)); @@ -251,7 +251,7 @@ class cryptTest extends TestCase { */ public function testDecrypt($data) { - $result = \Test_Helper::invokePrivate( + $result = self::invokePrivate( $this->crypt, 'decrypt', array($data['encrypted'], $data['iv'], $data['password'])); diff --git a/apps/encryption/tests/lib/crypto/encryptionTest.php b/apps/encryption/tests/lib/crypto/encryptionTest.php index d33aff877bf..c6c0d57eff5 100644 --- a/apps/encryption/tests/lib/crypto/encryptionTest.php +++ b/apps/encryption/tests/lib/crypto/encryptionTest.php @@ -103,8 +103,8 @@ class EncryptionTest extends TestCase { */ public function endTest() { // prepare internal variables - \Test_Helper::invokePrivate($this->instance, 'isWriteOperation', [true]); - \Test_Helper::invokePrivate($this->instance, 'writeCache', ['']); + self::invokePrivate($this->instance, 'isWriteOperation', [true]); + self::invokePrivate($this->instance, 'writeCache', ['']); $this->keyManagerMock->expects($this->any()) ->method('getPublicKey') @@ -142,7 +142,7 @@ class EncryptionTest extends TestCase { */ public function testGetPathToRealFile($path, $expected) { $this->assertSame($expected, - \Test_Helper::invokePrivate($this->instance, 'getPathToRealFile', array($path)) + self::invokePrivate($this->instance, 'getPathToRealFile', array($path)) ); } @@ -184,9 +184,9 @@ class EncryptionTest extends TestCase { $this->assertArrayHasKey('cipher', $result); $this->assertSame($expected, $result['cipher']); if ($mode === 'w') { - $this->assertTrue(\Test_Helper::invokePrivate($this->instance, 'isWriteOperation')); + $this->assertTrue(self::invokePrivate($this->instance, 'isWriteOperation')); } else { - $this->assertFalse(\Test_Helper::invokePrivate($this->instance, 'isWriteOperation')); + $this->assertFalse(self::invokePrivate($this->instance, 'isWriteOperation')); } } diff --git a/apps/files/l10n/oc.js b/apps/files/l10n/oc.js index c8d4d9c180b..a3beb77ef2a 100644 --- a/apps/files/l10n/oc.js +++ b/apps/files/l10n/oc.js @@ -1,38 +1,115 @@ OC.L10N.register( "files", { - "There is no error, the file uploaded with success" : "Amontcargament capitat, pas d'errors", - "The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form" : "Lo fichièr amontcargat es mai gròs que la directiva «MAX_FILE_SIZE» especifiada dins lo formulari HTML", - "The uploaded file was only partially uploaded" : "Lo fichièr foguèt pas completament amontcargat", - "No file was uploaded" : "Cap de fichièrs son estats amontcargats", - "Missing a temporary folder" : "Un dorsièr temporari manca", - "Failed to write to disk" : "L'escriptura sul disc a fracassat", + "Storage not available" : "Supòrt d'emmagazinatge pas disponible", + "Storage invalid" : "Supòrt d'emmagazinatge pas valable", + "Unknown error" : "Error Desconeguda ", + "Could not move %s - File with this name already exists" : "Impossible de desplaçar %s - Un fichièr que pòrta aqueste nom existís ja", + "Could not move %s" : "Impossible de desplaçar %s", + "Permission denied" : "Permission refusada", + "The target folder has been moved or deleted." : "Lo dorsièr cibla es estat desplaçat o suprimit.", + "The name %s is already used in the folder %s. Please choose a different name." : "Lo nom %s es ja utilizat dins lo dorsièr %s. Mercé de causir un nom diferent.", + "Error when creating the file" : "Error pendent la creacion del fichièr", + "Error when creating the folder" : "Error pendent la creacion del dorsièr", + "Unable to set upload directory." : "Impossible de definir lo dorsièr de destinacion.", + "Invalid Token" : "Geton invalid", + "No file was uploaded. Unknown error" : "Cap de fichièr es pas estat mandat. Error desconeguda", + "There is no error, the file uploaded with success" : "Pas cap d'error, lo fichièr es estat mandat amb succès.", + "The uploaded file exceeds the upload_max_filesize directive in php.ini: " : "Lo fichièr mandat depassa l'instruccion upload_max_filesize situada dins lo fichièr php.ini :", + "The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form" : "Lo fichièr mandat depassa la valor MAX_FILE_SIZE qu'èra especificada dins lo formulari HTML.", + "The uploaded file was only partially uploaded" : "Lo fichièr es estat mandat sonque parcialament.", + "No file was uploaded" : "Pas de fichièr mandat.", + "Missing a temporary folder" : "Abséncia de dorsièr temporari", + "Failed to write to disk" : "Error d'escritura sul disc", + "Not enough storage available" : "Pas pro d'espaci d'emmagazinatge de disponible", + "Upload failed. Could not find uploaded file" : "Lo mandadís a fracassat. Impossible de trobar lo fichièr mandat.", + "Upload failed. Could not get file info." : "Lo mandadís a fracassat. Impossible d'obténer las informacions del fichièr.", + "Invalid directory." : "Dorsièr invalid.", "Files" : "Fichièrs", - "Upload cancelled." : "Amontcargar anullat.", - "File upload is in progress. Leaving the page now will cancel the upload." : "Un amontcargar es a se far. Daissar aquesta pagina ara tamparà lo cargament. ", - "Rename" : "Torna nomenar", - "Delete" : "Escafa", - "Unshare" : "Pas partejador", - "Download" : "Avalcarga", - "Pending" : "Al esperar", + "All files" : "Totes los fichièrs", + "Favorites" : "Favorits", + "Home" : "Mos fichièrs", + "Unable to upload {filename} as it is a directory or has 0 bytes" : "Impossible de mandar {filename} perque s'agís d'un repertòri o d'un fichièr de talha nulla", + "Total file size {size1} exceeds upload limit {size2}" : "La talha totala del fichièr {size1} excedís la talha maximala de mandadís {size2}", + "Not enough free space, you are uploading {size1} but only {size2} is left" : "Espaci liure insufisent : ensajatz de mandar {size1} mas solament {size2} son disponibles", + "Upload cancelled." : "Mandadís anullat.", + "Could not get result from server." : "Pòt pas recebre los resultats del servidor.", + "File upload is in progress. Leaving the page now will cancel the upload." : "Lo mandadís del fichièr es en cors. Quitar aquesta pagina ara anullarà lo mandadís del fichièr.", + "{new_name} already exists" : "{new_name} existís ja", + "Could not create file" : "Impossible de crear lo fichièr", + "Could not create folder" : "Impossible de crear lo dorsièr", + "Rename" : "Renomenar", + "Delete" : "Suprimir", + "Disconnect storage" : "Desconnectar aqueste supòrt d'emmagazinatge", + "Unshare" : "Partejar pas mai", + "No permission to delete" : "Pas de permission de supression", + "Download" : "Telecargar", + "Select" : "Seleccionar", + "Pending" : "En espèra", + "Unable to determine date" : "Impossible de determinar la data", + "Error moving file." : "Error al moment del desplaçament del fichièr.", + "Error moving file" : "Error al moment del desplaçament del fichièr", "Error" : "Error", + "Could not rename file" : "Impossible de renomenar lo fichièr", + "Error deleting file." : "Error pendent la supression del fichièr.", + "No entries in this folder match '{filter}'" : "Cap d'entrada d'aqueste dorsièr correspond pas a '{filter}'", "Name" : "Nom", "Size" : "Talha", "Modified" : "Modificat", - "File handling" : "Manejament de fichièr", - "Maximum upload size" : "Talha maximum d'amontcargament", - "max. possible: " : "max. possible: ", - "Save" : "Enregistra", + "_%n folder_::_%n folders_" : ["%n dorsièr","%n dorsièrs"], + "_%n file_::_%n files_" : ["%n fichièr","%n fichièrs"], + "You don’t have permission to upload or create files here" : "Avètz pas la permission d'apondre de fichièrs aicí", + "_Uploading %n file_::_Uploading %n files_" : ["Mandadís de %n fichièr","Mandadís de %n fichièrs"], + "\"{name}\" is an invalid file name." : "\"{name}\" es pas un nom de fichièr valid.", + "File name cannot be empty." : "Lo nom de fichièr pòt pas èsser void.", + "Your storage is full, files can not be updated or synced anymore!" : "Vòstre espaci d'emmagazinatge es plen, los fichièrs pòdon pas mai èsser aponduts o sincronizats !", + "Your storage is almost full ({usedSpacePercent}%)" : "Vòstre espace d'emmagazinatge es gaireben plen ({usedSpacePercent}%)", + "_matches '{filter}'_::_match '{filter}'_" : ["correspond a '{filter}'","correspondon a '{filter}'"], + "{dirs} and {files}" : "{dirs} e {files}", + "Favorited" : "Marcat coma favorit", + "Favorite" : "Favorit", + "An error occurred while trying to update the tags" : "Una error s'es produsida al moment de la mesa a jorn de las etiquetas", + "A new file or folder has been <strong>created</strong>" : "Un novèl fichièr o repertòri es estat <strong>creat</strong>", + "A file or folder has been <strong>changed</strong>" : "Un fichièr o un repertòri es estat <strong>modificat</strong>", + "Limit notifications about creation and changes to your <strong>favorite files</strong> <em>(Stream only)</em>" : "Limitar las notifications a çò que concernís la creacion e la modificacion de vòstres <strong>fichièrs favorits</strong> <em>(Flux unicament)</em>", + "A file or folder has been <strong>deleted</strong>" : "Un fichièr o un repertòri es estat <strong>suprimit</strong>", + "A file or folder has been <strong>restored</strong>" : "Un fichièr o un repertòri es estat <strong>restablit</strong>", + "You created %1$s" : "Avètz creat %1$s", + "%2$s created %1$s" : "%2$s a creat %1$s", + "%1$s was created in a public folder" : "%1$s es estat creat dins un dorsièr public", + "You changed %1$s" : "Avètz modificat %1$s", + "%2$s changed %1$s" : "%2$s a modificat %1$s", + "You deleted %1$s" : "Avètz suprimit %1$s", + "%2$s deleted %1$s" : "%2$s a suprimit %1$s", + "You restored %1$s" : "Avètz restablit %1$s", + "%2$s restored %1$s" : "%2$s a restablit %1$s", + "%s could not be renamed as it has been deleted" : "%s pòt pas èsser renomenat perque es estat suprimit ", + "%s could not be renamed" : "%s pòt pas èsser renomenat", + "Upload (max. %s)" : "Mandadís (max. %s)", + "File handling" : "Gestion de fichièrs", + "Maximum upload size" : "Talha max. de mandadís", + "max. possible: " : "Max. possible :", + "Save" : "Salvar", + "Can not be edited from here due to insufficient permissions." : "Pòt pas èsser modificat aicí a causa de permissions insufisentas.", "Settings" : "Paramètres", - "New" : "Nòu", - "Text file" : "Fichièr de tèxte", + "WebDAV" : "WebDAV", + "Use this address to <a href=\"%s\" target=\"_blank\">access your Files via WebDAV</a>" : "Utilizatz aquesta adreça per <a href=\"%s\" target=\"_blank\">accedir a vòstres fichièrs per WebDAV</a>", + "New" : "Novèl", + "New text file" : "Novèl fichièr tèxte", + "Text file" : "Fichièr tèxte", + "New folder" : "Novèl dorsièr", "Folder" : "Dorsièr", - "Upload" : "Amontcarga", - "Cancel upload" : " Anulla l'amontcargar", + "Upload" : "Cargament", + "Cancel upload" : "Anullar lo mandadís", + "No files in here" : "Pas cap de fichièr aicí", + "Upload some content or sync with your devices!" : "Depausatz de contengut o sincronizatz vòstres aparelhs !", "No entries found in this folder" : "Cap d'entrada pas trobada dins aqueste dorsièr", "Select all" : "Seleccionar tot", - "Upload too large" : "Amontcargament tròp gròs", - "The files you are trying to upload exceed the maximum size for file uploads on this server." : "Los fichièrs que sias a amontcargar son tròp pesucs per la talha maxi pel servidor.", - "Files are being scanned, please wait." : "Los fiichièrs son a èsser explorats, " + "Upload too large" : "Mandadís tròp voluminós", + "The files you are trying to upload exceed the maximum size for file uploads on this server." : "Los fichièrs qu'ensajatz de mandar depassan la talha maximala de mandadís permesa per aqueste servidor.", + "Files are being scanned, please wait." : "Los fichièrs son en cors d'analisi, pacientatz.", + "Currently scanning" : "Analisi en cors", + "No favorites" : "Pas cap de favorit", + "Files and folders you mark as favorite will show up here" : "Los fichièrs e dorsièrs aponduts a vòstres favorits apareisseràn aicí" }, "nplurals=2; plural=(n > 1);"); diff --git a/apps/files/l10n/oc.json b/apps/files/l10n/oc.json index 7c8bd93d166..1a904502025 100644 --- a/apps/files/l10n/oc.json +++ b/apps/files/l10n/oc.json @@ -1,36 +1,113 @@ { "translations": { - "There is no error, the file uploaded with success" : "Amontcargament capitat, pas d'errors", - "The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form" : "Lo fichièr amontcargat es mai gròs que la directiva «MAX_FILE_SIZE» especifiada dins lo formulari HTML", - "The uploaded file was only partially uploaded" : "Lo fichièr foguèt pas completament amontcargat", - "No file was uploaded" : "Cap de fichièrs son estats amontcargats", - "Missing a temporary folder" : "Un dorsièr temporari manca", - "Failed to write to disk" : "L'escriptura sul disc a fracassat", + "Storage not available" : "Supòrt d'emmagazinatge pas disponible", + "Storage invalid" : "Supòrt d'emmagazinatge pas valable", + "Unknown error" : "Error Desconeguda ", + "Could not move %s - File with this name already exists" : "Impossible de desplaçar %s - Un fichièr que pòrta aqueste nom existís ja", + "Could not move %s" : "Impossible de desplaçar %s", + "Permission denied" : "Permission refusada", + "The target folder has been moved or deleted." : "Lo dorsièr cibla es estat desplaçat o suprimit.", + "The name %s is already used in the folder %s. Please choose a different name." : "Lo nom %s es ja utilizat dins lo dorsièr %s. Mercé de causir un nom diferent.", + "Error when creating the file" : "Error pendent la creacion del fichièr", + "Error when creating the folder" : "Error pendent la creacion del dorsièr", + "Unable to set upload directory." : "Impossible de definir lo dorsièr de destinacion.", + "Invalid Token" : "Geton invalid", + "No file was uploaded. Unknown error" : "Cap de fichièr es pas estat mandat. Error desconeguda", + "There is no error, the file uploaded with success" : "Pas cap d'error, lo fichièr es estat mandat amb succès.", + "The uploaded file exceeds the upload_max_filesize directive in php.ini: " : "Lo fichièr mandat depassa l'instruccion upload_max_filesize situada dins lo fichièr php.ini :", + "The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form" : "Lo fichièr mandat depassa la valor MAX_FILE_SIZE qu'èra especificada dins lo formulari HTML.", + "The uploaded file was only partially uploaded" : "Lo fichièr es estat mandat sonque parcialament.", + "No file was uploaded" : "Pas de fichièr mandat.", + "Missing a temporary folder" : "Abséncia de dorsièr temporari", + "Failed to write to disk" : "Error d'escritura sul disc", + "Not enough storage available" : "Pas pro d'espaci d'emmagazinatge de disponible", + "Upload failed. Could not find uploaded file" : "Lo mandadís a fracassat. Impossible de trobar lo fichièr mandat.", + "Upload failed. Could not get file info." : "Lo mandadís a fracassat. Impossible d'obténer las informacions del fichièr.", + "Invalid directory." : "Dorsièr invalid.", "Files" : "Fichièrs", - "Upload cancelled." : "Amontcargar anullat.", - "File upload is in progress. Leaving the page now will cancel the upload." : "Un amontcargar es a se far. Daissar aquesta pagina ara tamparà lo cargament. ", - "Rename" : "Torna nomenar", - "Delete" : "Escafa", - "Unshare" : "Pas partejador", - "Download" : "Avalcarga", - "Pending" : "Al esperar", + "All files" : "Totes los fichièrs", + "Favorites" : "Favorits", + "Home" : "Mos fichièrs", + "Unable to upload {filename} as it is a directory or has 0 bytes" : "Impossible de mandar {filename} perque s'agís d'un repertòri o d'un fichièr de talha nulla", + "Total file size {size1} exceeds upload limit {size2}" : "La talha totala del fichièr {size1} excedís la talha maximala de mandadís {size2}", + "Not enough free space, you are uploading {size1} but only {size2} is left" : "Espaci liure insufisent : ensajatz de mandar {size1} mas solament {size2} son disponibles", + "Upload cancelled." : "Mandadís anullat.", + "Could not get result from server." : "Pòt pas recebre los resultats del servidor.", + "File upload is in progress. Leaving the page now will cancel the upload." : "Lo mandadís del fichièr es en cors. Quitar aquesta pagina ara anullarà lo mandadís del fichièr.", + "{new_name} already exists" : "{new_name} existís ja", + "Could not create file" : "Impossible de crear lo fichièr", + "Could not create folder" : "Impossible de crear lo dorsièr", + "Rename" : "Renomenar", + "Delete" : "Suprimir", + "Disconnect storage" : "Desconnectar aqueste supòrt d'emmagazinatge", + "Unshare" : "Partejar pas mai", + "No permission to delete" : "Pas de permission de supression", + "Download" : "Telecargar", + "Select" : "Seleccionar", + "Pending" : "En espèra", + "Unable to determine date" : "Impossible de determinar la data", + "Error moving file." : "Error al moment del desplaçament del fichièr.", + "Error moving file" : "Error al moment del desplaçament del fichièr", "Error" : "Error", + "Could not rename file" : "Impossible de renomenar lo fichièr", + "Error deleting file." : "Error pendent la supression del fichièr.", + "No entries in this folder match '{filter}'" : "Cap d'entrada d'aqueste dorsièr correspond pas a '{filter}'", "Name" : "Nom", "Size" : "Talha", "Modified" : "Modificat", - "File handling" : "Manejament de fichièr", - "Maximum upload size" : "Talha maximum d'amontcargament", - "max. possible: " : "max. possible: ", - "Save" : "Enregistra", + "_%n folder_::_%n folders_" : ["%n dorsièr","%n dorsièrs"], + "_%n file_::_%n files_" : ["%n fichièr","%n fichièrs"], + "You don’t have permission to upload or create files here" : "Avètz pas la permission d'apondre de fichièrs aicí", + "_Uploading %n file_::_Uploading %n files_" : ["Mandadís de %n fichièr","Mandadís de %n fichièrs"], + "\"{name}\" is an invalid file name." : "\"{name}\" es pas un nom de fichièr valid.", + "File name cannot be empty." : "Lo nom de fichièr pòt pas èsser void.", + "Your storage is full, files can not be updated or synced anymore!" : "Vòstre espaci d'emmagazinatge es plen, los fichièrs pòdon pas mai èsser aponduts o sincronizats !", + "Your storage is almost full ({usedSpacePercent}%)" : "Vòstre espace d'emmagazinatge es gaireben plen ({usedSpacePercent}%)", + "_matches '{filter}'_::_match '{filter}'_" : ["correspond a '{filter}'","correspondon a '{filter}'"], + "{dirs} and {files}" : "{dirs} e {files}", + "Favorited" : "Marcat coma favorit", + "Favorite" : "Favorit", + "An error occurred while trying to update the tags" : "Una error s'es produsida al moment de la mesa a jorn de las etiquetas", + "A new file or folder has been <strong>created</strong>" : "Un novèl fichièr o repertòri es estat <strong>creat</strong>", + "A file or folder has been <strong>changed</strong>" : "Un fichièr o un repertòri es estat <strong>modificat</strong>", + "Limit notifications about creation and changes to your <strong>favorite files</strong> <em>(Stream only)</em>" : "Limitar las notifications a çò que concernís la creacion e la modificacion de vòstres <strong>fichièrs favorits</strong> <em>(Flux unicament)</em>", + "A file or folder has been <strong>deleted</strong>" : "Un fichièr o un repertòri es estat <strong>suprimit</strong>", + "A file or folder has been <strong>restored</strong>" : "Un fichièr o un repertòri es estat <strong>restablit</strong>", + "You created %1$s" : "Avètz creat %1$s", + "%2$s created %1$s" : "%2$s a creat %1$s", + "%1$s was created in a public folder" : "%1$s es estat creat dins un dorsièr public", + "You changed %1$s" : "Avètz modificat %1$s", + "%2$s changed %1$s" : "%2$s a modificat %1$s", + "You deleted %1$s" : "Avètz suprimit %1$s", + "%2$s deleted %1$s" : "%2$s a suprimit %1$s", + "You restored %1$s" : "Avètz restablit %1$s", + "%2$s restored %1$s" : "%2$s a restablit %1$s", + "%s could not be renamed as it has been deleted" : "%s pòt pas èsser renomenat perque es estat suprimit ", + "%s could not be renamed" : "%s pòt pas èsser renomenat", + "Upload (max. %s)" : "Mandadís (max. %s)", + "File handling" : "Gestion de fichièrs", + "Maximum upload size" : "Talha max. de mandadís", + "max. possible: " : "Max. possible :", + "Save" : "Salvar", + "Can not be edited from here due to insufficient permissions." : "Pòt pas èsser modificat aicí a causa de permissions insufisentas.", "Settings" : "Paramètres", - "New" : "Nòu", - "Text file" : "Fichièr de tèxte", + "WebDAV" : "WebDAV", + "Use this address to <a href=\"%s\" target=\"_blank\">access your Files via WebDAV</a>" : "Utilizatz aquesta adreça per <a href=\"%s\" target=\"_blank\">accedir a vòstres fichièrs per WebDAV</a>", + "New" : "Novèl", + "New text file" : "Novèl fichièr tèxte", + "Text file" : "Fichièr tèxte", + "New folder" : "Novèl dorsièr", "Folder" : "Dorsièr", - "Upload" : "Amontcarga", - "Cancel upload" : " Anulla l'amontcargar", + "Upload" : "Cargament", + "Cancel upload" : "Anullar lo mandadís", + "No files in here" : "Pas cap de fichièr aicí", + "Upload some content or sync with your devices!" : "Depausatz de contengut o sincronizatz vòstres aparelhs !", "No entries found in this folder" : "Cap d'entrada pas trobada dins aqueste dorsièr", "Select all" : "Seleccionar tot", - "Upload too large" : "Amontcargament tròp gròs", - "The files you are trying to upload exceed the maximum size for file uploads on this server." : "Los fichièrs que sias a amontcargar son tròp pesucs per la talha maxi pel servidor.", - "Files are being scanned, please wait." : "Los fiichièrs son a èsser explorats, " + "Upload too large" : "Mandadís tròp voluminós", + "The files you are trying to upload exceed the maximum size for file uploads on this server." : "Los fichièrs qu'ensajatz de mandar depassan la talha maximala de mandadís permesa per aqueste servidor.", + "Files are being scanned, please wait." : "Los fichièrs son en cors d'analisi, pacientatz.", + "Currently scanning" : "Analisi en cors", + "No favorites" : "Pas cap de favorit", + "Files and folders you mark as favorite will show up here" : "Los fichièrs e dorsièrs aponduts a vòstres favorits apareisseràn aicí" },"pluralForm" :"nplurals=2; plural=(n > 1);" }
\ No newline at end of file diff --git a/apps/files_external/l10n/cs_CZ.js b/apps/files_external/l10n/cs_CZ.js index 1ba836528d9..f2e86b5748c 100644 --- a/apps/files_external/l10n/cs_CZ.js +++ b/apps/files_external/l10n/cs_CZ.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Chyba při nastavení úložiště Google Drive", "Personal" : "Osobní", "System" : "Systém", + "Enable encryption" : "Povolit šifrování", "All users. Type to select user or group." : "Všichni uživatelé. Začněte psát pro výběr uživatelů a skupin.", "(group)" : "(skupina)", "Saved" : "Uloženo", diff --git a/apps/files_external/l10n/cs_CZ.json b/apps/files_external/l10n/cs_CZ.json index 012a335cf4e..b96a2e52274 100644 --- a/apps/files_external/l10n/cs_CZ.json +++ b/apps/files_external/l10n/cs_CZ.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Chyba při nastavení úložiště Google Drive", "Personal" : "Osobní", "System" : "Systém", + "Enable encryption" : "Povolit šifrování", "All users. Type to select user or group." : "Všichni uživatelé. Začněte psát pro výběr uživatelů a skupin.", "(group)" : "(skupina)", "Saved" : "Uloženo", diff --git a/apps/files_external/l10n/de.js b/apps/files_external/l10n/de.js index cd57210cef4..5809211ead5 100644 --- a/apps/files_external/l10n/de.js +++ b/apps/files_external/l10n/de.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Fehler beim Einrichten von Google Drive", "Personal" : "Persönlich", "System" : "System", + "Enable encryption" : "Verschlüsselung aktivieren", "All users. Type to select user or group." : "Alle Benutzer. Benutzer oder Gruppe zur Auswahl eingeben.", "(group)" : "(group)", "Saved" : "Gespeichert", diff --git a/apps/files_external/l10n/de.json b/apps/files_external/l10n/de.json index cb82b90b24a..0166d55f494 100644 --- a/apps/files_external/l10n/de.json +++ b/apps/files_external/l10n/de.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Fehler beim Einrichten von Google Drive", "Personal" : "Persönlich", "System" : "System", + "Enable encryption" : "Verschlüsselung aktivieren", "All users. Type to select user or group." : "Alle Benutzer. Benutzer oder Gruppe zur Auswahl eingeben.", "(group)" : "(group)", "Saved" : "Gespeichert", diff --git a/apps/files_external/l10n/de_DE.js b/apps/files_external/l10n/de_DE.js index a4c2d87d254..421f3f06665 100644 --- a/apps/files_external/l10n/de_DE.js +++ b/apps/files_external/l10n/de_DE.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Fehler beim Einrichten von Google Drive", "Personal" : "Persönlich", "System" : "System", + "Enable encryption" : "Verschlüsselung aktivieren", "All users. Type to select user or group." : "Alle Benutzer. Benutzer oder Gruppe zur Auswahl eingeben.", "(group)" : "(group)", "Saved" : "Gespeichert", diff --git a/apps/files_external/l10n/de_DE.json b/apps/files_external/l10n/de_DE.json index 9c0d2555fbf..24fb4107dff 100644 --- a/apps/files_external/l10n/de_DE.json +++ b/apps/files_external/l10n/de_DE.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Fehler beim Einrichten von Google Drive", "Personal" : "Persönlich", "System" : "System", + "Enable encryption" : "Verschlüsselung aktivieren", "All users. Type to select user or group." : "Alle Benutzer. Benutzer oder Gruppe zur Auswahl eingeben.", "(group)" : "(group)", "Saved" : "Gespeichert", diff --git a/apps/files_external/l10n/el.js b/apps/files_external/l10n/el.js index a5e6a59ff1a..e3b96e4cc4a 100644 --- a/apps/files_external/l10n/el.js +++ b/apps/files_external/l10n/el.js @@ -43,6 +43,7 @@ OC.L10N.register( "Username as share" : "Όνομα χρήστη ως διαμοιραζόμενος φάκελος", "URL" : "URL", "Secure https://" : "Ασφαλής σύνδεση https://", + "SFTP with secret key login" : "SFTP με σύνδεση με κρυφό κλειδί", "Public key" : "Δημόσιο κλειδί", "Storage with id \"%i\" not found" : "Αποθήκευση με id \"%i\" δεν βρέθηκε", "Invalid mount point" : "Μη έγκυρο σημείο ανάρτησης", @@ -53,6 +54,12 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Σφάλμα ρυθμίζωντας αποθήκευση Google Drive ", "Personal" : "Προσωπικά", "System" : "Σύστημα", + "Enable encryption" : "Ενεργοποίηση κρυπτογράφησης", + "Enable previews" : "Ενεργοποίηση προεπισκοπήσεων", + "Check for changes" : "Έλεγχος για αλλαγές", + "Never" : "Ποτέ", + "Once every direct access" : "Σε κάθε απευθείας πρόσβαση", + "Every time the filesystem is used" : "Κάθε φορά που χρησιμοποιείται το σύστημα αρχείων", "All users. Type to select user or group." : "Όλοι οι χρήστες. Πληκτρολογήστε για να επιλέξετε χρήστη ή ομάδα.", "(group)" : "(ομάδα)", "Saved" : "Αποθηκεύτηκαν", diff --git a/apps/files_external/l10n/el.json b/apps/files_external/l10n/el.json index 5a3d820c39b..e62da96551c 100644 --- a/apps/files_external/l10n/el.json +++ b/apps/files_external/l10n/el.json @@ -41,6 +41,7 @@ "Username as share" : "Όνομα χρήστη ως διαμοιραζόμενος φάκελος", "URL" : "URL", "Secure https://" : "Ασφαλής σύνδεση https://", + "SFTP with secret key login" : "SFTP με σύνδεση με κρυφό κλειδί", "Public key" : "Δημόσιο κλειδί", "Storage with id \"%i\" not found" : "Αποθήκευση με id \"%i\" δεν βρέθηκε", "Invalid mount point" : "Μη έγκυρο σημείο ανάρτησης", @@ -51,6 +52,12 @@ "Error configuring Google Drive storage" : "Σφάλμα ρυθμίζωντας αποθήκευση Google Drive ", "Personal" : "Προσωπικά", "System" : "Σύστημα", + "Enable encryption" : "Ενεργοποίηση κρυπτογράφησης", + "Enable previews" : "Ενεργοποίηση προεπισκοπήσεων", + "Check for changes" : "Έλεγχος για αλλαγές", + "Never" : "Ποτέ", + "Once every direct access" : "Σε κάθε απευθείας πρόσβαση", + "Every time the filesystem is used" : "Κάθε φορά που χρησιμοποιείται το σύστημα αρχείων", "All users. Type to select user or group." : "Όλοι οι χρήστες. Πληκτρολογήστε για να επιλέξετε χρήστη ή ομάδα.", "(group)" : "(ομάδα)", "Saved" : "Αποθηκεύτηκαν", diff --git a/apps/files_external/l10n/en_GB.js b/apps/files_external/l10n/en_GB.js index e4dfb3effcc..55f70ff8cb3 100644 --- a/apps/files_external/l10n/en_GB.js +++ b/apps/files_external/l10n/en_GB.js @@ -53,6 +53,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Error configuring Google Drive storage", "Personal" : "Personal", "System" : "System", + "Enable encryption" : "Enable encryption", "All users. Type to select user or group." : "All users. Type to select user or group.", "(group)" : "(group)", "Saved" : "Saved", diff --git a/apps/files_external/l10n/en_GB.json b/apps/files_external/l10n/en_GB.json index 6b66198cef4..516156c3d91 100644 --- a/apps/files_external/l10n/en_GB.json +++ b/apps/files_external/l10n/en_GB.json @@ -51,6 +51,7 @@ "Error configuring Google Drive storage" : "Error configuring Google Drive storage", "Personal" : "Personal", "System" : "System", + "Enable encryption" : "Enable encryption", "All users. Type to select user or group." : "All users. Type to select user or group.", "(group)" : "(group)", "Saved" : "Saved", diff --git a/apps/files_external/l10n/es.js b/apps/files_external/l10n/es.js index efd3d7fc40d..dbe7923d1f6 100644 --- a/apps/files_external/l10n/es.js +++ b/apps/files_external/l10n/es.js @@ -54,6 +54,12 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Error al configurar el almacenamiento de Google Drive", "Personal" : "Personal", "System" : "Sistema", + "Enable encryption" : "Habilitar cifrado", + "Enable previews" : "Habilitar previsualizaciones", + "Check for changes" : "Comprobar si hay cambios", + "Never" : "Nunca", + "Once every direct access" : "Una vez cada acceso directo", + "Every time the filesystem is used" : "Cada vez que filesystem es utilizado", "All users. Type to select user or group." : "Todos los usuarios. Teclee para seleccionar un usuario o grupo.", "(group)" : "(grupo)", "Saved" : "Guardado", diff --git a/apps/files_external/l10n/es.json b/apps/files_external/l10n/es.json index 231ea39b681..f2439287934 100644 --- a/apps/files_external/l10n/es.json +++ b/apps/files_external/l10n/es.json @@ -52,6 +52,12 @@ "Error configuring Google Drive storage" : "Error al configurar el almacenamiento de Google Drive", "Personal" : "Personal", "System" : "Sistema", + "Enable encryption" : "Habilitar cifrado", + "Enable previews" : "Habilitar previsualizaciones", + "Check for changes" : "Comprobar si hay cambios", + "Never" : "Nunca", + "Once every direct access" : "Una vez cada acceso directo", + "Every time the filesystem is used" : "Cada vez que filesystem es utilizado", "All users. Type to select user or group." : "Todos los usuarios. Teclee para seleccionar un usuario o grupo.", "(group)" : "(grupo)", "Saved" : "Guardado", diff --git a/apps/files_external/l10n/fi_FI.js b/apps/files_external/l10n/fi_FI.js index 78650275e40..430702d686a 100644 --- a/apps/files_external/l10n/fi_FI.js +++ b/apps/files_external/l10n/fi_FI.js @@ -45,6 +45,11 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Virhe Google Drive levyn asetuksia tehtäessä", "Personal" : "Henkilökohtainen", "System" : "Järjestelmä", + "Enable encryption" : "Käytä salausta", + "Check for changes" : "Tarkista muutokset", + "Never" : "Ei koskaan", + "Once every direct access" : "Kerran aina suoran käytön yhteydessä", + "Every time the filesystem is used" : "Aina kun tiedostojärjestelmää käytetään", "All users. Type to select user or group." : "Kaikki käyttäjät. Kirjoita valitaksesi käyttäjän tai ryhmän.", "(group)" : "(ryhmä)", "Saved" : "Tallennettu", diff --git a/apps/files_external/l10n/fi_FI.json b/apps/files_external/l10n/fi_FI.json index 5faae6052c0..1f3bf46423e 100644 --- a/apps/files_external/l10n/fi_FI.json +++ b/apps/files_external/l10n/fi_FI.json @@ -43,6 +43,11 @@ "Error configuring Google Drive storage" : "Virhe Google Drive levyn asetuksia tehtäessä", "Personal" : "Henkilökohtainen", "System" : "Järjestelmä", + "Enable encryption" : "Käytä salausta", + "Check for changes" : "Tarkista muutokset", + "Never" : "Ei koskaan", + "Once every direct access" : "Kerran aina suoran käytön yhteydessä", + "Every time the filesystem is used" : "Aina kun tiedostojärjestelmää käytetään", "All users. Type to select user or group." : "Kaikki käyttäjät. Kirjoita valitaksesi käyttäjän tai ryhmän.", "(group)" : "(ryhmä)", "Saved" : "Tallennettu", diff --git a/apps/files_external/l10n/fr.js b/apps/files_external/l10n/fr.js index 087c88522ec..7f607be5661 100644 --- a/apps/files_external/l10n/fr.js +++ b/apps/files_external/l10n/fr.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Erreur lors de la configuration du stockage Google Drive", "Personal" : "Personnel", "System" : "Système", + "Enable encryption" : "Activer le chiffrement", "All users. Type to select user or group." : "Tous les utilisateurs. Cliquez ici pour restreindre.", "(group)" : "(groupe)", "Saved" : "Sauvegardé", diff --git a/apps/files_external/l10n/fr.json b/apps/files_external/l10n/fr.json index b2edf4c363c..865fbaf8398 100644 --- a/apps/files_external/l10n/fr.json +++ b/apps/files_external/l10n/fr.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Erreur lors de la configuration du stockage Google Drive", "Personal" : "Personnel", "System" : "Système", + "Enable encryption" : "Activer le chiffrement", "All users. Type to select user or group." : "Tous les utilisateurs. Cliquez ici pour restreindre.", "(group)" : "(groupe)", "Saved" : "Sauvegardé", diff --git a/apps/files_external/l10n/gl.js b/apps/files_external/l10n/gl.js index 2c1b7b77b6f..9c46aa40b2d 100644 --- a/apps/files_external/l10n/gl.js +++ b/apps/files_external/l10n/gl.js @@ -54,6 +54,12 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Produciuse un erro ao configurar o almacenamento en Google Drive", "Personal" : "Persoal", "System" : "Sistema", + "Enable encryption" : "Activar o cifrado", + "Enable previews" : "Activar as vistas previas", + "Check for changes" : "Comprobar se hai cambios", + "Never" : "Nunca", + "Once every direct access" : "Unha vez cada acceso directo", + "Every time the filesystem is used" : "Cada vez que se utiliza o sistema de ficheiros", "All users. Type to select user or group." : "Todos os usuarios. Escriba para seleccionar usuario ou grupo.", "(group)" : "(grupo)", "Saved" : "Gardado", diff --git a/apps/files_external/l10n/gl.json b/apps/files_external/l10n/gl.json index dc4e151eebd..18069fcd2b8 100644 --- a/apps/files_external/l10n/gl.json +++ b/apps/files_external/l10n/gl.json @@ -52,6 +52,12 @@ "Error configuring Google Drive storage" : "Produciuse un erro ao configurar o almacenamento en Google Drive", "Personal" : "Persoal", "System" : "Sistema", + "Enable encryption" : "Activar o cifrado", + "Enable previews" : "Activar as vistas previas", + "Check for changes" : "Comprobar se hai cambios", + "Never" : "Nunca", + "Once every direct access" : "Unha vez cada acceso directo", + "Every time the filesystem is used" : "Cada vez que se utiliza o sistema de ficheiros", "All users. Type to select user or group." : "Todos os usuarios. Escriba para seleccionar usuario ou grupo.", "(group)" : "(grupo)", "Saved" : "Gardado", diff --git a/apps/files_external/l10n/hy.js b/apps/files_external/l10n/hy.js index 00c24e3f92a..2030a284acb 100644 --- a/apps/files_external/l10n/hy.js +++ b/apps/files_external/l10n/hy.js @@ -1,6 +1,7 @@ OC.L10N.register( "files_external", { + "Personal" : "Անձնական", "Delete" : "Ջնջել" }, "nplurals=2; plural=(n != 1);"); diff --git a/apps/files_external/l10n/hy.json b/apps/files_external/l10n/hy.json index 081a2c5f49e..fa925e0854d 100644 --- a/apps/files_external/l10n/hy.json +++ b/apps/files_external/l10n/hy.json @@ -1,4 +1,5 @@ { "translations": { + "Personal" : "Անձնական", "Delete" : "Ջնջել" },"pluralForm" :"nplurals=2; plural=(n != 1);" }
\ No newline at end of file diff --git a/apps/files_external/l10n/id.js b/apps/files_external/l10n/id.js index 81d243b12ae..ff582a863e9 100644 --- a/apps/files_external/l10n/id.js +++ b/apps/files_external/l10n/id.js @@ -53,6 +53,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Kesalahan dalam mengkonfigurasi penyimpanan Google Drive", "Personal" : "Pribadi", "System" : "Sistem", + "Enable encryption" : "Aktifkan enkripsi", "All users. Type to select user or group." : "Semua pengguna. Ketik untuk memilih pengguna atau grup.", "(group)" : "(grup)", "Saved" : "Disimpan", diff --git a/apps/files_external/l10n/id.json b/apps/files_external/l10n/id.json index b8acdedfd2d..2c1c450e9af 100644 --- a/apps/files_external/l10n/id.json +++ b/apps/files_external/l10n/id.json @@ -51,6 +51,7 @@ "Error configuring Google Drive storage" : "Kesalahan dalam mengkonfigurasi penyimpanan Google Drive", "Personal" : "Pribadi", "System" : "Sistem", + "Enable encryption" : "Aktifkan enkripsi", "All users. Type to select user or group." : "Semua pengguna. Ketik untuk memilih pengguna atau grup.", "(group)" : "(grup)", "Saved" : "Disimpan", diff --git a/apps/files_external/l10n/it.js b/apps/files_external/l10n/it.js index 72aba20087e..c5d46777cf8 100644 --- a/apps/files_external/l10n/it.js +++ b/apps/files_external/l10n/it.js @@ -54,6 +54,12 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Errore durante la configurazione dell'archivio Google Drive", "Personal" : "Personale", "System" : "Sistema", + "Enable encryption" : "Abilita cifratura", + "Enable previews" : "Abilita le anteprime", + "Check for changes" : "Controlla le modifiche", + "Never" : "Mai", + "Once every direct access" : "Una volta per ogni accesso diretto", + "Every time the filesystem is used" : "Ogni volta che il filesystem viene utilizzato", "All users. Type to select user or group." : "Tutti gli utenti. Digita per selezionare utente o gruppo.", "(group)" : "(gruppo)", "Saved" : "Salvato", diff --git a/apps/files_external/l10n/it.json b/apps/files_external/l10n/it.json index d2549d790cd..6bda84a7e2d 100644 --- a/apps/files_external/l10n/it.json +++ b/apps/files_external/l10n/it.json @@ -52,6 +52,12 @@ "Error configuring Google Drive storage" : "Errore durante la configurazione dell'archivio Google Drive", "Personal" : "Personale", "System" : "Sistema", + "Enable encryption" : "Abilita cifratura", + "Enable previews" : "Abilita le anteprime", + "Check for changes" : "Controlla le modifiche", + "Never" : "Mai", + "Once every direct access" : "Una volta per ogni accesso diretto", + "Every time the filesystem is used" : "Ogni volta che il filesystem viene utilizzato", "All users. Type to select user or group." : "Tutti gli utenti. Digita per selezionare utente o gruppo.", "(group)" : "(gruppo)", "Saved" : "Salvato", diff --git a/apps/files_external/l10n/ja.js b/apps/files_external/l10n/ja.js index cd50ae8c530..7abf8067b6d 100644 --- a/apps/files_external/l10n/ja.js +++ b/apps/files_external/l10n/ja.js @@ -53,6 +53,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Googleドライブストレージの設定エラー", "Personal" : "個人", "System" : "システム", + "Enable encryption" : "暗号化を有効に", "All users. Type to select user or group." : "すべてのユーザー。ユーザー、グループを追加", "(group)" : "(グループ)", "Saved" : "保存されました", diff --git a/apps/files_external/l10n/ja.json b/apps/files_external/l10n/ja.json index 81da7f57397..6da6fe15b12 100644 --- a/apps/files_external/l10n/ja.json +++ b/apps/files_external/l10n/ja.json @@ -51,6 +51,7 @@ "Error configuring Google Drive storage" : "Googleドライブストレージの設定エラー", "Personal" : "個人", "System" : "システム", + "Enable encryption" : "暗号化を有効に", "All users. Type to select user or group." : "すべてのユーザー。ユーザー、グループを追加", "(group)" : "(グループ)", "Saved" : "保存されました", diff --git a/apps/files_external/l10n/ko.js b/apps/files_external/l10n/ko.js index 61996d8ba27..79fe1e3f4bc 100644 --- a/apps/files_external/l10n/ko.js +++ b/apps/files_external/l10n/ko.js @@ -53,6 +53,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Google 드라이브 저장소 설정 오류", "Personal" : "개인", "System" : "시스템", + "Enable encryption" : "암호화 사용", "All users. Type to select user or group." : "모든 사용자입니다. 사용자나 그룹을 선택하려면 입력하십시오", "(group)" : "(그룹)", "Saved" : "저장됨", diff --git a/apps/files_external/l10n/ko.json b/apps/files_external/l10n/ko.json index d0fabd105e1..ef286b2b347 100644 --- a/apps/files_external/l10n/ko.json +++ b/apps/files_external/l10n/ko.json @@ -51,6 +51,7 @@ "Error configuring Google Drive storage" : "Google 드라이브 저장소 설정 오류", "Personal" : "개인", "System" : "시스템", + "Enable encryption" : "암호화 사용", "All users. Type to select user or group." : "모든 사용자입니다. 사용자나 그룹을 선택하려면 입력하십시오", "(group)" : "(그룹)", "Saved" : "저장됨", diff --git a/apps/files_external/l10n/nb_NO.js b/apps/files_external/l10n/nb_NO.js index f120e34308a..74a9fc126d2 100644 --- a/apps/files_external/l10n/nb_NO.js +++ b/apps/files_external/l10n/nb_NO.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Feil med konfigurering av Google Drive", "Personal" : "Personlig", "System" : "System", + "Enable encryption" : "Aktiver kryptering", "All users. Type to select user or group." : "Alle brukere. Tast for å velge bruker eller gruppe.", "(group)" : "(gruppe)", "Saved" : "Lagret", diff --git a/apps/files_external/l10n/nb_NO.json b/apps/files_external/l10n/nb_NO.json index 1ad6011fcf4..d92ab663221 100644 --- a/apps/files_external/l10n/nb_NO.json +++ b/apps/files_external/l10n/nb_NO.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Feil med konfigurering av Google Drive", "Personal" : "Personlig", "System" : "System", + "Enable encryption" : "Aktiver kryptering", "All users. Type to select user or group." : "Alle brukere. Tast for å velge bruker eller gruppe.", "(group)" : "(gruppe)", "Saved" : "Lagret", diff --git a/apps/files_external/l10n/nl.js b/apps/files_external/l10n/nl.js index 0b209d2ec37..295f48f8f4e 100644 --- a/apps/files_external/l10n/nl.js +++ b/apps/files_external/l10n/nl.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Fout tijdens het configureren van Google Drive opslag", "Personal" : "Persoonlijk", "System" : "Systeem", + "Enable encryption" : "Versleuteling inschakelen", "All users. Type to select user or group." : "Alle gebruikers. Tikken om een gebruiker of groep te selecteren.", "(group)" : "(groep)", "Saved" : "Bewaard", diff --git a/apps/files_external/l10n/nl.json b/apps/files_external/l10n/nl.json index b5a6215f708..956e1dc638c 100644 --- a/apps/files_external/l10n/nl.json +++ b/apps/files_external/l10n/nl.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Fout tijdens het configureren van Google Drive opslag", "Personal" : "Persoonlijk", "System" : "Systeem", + "Enable encryption" : "Versleuteling inschakelen", "All users. Type to select user or group." : "Alle gebruikers. Tikken om een gebruiker of groep te selecteren.", "(group)" : "(groep)", "Saved" : "Bewaard", diff --git a/apps/files_external/l10n/pt_BR.js b/apps/files_external/l10n/pt_BR.js index d1036957f99..c05f2089536 100644 --- a/apps/files_external/l10n/pt_BR.js +++ b/apps/files_external/l10n/pt_BR.js @@ -54,6 +54,12 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Erro ao configurar armazenamento do Google Drive", "Personal" : "Pessoal", "System" : "Sistema", + "Enable encryption" : "Ativar criptografia", + "Enable previews" : "Habilitar visualizações prévias", + "Check for changes" : "Verifique se há alterações", + "Never" : "Nunca", + "Once every direct access" : "Uma vez a cada acesso direto", + "Every time the filesystem is used" : "Toda vez que o sistema de arquivos é usado", "All users. Type to select user or group." : "Todos os usuários. Digite para selecionar usuário ou grupo.", "(group)" : "(grupo)", "Saved" : "Salvo", diff --git a/apps/files_external/l10n/pt_BR.json b/apps/files_external/l10n/pt_BR.json index e6dcc5bd03a..92423280fca 100644 --- a/apps/files_external/l10n/pt_BR.json +++ b/apps/files_external/l10n/pt_BR.json @@ -52,6 +52,12 @@ "Error configuring Google Drive storage" : "Erro ao configurar armazenamento do Google Drive", "Personal" : "Pessoal", "System" : "Sistema", + "Enable encryption" : "Ativar criptografia", + "Enable previews" : "Habilitar visualizações prévias", + "Check for changes" : "Verifique se há alterações", + "Never" : "Nunca", + "Once every direct access" : "Uma vez a cada acesso direto", + "Every time the filesystem is used" : "Toda vez que o sistema de arquivos é usado", "All users. Type to select user or group." : "Todos os usuários. Digite para selecionar usuário ou grupo.", "(group)" : "(grupo)", "Saved" : "Salvo", diff --git a/apps/files_external/l10n/sr.js b/apps/files_external/l10n/sr.js index b321445fefa..789a641114d 100644 --- a/apps/files_external/l10n/sr.js +++ b/apps/files_external/l10n/sr.js @@ -54,6 +54,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Грешка при подешавању Гугл диск складишта", "Personal" : "Лично", "System" : "Систем", + "Enable encryption" : "Укључи шифровање", "All users. Type to select user or group." : "Сви корисници. Куцајте за избор корисника или групе.", "(group)" : "(група)", "Saved" : "Сачувано", diff --git a/apps/files_external/l10n/sr.json b/apps/files_external/l10n/sr.json index 3ae53ba8409..bdb46575fc6 100644 --- a/apps/files_external/l10n/sr.json +++ b/apps/files_external/l10n/sr.json @@ -52,6 +52,7 @@ "Error configuring Google Drive storage" : "Грешка при подешавању Гугл диск складишта", "Personal" : "Лично", "System" : "Систем", + "Enable encryption" : "Укључи шифровање", "All users. Type to select user or group." : "Сви корисници. Куцајте за избор корисника или групе.", "(group)" : "(група)", "Saved" : "Сачувано", diff --git a/apps/files_external/l10n/tr.js b/apps/files_external/l10n/tr.js index 3845e0fd97b..824c58aad5d 100644 --- a/apps/files_external/l10n/tr.js +++ b/apps/files_external/l10n/tr.js @@ -53,6 +53,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Google Drive depo yapılandırma hatası", "Personal" : "Kişisel", "System" : "Sistem", + "Enable encryption" : "Kriptolamayı aç", "All users. Type to select user or group." : "Tüm kullanıcılar. Kullanıcı veya grup seçmek için yazın.", "(group)" : "(grup)", "Saved" : "Kaydedildi", diff --git a/apps/files_external/l10n/tr.json b/apps/files_external/l10n/tr.json index 67af4f8d67d..5d616d4a97f 100644 --- a/apps/files_external/l10n/tr.json +++ b/apps/files_external/l10n/tr.json @@ -51,6 +51,7 @@ "Error configuring Google Drive storage" : "Google Drive depo yapılandırma hatası", "Personal" : "Kişisel", "System" : "Sistem", + "Enable encryption" : "Kriptolamayı aç", "All users. Type to select user or group." : "Tüm kullanıcılar. Kullanıcı veya grup seçmek için yazın.", "(group)" : "(grup)", "Saved" : "Kaydedildi", diff --git a/apps/files_external/l10n/uk.js b/apps/files_external/l10n/uk.js index d31efca661e..6e061a0526b 100644 --- a/apps/files_external/l10n/uk.js +++ b/apps/files_external/l10n/uk.js @@ -53,6 +53,7 @@ OC.L10N.register( "Error configuring Google Drive storage" : "Помилка при налаштуванні сховища Google Drive", "Personal" : "Особисте", "System" : "Система", + "Enable encryption" : "Увімкнути шифрування", "All users. Type to select user or group." : "Всі користувачі. Введіть ім'я користувача або групи.", "(group)" : "(група)", "Saved" : "Збережено", diff --git a/apps/files_external/l10n/uk.json b/apps/files_external/l10n/uk.json index e8306c44580..bb7c337595b 100644 --- a/apps/files_external/l10n/uk.json +++ b/apps/files_external/l10n/uk.json @@ -51,6 +51,7 @@ "Error configuring Google Drive storage" : "Помилка при налаштуванні сховища Google Drive", "Personal" : "Особисте", "System" : "Система", + "Enable encryption" : "Увімкнути шифрування", "All users. Type to select user or group." : "Всі користувачі. Введіть ім'я користувача або групи.", "(group)" : "(група)", "Saved" : "Збережено", diff --git a/apps/files_sharing/appinfo/app.php b/apps/files_sharing/appinfo/app.php index 19d3b6cd9cc..c54038f17e3 100644 --- a/apps/files_sharing/appinfo/app.php +++ b/apps/files_sharing/appinfo/app.php @@ -49,6 +49,7 @@ $application->registerMountProviders(); $application->setupPropagation(); \OCP\App::registerAdmin('files_sharing', 'settings-admin'); +\OCP\App::registerPersonal('files_sharing', 'settings-personal'); \OCA\Files_Sharing\Helper::registerHooks(); diff --git a/apps/files_sharing/lib/helper.php b/apps/files_sharing/lib/helper.php index 05b0352ca1f..c76704802b1 100644 --- a/apps/files_sharing/lib/helper.php +++ b/apps/files_sharing/lib/helper.php @@ -306,4 +306,20 @@ class Helper { \OC::$server->getConfig()->setSystemValue('share_folder', $shareFolder); } + /** + * remove protocol from URL + * + * @param string $url + * @return string + */ + public static function removeProtocolFromUrl($url) { + if (strpos($url, 'https://') === 0) { + return substr($url, strlen('https://')); + } else if (strpos($url, 'http://') === 0) { + return substr($url, strlen('http://')); + } + + return $url; + } + } diff --git a/apps/files_sharing/settings-personal.php b/apps/files_sharing/settings-personal.php new file mode 100644 index 00000000000..1aff784b488 --- /dev/null +++ b/apps/files_sharing/settings-personal.php @@ -0,0 +1,32 @@ +<?php +/** + * @author Björn Schießle <schiessle@owncloud.com> + * @author Morris Jobke <hey@morrisjobke.de> + * + * @copyright Copyright (c) 2015, ownCloud, Inc. + * @license AGPL-3.0 + * + * This code is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License, version 3, + * as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License, version 3, + * along with this program. If not, see <http://www.gnu.org/licenses/> + * + */ + +\OC_Util::checkLoggedIn(); + +$uid = \OC::$server->getUserSession()->getUser()->getUID(); +$server = \OC::$server->getURLGenerator()->getAbsoluteURL('/'); +$cloudID = $uid . '@' . rtrim(\OCA\Files_Sharing\Helper::removeProtocolFromUrl($server), '/'); + +$tmpl = new OCP\Template('files_sharing', 'settings-personal'); +$tmpl->assign('cloudId', $cloudID); + +return $tmpl->fetchPage(); diff --git a/apps/files_sharing/templates/settings-personal.php b/apps/files_sharing/templates/settings-personal.php new file mode 100644 index 00000000000..84d8e8a1b13 --- /dev/null +++ b/apps/files_sharing/templates/settings-personal.php @@ -0,0 +1,12 @@ +<?php +/** @var OC_L10N $l */ +/** @var array $_ */ +?> +<div id="fileSharingSettings" class="section"> + <h2><?php p($l->t('Federated Cloud'));?></h2> + + <p> + <?php p($l->t('Your Federated Cloud ID: %s', [$_['cloudId']])); ?> + </p> + +</div> diff --git a/apps/files_sharing/tests/external/managertest.php b/apps/files_sharing/tests/external/managertest.php index f7b216530d5..df01ea0f738 100644 --- a/apps/files_sharing/tests/external/managertest.php +++ b/apps/files_sharing/tests/external/managertest.php @@ -76,7 +76,7 @@ class ManagerTest extends TestCase { $this->assertCount(1, $openShares); $this->assertExternalShareEntry($shareData1, $openShares[0], 1, '{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertNotMount('SharedFolder'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); @@ -88,7 +88,7 @@ class ManagerTest extends TestCase { // New share falls back to "-1" appendix, because the name is already taken $this->assertExternalShareEntry($shareData2, $openShares[1], 2, '{{TemporaryMountPointName#' . $shareData2['name'] . '}}-1'); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertNotMount('SharedFolder'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}-1'); @@ -101,7 +101,7 @@ class ManagerTest extends TestCase { $this->manager->acceptShare($openShares[0]['id']); // Check remaining shares - Accepted - $acceptedShares = \Test_Helper::invokePrivate($this->manager, 'getShares', [true]); + $acceptedShares = self::invokePrivate($this->manager, 'getShares', [true]); $this->assertCount(1, $acceptedShares); $shareData1['accepted'] = true; $this->assertExternalShareEntry($shareData1, $acceptedShares[0], 1, $shareData1['name']); @@ -110,7 +110,7 @@ class ManagerTest extends TestCase { $this->assertCount(1, $openShares); $this->assertExternalShareEntry($shareData2, $openShares[0], 2, '{{TemporaryMountPointName#' . $shareData2['name'] . '}}-1'); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertMount($shareData1['name']); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}-1'); @@ -123,7 +123,7 @@ class ManagerTest extends TestCase { // New share falls back to the original name (no "-\d", because the name is not taken) $this->assertExternalShareEntry($shareData3, $openShares[1], 3, '{{TemporaryMountPointName#' . $shareData3['name'] . '}}'); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertMount($shareData1['name']); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}-1'); @@ -135,13 +135,13 @@ class ManagerTest extends TestCase { // Decline the third share $this->manager->declineShare($openShares[1]['id']); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertMount($shareData1['name']); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}-1'); // Check remaining shares - Accepted - $acceptedShares = \Test_Helper::invokePrivate($this->manager, 'getShares', [true]); + $acceptedShares = self::invokePrivate($this->manager, 'getShares', [true]); $this->assertCount(1, $acceptedShares); $shareData1['accepted'] = true; $this->assertExternalShareEntry($shareData1, $acceptedShares[0], 1, $shareData1['name']); @@ -150,7 +150,7 @@ class ManagerTest extends TestCase { $this->assertCount(1, $openShares); $this->assertExternalShareEntry($shareData2, $openShares[0], 2, '{{TemporaryMountPointName#' . $shareData2['name'] . '}}-1'); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertMount($shareData1['name']); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}-1'); @@ -163,10 +163,10 @@ class ManagerTest extends TestCase { ->with($this->stringStartsWith('http://localhost/ocs/v1.php/cloud/shares/' . $acceptedShares[0]['remote_id'] . '/decline'), $this->anything()); $this->manager->removeUserShares($this->uid); - $this->assertEmpty(\Test_Helper::invokePrivate($this->manager, 'getShares', [null]), 'Asserting all shares for the user have been deleted'); + $this->assertEmpty(self::invokePrivate($this->manager, 'getShares', [null]), 'Asserting all shares for the user have been deleted'); $this->mountManager->clear(); - \Test_Helper::invokePrivate($this->manager, 'setupMounts'); + self::invokePrivate($this->manager, 'setupMounts'); $this->assertNotMount($shareData1['name']); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}'); $this->assertNotMount('{{TemporaryMountPointName#' . $shareData1['name'] . '}}-1'); diff --git a/apps/files_sharing/tests/middleware/sharingcheckmiddleware.php b/apps/files_sharing/tests/middleware/sharingcheckmiddleware.php index b1113e7a455..c52036e6f5b 100644 --- a/apps/files_sharing/tests/middleware/sharingcheckmiddleware.php +++ b/apps/files_sharing/tests/middleware/sharingcheckmiddleware.php @@ -58,7 +58,7 @@ class SharingCheckMiddlewareTest extends \Test\TestCase { ->with('core', 'shareapi_allow_links', 'yes') ->will($this->returnValue('yes')); - $this->assertTrue(\Test_Helper::invokePrivate($this->sharingCheckMiddleware, 'isSharingEnabled')); + $this->assertTrue(self::invokePrivate($this->sharingCheckMiddleware, 'isSharingEnabled')); } public function testIsSharingEnabledWithAppDisabled() { @@ -68,7 +68,7 @@ class SharingCheckMiddlewareTest extends \Test\TestCase { ->with('files_sharing') ->will($this->returnValue(false)); - $this->assertFalse(\Test_Helper::invokePrivate($this->sharingCheckMiddleware, 'isSharingEnabled')); + $this->assertFalse(self::invokePrivate($this->sharingCheckMiddleware, 'isSharingEnabled')); } public function testIsSharingEnabledWithSharingDisabled() { @@ -84,6 +84,6 @@ class SharingCheckMiddlewareTest extends \Test\TestCase { ->with('core', 'shareapi_allow_links', 'yes') ->will($this->returnValue('no')); - $this->assertFalse(\Test_Helper::invokePrivate($this->sharingCheckMiddleware, 'isSharingEnabled')); + $this->assertFalse(self::invokePrivate($this->sharingCheckMiddleware, 'isSharingEnabled')); } } diff --git a/apps/files_trashbin/lib/trashbin.php b/apps/files_trashbin/lib/trashbin.php index baa0c4cbe71..853bc1eda69 100644 --- a/apps/files_trashbin/lib/trashbin.php +++ b/apps/files_trashbin/lib/trashbin.php @@ -175,6 +175,10 @@ class Trashbin { } self::setUpTrash($user); + if ($owner !== $user) { + // also setup for owner + self::setUpTrash($owner); + } $path_parts = pathinfo($file_path); @@ -222,7 +226,7 @@ class Trashbin { \OCP\Util::emitHook('\OCA\Files_Trashbin\Trashbin', 'post_moveToTrash', array('filePath' => \OC\Files\Filesystem::normalizePath($file_path), 'trashPath' => \OC\Files\Filesystem::normalizePath($filename . '.d' . $timestamp))); - $size += self::retainVersions($file_path, $filename, $timestamp); + $size += self::retainVersions($file_path, $filename, $owner, $ownerPath, $timestamp); // if owner !== user we need to also add a copy to the owners trash if ($user !== $owner) { @@ -248,23 +252,19 @@ class Trashbin { * * @param string $file_path path to original file * @param string $filename of deleted file + * @param string $owner owner user id + * @param string $ownerPath path relative to the owner's home storage * @param integer $timestamp when the file was deleted * * @return int size of stored versions */ - private static function retainVersions($file_path, $filename, $timestamp) { + private static function retainVersions($file_path, $filename, $owner, $ownerPath, $timestamp) { $size = 0; - if (\OCP\App::isEnabled('files_versions')) { + if (\OCP\App::isEnabled('files_versions') && !empty($ownerPath)) { $user = \OCP\User::getUser(); $rootView = new \OC\Files\View('/'); - list($owner, $ownerPath) = self::getUidAndFilename($file_path); - // file has been deleted in between - if (empty($ownerPath)) { - return 0; - } - if ($rootView->is_dir($owner . '/files_versions/' . $ownerPath)) { $size += self::calculateSize(new \OC\Files\View('/' . $owner . '/files_versions/' . $ownerPath)); if ($owner !== $user) { diff --git a/apps/files_trashbin/tests/storage.php b/apps/files_trashbin/tests/storage.php index f99bc91dd26..637543683dc 100644 --- a/apps/files_trashbin/tests/storage.php +++ b/apps/files_trashbin/tests/storage.php @@ -192,6 +192,10 @@ class Storage extends \Test\TestCase { $this->assertEquals(1, count($results)); $name = $results[0]->getName(); $this->assertEquals('test.txt.v', substr($name, 0, strlen('test.txt.v'))); + + // versions deleted + $results = $this->rootView->getDirectoryContent($this->user . '/files_versions/'); + $this->assertEquals(0, count($results)); } /** @@ -223,6 +227,118 @@ class Storage extends \Test\TestCase { $this->assertEquals(1, count($results)); $name = $results[0]->getName(); $this->assertEquals('inside.txt.v', substr($name, 0, strlen('inside.txt.v'))); + + // versions deleted + $results = $this->rootView->getDirectoryContent($this->user . '/files_versions/folder/'); + $this->assertEquals(0, count($results)); + } + + /** + * Test that deleted versions properly land in the trashbin when deleting as share recipient. + */ + public function testDeleteVersionsOfFileAsRecipient() { + \OCA\Files_Versions\Hooks::connectHooks(); + + $this->userView->mkdir('share'); + // trigger a version (multiple would not work because of the expire logic) + $this->userView->file_put_contents('share/test.txt', 'v1'); + $this->userView->file_put_contents('share/test.txt', 'v2'); + + $results = $this->rootView->getDirectoryContent($this->user . '/files_versions/share/'); + $this->assertEquals(1, count($results)); + + $recipientUser = $this->getUniqueId('recipient_'); + \OC::$server->getUserManager()->createUser($recipientUser, $recipientUser); + + $fileinfo = $this->userView->getFileInfo('share'); + $this->assertTrue(\OCP\Share::shareItem('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_USER, + $recipientUser, 31)); + + $this->loginAsUser($recipientUser); + + // delete as recipient + $recipientView = new \OC\Files\View('/' . $recipientUser . '/files'); + $recipientView->unlink('share/test.txt'); + + // rescan trash storage for both users + list($rootStorage,) = $this->rootView->resolvePath($this->user . '/files_trashbin'); + $rootStorage->getScanner()->scan(''); + + // check if versions are in trashbin for both users + $results = $this->rootView->getDirectoryContent($this->user . '/files_trashbin/versions'); + $this->assertEquals(1, count($results), 'Versions in owner\'s trashbin'); + $name = $results[0]->getName(); + $this->assertEquals('test.txt.v', substr($name, 0, strlen('test.txt.v'))); + + $results = $this->rootView->getDirectoryContent($recipientUser . '/files_trashbin/versions'); + $this->assertEquals(1, count($results), 'Versions in recipient\'s trashbin'); + $name = $results[0]->getName(); + $this->assertEquals('test.txt.v', substr($name, 0, strlen('test.txt.v'))); + + // versions deleted + $results = $this->rootView->getDirectoryContent($this->user . '/files_versions/share/'); + $this->assertEquals(0, count($results)); + } + + /** + * Test that deleted versions properly land in the trashbin when deleting as share recipient. + */ + public function testDeleteVersionsOfFolderAsRecipient() { + \OCA\Files_Versions\Hooks::connectHooks(); + + $this->userView->mkdir('share'); + $this->userView->mkdir('share/folder'); + // trigger a version (multiple would not work because of the expire logic) + $this->userView->file_put_contents('share/folder/test.txt', 'v1'); + $this->userView->file_put_contents('share/folder/test.txt', 'v2'); + + $results = $this->rootView->getDirectoryContent($this->user . '/files_versions/share/folder/'); + $this->assertEquals(1, count($results)); + + $recipientUser = $this->getUniqueId('recipient_'); + \OC::$server->getUserManager()->createUser($recipientUser, $recipientUser); + + $fileinfo = $this->userView->getFileInfo('share'); + $this->assertTrue(\OCP\Share::shareItem('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_USER, + $recipientUser, 31)); + + $this->loginAsUser($recipientUser); + + // delete as recipient + $recipientView = new \OC\Files\View('/' . $recipientUser . '/files'); + $recipientView->rmdir('share/folder'); + + // rescan trash storage + list($rootStorage,) = $this->rootView->resolvePath($this->user . '/files_trashbin'); + $rootStorage->getScanner()->scan(''); + + // check if versions are in trashbin for owner + $results = $this->rootView->getDirectoryContent($this->user . '/files_trashbin/versions'); + $this->assertEquals(1, count($results)); + $name = $results[0]->getName(); + $this->assertEquals('folder.d', substr($name, 0, strlen('folder.d'))); + + // check if file versions are in trashbin for owner + $results = $this->rootView->getDirectoryContent($this->user . '/files_trashbin/versions/' . $name . '/'); + $this->assertEquals(1, count($results)); + $name = $results[0]->getName(); + $this->assertEquals('test.txt.v', substr($name, 0, strlen('test.txt.v'))); + + // check if versions are in trashbin for recipient + $results = $this->rootView->getDirectoryContent($recipientUser . '/files_trashbin/versions'); + $this->assertEquals(1, count($results)); + $name = $results[0]->getName(); + $this->assertEquals('folder.d', substr($name, 0, strlen('folder.d'))); + + // check if file versions are in trashbin for recipient + $results = $this->rootView->getDirectoryContent($recipientUser . '/files_trashbin/versions/' . $name . '/'); + $this->assertEquals(1, count($results)); + $name = $results[0]->getName(); + $this->assertEquals('test.txt.v', substr($name, 0, strlen('test.txt.v'))); + + // versions deleted + $results = $this->rootView->getDirectoryContent($recipientUser . '/files_versions/share/folder/'); + $this->assertEquals(0, count($results)); } /** diff --git a/apps/user_ldap/l10n/el.js b/apps/user_ldap/l10n/el.js index 371d1a4e783..c8207dbabfe 100644 --- a/apps/user_ldap/l10n/el.js +++ b/apps/user_ldap/l10n/el.js @@ -78,6 +78,9 @@ OC.L10N.register( "Verify settings" : "Επιβεβαίωση ρυθμίσεων", "1. Server" : "1. Διακομιστής", "%s. Server:" : "%s. Διακομιστής:", + "Adds a new and blank configuration" : "Προσθέτει μια νέα και κενή διαμόρφωση", + "Copy current configuration into new directory binding" : "Αντιγραφή της τρέχουσας διαμόρφωσης σε νέο κατάλογο", + "Delete the current configuration" : "Διαγραφή τρέχουσας διαμόρφωσης", "Host" : "Διακομιστής", "You can omit the protocol, except you require SSL. Then start with ldaps://" : "Μπορείτε να παραλείψετε το πρωτόκολλο, εκτός αν απαιτείται SSL. Σε αυτή την περίπτωση ξεκινήστε με ldaps://", "Port" : "Θύρα", diff --git a/apps/user_ldap/l10n/el.json b/apps/user_ldap/l10n/el.json index 7a863409b7d..1e861ba8f82 100644 --- a/apps/user_ldap/l10n/el.json +++ b/apps/user_ldap/l10n/el.json @@ -76,6 +76,9 @@ "Verify settings" : "Επιβεβαίωση ρυθμίσεων", "1. Server" : "1. Διακομιστής", "%s. Server:" : "%s. Διακομιστής:", + "Adds a new and blank configuration" : "Προσθέτει μια νέα και κενή διαμόρφωση", + "Copy current configuration into new directory binding" : "Αντιγραφή της τρέχουσας διαμόρφωσης σε νέο κατάλογο", + "Delete the current configuration" : "Διαγραφή τρέχουσας διαμόρφωσης", "Host" : "Διακομιστής", "You can omit the protocol, except you require SSL. Then start with ldaps://" : "Μπορείτε να παραλείψετε το πρωτόκολλο, εκτός αν απαιτείται SSL. Σε αυτή την περίπτωση ξεκινήστε με ldaps://", "Port" : "Θύρα", diff --git a/apps/user_ldap/l10n/it.js b/apps/user_ldap/l10n/it.js index 4ae5d598f7a..55c1abb333f 100644 --- a/apps/user_ldap/l10n/it.js +++ b/apps/user_ldap/l10n/it.js @@ -79,6 +79,7 @@ OC.L10N.register( "1. Server" : "1. server", "%s. Server:" : "%s. server:", "Adds a new and blank configuration" : "Aggiunge una nuova configurazione", + "Copy current configuration into new directory binding" : "Copia la configurazione attuale nella nuova cartella associata", "Delete the current configuration" : "Elimina la configurazione attuale", "Host" : "Host", "You can omit the protocol, except you require SSL. Then start with ldaps://" : "È possibile omettere il protocollo, ad eccezione se è necessario SSL. Quindi inizia con ldaps://", diff --git a/apps/user_ldap/l10n/it.json b/apps/user_ldap/l10n/it.json index 98243da37f1..9bf6de0e336 100644 --- a/apps/user_ldap/l10n/it.json +++ b/apps/user_ldap/l10n/it.json @@ -77,6 +77,7 @@ "1. Server" : "1. server", "%s. Server:" : "%s. server:", "Adds a new and blank configuration" : "Aggiunge una nuova configurazione", + "Copy current configuration into new directory binding" : "Copia la configurazione attuale nella nuova cartella associata", "Delete the current configuration" : "Elimina la configurazione attuale", "Host" : "Host", "You can omit the protocol, except you require SSL. Then start with ldaps://" : "È possibile omettere il protocollo, ad eccezione se è necessario SSL. Quindi inizia con ldaps://", diff --git a/config/config.sample.php b/config/config.sample.php index 23a27fa3ec0..566812444da 100644 --- a/config/config.sample.php +++ b/config/config.sample.php @@ -1043,7 +1043,7 @@ $CONFIG = array( * Memory caching backend for file locking * Because most memcache backends can clean values without warning using redis is recommended */ -'memcache.locking' => '\OC\Memcache\Redis', +'memcache.locking' => '\\OC\\Memcache\\Redis', /** * This entry is just here to show a warning in case somebody copied the sample diff --git a/core/ajax/update.php b/core/ajax/update.php index 22133f9774c..6a29b5b1c33 100644 --- a/core/ajax/update.php +++ b/core/ajax/update.php @@ -44,12 +44,15 @@ if (OC::checkUpgrade(false)) { $incompatibleApps = []; $disabledThirdPartyApps = []; - $updater->listen('\OC\Updater', 'maintenanceStart', function () use ($eventSource, $l) { + $updater->listen('\OC\Updater', 'maintenanceEnabled', function () use ($eventSource, $l) { $eventSource->send('success', (string)$l->t('Turned on maintenance mode')); }); - $updater->listen('\OC\Updater', 'maintenanceEnd', function () use ($eventSource, $l) { + $updater->listen('\OC\Updater', 'maintenanceDisabled', function () use ($eventSource, $l) { $eventSource->send('success', (string)$l->t('Turned off maintenance mode')); }); + $updater->listen('\OC\Updater', 'maintenanceActive', function () use ($eventSource, $l) { + $eventSource->send('success', (string)$l->t('Maintenance mode is kept active')); + }); $updater->listen('\OC\Updater', 'dbUpgrade', function () use ($eventSource, $l) { $eventSource->send('success', (string)$l->t('Updated database')); }); diff --git a/core/command/upgrade.php b/core/command/upgrade.php index 85bd430db58..2d6394fea85 100644 --- a/core/command/upgrade.php +++ b/core/command/upgrade.php @@ -118,12 +118,17 @@ class Upgrade extends Command { $updater->setUpdateStepEnabled($updateStepEnabled); $updater->setSkip3rdPartyAppsDisable($skip3rdPartyAppsDisable); - $updater->listen('\OC\Updater', 'maintenanceStart', function () use($output) { + $updater->listen('\OC\Updater', 'maintenanceEnabled', function () use($output) { $output->writeln('<info>Turned on maintenance mode</info>'); }); - $updater->listen('\OC\Updater', 'maintenanceEnd', + $updater->listen('\OC\Updater', 'maintenanceDisabled', function () use($output) { + $output->writeln('<info>Turned off maintenance mode</info>'); + }); + $updater->listen('\OC\Updater', 'maintenanceActive', function () use($output) { + $output->writeln('<info>Maintenance mode is kept active</info>'); + }); + $updater->listen('\OC\Updater', 'updateEnd', function () use($output, $updateStepEnabled, $self) { - $output->writeln('<info>Turned off maintenance mode</info>'); $mode = $updateStepEnabled ? 'Update' : 'Update simulation'; $status = $self->upgradeFailed ? 'failed' : 'successful'; $message = "<info>$mode $status</info>"; diff --git a/core/css/fixes.css b/core/css/fixes.css index 894d9bc14a5..7ef44ba6909 100644 --- a/core/css/fixes.css +++ b/core/css/fixes.css @@ -64,6 +64,12 @@ select { visibility: hidden; } +/* fix installation screen rendering issue for IE8+9 */ +.lte9 #body-login { + min-height: 100%; + height: auto !important; +} + /* oc-dialog only uses box shadow which is not supported by ie8 */ .ie8 .oc-dialog { border: 1px solid #888888; diff --git a/core/l10n/el.js b/core/l10n/el.js index 1924b6e039b..28a681af797 100644 --- a/core/l10n/el.js +++ b/core/l10n/el.js @@ -149,6 +149,7 @@ OC.L10N.register( "New Password" : "Νέος Κωδικός", "Reset password" : "Επαναφορά συνθηματικού", "Searching other places" : "Έρευνα σε άλλα σημεία.", + "No search results in other places" : "Δεν υπάρχουν αποτελέσματα αναζήτησης σε άλλες τοποθεσίες", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} αποτελέσματα έρευνας σε άλλα σημεία","{count} αποτελέσματα έρευνας σε άλλα σημεία"], "Personal" : "Προσωπικά", "Users" : "Χρήστες", diff --git a/core/l10n/el.json b/core/l10n/el.json index 26115d6e511..4e73f731d66 100644 --- a/core/l10n/el.json +++ b/core/l10n/el.json @@ -147,6 +147,7 @@ "New Password" : "Νέος Κωδικός", "Reset password" : "Επαναφορά συνθηματικού", "Searching other places" : "Έρευνα σε άλλα σημεία.", + "No search results in other places" : "Δεν υπάρχουν αποτελέσματα αναζήτησης σε άλλες τοποθεσίες", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} αποτελέσματα έρευνας σε άλλα σημεία","{count} αποτελέσματα έρευνας σε άλλα σημεία"], "Personal" : "Προσωπικά", "Users" : "Χρήστες", diff --git a/core/l10n/es.js b/core/l10n/es.js index 9e147e43a13..d75e0896d20 100644 --- a/core/l10n/es.js +++ b/core/l10n/es.js @@ -149,6 +149,7 @@ OC.L10N.register( "New Password" : "Contraseña nueva", "Reset password" : "Restablecer contraseña", "Searching other places" : "Buscando en otros lugares", + "No search results in other places" : "Sin resultados de búsqueda en otros sitios", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} resultado de búsqueda en otros lugares","{count} resultados de búsqueda en otros lugares"], "Personal" : "Personal", "Users" : "Usuarios", diff --git a/core/l10n/es.json b/core/l10n/es.json index d402d00b726..3350f15add8 100644 --- a/core/l10n/es.json +++ b/core/l10n/es.json @@ -147,6 +147,7 @@ "New Password" : "Contraseña nueva", "Reset password" : "Restablecer contraseña", "Searching other places" : "Buscando en otros lugares", + "No search results in other places" : "Sin resultados de búsqueda en otros sitios", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} resultado de búsqueda en otros lugares","{count} resultados de búsqueda en otros lugares"], "Personal" : "Personal", "Users" : "Usuarios", diff --git a/core/l10n/fi_FI.js b/core/l10n/fi_FI.js index ce44ef0ceb3..64034a39435 100644 --- a/core/l10n/fi_FI.js +++ b/core/l10n/fi_FI.js @@ -149,6 +149,7 @@ OC.L10N.register( "New Password" : "Uusi salasana", "Reset password" : "Palauta salasana", "Searching other places" : "Etsitään muista paikoista", + "No search results in other places" : "Ei hakutuloksia muista paikoista", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} hakutulos muualla","{count} hakutulosta muualla"], "Personal" : "Henkilökohtainen", "Users" : "Käyttäjät", diff --git a/core/l10n/fi_FI.json b/core/l10n/fi_FI.json index 8f1ea16fcd7..8ca65e44ba3 100644 --- a/core/l10n/fi_FI.json +++ b/core/l10n/fi_FI.json @@ -147,6 +147,7 @@ "New Password" : "Uusi salasana", "Reset password" : "Palauta salasana", "Searching other places" : "Etsitään muista paikoista", + "No search results in other places" : "Ei hakutuloksia muista paikoista", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} hakutulos muualla","{count} hakutulosta muualla"], "Personal" : "Henkilökohtainen", "Users" : "Käyttäjät", diff --git a/core/l10n/gl.js b/core/l10n/gl.js index 65176174f14..795af443c96 100644 --- a/core/l10n/gl.js +++ b/core/l10n/gl.js @@ -149,6 +149,7 @@ OC.L10N.register( "New Password" : "Novo contrasinal", "Reset password" : "Restabelecer o contrasinal", "Searching other places" : "Buscando noutros lugares", + "No search results in other places" : "Sen resultados na busca noutros lugares", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} resultado na busca noutros lugares","{count} resultados na busca noutros lugares"], "Personal" : "Persoal", "Users" : "Usuarios", diff --git a/core/l10n/gl.json b/core/l10n/gl.json index d5576cc37e1..464db5691d9 100644 --- a/core/l10n/gl.json +++ b/core/l10n/gl.json @@ -147,6 +147,7 @@ "New Password" : "Novo contrasinal", "Reset password" : "Restabelecer o contrasinal", "Searching other places" : "Buscando noutros lugares", + "No search results in other places" : "Sen resultados na busca noutros lugares", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} resultado na busca noutros lugares","{count} resultados na busca noutros lugares"], "Personal" : "Persoal", "Users" : "Usuarios", diff --git a/core/l10n/hy.js b/core/l10n/hy.js index bebec67e8a2..26250b0c55a 100644 --- a/core/l10n/hy.js +++ b/core/l10n/hy.js @@ -20,6 +20,9 @@ OC.L10N.register( "October" : "Հոկտեմբեր", "November" : "Նոյեմբեր", "December" : "Դեկտեմբեր", - "Delete" : "Ջնջել" + "group" : "խումբ", + "Delete" : "Ջնջել", + "Add" : "Ավելացնել", + "Personal" : "Անձնական" }, "nplurals=2; plural=(n != 1);"); diff --git a/core/l10n/hy.json b/core/l10n/hy.json index 819972fdba5..76a0da8ccdc 100644 --- a/core/l10n/hy.json +++ b/core/l10n/hy.json @@ -18,6 +18,9 @@ "October" : "Հոկտեմբեր", "November" : "Նոյեմբեր", "December" : "Դեկտեմբեր", - "Delete" : "Ջնջել" + "group" : "խումբ", + "Delete" : "Ջնջել", + "Add" : "Ավելացնել", + "Personal" : "Անձնական" },"pluralForm" :"nplurals=2; plural=(n != 1);" }
\ No newline at end of file diff --git a/core/l10n/it.js b/core/l10n/it.js index d7df3becda6..6df9d7d4d84 100644 --- a/core/l10n/it.js +++ b/core/l10n/it.js @@ -149,6 +149,7 @@ OC.L10N.register( "New Password" : "Nuova password", "Reset password" : "Ripristina la password", "Searching other places" : "Ricerca in altre posizioni", + "No search results in other places" : "Nessun risultato di ricerca in altre posizioni", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} risultato di ricerca in altre posizioni","{count} risultati di ricerca in altre posizioni"], "Personal" : "Personale", "Users" : "Utenti", diff --git a/core/l10n/it.json b/core/l10n/it.json index 43b408edff9..e2d0bf43b09 100644 --- a/core/l10n/it.json +++ b/core/l10n/it.json @@ -147,6 +147,7 @@ "New Password" : "Nuova password", "Reset password" : "Ripristina la password", "Searching other places" : "Ricerca in altre posizioni", + "No search results in other places" : "Nessun risultato di ricerca in altre posizioni", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} risultato di ricerca in altre posizioni","{count} risultati di ricerca in altre posizioni"], "Personal" : "Personale", "Users" : "Utenti", diff --git a/core/l10n/pt_BR.js b/core/l10n/pt_BR.js index 004740b5826..9e8ca3d5046 100644 --- a/core/l10n/pt_BR.js +++ b/core/l10n/pt_BR.js @@ -149,6 +149,7 @@ OC.L10N.register( "New Password" : "Nova Senha", "Reset password" : "Redefinir senha", "Searching other places" : "Pesquisando em outros lugares", + "No search results in other places" : "Nenhum resultado de pesquisa em outros lugares", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} resultados da pesquisa em outros lugares","{count} resultados da pesquisa em outros lugares"], "Personal" : "Pessoal", "Users" : "Usuários", diff --git a/core/l10n/pt_BR.json b/core/l10n/pt_BR.json index 7ba111e5a88..6ccb06ccb59 100644 --- a/core/l10n/pt_BR.json +++ b/core/l10n/pt_BR.json @@ -147,6 +147,7 @@ "New Password" : "Nova Senha", "Reset password" : "Redefinir senha", "Searching other places" : "Pesquisando em outros lugares", + "No search results in other places" : "Nenhum resultado de pesquisa em outros lugares", "_{count} search result in other places_::_{count} search results in other places_" : ["{count} resultados da pesquisa em outros lugares","{count} resultados da pesquisa em outros lugares"], "Personal" : "Pessoal", "Users" : "Usuários", diff --git a/lib/l10n/el.js b/lib/l10n/el.js index 9d05e40e533..c6c794d154c 100644 --- a/lib/l10n/el.js +++ b/lib/l10n/el.js @@ -35,6 +35,7 @@ OC.L10N.register( "_%n year ago_::_%n years ago_" : ["%n χρόνο πριν","%n χρόνια πριν"], "seconds ago" : "δευτερόλεπτα πριν", "web services under your control" : "υπηρεσίες δικτύου υπό τον έλεγχό σας", + "Module with id: %s does not exists. Please enable it in your apps settings or contact your administrator." : "Η μονάδα με id: %s δεν υπάρχει. Παρακαλούμε ενεργοποιήστε τη στις ρυθμίσεις των εφαρμογών σας ή επικοινωνήστε με το διαχειριστή σας.", "Empty filename is not allowed" : "Δεν επιτρέπεται άδειο όνομα αρχείου", "Dot files are not allowed" : "Δεν επιτρέπονται αρχεία που ξεκινούν από τελεία - Dot ", "4-byte characters are not supported in file names" : "Χαρακτήρες 4-byte δεν υποστηρίζονται σε ονόματα αρχείων", diff --git a/lib/l10n/el.json b/lib/l10n/el.json index 84d2b8f4925..4d8cd7e33a5 100644 --- a/lib/l10n/el.json +++ b/lib/l10n/el.json @@ -33,6 +33,7 @@ "_%n year ago_::_%n years ago_" : ["%n χρόνο πριν","%n χρόνια πριν"], "seconds ago" : "δευτερόλεπτα πριν", "web services under your control" : "υπηρεσίες δικτύου υπό τον έλεγχό σας", + "Module with id: %s does not exists. Please enable it in your apps settings or contact your administrator." : "Η μονάδα με id: %s δεν υπάρχει. Παρακαλούμε ενεργοποιήστε τη στις ρυθμίσεις των εφαρμογών σας ή επικοινωνήστε με το διαχειριστή σας.", "Empty filename is not allowed" : "Δεν επιτρέπεται άδειο όνομα αρχείου", "Dot files are not allowed" : "Δεν επιτρέπονται αρχεία που ξεκινούν από τελεία - Dot ", "4-byte characters are not supported in file names" : "Χαρακτήρες 4-byte δεν υποστηρίζονται σε ονόματα αρχείων", diff --git a/lib/l10n/hy.js b/lib/l10n/hy.js index a12702211c2..c52c1de970f 100644 --- a/lib/l10n/hy.js +++ b/lib/l10n/hy.js @@ -1,10 +1,6 @@ OC.L10N.register( "lib", { - "_%n day ago_::_%n days ago_" : ["",""], - "_%n month ago_::_%n months ago_" : ["",""], - "_%n year ago_::_%n years ago_" : ["",""], - "_%n hour ago_::_%n hours ago_" : ["",""], - "_%n minute ago_::_%n minutes ago_" : ["",""] + "Personal" : "Անձնական" }, "nplurals=2; plural=(n != 1);"); diff --git a/lib/l10n/hy.json b/lib/l10n/hy.json index b994fa289eb..9b571e73868 100644 --- a/lib/l10n/hy.json +++ b/lib/l10n/hy.json @@ -1,8 +1,4 @@ { "translations": { - "_%n day ago_::_%n days ago_" : ["",""], - "_%n month ago_::_%n months ago_" : ["",""], - "_%n year ago_::_%n years ago_" : ["",""], - "_%n hour ago_::_%n hours ago_" : ["",""], - "_%n minute ago_::_%n minutes ago_" : ["",""] + "Personal" : "Անձնական" },"pluralForm" :"nplurals=2; plural=(n != 1);" }
\ No newline at end of file diff --git a/lib/private/connector/sabre/directory.php b/lib/private/connector/sabre/directory.php index 82e1b55d763..58f16a2bd04 100644 --- a/lib/private/connector/sabre/directory.php +++ b/lib/private/connector/sabre/directory.php @@ -104,6 +104,8 @@ class Directory extends \OC\Connector\Sabre\Node return $node->put($data); } catch (\OCP\Files\StorageNotAvailableException $e) { throw new \Sabre\DAV\Exception\ServiceUnavailable($e->getMessage()); + } catch (\OCP\Files\InvalidPathException $ex) { + throw new InvalidPath($ex->getMessage()); } catch (LockedException $e) { throw new FileLocked($e->getMessage(), $e->getCode(), $e); } diff --git a/lib/private/encryption/keys/storage.php b/lib/private/encryption/keys/storage.php index 692633f98da..fa317851a56 100644 --- a/lib/private/encryption/keys/storage.php +++ b/lib/private/encryption/keys/storage.php @@ -232,22 +232,8 @@ class Storage implements IStorage { */ public function renameKeys($source, $target) { - list($owner, $source) = $this->util->getUidAndFilename($source); - list(, $target) = $this->util->getUidAndFilename($target); - $systemWideSource = $this->util->isSystemWideMountPoint($source, $owner); - $systemWideTarget = $this->util->isSystemWideMountPoint($target, $owner); - - if ($systemWideSource) { - $sourcePath = $this->keys_base_dir . $source . '/'; - } else { - $sourcePath = '/' . $owner . $this->keys_base_dir . $source . '/'; - } - - if ($systemWideTarget) { - $targetPath = $this->keys_base_dir . $target . '/'; - } else { - $targetPath = '/' . $owner . $this->keys_base_dir . $target . '/'; - } + $sourcePath = $this->getPathToKeys($source); + $targetPath = $this->getPathToKeys($target); if ($this->view->file_exists($sourcePath)) { $this->keySetPreparation(dirname($targetPath)); @@ -259,6 +245,7 @@ class Storage implements IStorage { return false; } + /** * copy keys if a file was renamed * @@ -268,21 +255,8 @@ class Storage implements IStorage { */ public function copyKeys($source, $target) { - list($owner, $source) = $this->util->getUidAndFilename($source); - list(, $target) = $this->util->getUidAndFilename($target); - $systemWideTarget = $this->util->isSystemWideMountPoint($target, $owner); - $systemWideSource = $this->util->isSystemWideMountPoint($source, $owner); - - if ($systemWideSource) { - $sourcePath = $this->keys_base_dir . $source . '/'; - } else { - $sourcePath = '/' . $owner . $this->keys_base_dir . $source . '/'; - } - if ($systemWideTarget) { - $targetPath = $this->keys_base_dir . $target . '/'; - } else { - $targetPath = '/' . $owner . $this->keys_base_dir . $target . '/'; - } + $sourcePath = $this->getPathToKeys($source); + $targetPath = $this->getPathToKeys($target); if ($this->view->file_exists($sourcePath)) { $this->keySetPreparation(dirname($targetPath)); @@ -294,6 +268,25 @@ class Storage implements IStorage { } /** + * get system wide path and detect mount points + * + * @param string $path + * @return string + */ + protected function getPathToKeys($path) { + list($owner, $relativePath) = $this->util->getUidAndFilename($path); + $systemWideMountPoint = $this->util->isSystemWideMountPoint($relativePath, $owner); + + if ($systemWideMountPoint) { + $systemPath = $this->keys_base_dir . $relativePath . '/'; + } else { + $systemPath = '/' . $owner . $this->keys_base_dir . $relativePath . '/'; + } + + return $systemPath; + } + + /** * Make preparations to filesystem for saving a key file * * @param string $path relative to the views root diff --git a/lib/private/encryption/manager.php b/lib/private/encryption/manager.php index ecbb86993ec..4841533cac1 100644 --- a/lib/private/encryption/manager.php +++ b/lib/private/encryption/manager.php @@ -151,8 +151,8 @@ class Manager implements IManager { if (isset($this->encryptionModules[$moduleId])) { return call_user_func($this->encryptionModules[$moduleId]['callback']); } else { - $message = "Module with id: $moduleId does not exists."; - $hint = $this->l->t('Module with id: %s does not exists. Please enable it in your apps settings or contact your administrator.', [$moduleId]); + $message = "Module with id: $moduleId does not exist."; + $hint = $this->l->t('Module with id: %s does not exist. Please enable it in your apps settings or contact your administrator.', [$moduleId]); throw new Exceptions\ModuleDoesNotExistsException($message, $hint); } } else { @@ -208,49 +208,16 @@ class Manager implements IManager { return $this->config->getAppValue('core', 'default_encryption_module'); } + /** + * Add storage wrapper + */ public static function setupStorage() { - \OC\Files\Filesystem::addStorageWrapper('oc_encryption', function ($mountPoint, $storage, IMountPoint $mount) { - $parameters = [ - 'storage' => $storage, - 'mountPoint' => $mountPoint, - 'mount' => $mount]; - - if (!($storage instanceof Shared)) { - $manager = \OC::$server->getEncryptionManager(); - $util = new Util( - new View(), - \OC::$server->getUserManager(), - \OC::$server->getGroupManager(), - \OC::$server->getConfig() - ); - $user = \OC::$server->getUserSession()->getUser(); - $logger = \OC::$server->getLogger(); - $mountManager = Filesystem::getMountManager(); - $uid = $user ? $user->getUID() : null; - $fileHelper = \OC::$server->getEncryptionFilesHelper(); - $keyStorage = \OC::$server->getEncryptionKeyStorage(); - $update = new Update( - new View(), - $util, - Filesystem::getMountManager(), - $manager, - $fileHelper, - $uid - ); - return new Encryption( - $parameters, - $manager, - $util, - $logger, - $fileHelper, - $uid, - $keyStorage, - $update, - $mountManager - ); - } else { - return $storage; - } - }, 2); + $util = new Util( + new View(), + \OC::$server->getUserManager(), + \OC::$server->getGroupManager(), + \OC::$server->getConfig() + ); + \OC\Files\Filesystem::addStorageWrapper('oc_encryption', array($util, 'wrapStorage'), 2); } } diff --git a/lib/private/encryption/util.php b/lib/private/encryption/util.php index b77672d2f6b..80499249561 100644 --- a/lib/private/encryption/util.php +++ b/lib/private/encryption/util.php @@ -26,8 +26,11 @@ use OC\Encryption\Exceptions\EncryptionHeaderKeyExistsException; use OC\Encryption\Exceptions\EncryptionHeaderToLargeException; use OC\Encryption\Exceptions\ModuleDoesNotExistsException; use OC\Files\Filesystem; +use OC\Files\Storage\Wrapper\Encryption; use OC\Files\View; use OCP\Encryption\IEncryptionModule; +use OCP\Files\Mount\IMountPoint; +use OCP\Files\Storage; use OCP\IConfig; class Util { @@ -386,4 +389,52 @@ class Util { return ($enabled === '1') ? true : false; } + /** + * Wraps the given storage when it is not a shared storage + * + * @param string $mountPoint + * @param Storage $storage + * @param IMountPoint $mount + * @return Encryption|Storage + */ + public function wrapStorage($mountPoint, Storage $storage, IMountPoint $mount) { + $parameters = [ + 'storage' => $storage, + 'mountPoint' => $mountPoint, + 'mount' => $mount]; + + if (!$storage->instanceOfStorage('OC\Files\Storage\Shared') + && !$storage->instanceOfStorage('OCA\Files_Sharing\External\Storage') + && !$storage->instanceOfStorage('OC\Files\Storage\OwnCloud')) { + + $manager = \OC::$server->getEncryptionManager(); + $user = \OC::$server->getUserSession()->getUser(); + $logger = \OC::$server->getLogger(); + $mountManager = Filesystem::getMountManager(); + $uid = $user ? $user->getUID() : null; + $fileHelper = \OC::$server->getEncryptionFilesHelper(); + $keyStorage = \OC::$server->getEncryptionKeyStorage(); + $update = new Update( + new View(), + $this, + Filesystem::getMountManager(), + $manager, + $fileHelper, + $uid + ); + return new Encryption( + $parameters, + $manager, + $this, + $logger, + $fileHelper, + $uid, + $keyStorage, + $update, + $mountManager + ); + } else { + return $storage; + } + } } diff --git a/lib/private/files/storage/wrapper/encryption.php b/lib/private/files/storage/wrapper/encryption.php index d1e22bb6d40..056f823c18b 100644 --- a/lib/private/files/storage/wrapper/encryption.php +++ b/lib/private/files/storage/wrapper/encryption.php @@ -535,7 +535,13 @@ class Encryption extends Wrapper { * @return string */ public function getLocalFile($path) { - return $this->getCachedFile($path); + if ($this->encryptionManager->isEnabled()) { + $cachedFile = $this->getCachedFile($path); + if (is_string($cachedFile)) { + return $cachedFile; + } + } + return $this->storage->getLocalFile($path); } /** diff --git a/lib/private/memcache/redis.php b/lib/private/memcache/redis.php index 78d061404ef..cfc35dcc377 100644 --- a/lib/private/memcache/redis.php +++ b/lib/private/memcache/redis.php @@ -151,7 +151,8 @@ class Redis extends Cache implements IMemcache { } static public function isAvailable() { - return extension_loaded('redis'); + return extension_loaded('redis') + && version_compare(phpversion('redis'), '2.2.5', '>='); } } diff --git a/lib/private/updater.php b/lib/private/updater.php index 8371193ef79..7f1a493d2a0 100644 --- a/lib/private/updater.php +++ b/lib/private/updater.php @@ -176,14 +176,18 @@ class Updater extends BasicEmitter { * @return bool true if the operation succeeded, false otherwise */ public function upgrade() { - $this->config->setSystemValue('maintenance', true); + $wasMaintenanceModeEnabled = $this->config->getSystemValue('maintenance', false); + + if(!$wasMaintenanceModeEnabled) { + $this->config->setSystemValue('maintenance', true); + $this->emit('\OC\Updater', 'maintenanceEnabled'); + } $installedVersion = $this->config->getSystemValue('version', '0.0.0'); $currentVersion = implode('.', \OC_Util::getVersion()); if ($this->log) { $this->log->debug('starting upgrade from ' . $installedVersion . ' to ' . $currentVersion, array('app' => 'core')); } - $this->emit('\OC\Updater', 'maintenanceStart'); try { $this->doUpgrade($currentVersion, $installedVersion); @@ -191,8 +195,14 @@ class Updater extends BasicEmitter { $this->emit('\OC\Updater', 'failure', array($exception->getMessage())); } - $this->config->setSystemValue('maintenance', false); - $this->emit('\OC\Updater', 'maintenanceEnd'); + $this->emit('\OC\Updater', 'updateEnd'); + + if(!$wasMaintenanceModeEnabled) { + $this->config->setSystemValue('maintenance', false); + $this->emit('\OC\Updater', 'maintenanceDisabled'); + } else { + $this->emit('\OC\Updater', 'maintenanceActive'); + } } /** diff --git a/settings/admin.php b/settings/admin.php index f2e01adab11..ee252ceb141 100644 --- a/settings/admin.php +++ b/settings/admin.php @@ -35,6 +35,7 @@ OC_Util::checkAdminUser(); OC_App::setActiveNavigationEntry("admin"); $template = new OC_Template('settings', 'admin', 'user'); +$l = OC_L10N::get('settings'); $showLog = (\OC::$server->getConfig()->getSystemValue('log_type', 'owncloud') === 'owncloud'); $numEntriesToLoad = 3; @@ -128,13 +129,23 @@ $template->assign('getenvServerNotWorking', empty($path)); // warn if Windows is used $template->assign('WindowsWarning', OC_Util::runningOnWindows()); -// warn if outdated version of APCu is used -$template->assign('ApcuOutdatedWarning', - extension_loaded('apcu') && version_compare(phpversion('apc'), '4.0.6') === -1); +// warn if outdated version of a memcache module is used +$caches = [ + 'apcu' => ['name' => $l->t('APCu'), 'version' => '4.0.6'], + 'redis' => ['name' => $l->t('Redis'), 'version' => '2.2.5'], +]; + +$outdatedCaches = []; +foreach ($caches as $php_module => $data) { + $isOutdated = extension_loaded($php_module) && version_compare(phpversion($php_module), $data['version'], '<'); + if ($isOutdated) { + $outdatedCaches[$php_module] = $data; + } +} +$template->assign('OutdatedCacheWarning', $outdatedCaches); // add hardcoded forms from the template $forms = OC_App::getForms('admin'); -$l = OC_L10N::get('settings'); $formsAndMore = array(); if ($request->getServerProtocol() !== 'https' || !OC_Util::isAnnotationsWorking() || $suggestedOverwriteCliUrl || !OC_Util::isSetLocaleWorking() || diff --git a/settings/l10n/el.js b/settings/l10n/el.js index 159153f4b55..b6ee7c5ac48 100644 --- a/settings/l10n/el.js +++ b/settings/l10n/el.js @@ -8,6 +8,7 @@ OC.L10N.register( "Cron" : "Cron", "Email server" : "Διακομιστής Email", "Log" : "Καταγραφές", + "Server Status" : "Κατάσταση διακομιστή", "Tips & tricks" : "Συμβουλές & τεχνάσματα", "Updates" : "Ενημερώσεις", "Authentication error" : "Σφάλμα πιστοποίησης", @@ -53,6 +54,9 @@ OC.L10N.register( "Migration in progress. Please wait until the migration is finished" : "Μετάβαση σε εξέλιξη. Παρακαλούμε περιμένετε μέχρι να ολοκληρωθεί η μετάβαση", "Migration started …" : "Η μετάβαση ξεκίνησε ...", "Sending..." : "Αποστέλεται...", + "Official" : "Επίσημο", + "Approved" : "Εγκεκριμένο", + "Experimental" : "Πειραματικό", "All" : "Όλες", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Οι επίσημες εφαρμογές αναπτύσσονται από την κοινότητα ownCloud. Προσφέρουν λειτουργικότητα κοντά στο ownCloud και είναι έτοιμες για χρήση.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Οι εγκεκριμένες εφαρμογές αναπτύχθηκαν από αξιόπιστους προγραμματιστές και έχουν περάσει έναν συνοπτικό έλεγχο ασφαλείας. Διατηρούνται ενεργά σε ένα αποθετήριο ανοιχτού κώδικα και οι συντηρητές θεωρούν οτι είναι σταθερές για κανονική χρήση.", @@ -179,6 +183,8 @@ OC.L10N.register( "Improving the config.php" : "Βελτίωση του config.php", "Theming" : "Θέματα", "Hardening and security guidance" : "Οδηγίες ασφάλειας και θωράκισης", + "Experimental File Lock is enabled." : "Το πειραματικό κλείδωμα αρχείων είναι ενεργοποιημένο.", + "Experimental File Lock is disabled." : "Το πειραματικό κλείδωμα αρχείων είναι απενεργοποιημένο.", "Version" : "Έκδοση", "Developer documentation" : "Τεκμηρίωση προγραμματιστή", "Experimental applications ahead" : "Πειραματικές εφαρμογές", diff --git a/settings/l10n/el.json b/settings/l10n/el.json index 9c59d8aabaa..7cabf7f8a92 100644 --- a/settings/l10n/el.json +++ b/settings/l10n/el.json @@ -6,6 +6,7 @@ "Cron" : "Cron", "Email server" : "Διακομιστής Email", "Log" : "Καταγραφές", + "Server Status" : "Κατάσταση διακομιστή", "Tips & tricks" : "Συμβουλές & τεχνάσματα", "Updates" : "Ενημερώσεις", "Authentication error" : "Σφάλμα πιστοποίησης", @@ -51,6 +52,9 @@ "Migration in progress. Please wait until the migration is finished" : "Μετάβαση σε εξέλιξη. Παρακαλούμε περιμένετε μέχρι να ολοκληρωθεί η μετάβαση", "Migration started …" : "Η μετάβαση ξεκίνησε ...", "Sending..." : "Αποστέλεται...", + "Official" : "Επίσημο", + "Approved" : "Εγκεκριμένο", + "Experimental" : "Πειραματικό", "All" : "Όλες", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Οι επίσημες εφαρμογές αναπτύσσονται από την κοινότητα ownCloud. Προσφέρουν λειτουργικότητα κοντά στο ownCloud και είναι έτοιμες για χρήση.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Οι εγκεκριμένες εφαρμογές αναπτύχθηκαν από αξιόπιστους προγραμματιστές και έχουν περάσει έναν συνοπτικό έλεγχο ασφαλείας. Διατηρούνται ενεργά σε ένα αποθετήριο ανοιχτού κώδικα και οι συντηρητές θεωρούν οτι είναι σταθερές για κανονική χρήση.", @@ -177,6 +181,8 @@ "Improving the config.php" : "Βελτίωση του config.php", "Theming" : "Θέματα", "Hardening and security guidance" : "Οδηγίες ασφάλειας και θωράκισης", + "Experimental File Lock is enabled." : "Το πειραματικό κλείδωμα αρχείων είναι ενεργοποιημένο.", + "Experimental File Lock is disabled." : "Το πειραματικό κλείδωμα αρχείων είναι απενεργοποιημένο.", "Version" : "Έκδοση", "Developer documentation" : "Τεκμηρίωση προγραμματιστή", "Experimental applications ahead" : "Πειραματικές εφαρμογές", diff --git a/settings/l10n/fi_FI.js b/settings/l10n/fi_FI.js index 73e04bcfe0c..b0cea5a0e12 100644 --- a/settings/l10n/fi_FI.js +++ b/settings/l10n/fi_FI.js @@ -8,6 +8,7 @@ OC.L10N.register( "Cron" : "Cron", "Email server" : "Sähköpostipalvelin", "Log" : "Loki", + "Server Status" : "Palvelimen tila", "Tips & tricks" : "Vinkit", "Updates" : "Päivitykset", "Authentication error" : "Tunnistautumisvirhe", @@ -53,6 +54,9 @@ OC.L10N.register( "Migration in progress. Please wait until the migration is finished" : "Migraatio on kesken. Odota kunnes migraatio valmistuu", "Migration started …" : "Migraatio käynnistyi…", "Sending..." : "Lähetetään...", + "Official" : "Virallinen", + "Approved" : "Hyväksytty", + "Experimental" : "Kokeellinen", "All" : "Kaikki", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Viralliset sovellukset kehitetään ownCloud-yhteisön toimesta. Sovellukset tarjoavat lisäominaisuuksia ownCloudin keskeisiin toimintoihin liittyen ja ovat valmiita tuotantokäyttöön.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Hyväksytyt sovellukset on kehitetty luotettujen kehittäjien toimesta. Hyväksytyille sovelluksille on suoritettu pintapuolinen turvallisuustarkastus. Sovelluksia ylläpidetään avoimen koodin tietovarastoissa. Sovellusten kehittäjät mieltävät sovellukset vakaiksi ja valmiiksi tavalliseen käyttöön.", @@ -169,6 +173,8 @@ OC.L10N.register( "Improving the config.php" : "Config.php-tiedoston parantaminen", "Theming" : "Teemojen käyttö", "Hardening and security guidance" : "Turvaamis- ja tietoturvaopas", + "Experimental File Lock is enabled." : "Kokeellinen tiedostolukitus on käytössä.", + "Experimental File Lock is disabled." : "Kokeellinen tiedostolukitus on pois käytöstä.", "Version" : "Versio", "Developer documentation" : "Kehittäjädokumentaatio", "Experimental applications ahead" : "Kokeellisia sovelluksia edessä", diff --git a/settings/l10n/fi_FI.json b/settings/l10n/fi_FI.json index 0d9157466c9..00baee63267 100644 --- a/settings/l10n/fi_FI.json +++ b/settings/l10n/fi_FI.json @@ -6,6 +6,7 @@ "Cron" : "Cron", "Email server" : "Sähköpostipalvelin", "Log" : "Loki", + "Server Status" : "Palvelimen tila", "Tips & tricks" : "Vinkit", "Updates" : "Päivitykset", "Authentication error" : "Tunnistautumisvirhe", @@ -51,6 +52,9 @@ "Migration in progress. Please wait until the migration is finished" : "Migraatio on kesken. Odota kunnes migraatio valmistuu", "Migration started …" : "Migraatio käynnistyi…", "Sending..." : "Lähetetään...", + "Official" : "Virallinen", + "Approved" : "Hyväksytty", + "Experimental" : "Kokeellinen", "All" : "Kaikki", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Viralliset sovellukset kehitetään ownCloud-yhteisön toimesta. Sovellukset tarjoavat lisäominaisuuksia ownCloudin keskeisiin toimintoihin liittyen ja ovat valmiita tuotantokäyttöön.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Hyväksytyt sovellukset on kehitetty luotettujen kehittäjien toimesta. Hyväksytyille sovelluksille on suoritettu pintapuolinen turvallisuustarkastus. Sovelluksia ylläpidetään avoimen koodin tietovarastoissa. Sovellusten kehittäjät mieltävät sovellukset vakaiksi ja valmiiksi tavalliseen käyttöön.", @@ -167,6 +171,8 @@ "Improving the config.php" : "Config.php-tiedoston parantaminen", "Theming" : "Teemojen käyttö", "Hardening and security guidance" : "Turvaamis- ja tietoturvaopas", + "Experimental File Lock is enabled." : "Kokeellinen tiedostolukitus on käytössä.", + "Experimental File Lock is disabled." : "Kokeellinen tiedostolukitus on pois käytöstä.", "Version" : "Versio", "Developer documentation" : "Kehittäjädokumentaatio", "Experimental applications ahead" : "Kokeellisia sovelluksia edessä", diff --git a/settings/l10n/gl.js b/settings/l10n/gl.js index 44619310294..56a7b351d27 100644 --- a/settings/l10n/gl.js +++ b/settings/l10n/gl.js @@ -8,6 +8,7 @@ OC.L10N.register( "Cron" : "Cron", "Email server" : "Servidor de correo", "Log" : "Rexistro", + "Server Status" : "Estado do servidor", "Tips & tricks" : "Trucos e consellos", "Updates" : "Actualizacións", "Authentication error" : "Produciuse un erro de autenticación", @@ -53,6 +54,9 @@ OC.L10N.register( "Migration in progress. Please wait until the migration is finished" : "A migración está en proceso. Agarde a que remate.", "Migration started …" : "Iniciada a migración ...", "Sending..." : "Enviando...", + "Official" : "Oficial", + "Approved" : "Aprobado", + "Experimental" : "Experimental", "All" : "Todo", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "As aplicacións oficiais son desenvolvidas pola comunidade dentro de ownCloud. Ofrecen una funcionalidade central para ownCloud e están preparadas para o seu uso en produción.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "As aplicacións aprobadas son desenvolvidas por desenvolvedores de confianza e pasaron un control de seguridade superficial. Mantéñense activamente nun repositorio de código aberto e os seus mantedores consideran que son estábeis para uso casual normal.", @@ -179,6 +183,8 @@ OC.L10N.register( "Improving the config.php" : "Mellorando o config.php", "Theming" : "Tematización", "Hardening and security guidance" : "Orientacións sobre fortificación e seguridade", + "Experimental File Lock is enabled." : "O bloqueo de ficheiros (experimental) está activado.", + "Experimental File Lock is disabled." : "O bloqueo de ficheiros (experimental) está desactivado.", "Version" : "Versión", "Developer documentation" : "Documentación do desenvolvedor", "Experimental applications ahead" : "Ante as aplicacións experimentais", diff --git a/settings/l10n/gl.json b/settings/l10n/gl.json index beb68e28559..0546f5f0f57 100644 --- a/settings/l10n/gl.json +++ b/settings/l10n/gl.json @@ -6,6 +6,7 @@ "Cron" : "Cron", "Email server" : "Servidor de correo", "Log" : "Rexistro", + "Server Status" : "Estado do servidor", "Tips & tricks" : "Trucos e consellos", "Updates" : "Actualizacións", "Authentication error" : "Produciuse un erro de autenticación", @@ -51,6 +52,9 @@ "Migration in progress. Please wait until the migration is finished" : "A migración está en proceso. Agarde a que remate.", "Migration started …" : "Iniciada a migración ...", "Sending..." : "Enviando...", + "Official" : "Oficial", + "Approved" : "Aprobado", + "Experimental" : "Experimental", "All" : "Todo", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "As aplicacións oficiais son desenvolvidas pola comunidade dentro de ownCloud. Ofrecen una funcionalidade central para ownCloud e están preparadas para o seu uso en produción.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "As aplicacións aprobadas son desenvolvidas por desenvolvedores de confianza e pasaron un control de seguridade superficial. Mantéñense activamente nun repositorio de código aberto e os seus mantedores consideran que son estábeis para uso casual normal.", @@ -177,6 +181,8 @@ "Improving the config.php" : "Mellorando o config.php", "Theming" : "Tematización", "Hardening and security guidance" : "Orientacións sobre fortificación e seguridade", + "Experimental File Lock is enabled." : "O bloqueo de ficheiros (experimental) está activado.", + "Experimental File Lock is disabled." : "O bloqueo de ficheiros (experimental) está desactivado.", "Version" : "Versión", "Developer documentation" : "Documentación do desenvolvedor", "Experimental applications ahead" : "Ante as aplicacións experimentais", diff --git a/settings/l10n/it.js b/settings/l10n/it.js index 7c07db78f87..c62bde67223 100644 --- a/settings/l10n/it.js +++ b/settings/l10n/it.js @@ -8,6 +8,7 @@ OC.L10N.register( "Cron" : "Cron", "Email server" : "Server di posta", "Log" : "Log", + "Server Status" : "Stato del server", "Tips & tricks" : "Suggerimenti e trucchi", "Updates" : "Aggiornamenti", "Authentication error" : "Errore di autenticazione", @@ -53,6 +54,9 @@ OC.L10N.register( "Migration in progress. Please wait until the migration is finished" : "Migrazione in corso. Attendi fino al completamento della migrazione", "Migration started …" : "Migrazione avviata...", "Sending..." : "Invio in corso...", + "Official" : "Ufficiale", + "Approved" : "Approvata", + "Experimental" : "Sperimentale", "All" : "Tutti", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Le applicazioni ufficiali sono sviluppate da e con la comunità di ownCloud. Offrono le funzioni fondamentali di ownCloud e sono pronte per l'utilizzo in produzione.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Le applicazioni approvate sono sviluppate da sviluppatori affidabili e hanno passato un rapido controllo di sicurezza. Sono attivamente mantenute in un deposito aperto del codice e i loro responsabili le ritengono pronte sia per un utilizzo casuale che per un utilizzo continuativo.", @@ -179,6 +183,8 @@ OC.L10N.register( "Improving the config.php" : "Ottimizzare il config.php", "Theming" : "Temi", "Hardening and security guidance" : "Guida alla messa in sicurezza", + "Experimental File Lock is enabled." : "Il blocco file sperimentale è abilitato.", + "Experimental File Lock is disabled." : "Il blocco file sperimentale è disabilitato.", "Version" : "Versione", "Developer documentation" : "Documentazione dello sviluppatore", "Experimental applications ahead" : "Prima le applicazioni sperimentali", diff --git a/settings/l10n/it.json b/settings/l10n/it.json index e13c850885a..dc7a563e9f6 100644 --- a/settings/l10n/it.json +++ b/settings/l10n/it.json @@ -6,6 +6,7 @@ "Cron" : "Cron", "Email server" : "Server di posta", "Log" : "Log", + "Server Status" : "Stato del server", "Tips & tricks" : "Suggerimenti e trucchi", "Updates" : "Aggiornamenti", "Authentication error" : "Errore di autenticazione", @@ -51,6 +52,9 @@ "Migration in progress. Please wait until the migration is finished" : "Migrazione in corso. Attendi fino al completamento della migrazione", "Migration started …" : "Migrazione avviata...", "Sending..." : "Invio in corso...", + "Official" : "Ufficiale", + "Approved" : "Approvata", + "Experimental" : "Sperimentale", "All" : "Tutti", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Le applicazioni ufficiali sono sviluppate da e con la comunità di ownCloud. Offrono le funzioni fondamentali di ownCloud e sono pronte per l'utilizzo in produzione.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Le applicazioni approvate sono sviluppate da sviluppatori affidabili e hanno passato un rapido controllo di sicurezza. Sono attivamente mantenute in un deposito aperto del codice e i loro responsabili le ritengono pronte sia per un utilizzo casuale che per un utilizzo continuativo.", @@ -177,6 +181,8 @@ "Improving the config.php" : "Ottimizzare il config.php", "Theming" : "Temi", "Hardening and security guidance" : "Guida alla messa in sicurezza", + "Experimental File Lock is enabled." : "Il blocco file sperimentale è abilitato.", + "Experimental File Lock is disabled." : "Il blocco file sperimentale è disabilitato.", "Version" : "Versione", "Developer documentation" : "Documentazione dello sviluppatore", "Experimental applications ahead" : "Prima le applicazioni sperimentali", diff --git a/settings/l10n/pt_BR.js b/settings/l10n/pt_BR.js index b4904d1412c..cf0bc409318 100644 --- a/settings/l10n/pt_BR.js +++ b/settings/l10n/pt_BR.js @@ -8,6 +8,7 @@ OC.L10N.register( "Cron" : "Cron", "Email server" : "Servidor de Email", "Log" : "Registro", + "Server Status" : "Status do Servidor", "Tips & tricks" : "Dicas & Truques", "Updates" : "Atualizações", "Authentication error" : "Erro de autenticação", @@ -53,6 +54,9 @@ OC.L10N.register( "Migration in progress. Please wait until the migration is finished" : "Migração em progresso. Por favor aguarde até que a migração seja finalizada", "Migration started …" : "Migração iniciada ...", "Sending..." : "Enviando...", + "Official" : "Oficial", + "Approved" : "Aprovado", + "Experimental" : "Experimental", "All" : "Todos", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Aplicativos oficiais são desenvolvidos por e dentro da comunidade ownCloud. Eles oferecem funcionalidade central para ownCloud e estão prontos para uso em produção.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Aplicativos aprovados são desenvolvidos pelos desenvolvedores confiáveis e passaram por uma verificação de segurança superficial. Eles são ativamente mantidos em um repositório de código aberto e seus mantenedores consideram que eles para sejam estáveis para um casual uso normal.", @@ -179,6 +183,8 @@ OC.L10N.register( "Improving the config.php" : "Melhorando o config.php", "Theming" : "Elaborar um tema", "Hardening and security guidance" : "Orientações de proteção e segurança", + "Experimental File Lock is enabled." : "Bloqueio de Arquivo Experimental está habilitado.", + "Experimental File Lock is disabled." : "Bloqueio de Arquivo Experimental está desativado.", "Version" : "Versão", "Developer documentation" : "Documentação do desenvolvedor", "Experimental applications ahead" : "Aplicações experimentais à frente", diff --git a/settings/l10n/pt_BR.json b/settings/l10n/pt_BR.json index 735620e3b7f..ad62c0afced 100644 --- a/settings/l10n/pt_BR.json +++ b/settings/l10n/pt_BR.json @@ -6,6 +6,7 @@ "Cron" : "Cron", "Email server" : "Servidor de Email", "Log" : "Registro", + "Server Status" : "Status do Servidor", "Tips & tricks" : "Dicas & Truques", "Updates" : "Atualizações", "Authentication error" : "Erro de autenticação", @@ -51,6 +52,9 @@ "Migration in progress. Please wait until the migration is finished" : "Migração em progresso. Por favor aguarde até que a migração seja finalizada", "Migration started …" : "Migração iniciada ...", "Sending..." : "Enviando...", + "Official" : "Oficial", + "Approved" : "Aprovado", + "Experimental" : "Experimental", "All" : "Todos", "Official apps are developed by and within the ownCloud community. They offer functionality central to ownCloud and are ready for production use." : "Aplicativos oficiais são desenvolvidos por e dentro da comunidade ownCloud. Eles oferecem funcionalidade central para ownCloud e estão prontos para uso em produção.", "Approved apps are developed by trusted developers and have passed a cursory security check. They are actively maintained in an open code repository and their maintainers deem them to be stable for casual to normal use." : "Aplicativos aprovados são desenvolvidos pelos desenvolvedores confiáveis e passaram por uma verificação de segurança superficial. Eles são ativamente mantidos em um repositório de código aberto e seus mantenedores consideram que eles para sejam estáveis para um casual uso normal.", @@ -177,6 +181,8 @@ "Improving the config.php" : "Melhorando o config.php", "Theming" : "Elaborar um tema", "Hardening and security guidance" : "Orientações de proteção e segurança", + "Experimental File Lock is enabled." : "Bloqueio de Arquivo Experimental está habilitado.", + "Experimental File Lock is disabled." : "Bloqueio de Arquivo Experimental está desativado.", "Version" : "Versão", "Developer documentation" : "Documentação do desenvolvedor", "Experimental applications ahead" : "Aplicações experimentais à frente", diff --git a/settings/templates/admin.php b/settings/templates/admin.php index 3d253d4cbbd..fb6ef9b3e77 100644 --- a/settings/templates/admin.php +++ b/settings/templates/admin.php @@ -106,11 +106,11 @@ if ($_['WindowsWarning']) { <?php } -// APCU Warning if outdated -if ($_['ApcuOutdatedWarning']) { +// Warning if memcache is outdated +foreach ($_['OutdatedCacheWarning'] as $php_module => $data) { ?> <li> - <?php p($l->t('APCu below version 4.0.6 is installed, for stability and performance reasons we recommend to update to a newer APCu version.')); ?> + <?php p($l->t('%1$s below version %2$s is installed, for stability and performance reasons we recommend to update to a newer %1$s version.', $data)); ?> </li> <?php } diff --git a/tests/core/command/encryption/disabletest.php b/tests/core/command/encryption/disabletest.php index 26c814a9c4e..dfd06e2e26e 100644 --- a/tests/core/command/encryption/disabletest.php +++ b/tests/core/command/encryption/disabletest.php @@ -80,6 +80,6 @@ class DisableTest extends TestCase { ->with('core', 'encryption_enabled', 'no'); } - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } } diff --git a/tests/core/command/encryption/enabletest.php b/tests/core/command/encryption/enabletest.php index 377d0e2a528..e2357464aa1 100644 --- a/tests/core/command/encryption/enabletest.php +++ b/tests/core/command/encryption/enabletest.php @@ -114,6 +114,6 @@ class EnableTest extends TestCase { ->method('writeln') ->with($this->stringContains($expectedDefaultModuleString)); - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } } diff --git a/tests/core/command/encryption/setdefaultmoduletest.php b/tests/core/command/encryption/setdefaultmoduletest.php index e2a61dd10f6..3230a57db07 100644 --- a/tests/core/command/encryption/setdefaultmoduletest.php +++ b/tests/core/command/encryption/setdefaultmoduletest.php @@ -87,6 +87,6 @@ class SetDefaultModuleTest extends TestCase { ->method('writeln') ->with($this->stringContains($expectedString)); - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } } diff --git a/tests/core/command/user/deletetest.php b/tests/core/command/user/deletetest.php index bfcf031b719..99822ec6589 100644 --- a/tests/core/command/user/deletetest.php +++ b/tests/core/command/user/deletetest.php @@ -83,7 +83,7 @@ class DeleteTest extends TestCase { ->method('writeln') ->with($this->stringContains($expectedString)); - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } public function testInvalidUser() { @@ -101,6 +101,6 @@ class DeleteTest extends TestCase { ->method('writeln') ->with($this->stringContains('User does not exist')); - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } } diff --git a/tests/core/command/user/lastseentest.php b/tests/core/command/user/lastseentest.php index 7eda6fb27ed..84805f5c072 100644 --- a/tests/core/command/user/lastseentest.php +++ b/tests/core/command/user/lastseentest.php @@ -82,7 +82,7 @@ class LastSeenTest extends TestCase { ->method('writeln') ->with($this->stringContains($expectedString)); - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } public function testInvalidUser() { @@ -100,6 +100,6 @@ class LastSeenTest extends TestCase { ->method('writeln') ->with($this->stringContains('User does not exist')); - \Test_Helper::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); + self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]); } } diff --git a/tests/lib/activitymanager.php b/tests/lib/activitymanager.php index d3263fa2ede..a35daeaf494 100644 --- a/tests/lib/activitymanager.php +++ b/tests/lib/activitymanager.php @@ -156,7 +156,7 @@ class Test_ActivityManager extends \Test\TestCase { */ public function testGetUserFromTokenThrowInvalidToken($token, $users) { $this->mockRSSToken($token, $token, $users); - \Test_Helper::invokePrivate($this->activityManager, 'getUserFromToken'); + self::invokePrivate($this->activityManager, 'getUserFromToken'); } public function getUserFromTokenData() { diff --git a/tests/lib/appframework/http/RequestTest.php b/tests/lib/appframework/http/RequestTest.php index 282d13a3397..a4bf3519bfc 100644 --- a/tests/lib/appframework/http/RequestTest.php +++ b/tests/lib/appframework/http/RequestTest.php @@ -797,7 +797,7 @@ class RequestTest extends \Test\TestCase { $this->stream ); - $this->assertNull(\Test_Helper::invokePrivate($request, 'getOverwriteHost')); + $this->assertNull(self::invokePrivate($request, 'getOverwriteHost')); } public function testGetOverwriteHostWithOverwrite() { @@ -824,7 +824,7 @@ class RequestTest extends \Test\TestCase { $this->stream ); - $this->assertSame('www.owncloud.org', \Test_Helper::invokePrivate($request, 'getOverwriteHost')); + $this->assertSame('www.owncloud.org', self::invokePrivate($request, 'getOverwriteHost')); } public function testGetPathInfoWithSetEnv() { diff --git a/tests/lib/appframework/middleware/security/CORSMiddlewareTest.php b/tests/lib/appframework/middleware/security/CORSMiddlewareTest.php index 92ea5450ab9..5c93c95e188 100644 --- a/tests/lib/appframework/middleware/security/CORSMiddlewareTest.php +++ b/tests/lib/appframework/middleware/security/CORSMiddlewareTest.php @@ -121,6 +121,13 @@ class CORSMiddlewareTest extends \Test\TestCase { ); $this->reflector->reflect($this, __FUNCTION__); $middleware = new CORSMiddleware($request, $this->reflector, $this->session); + $this->session->expects($this->never()) + ->method('logout'); + $this->session->expects($this->never()) + ->method('login') + ->with($this->equalTo('user'), $this->equalTo('pass')) + ->will($this->returnValue(true)); + $this->reflector->reflect($this, __FUNCTION__); $middleware->beforeController($this, __FUNCTION__, new Response()); } diff --git a/tests/lib/encryption/keys/storage.php b/tests/lib/encryption/keys/storage.php index 45cd272cca0..8af3821dc93 100644 --- a/tests/lib/encryption/keys/storage.php +++ b/tests/lib/encryption/keys/storage.php @@ -361,7 +361,46 @@ class StorageTest extends TestCase { array('/user1/files/source.txt', '/user1/files/target.txt', true, false, '/files_encryption/keys/files/source.txt/', '/user1/files_encryption/keys/files/target.txt/'), + array('/user2/files/source.txt', '/user1/files/target.txt', false, false, + '/user2/files_encryption/keys/files/source.txt/', '/user1/files_encryption/keys/files/target.txt/'), + array('/user2/files/foo/source.txt', '/user1/files/target.txt', false, false, + '/user2/files_encryption/keys/files/foo/source.txt/', '/user1/files_encryption/keys/files/target.txt/'), + array('/user2/files/source.txt', '/user1/files/foo/target.txt', false, false, + '/user2/files_encryption/keys/files/source.txt/', '/user1/files_encryption/keys/files/foo/target.txt/'), + array('/user2/files/source.txt', '/user1/files/foo/target.txt', true, true, + '/files_encryption/keys/files/source.txt/', '/files_encryption/keys/files/foo/target.txt/'), + array('/user2/files/source.txt', '/user1/files/target.txt', false, true, + '/user2/files_encryption/keys/files/source.txt/', '/files_encryption/keys/files/target.txt/'), + array('/user2/files/source.txt', '/user1/files/target.txt', true, false, + '/files_encryption/keys/files/source.txt/', '/user1/files_encryption/keys/files/target.txt/'), + ); + } + /** + * @dataProvider dataTestGetPathToKeys + * + * @param string $path + * @param boolean $systemWideMountPoint + * @param string $expected + */ + public function testGetPathToKeys($path, $systemWideMountPoint, $expected) { + + $this->util->expects($this->any()) + ->method('getUidAndFilename') + ->will($this->returnCallback(array($this, 'getUidAndFilenameCallback'))); + $this->util->expects($this->any()) + ->method('isSystemWideMountPoint') + ->willReturn($systemWideMountPoint); + + $this->assertSame($expected, + self::invokePrivate($this->storage, 'getPathToKeys', [$path]) + ); + } + + public function dataTestGetPathToKeys() { + return array( + array('/user1/files/source.txt', false, '/user1/files_encryption/keys/files/source.txt/'), + array('/user1/files/source.txt', true, '/files_encryption/keys/files/source.txt/') ); } @@ -382,7 +421,7 @@ class StorageTest extends TestCase { '/user1/files_encryption', '/user1'); - \Test_Helper::invokePrivate($this->storage, 'keySetPreparation', array('/user1/files_encryption/keys/foo')); + self::invokePrivate($this->storage, 'keySetPreparation', array('/user1/files_encryption/keys/foo')); } public function mkdirCallback() { diff --git a/tests/lib/encryption/managertest.php b/tests/lib/encryption/managertest.php index 3b1e07ffd69..9af7bc2c134 100644 --- a/tests/lib/encryption/managertest.php +++ b/tests/lib/encryption/managertest.php @@ -81,7 +81,7 @@ class ManagerTest extends TestCase { /** * @expectedException \OC\Encryption\Exceptions\ModuleDoesNotExistsException - * @expectedExceptionMessage Module with id: unknown does not exists. + * @expectedExceptionMessage Module with id: unknown does not exist. */ public function testGetEncryptionModuleUnknown() { $this->config->expects($this->any())->method('getAppValue')->willReturn(true); @@ -127,7 +127,7 @@ class ManagerTest extends TestCase { $en0 = $this->manager->getEncryptionModule('ID0'); $this->assertEquals('ID0', $en0->getId()); - $en0 = \Test_Helper::invokePrivate($this->manager, 'getDefaultEncryptionModule'); + $en0 = self::invokePrivate($this->manager, 'getDefaultEncryptionModule'); $this->assertEquals('ID0', $en0->getId()); $this->assertEquals('ID0', $this->manager->getDefaultEncryptionModuleId()); @@ -195,7 +195,7 @@ class ManagerTest extends TestCase { // // /** // * @expectedException \OC\Encryption\Exceptions\ModuleDoesNotExistsException -// * @expectedExceptionMessage Module with id: unknown does not exists. +// * @expectedExceptionMessage Module with id: unknown does not exist. // */ // public function testGetEncryptionModuleUnknown() { // $config = $this->getMock('\OCP\IConfig'); diff --git a/tests/lib/encryption/utiltest.php b/tests/lib/encryption/utiltest.php index d3a4e211daa..d5f5ce4c2e9 100644 --- a/tests/lib/encryption/utiltest.php +++ b/tests/lib/encryption/utiltest.php @@ -194,4 +194,49 @@ class UtilTest extends TestCase { ); } + /** + * @dataProvider provideWrapStorage + */ + public function testWrapStorage($expectedWrapped, $wrappedStorages) { + $storage = $this->getMockBuilder('OC\Files\Storage\Storage') + ->disableOriginalConstructor() + ->getMock(); + + foreach ($wrappedStorages as $wrapper) { + $storage->expects($this->any()) + ->method('instanceOfStorage') + ->willReturnMap([ + [$wrapper, true], + ]); + } + + $mount = $this->getMockBuilder('OCP\Files\Mount\IMountPoint') + ->disableOriginalConstructor() + ->getMock(); + + $returnedStorage = $this->util->wrapStorage('mountPoint', $storage, $mount); + + $this->assertEquals( + $expectedWrapped, + $returnedStorage->instanceOfStorage('OC\Files\Storage\Wrapper\Encryption'), + 'Asserted that the storage is (not) wrapped with encryption' + ); + } + + public function provideWrapStorage() { + return [ + // Wrap when not wrapped or not wrapped with storage + [true, []], + [true, ['OCA\Files_Trashbin\Storage']], + + // Do not wrap shared storages + [false, ['OC\Files\Storage\Shared']], + [false, ['OCA\Files_Sharing\External\Storage']], + [false, ['OC\Files\Storage\OwnCloud']], + [false, ['OC\Files\Storage\Shared', 'OCA\Files_Sharing\External\Storage']], + [false, ['OC\Files\Storage\Shared', 'OC\Files\Storage\OwnCloud']], + [false, ['OCA\Files_Sharing\External\Storage', 'OC\Files\Storage\OwnCloud']], + [false, ['OC\Files\Storage\Shared', 'OCA\Files_Sharing\External\Storage', 'OC\Files\Storage\OwnCloud']], + ]; + } } diff --git a/tests/lib/files/pathverificationtest.php b/tests/lib/files/pathverificationtest.php index 65342c7799e..b59aceba7b1 100644 --- a/tests/lib/files/pathverificationtest.php +++ b/tests/lib/files/pathverificationtest.php @@ -94,7 +94,7 @@ class PathVerification extends \Test\TestCase { $storage = new Local(['datadir' => '']); $fileName = " 123{$fileName}456 "; - \Test_Helper::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); + self::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); } public function providesInvalidCharsWindows() { @@ -151,7 +151,7 @@ class PathVerification extends \Test\TestCase { $storage = new Local(['datadir' => '']); $fileName = " 123{$fileName}456 "; - \Test_Helper::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); + self::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); } public function providesInvalidCharsPosix() { @@ -200,7 +200,7 @@ class PathVerification extends \Test\TestCase { public function testPathVerificationReservedNamesWindows($fileName) { $storage = new Local(['datadir' => '']); - \Test_Helper::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); + self::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); } public function providesReservedNamesWindows() { @@ -236,8 +236,8 @@ class PathVerification extends \Test\TestCase { public function testPathVerificationValidPaths($fileName) { $storage = new Local(['datadir' => '']); - \Test_Helper::invokePrivate($storage, 'verifyPosixPath', [$fileName]); - \Test_Helper::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); + self::invokePrivate($storage, 'verifyPosixPath', [$fileName]); + self::invokePrivate($storage, 'verifyWindowsPath', [$fileName]); // nothing thrown $this->assertTrue(true); } diff --git a/tests/lib/files/storage/wrapper/encryption.php b/tests/lib/files/storage/wrapper/encryption.php index d286978d926..520091df42d 100644 --- a/tests/lib/files/storage/wrapper/encryption.php +++ b/tests/lib/files/storage/wrapper/encryption.php @@ -355,7 +355,7 @@ class Encryption extends \Test\Files\Storage\Storage { } $this->assertSame($expected, - \Test_Helper::invokePrivate($this->instance, 'copyKeys', ['/source', '/target']) + self::invokePrivate($this->instance, 'copyKeys', ['/source', '/target']) ); } diff --git a/tests/lib/helper.php b/tests/lib/helper.php index 03c6dacde64..bd527de160d 100644 --- a/tests/lib/helper.php +++ b/tests/lib/helper.php @@ -509,28 +509,9 @@ class Test_Helper extends \Test\TestCase { * @param $methodName * @param array $parameters * @return mixed + * @deprecated Please extend \Test\TestCase and use self::invokePrivate() then */ public static function invokePrivate($object, $methodName, array $parameters = array()) { - $reflection = new ReflectionClass(get_class($object)); - - if ($reflection->hasMethod($methodName)) { - $method = $reflection->getMethod($methodName); - - $method->setAccessible(true); - - return $method->invokeArgs($object, $parameters); - } elseif ($reflection->hasProperty($methodName)) { - $property = $reflection->getProperty($methodName); - - $property->setAccessible(true); - - if (!empty($parameters)) { - $property->setValue($object, array_pop($parameters)); - } - - return $property->getValue($object); - } - - return false; + return parent::invokePrivate($object, $methodName, $parameters); } } diff --git a/tests/lib/http/client/clienttest.php b/tests/lib/http/client/clienttest.php index bd909769b09..c76fe0532a7 100644 --- a/tests/lib/http/client/clienttest.php +++ b/tests/lib/http/client/clienttest.php @@ -47,7 +47,7 @@ class ClientTest extends \Test\TestCase { ->method('getSystemValue') ->with('proxyuserpwd', null) ->willReturn(null); - $this->assertSame('', \Test_Helper::invokePrivate($this->client, 'getProxyUri')); + $this->assertSame('', self::invokePrivate($this->client, 'getProxyUri')); } public function testGetProxyUriProxyHostEmptyPassword() { @@ -61,7 +61,7 @@ class ClientTest extends \Test\TestCase { ->method('getSystemValue') ->with('proxyuserpwd', null) ->willReturn(null); - $this->assertSame('foo', \Test_Helper::invokePrivate($this->client, 'getProxyUri')); + $this->assertSame('foo', self::invokePrivate($this->client, 'getProxyUri')); } public function testGetProxyUriProxyHostWithPassword() { @@ -75,7 +75,7 @@ class ClientTest extends \Test\TestCase { ->method('getSystemValue') ->with('proxyuserpwd', null) ->willReturn('username:password'); - $this->assertSame('username:password@foo', \Test_Helper::invokePrivate($this->client, 'getProxyUri')); + $this->assertSame('username:password@foo', self::invokePrivate($this->client, 'getProxyUri')); } public function testGet() { diff --git a/tests/lib/mail/mailer.php b/tests/lib/mail/mailer.php index 7e5e689741a..21565f9ffb5 100644 --- a/tests/lib/mail/mailer.php +++ b/tests/lib/mail/mailer.php @@ -35,7 +35,7 @@ class MailerTest extends TestCase { } public function testGetMailInstance() { - $this->assertEquals(\Swift_MailTransport::newInstance(), \Test_Helper::invokePrivate($this->mailer, 'getMailinstance')); + $this->assertEquals(\Swift_MailTransport::newInstance(), self::invokePrivate($this->mailer, 'getMailinstance')); } public function testGetSendMailInstanceSendMail() { @@ -45,7 +45,7 @@ class MailerTest extends TestCase { ->with('mail_smtpmode', 'sendmail') ->will($this->returnValue('sendmail')); - $this->assertEquals(\Swift_SendmailTransport::newInstance('/usr/sbin/sendmail -bs'), \Test_Helper::invokePrivate($this->mailer, 'getSendMailInstance')); + $this->assertEquals(\Swift_SendmailTransport::newInstance('/usr/sbin/sendmail -bs'), self::invokePrivate($this->mailer, 'getSendMailInstance')); } public function testGetSendMailInstanceSendMailQmail() { @@ -55,11 +55,11 @@ class MailerTest extends TestCase { ->with('mail_smtpmode', 'sendmail') ->will($this->returnValue('qmail')); - $this->assertEquals(\Swift_SendmailTransport::newInstance('/var/qmail/bin/sendmail -bs'), \Test_Helper::invokePrivate($this->mailer, 'getSendMailInstance')); + $this->assertEquals(\Swift_SendmailTransport::newInstance('/var/qmail/bin/sendmail -bs'), self::invokePrivate($this->mailer, 'getSendMailInstance')); } public function testGetInstanceDefault() { - $this->assertInstanceOf('\Swift_MailTransport', \Test_Helper::invokePrivate($this->mailer, 'getInstance')); + $this->assertInstanceOf('\Swift_MailTransport', self::invokePrivate($this->mailer, 'getInstance')); } public function testGetInstancePhp() { @@ -68,7 +68,7 @@ class MailerTest extends TestCase { ->method('getSystemValue') ->will($this->returnValue('php')); - $this->assertInstanceOf('\Swift_MailTransport', \Test_Helper::invokePrivate($this->mailer, 'getInstance')); + $this->assertInstanceOf('\Swift_MailTransport', self::invokePrivate($this->mailer, 'getInstance')); } public function testGetInstanceSendmail() { @@ -77,7 +77,7 @@ class MailerTest extends TestCase { ->method('getSystemValue') ->will($this->returnValue('sendmail')); - $this->assertInstanceOf('\Swift_SendmailTransport', \Test_Helper::invokePrivate($this->mailer, 'getInstance')); + $this->assertInstanceOf('\Swift_SendmailTransport', self::invokePrivate($this->mailer, 'getInstance')); } public function testCreateMessage() { diff --git a/tests/lib/mail/message.php b/tests/lib/mail/message.php index c75cc18b650..8ee3c33627c 100644 --- a/tests/lib/mail/message.php +++ b/tests/lib/mail/message.php @@ -42,7 +42,7 @@ class MessageTest extends TestCase { * @dataProvider mailAddressProvider */ public function testConvertAddresses($unconverted, $expected) { - $this->assertSame($expected, \Test_Helper::invokePrivate($this->message, 'convertAddresses', array($unconverted))); + $this->assertSame($expected, self::invokePrivate($this->message, 'convertAddresses', array($unconverted))); } public function testSetFrom() { diff --git a/tests/lib/ocsclienttest.php b/tests/lib/ocsclienttest.php index f4bf1536291..ca8a2a2a2e8 100644 --- a/tests/lib/ocsclienttest.php +++ b/tests/lib/ocsclienttest.php @@ -76,7 +76,7 @@ class OCSClientTest extends \Test\TestCase { ->method('getSystemValue') ->with('appstoreurl', 'https://api.owncloud.com/v1') ->will($this->returnValue('https://api.owncloud.com/v1')); - $this->assertSame('https://api.owncloud.com/v1', Test_Helper::invokePrivate($this->ocsClient, 'getAppStoreUrl')); + $this->assertSame('https://api.owncloud.com/v1', self::invokePrivate($this->ocsClient, 'getAppStoreUrl')); } public function testGetCategoriesDisabledAppStore() { diff --git a/tests/lib/repair/cleantags.php b/tests/lib/repair/cleantags.php index 75bbbd07503..b455aa870fb 100644 --- a/tests/lib/repair/cleantags.php +++ b/tests/lib/repair/cleantags.php @@ -64,15 +64,15 @@ class CleanTags extends \Test\TestCase { $this->assertEntryCount('*PREFIX*vcategory_to_object', 4, 'Assert tag entries count before repair step'); $this->assertEntryCount('*PREFIX*vcategory', 4, 'Assert tag categories count before repair step'); - \Test_Helper::invokePrivate($this->repair, 'deleteOrphanFileEntries'); + self::invokePrivate($this->repair, 'deleteOrphanFileEntries'); $this->assertEntryCount('*PREFIX*vcategory_to_object', 3, 'Assert tag entries count after cleaning file entries'); $this->assertEntryCount('*PREFIX*vcategory', 4, 'Assert tag categories count after cleaning file entries'); - \Test_Helper::invokePrivate($this->repair, 'deleteOrphanTagEntries'); + self::invokePrivate($this->repair, 'deleteOrphanTagEntries'); $this->assertEntryCount('*PREFIX*vcategory_to_object', 2, 'Assert tag entries count after cleaning tag entries'); $this->assertEntryCount('*PREFIX*vcategory', 4, 'Assert tag categories count after cleaning tag entries'); - \Test_Helper::invokePrivate($this->repair, 'deleteOrphanCategoryEntries'); + self::invokePrivate($this->repair, 'deleteOrphanCategoryEntries'); $this->assertEntryCount('*PREFIX*vcategory_to_object', 2, 'Assert tag entries count after cleaning category entries'); $this->assertEntryCount('*PREFIX*vcategory', 2, 'Assert tag categories count after cleaning category entries'); } diff --git a/tests/lib/security/hasher.php b/tests/lib/security/hasher.php index 330789c67a0..a6f7df5b79f 100644 --- a/tests/lib/security/hasher.php +++ b/tests/lib/security/hasher.php @@ -11,7 +11,7 @@ use OC\Security\Hasher; /** * Class HasherTest */ -class HasherTest extends \PHPUnit_Framework_TestCase { +class HasherTest extends \Test\TestCase { /** * @return array @@ -70,14 +70,15 @@ class HasherTest extends \PHPUnit_Framework_TestCase { ); } - - /** @var Hasher */ protected $hasher; + /** @var \OCP\IConfig */ protected $config; protected function setUp() { + parent::setUp(); + $this->config = $this->getMockBuilder('\OCP\IConfig') ->disableOriginalConstructor()->getMock(); @@ -93,7 +94,7 @@ class HasherTest extends \PHPUnit_Framework_TestCase { * @dataProvider versionHashProvider */ function testSplitHash($hash, $expected) { - $relativePath = \Test_Helper::invokePrivate($this->hasher, 'splitHash', array($hash)); + $relativePath = self::invokePrivate($this->hasher, 'splitHash', array($hash)); $this->assertSame($expected, $relativePath); } diff --git a/tests/lib/setup.php b/tests/lib/setup.php index caaeec08fb3..79ca0c0be90 100644 --- a/tests/lib/setup.php +++ b/tests/lib/setup.php @@ -120,7 +120,7 @@ class Test_OC_Setup extends \Test\TestCase { * If it hasn't this test will fail. */ public function testHtaccessIsCurrent() { - $result = Test_Helper::invokePrivate( + $result = self::invokePrivate( $this->setupClass, 'isCurrentHtaccess' ); diff --git a/tests/lib/share/share.php b/tests/lib/share/share.php index 5909102f797..f03ed43e7fc 100644 --- a/tests/lib/share/share.php +++ b/tests/lib/share/share.php @@ -1051,7 +1051,7 @@ class Test_Share extends \Test\TestCase { */ function testRemoveProtocolFromUrl($url, $expectedResult) { $share = new \OC\Share\Share(); - $result = \Test_Helper::invokePrivate($share, 'removeProtocolFromUrl', array($url)); + $result = self::invokePrivate($share, 'removeProtocolFromUrl', array($url)); $this->assertSame($expectedResult, $result); } diff --git a/tests/lib/tempmanager.php b/tests/lib/tempmanager.php index 72741d0dec6..0fa025d44c8 100644 --- a/tests/lib/tempmanager.php +++ b/tests/lib/tempmanager.php @@ -154,7 +154,7 @@ class TempManager extends \Test\TestCase { public function testBuildFileNameWithPostfix() { $logger = $this->getMock('\Test\NullLogger'); - $tmpManager = \Test_Helper::invokePrivate( + $tmpManager = self::invokePrivate( $this->getManager($logger), 'buildFileNameWithSuffix', ['/tmp/myTemporaryFile', 'postfix'] @@ -165,7 +165,7 @@ class TempManager extends \Test\TestCase { public function testBuildFileNameWithoutPostfix() { $logger = $this->getMock('\Test\NullLogger'); - $tmpManager = \Test_Helper::invokePrivate( + $tmpManager = self::invokePrivate( $this->getManager($logger), 'buildFileNameWithSuffix', ['/tmp/myTemporaryFile', ''] @@ -176,7 +176,7 @@ class TempManager extends \Test\TestCase { public function testBuildFileNameWithSuffixPathTraversal() { $logger = $this->getMock('\Test\NullLogger'); - $tmpManager = \Test_Helper::invokePrivate( + $tmpManager = self::invokePrivate( $this->getManager($logger), 'buildFileNameWithSuffix', ['foo', '../Traversal\\../FileName'] diff --git a/tests/lib/testcase.php b/tests/lib/testcase.php index d8595c83a91..8551edab71f 100644 --- a/tests/lib/testcase.php +++ b/tests/lib/testcase.php @@ -50,6 +50,38 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase { } /** + * Allows us to test private methods/properties + * + * @param $object + * @param $methodName + * @param array $parameters + * @return mixed + */ + protected static function invokePrivate($object, $methodName, array $parameters = array()) { + $reflection = new \ReflectionClass(get_class($object)); + + if ($reflection->hasMethod($methodName)) { + $method = $reflection->getMethod($methodName); + + $method->setAccessible(true); + + return $method->invokeArgs($object, $parameters); + } elseif ($reflection->hasProperty($methodName)) { + $property = $reflection->getProperty($methodName); + + $property->setAccessible(true); + + if (!empty($parameters)) { + $property->setValue($object, array_pop($parameters)); + } + + return $property->getValue($object); + } + + return false; + } + + /** * Returns a unique identifier as uniqid() is not reliable sometimes * * @param string $prefix diff --git a/tests/settings/controller/CheckSetupControllerTest.php b/tests/settings/controller/CheckSetupControllerTest.php index b21e78c831d..b39d13ac26b 100644 --- a/tests/settings/controller/CheckSetupControllerTest.php +++ b/tests/settings/controller/CheckSetupControllerTest.php @@ -81,7 +81,7 @@ class CheckSetupControllerTest extends TestCase { ->will($this->returnValue(false)); $this->assertFalse( - \Test_Helper::invokePrivate( + self::invokePrivate( $this->checkSetupController, 'isInternetConnectionWorking' ) @@ -109,7 +109,7 @@ class CheckSetupControllerTest extends TestCase { $this->assertTrue( - \Test_Helper::invokePrivate( + self::invokePrivate( $this->checkSetupController, 'isInternetConnectionWorking' ) @@ -134,7 +134,7 @@ class CheckSetupControllerTest extends TestCase { ->will($this->returnValue($client)); $this->assertFalse( - \Test_Helper::invokePrivate( + self::invokePrivate( $this->checkSetupController, 'isInternetConnectionWorking' ) @@ -162,7 +162,7 @@ class CheckSetupControllerTest extends TestCase { ->will($this->returnValue($client)); $this->assertFalse( - \Test_Helper::invokePrivate( + self::invokePrivate( $this->checkSetupController, 'isInternetConnectionWorking' ) @@ -176,7 +176,7 @@ class CheckSetupControllerTest extends TestCase { ->will($this->returnValue(null)); $this->assertFalse( - \Test_Helper::invokePrivate( + self::invokePrivate( $this->checkSetupController, 'isMemcacheConfigured' ) @@ -190,7 +190,7 @@ class CheckSetupControllerTest extends TestCase { ->will($this->returnValue('SomeProvider')); $this->assertTrue( - \Test_Helper::invokePrivate( + self::invokePrivate( $this->checkSetupController, 'isMemcacheConfigured' ) @@ -239,7 +239,7 @@ class CheckSetupControllerTest extends TestCase { 'dataDirectoryProtected' => true, 'isMemcacheConfigured' => true, 'memcacheDocs' => 'http://doc.owncloud.org/server/go.php?to=admin-performance', - 'isUrandomAvailable' => \Test_Helper::invokePrivate($this->checkSetupController, 'isUrandomAvailable'), + 'isUrandomAvailable' => self::invokePrivate($this->checkSetupController, 'isUrandomAvailable'), 'securityDocs' => 'https://doc.owncloud.org/server/8.1/admin_manual/configuration_server/hardening.html', ] ); diff --git a/tests/settings/controller/userscontrollertest.php b/tests/settings/controller/userscontrollertest.php index e70b235f603..5f98cf21c04 100644 --- a/tests/settings/controller/userscontrollertest.php +++ b/tests/settings/controller/userscontrollertest.php @@ -1290,7 +1290,7 @@ class UsersControllerTest extends \Test\TestCase { list($user, $expectedResult) = $this->mockUser(); - $result = \Test_Helper::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); + $result = self::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); $this->assertEquals($expectedResult, $result); } @@ -1327,7 +1327,7 @@ class UsersControllerTest extends \Test\TestCase { ) ->will($this->returnValue('1')); - $result = \Test_Helper::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); + $result = self::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); $this->assertEquals($expectedResult, $result); } @@ -1345,7 +1345,7 @@ class UsersControllerTest extends \Test\TestCase { $expectedResult['isRestoreDisabled'] = true; - $result = \Test_Helper::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); + $result = self::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); $this->assertEquals($expectedResult, $result); } @@ -1384,7 +1384,7 @@ class UsersControllerTest extends \Test\TestCase { $expectedResult['isRestoreDisabled'] = true; - $result = \Test_Helper::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); + $result = self::invokePrivate($this->container['UsersController'], 'formatUserForIndex', [$user]); $this->assertEquals($expectedResult, $result); } |