summaryrefslogtreecommitdiffstats
path: root/apps/encryption/l10n/bg.js
blob: 9d80ee86aa6b35b083a25c14c0a7634e17c5e85c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
OC.L10N.register(
    "encryption",
    {
    "Missing recovery key password" : "Липсва парола за възстановяване",
    "Please repeat the recovery key password" : "Повтори новата парола за възстановяване",
    "Repeated recovery key password does not match the provided recovery key password" : "Повторената парола за възстановяване не съвпада със зададената парола за възстановяване",
    "Recovery key successfully enabled" : "Успешно включване на опцията ключ за възстановяване.",
    "Could not enable recovery key. Please check your recovery key password!" : "Неуспешно включване на опцията ключ за възстановяване. Моля, провери паролата за ключа за възстановяване.",
    "Recovery key successfully disabled" : "Успешно изключване на ключа за възстановяване.",
    "Could not disable recovery key. Please check your recovery key password!" : "Неуспешно изключване на ключа за възстановяване. Моля, провери паролата за ключа за възстановяване!",
    "Missing parameters" : "Липсващи параметри",
    "Please provide the old recovery password" : "Моля, въведете старата парола за възстановяване",
    "Please provide a new recovery password" : "Моля, задай нова парола за възстановяване",
    "Please repeat the new recovery password" : "Моля, въведете новата парола за възстановяване отново",
    "Password successfully changed." : "Паролата е успешно променена.",
    "Could not change the password. Maybe the old password was not correct." : "Грешка при промяна на паролата. Може би старата ти парола е сгрешена.",
    "Recovery Key disabled" : "Изключване на ключа за възстановяване.",
    "Recovery Key enabled" : "Включване на ключа за възстановяване.",
    "Could not enable the recovery key, please try again or contact your administrator" : "Неуспешно активиране на ключа за възстановяване, моля, опитайте отново или се свържете с вашия администратор",
    "Could not update the private key password." : "Неуспешна промяна на паролата на личния ключ",
    "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." : "Успешно променена тайната парола за ключа.",
    "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." : "Програмата за криптиране е включена, но вашите ключове не са инициализирани. Моля отпишете си и се впишете отново.",
    "Please enable server side encryption in the admin settings in order to use the encryption module." : "Моля, активирайте сървърното криптиране в администраторските настройки, за да използвате модула за криптиране.",
    "Encryption app is enabled and ready" : "Приложението за шифроване е активирано и готово",
    "Bad Signature" : "Лош подпис",
    "Missing Signature" : "Липсва подпис",
    "one-time password for server-side-encryption" : "еднократна парола за криптиране от страна на сървъра",
    "Encryption password" : "Парола за криптиране",
    "The administration enabled server-side-encryption. Your files were encrypted using the password <strong>%s</strong>." : "Администрацията е активирала криптирането от страна на сървъра. Файловете ви бяха криптирани със следната парола <strong>%s</strong>",
    "The administration enabled server-side-encryption. Your files were encrypted using the password \"%s\"." : "Администрацията е активирала криптирането от страна на сървъра. Файловете ви са били криптирани с помощта на паролата „%s“",
    "Cannot decrypt this file, probably this is a shared file. Please ask the file owner to reshare the file with you." : "Файлът не може да бъде разшифрован, вероятно е споделен файл. Моля, помолете собственика на файла да го сподели повторно с вас.",
    "Cannot read this file, probably this is a shared file. Please ask the file owner to reshare the file with you." : "Файлът не може да бъде прочетен, вероятно е споделен файл. Моля, помолете собственика на файла да го сподели повторно с вас.",
    "Default encryption module" : "Модул за криптиране по подразбиране:",
    "Default encryption module for server-side encryption" : "Модул за криптиране по подразбиране за сървърно криптиране",
    "In order to use this encryption module you need to enable server-side encryption in the admin settings. Once enabled this module will encrypt all your files transparently. The encryption is based on AES 256 keys.\nThe module will not touch existing files, only new files will be encrypted after server-side encryption was enabled. It is also not possible to disable the encryption again and switch back to an unencrypted system.\nPlease read the documentation to know all implications before you decide to enable server-side encryption." : "За да използвате този модул за криптиране, трябва да активирате от страна на сървъра криптирането в администраторските настройки. След като бъде активиран, този модул ще шифрова всичките ви файлове прозрачно. Криптирането се базира на AES 256 ключове.\nМодулът няма да засяга съществуващи файлове, само новите файлове ще бъдат криптирани след активиране на криптиране от страна на сървъра. Също така не е възможно да деактивирате криптирането отново и да се върнете към нешифрована система.\nМоля, прочетете документацията, за да сте наясно за всички последици, преди да решите да активирате сървърното криптиране.",
    "Encryption app is enabled but your keys are not initialized, please log-out and log-in again" : "Приложението за криптиране е включено, но вашите ключове не са инициализирани. Моля отпишете си и се впишете отново.",
    "Encrypt the home storage" : "Шифровайте домашното хранилище",
    "Enabling this option encrypts all files stored on the main storage, otherwise only files on external storage will be encrypted" : "Активирането на тази опция криптира всички файлове, съхранявани в основното хранилище, в противен случай ще бъдат криптирани само файлове от външно хранилище",
    "Enable recovery key" : "Активиране на ключа за въстановяване:",
    "Disable recovery key" : "Изключване на въстановяването на ключа:",
    "The recovery key is an extra encryption key that is used to encrypt files. It allows recovery of a user's files if the user forgets his or her password." : "Ключът за възстановяване е допълнителен ключ за криптиране, който се използва за криптиране на файлове. Той позволява възстановяване на файлове на потребител, ако потребителят си забрави паролата.",
    "Recovery key password" : "Парола за възстановяане на ключа",
    "Repeat recovery key password" : "Повторение на паролата за възстановяане на ключа",
    "Change recovery key password:" : "Промени паролата за въстановяване на ключа:",
    "Old recovery key password" : "Стара парола за възстановяане на ключа",
    "New recovery key password" : "Нова парола за възстановяане на ключа",
    "Repeat new recovery key password" : "Повторение на новата парола за възстановяане на ключа",
    "Change Password" : "Промени Паролата",
    "Basic encryption module" : "Основен модул за криптиране",
    "Your private key password no longer matches your log-in password." : "Личният ви ключ не съвпада с паролата за вписване.",
    "Set your old private key password to your current log-in password:" : "Промени паролата за тайния ти включ на паролата за вписване:",
    " If you don't remember your old password you can ask your administrator to recover your files." : "Ако не помниш старата парола помоли администратора да възстанови файловете ти.",
    "Old log-in password" : "Стара парола за вписване",
    "Current log-in password" : "Текуща парола за вписване",
    "Update Private Key Password" : "Промени Тайната Парола за Ключа",
    "Enable password recovery:" : "Включи опцията възстановяване на паролата:",
    "Enabling this option will allow you to reobtain access to your encrypted files in case of password loss" : "Избирането на тази опция ще ти позволи да възстановиш достъпа си до файловете в случай на изгубена парола.",
    "Enabled" : "Включено",
    "Disabled" : "Изключено",
    "In order to use this encryption module you need to enable server-side\n\t\tencryption in the admin settings. Once enabled this module will encrypt\n\t\tall your files transparently. The encryption is based on AES 256 keys.\n\t\tThe module won't touch existing files, only new files will be encrypted\n\t\tafter server-side encryption was enabled. It is also not possible to\n\t\tdisable the encryption again and switch back to a unencrypted system.\n\t\tPlease read the documentation to know all implications before you decide\n\t\tto enable server-side encryption." : "За да използвате този модул за криптиране, трябва да активирате от страна на сървъра\nкриптирането в администраторските настройки. След като бъде активиран, този модул ще шифрова\nвсичките ви файлове прозрачно. Криптирането се основава на AES 256 ключове.\nМодулът няма да засяга съществуващи файлове, само новите файлове ще бъдат криптирани\nслед активиране на криптиране от страна на сървъра. Също така не е възможно да\nдеактивирайте криптирането отново и се върнете към нешифрована система.\nМоля, прочетете документацията, за да знаете всички последици, преди да решите\nда активирате сървърно криптиране.",
    "Hey there,\n\nThe administration enabled server-side-encryption. Your files were encrypted using the password \"%s\".\n\nPlease login to the web interface, go to the section \"Basic encryption module\" of your personal settings and update your encryption password by entering this password into the \"Old log-in password\" field and your current login-password.\n\n" : "Здравей,\n\nАдминистрацията активира шифроването от страна на сървъра. Файловете ви са криптирани със следната парола \"%s\".\n\nМоля да влезете в уеб интерфейса, да отидете в раздела „основен модул за криптиране“ на вашите лични настройки и да актуализирате паролата си за криптиране, като въведете тази парола в полето „стара парола за влизане“ и текущата парола за вход.\n\n",
    "The share will expire on %s." : "Споделянето ще изтече на %s.",
    "Cheers!" : "Поздрави!",
    "Hey there,<br><br>The administration enabled server-side-encryption. Your files were encrypted using the password <strong>%s</strong>.<br><br>Please login to the web interface, go to the section \"Basic encryption module\" of your personal settings and update your encryption password by entering this password into the \"Old log-in password\" field and your current login-password.<br><br>" : "Здравей, <br><br>Администрацията активира шифроването от страна на сървъра. Файловете ви са криптирани със следната парола <strong>%s</strong>.<br><br> Моля да влезете в уеб интерфейса, да отидете в раздела „основен модул за криптиране“ на вашите лични настройки и да актуализирате паролата си за криптиране, като въведете тази парола в полето „стара парола за влизане“ и текущата парола за вход. <br><br>",
    "Please login to the web interface, go to the \"Security\" section of your personal settings and update your encryption password by entering this password into the \"Old log-in password\" field and your current login-password." : "Моля, влезте в уеб интерфейса, отидете в раздел „Сигурност“ на личните си настройки и актуализирайте паролата си за криптиране, като въведете тази парола в полето „Стара парола за влизане“ и текущата си парола за влизане."
},
"nplurals=2; plural=(n != 1);");
() && $this->isCached($fileNameCSS, $app)) { // Inject icons vars css if any return $this->injectCssVariablesIfAny(); } try { $folder = $this->appData->getFolder($app); } catch (NotFoundException $e) { // creating css appdata folder $folder = $this->appData->newFolder($app); } $lockKey = $webDir . '/' . $fileNameSCSS; if (!$this->lockingCache->add($lockKey, 'locked!', 120)) { $retry = 0; sleep(1); while ($retry < 10) { if (!$this->variablesChanged() && $this->isCached($fileNameCSS, $app)) { // Inject icons vars css if any $this->lockingCache->remove($lockKey); $this->logger->debug('SCSSCacher: ' .$lockKey.' is now available after '.$retry.'s. Moving on...', ['app' => 'core']); return $this->injectCssVariablesIfAny(); } $this->logger->debug('SCSSCacher: scss cache file locked for '.$lockKey, ['app' => 'core']); sleep($retry); $retry++; } $this->logger->debug('SCSSCacher: Giving up scss caching for '.$lockKey, ['app' => 'core']); return false; } try { $cached = $this->cache($path, $fileNameCSS, $fileNameSCSS, $folder, $webDir); } catch (\Exception $e) { $this->lockingCache->remove($lockKey); throw $e; } // Cleaning lock $this->lockingCache->remove($lockKey); // Inject icons vars css if any if ($this->iconsCacher->getCachedCSS() && $this->iconsCacher->getCachedCSS()->getSize() > 0) { $this->iconsCacher->injectCss(); } return $cached; } /** * @param $appName * @param $fileName * @return ISimpleFile */ public function getCachedCSS(string $appName, string $fileName): ISimpleFile { $folder = $this->appData->getFolder($appName); $cachedFileName = $this->prependVersionPrefix($this->prependBaseurlPrefix($fileName), $appName); return $folder->getFile($cachedFileName); } /** * Check if the file is cached or not * @param string $fileNameCSS * @param string $app * @return boolean */ private function isCached(string $fileNameCSS, string $app) { $key = $this->config->getSystemValue('version') . '/' . $app . '/' . $fileNameCSS; // If the file mtime is more recent than our cached one, // let's consider the file is properly cached if ($cacheValue = $this->isCachedCache->get($key)) { if ($cacheValue > $this->timeFactory->getTime()) { return true; } } // Creating file cache if none for further checks try { $folder = $this->appData->getFolder($app); } catch (NotFoundException $e) { return false; } // Checking if file size is coherent // and if one of the css dependency changed try { $cachedFile = $folder->getFile($fileNameCSS); if ($cachedFile->getSize() > 0) { $depFileName = $fileNameCSS . '.deps'; $deps = $this->depsCache->get($folder->getName() . '-' . $depFileName); if ($deps === null) { $depFile = $folder->getFile($depFileName); $deps = $depFile->getContent(); // Set to memcache for next run $this->depsCache->set($folder->getName() . '-' . $depFileName, $deps); } $deps = json_decode($deps, true); foreach ((array) $deps as $file => $mtime) { if (!file_exists($file) || filemtime($file) > $mtime) { return false; } } $this->isCachedCache->set($key, $this->timeFactory->getTime() + 5 * 60); return true; } return false; } catch (NotFoundException $e) { return false; } } /** * Check if the variables file has changed * @return bool */ private function variablesChanged(): bool { $injectedVariables = $this->getInjectedVariables(); if ($this->config->getAppValue('core', 'theming.variables') !== md5($injectedVariables)) { $this->config->setAppValue('core', 'theming.variables', md5($injectedVariables)); $this->resetCache(); return true; } return false; } /** * Cache the file with AppData * * @param string $path * @param string $fileNameCSS * @param string $fileNameSCSS * @param ISimpleFolder $folder * @param string $webDir * @return boolean * @throws NotPermittedException */ private function cache(string $path, string $fileNameCSS, string $fileNameSCSS, ISimpleFolder $folder, string $webDir) { $scss = new Compiler(); $scss->setImportPaths([ $path, $this->serverRoot . '/core/css/' ]); // Continue after throw $scss->setIgnoreErrors(true); if ($this->config->getSystemValue('debug')) { // Debug mode $scss->setFormatter(Expanded::class); $scss->setLineNumberStyle(Compiler::LINE_COMMENTS); } else { // Compression $scss->setFormatter(Crunched::class); } try { $cachedfile = $folder->getFile($fileNameCSS); } catch (NotFoundException $e) { $cachedfile = $folder->newFile($fileNameCSS); } $depFileName = $fileNameCSS . '.deps'; try { $depFile = $folder->getFile($depFileName); } catch (NotFoundException $e) { $depFile = $folder->newFile($depFileName); } // Compile try { $compiledScss = $scss->compile( '$webroot: \'' . $this->getRoutePrefix() . '\';' . $this->getInjectedVariables() . '@import "variables.scss";' . '@import "functions.scss";' . '@import "' . $fileNameSCSS . '";'); } catch (ParserException $e) { $this->logger->logException($e, ['app' => 'core']); return false; } // Parse Icons and create related css variables $compiledScss = $this->iconsCacher->setIconsCss($compiledScss); // Gzip file try { $gzipFile = $folder->getFile($fileNameCSS . '.gzip'); # Safari doesn't like .gz } catch (NotFoundException $e) { $gzipFile = $folder->newFile($fileNameCSS . '.gzip'); # Safari doesn't like .gz } try { $data = $this->rebaseUrls($compiledScss, $webDir); $cachedfile->putContent($data); $deps = json_encode($scss->getParsedFiles()); $depFile->putContent($deps); $this->depsCache->set($folder->getName() . '-' . $depFileName, $deps); $gzipFile->putContent(gzencode($data, 9)); $this->logger->debug('SCSSCacher: ' . $webDir . '/' . $fileNameSCSS . ' compiled and successfully cached', ['app' => 'core']); return true; } catch (NotPermittedException $e) { $this->logger->error('SCSSCacher: unable to cache: ' . $fileNameSCSS); return false; } } /** * Reset scss cache by deleting all generated css files * We need to regenerate all files when variables change */ public function resetCache() { if (!$this->lockingCache->add('resetCache', 'locked!', 120)) { return; } $this->injectedVariables = null; // do not clear locks $this->cacheFactory->createDistributed('SCSS-deps-')->clear(); $this->cacheFactory->createDistributed('SCSS-cached-')->clear(); $appDirectory = $this->appData->getDirectoryListing(); foreach ($appDirectory as $folder) { foreach ($folder->getDirectoryListing() as $file) { try { $file->delete(); } catch (NotPermittedException $e) { $this->logger->logException($e, ['message' => 'SCSSCacher: unable to delete file: ' . $file->getName()]); } } } $this->logger->debug('SCSSCacher: css cache cleared!'); $this->lockingCache->remove('resetCache'); } /** * @return string SCSS code for variables from OC_Defaults */ private function getInjectedVariables(): string { if ($this->injectedVariables !== null) { return $this->injectedVariables; } $variables = ''; foreach ($this->defaults->getScssVariables() as $key => $value) { $variables .= '$' . $key . ': ' . $value . ' !default;'; } // check for valid variables / otherwise fall back to defaults try { $scss = new Compiler(); $scss->compile($variables); $this->injectedVariables = $variables; } catch (ParserException $e) { $this->logger->logException($e, ['app' => 'core']); } return $variables; } /** * Add the correct uri prefix to make uri valid again * @param string $css * @param string $webDir * @return string */ private function rebaseUrls(string $css, string $webDir): string { $re = '/url\([\'"]([^\/][\.\w?=\/-]*)[\'"]\)/x'; $subst = 'url(\'' . $webDir . '/$1\')'; return preg_replace($re, $subst, $css); } /** * Return the cached css file uri * @param string $appName the app name * @param string $fileName * @return string */ public function getCachedSCSS(string $appName, string $fileName): string { $tmpfileLoc = explode('/', $fileName); $fileName = array_pop($tmpfileLoc); $fileName = $this->prependVersionPrefix($this->prependBaseurlPrefix(str_replace('.scss', '.css', $fileName)), $appName); return substr($this->urlGenerator->linkToRoute('core.Css.getCss', [ 'fileName' => $fileName, 'appName' => $appName, 'v' => $this->config->getAppValue('core', 'theming.variables', '0') ]), \strlen(\OC::$WEBROOT) + 1); } /** * Prepend hashed base url to the css file * @param string $cssFile * @return string */ private function prependBaseurlPrefix(string $cssFile): string { return substr(md5($this->urlGenerator->getBaseUrl() . $this->getRoutePrefix()), 0, 4) . '-' . $cssFile; } private function getRoutePrefix() { $frontControllerActive = ($this->config->getSystemValue('htaccess.IgnoreFrontController', false) === true || getenv('front_controller_active') === 'true'); $prefix = \OC::$WEBROOT . '/index.php'; if ($frontControllerActive) { $prefix = \OC::$WEBROOT; } return $prefix; } /** * Prepend hashed app version hash * @param string $cssFile * @param string $appId * @return string */ private function prependVersionPrefix(string $cssFile, string $appId): string { $appVersion = \OC_App::getAppVersion($appId); if ($appVersion !== '0') { return substr(md5($appVersion), 0, 4) . '-' . $cssFile; } $coreVersion = \OC_Util::getVersionString(); return substr(md5($coreVersion), 0, 4) . '-' . $cssFile; } /** * Get WebDir root * @param string $path the css file path * @param string $appName the app name * @param string $serverRoot the server root path * @param string $webRoot the nextcloud installation root path * @return string the webDir */ private function getWebDir(string $path, string $appName, string $serverRoot, string $webRoot): string { // Detect if path is within server root AND if path is within an app path if (strpos($path, $serverRoot) === false && $appWebPath = \OC_App::getAppWebPath($appName)) { // Get the file path within the app directory $appDirectoryPath = explode($appName, $path)[1]; // Remove the webroot return str_replace($webRoot, '', $appWebPath . $appDirectoryPath); } return $webRoot . substr($path, strlen($serverRoot)); } /** * Add the icons css cache in the header if needed * * @return boolean true */ private function injectCssVariablesIfAny() { // Inject icons vars css if any if ($this->iconsCacher->getCachedCSS() && $this->iconsCacher->getCachedCSS()->getSize() > 0) { $this->iconsCacher->injectCss(); } return true; } }