From: Jeremy Benoist Date: Thu, 27 Oct 2016 05:30:50 +0000 (+0200) Subject: Merge pull request #2500 from wallabag/add-check-composer X-Git-Tag: 2.1.3~18 X-Git-Url: https://git.immae.eu/?a=commitdiff_plain;h=f3b637fbfee2fa9f66e53cbadd05e85771eece9d;hp=c5ad143e750254adb185ab6956dc87d2585ae54d;p=github%2Fwallabag%2Fwallabag.git Merge pull request #2500 from wallabag/add-check-composer Added a check in Makefile to see if composer is installed --- diff --git a/.travis.yml b/.travis.yml index c7bb05fb..a8f6a744 100644 --- a/.travis.yml +++ b/.travis.yml @@ -75,4 +75,6 @@ script: - if [[ $VALIDATE_TRANSLATION_FILE = '' ]]; then phpunit -v ; fi; - if [[ $CS_FIXER = run ]]; then php bin/php-cs-fixer fix src/ --verbose --dry-run ; fi; - if [[ $VALIDATE_TRANSLATION_FILE = run ]]; then php bin/console lint:yaml src/Wallabag/CoreBundle/Resources/translations -v ; fi; + - if [[ $VALIDATE_TRANSLATION_FILE = run ]]; then php bin/console lint:yaml app/Resources/CraueConfigBundle/translations -v ; fi; + - if [[ $VALIDATE_TRANSLATION_FILE = run ]]; then php bin/console lint:yaml app/Resources/FOSUserBundle/translations -v ; fi; - if [[ $ASSETS = build ]]; then ./node_modules/grunt-cli/bin/grunt tests; fi; diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.da.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.da.yml index 85079330..3e11d675 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.da.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.da.yml @@ -23,7 +23,7 @@ export: "eksport" import: "import" misc: "misc" modify_settings: "Gem ændring" -piwik_host: Hosting af din side hos Piwik +piwik_host: Hosting af din side hos Piwik (uden http:// eller https://) piwik_site_id: ID for din side hos Piwik piwik_enabled: Aktiver Piwik demo_mode_enabled: "Aktiver demo-indstilling? (anvendes kun til wallabags offentlige demo)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.de.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.de.yml index b3412af7..c74b5c1f 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.de.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.de.yml @@ -23,7 +23,7 @@ export: "Export" import: "Import" misc: "Verschiedenes" modify_settings: "Übernehmen" -piwik_host: Host deiner Webseite in Piwik +piwik_host: Host deiner Webseite in Piwik (ohne http:// oder https://) piwik_site_id: ID deiner Webseite in Piwik piwik_enabled: Piwik aktivieren demo_mode_enabled: "Test-Modus aktivieren? (nur für die öffentliche wallabag-Demo genutzt)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.en.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.en.yml index 8aaa27e7..77c09db4 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.en.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.en.yml @@ -23,7 +23,7 @@ export: "export" import: "import" misc: "misc" modify_settings: "apply" -piwik_host: Host of your website in Piwik +piwik_host: Host of your website in Piwik (without http:// ou https://) piwik_site_id: ID of your website in Piwik piwik_enabled: Enable Piwik demo_mode_enabled: "Enable demo mode ? (only used for the wallabag public demo)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.es.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.es.yml index bf3a79af..baa83849 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.es.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.es.yml @@ -23,7 +23,7 @@ export: "exportar" import: "importar" misc: "misc" modify_settings: "modificar configuración" -piwik_host: Host de tu website de Piwik +piwik_host: Host de tu website de Piwik (sin http:// o https://) piwik_site_id: ID de tu website de Piwik piwik_enabled: Activar Piwik demo_mode_enabled: "Activar modo demo (sólo usado para la demo de wallabag)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fa.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fa.yml index d86c4343..b394977e 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fa.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fa.yml @@ -23,7 +23,7 @@ export: "برون‌سپاری" import: "درون‌ریزی" misc: "غیره" modify_settings: "اعمال" -# piwik_host: Host of your website in Piwik +# piwik_host: Host of your website in Piwik (without http:// or https://) # piwik_site_id: ID of your website in Piwik # piwik_enabled: Enable Piwik # demo_mode_enabled: "Enable demo mode ? (only used for the wallabag public demo)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fr.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fr.yml index 5e1ecf26..31a80880 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fr.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.fr.yml @@ -23,7 +23,7 @@ export: "export" import: "import" misc: "divers" modify_settings: "appliquer" -piwik_host: URL de votre site dans Piwik +piwik_host: URL de votre site dans Piwik (sans http:// ou https://) piwik_site_id: ID de votre site dans Piwik piwik_enabled: Activer Piwik demo_mode_enabled: "Activer le mode démo ? (utiliser uniquement pour la démo publique de wallabag)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.it.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.it.yml index 9d820e4b..ba038556 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.it.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.it.yml @@ -23,7 +23,7 @@ export: "esporta" import: "importa" misc: "misc" modify_settings: "applica" -piwik_host: Host del tuo sito in Piwik +piwik_host: Host del tuo sito in Piwik (senza http:// o https://) piwik_site_id: ID del tuo sito in Piwik piwik_enabled: Abilita Piwik demo_mode_enabled: "Abilita modalità demo ? (usato solo per la demo pubblica di wallabag)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.oc.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.oc.yml index 49dc7732..55249e33 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.oc.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.oc.yml @@ -23,7 +23,7 @@ export: "expòrt" import: "impòrt" misc: "divèrs" modify_settings: "aplicar" -piwik_host: URL de vòstre site dins Piwik +piwik_host: URL de vòstre site dins Piwik (sense http:// o https://) piwik_site_id: ID de vòstre site dins Piwik piwik_enabled: Activar Piwik demo_mode_enabled: "Activar lo mode demostracion ? (utilizar solament per la demostracion publica de wallabag)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pl.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pl.yml index 7432b0a7..42cc5b52 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pl.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pl.yml @@ -23,7 +23,7 @@ export: "eksport" import: "import" misc: "różne" modify_settings: "zatwierdz" -piwik_host: Host twojej strony Piwik +piwik_host: Host twojej strony Piwik (bez http:// lub https://) piwik_site_id: ID twojej strony Piwik piwik_enabled: Włacz Piwik demo_mode_enabled: "Włacz tryb demo? (używany wyłącznie dla publicznej demonstracji Wallabag)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pt.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pt.yml new file mode 100644 index 00000000..e8260422 --- /dev/null +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.pt.yml @@ -0,0 +1,29 @@ +download_pictures: Download imagens no seu servidor +carrot: Habilitar compartilhamento para o Carrot +diaspora_url: URL Diaspora, se o serviço está habilitado +export_epub: Habilita exportação para ePub +export_mobi: Habilita exportação para .mobi +export_pdf: Habilita exportação para PDF +export_csv: Habilita exportação para CSV +export_json: Habilita exportação para JSON +export_txt: Habilita exportação para TXT +export_xml: Habilita exportação para XML +pocket_consumer_key: Chave de consumidor do Pocket para importar conteúdo (https://getpocket.com/developer/docs/authentication) +shaarli_url: URL Shaarli, se o serviço está habilitado +share_diaspora: Habilitar compartilhamento para o Diaspora +share_mail: Habilitar compartilhamento por e-mail +share_shaarli: Habilitar compartilhamento para o Shaarli +share_twitter: Habilitar compartilhamento para o Twitter +show_printlink: Mostrar um link para imprimir o conteúdo +wallabag_support_url: URL de Suporte do wallabag +wallabag_url: URL de *sua* instância do wallabag +entry: "artigo" +export: "exportar" +import: "importar" +misc: "misc" +modify_settings: "aplicar" +piwik_host: Host de seu website Piwik +piwik_site_id: ID de seu website Piwik +piwik_enabled: Habilitar Piwik +demo_mode_enabled: "Habilitar modo demo? (somente usado para o demo público do wallabag)" +demo_mode_username: "Usuário demo" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.ro.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.ro.yml index 20d664f7..8e72b955 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.ro.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.ro.yml @@ -23,7 +23,7 @@ export: "exportă" import: "importă" misc: "diverse" modify_settings: "aplică" -# piwik_host: Host of your website in Piwik +# piwik_host: Host of your website in Piwik (without http:// or https://) # piwik_site_id: ID of your website in Piwik # piwik_enabled: Enable Piwik # demo_mode_enabled: "Enable demo mode ? (only used for the wallabag public demo)" diff --git a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.tr.yml b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.tr.yml index 4b4d3edb..55f70843 100644 --- a/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.tr.yml +++ b/app/Resources/CraueConfigBundle/translations/CraueConfigBundle.tr.yml @@ -23,7 +23,7 @@ # import: "import" # misc: "misc" # modify_settings: "apply" -# piwik_host: Host of your website in Piwik +# piwik_host: Host of your website in Piwik (without http:// or https://) # piwik_site_id: ID of your website in Piwik # piwik_enabled: Enable Piwik # demo_mode_enabled: "Enable demo mode ? (only used for the wallabag public demo)" diff --git a/app/Resources/FOSUserBundle/translations/FOSUserBundle.pt.yml b/app/Resources/FOSUserBundle/translations/FOSUserBundle.pt.yml new file mode 100644 index 00000000..85eadfd8 --- /dev/null +++ b/app/Resources/FOSUserBundle/translations/FOSUserBundle.pt.yml @@ -0,0 +1,2 @@ +Login: "Login" +Enter your email address below and we'll send you password reset instructions.: "Digite seu endereço de e-mail para enviarmos as instruções de recupeção de sua senha." diff --git a/app/config/config.yml b/app/config/config.yml index ed2e7416..81d1728a 100644 --- a/app/config/config.yml +++ b/app/config/config.yml @@ -30,7 +30,7 @@ framework: assets: ~ wallabag_core: - version: 2.1.2 + version: 2.1.3-dev paypal_url: "https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=9UBA65LG3FX9Y&lc=gb" languages: en: 'English' @@ -44,12 +44,15 @@ wallabag_core: es: 'Español' oc: 'Occitan' it: 'Italiano' + pt: 'Português' items_on_page: 12 theme: material language: '%locale%' rss_limit: 50 reading_speed: 1 cache_lifetime: 10 + fetching_error_message: | + wallabag can't retrieve contents for this article. Please troubleshoot this issue. wallabag_user: registration_enabled: "%fosuser_registration%" diff --git a/docs/de/index.rst b/docs/de/index.rst index a380d7bd..b422bf83 100644 --- a/docs/de/index.rst +++ b/docs/de/index.rst @@ -45,6 +45,7 @@ Die Dokumentation ist in anderen Sprachen verfügbar : user/tags user/android user/parameters + user/backup .. _dev-docs: diff --git a/docs/de/user/backup.rst b/docs/de/user/backup.rst new file mode 100644 index 00000000..ffe3ce37 --- /dev/null +++ b/docs/de/user/backup.rst @@ -0,0 +1,25 @@ +wallabag sichern +================ +Da es manchmal vorkommen kann, dass dir ein Fehler mit deiner wallabag unterläuft und du Daten verlierst oder deine wallabag auf einen anderen Server verschieben willst, ist eine Sicherung der Daten sicher ratsam. +Dieser Artikel beschreibt, was du für die Sicherung benötigst. + +Grundlegende Einstellungen +-------------------------- +wallabag speichert grundlegende Parameter (etwa der SMTP-Server oder das Datenbank-Backend) in der Datei `app/config/parameters.yml`. + +Datenbank +--------- +Da wallabag verschiedene Datenbank-Typen unterstützt, hängt der Weg der Sicherung von dem verwendeten Typ ab. Daher verweisen wir an dieser Stelle auf die entsprechenden Dokumentationen: + +Hier sind einige Beispiele: + +- MySQL: http://dev.mysql.com/doc/refman/5.7/en/backup-methods.html +- PostgreSQL: https://www.postgresql.org/docs/current/static/backup.html + +SQLite +~~~~~~ +Um die SQLite-Datenbank zu sichern, ist es lediglich notwendig, das Verzeichnis `data/db` aus dem wallabag-Installations-Ordner zu kopieren. + +Bilder +------ +Die Bilder, die von wallabag empfangen worden, sind unter `data/assets/images` gespeichert (der Bilder-Speicher wird in wallabag 2.2 implementiert). diff --git a/docs/de/user/upgrade-2.1.x-2.1.y.rst b/docs/de/user/upgrade-2.1.x-2.1.y.rst index e638ea9b..2f9b7791 100644 --- a/docs/de/user/upgrade-2.1.x-2.1.y.rst +++ b/docs/de/user/upgrade-2.1.x-2.1.y.rst @@ -26,7 +26,7 @@ Lade das neueste Release von wallabag herunter: wget http://wllbg.org/latest-v2-package && tar xvf latest-v2-package -(md5 Hashsumme von 2.1.1: ``9584a3b60a2b2a4de87f536548caac93``) +Du findest die `md5 Hashsumme des neuesten Pakets auf unserer Website `_. Entpacke das Archiv in deinen wallabag Ordner und ersetze ``app/config/parameters.yml`` mit deiner Datei. diff --git a/docs/en/index.rst b/docs/en/index.rst index 6d85db2b..0ead261b 100644 --- a/docs/en/index.rst +++ b/docs/en/index.rst @@ -46,6 +46,7 @@ The documentation is available in other languages: user/tags user/android user/parameters + user/backup .. _dev-docs: diff --git a/docs/en/user/android.rst b/docs/en/user/android.rst index ccbad264..91dcb2fc 100644 --- a/docs/en/user/android.rst +++ b/docs/en/user/android.rst @@ -79,7 +79,7 @@ Known limitations 2FA ~~~ -Currently the does not support two-factor authentication. You should disable that to get the app working. +Currently the Android application does not support two-factor authentication. You should disable that to get the application working. Limited amount of articles with wallabag v2 diff --git a/docs/en/user/backup.rst b/docs/en/user/backup.rst new file mode 100644 index 00000000..51721000 --- /dev/null +++ b/docs/en/user/backup.rst @@ -0,0 +1,25 @@ +Backup wallabag +=============== +Because sometimes you may do a mistake with your wallabag and lose data or in case you need to move your wallabag to another server you want to backup your data. +This articles describes what you need to backup. + +Basic settings +-------------- +wallabag stores some basic parameters (like SMTP server or database backend) in the file `app/config/parameters.yml`. + +Database +-------- +As wallabag supports different kinds of database, the way to perform the backup depends on the database you use, so you need to refer to the vendor documentation. + +Here's some examples: + +- MySQL: http://dev.mysql.com/doc/refman/5.7/en/backup-methods.html +- PostgreSQL: https://www.postgresql.org/docs/current/static/backup.html + +SQLite +~~~~~~ +To backup the SQLite database, you just need to copy the directory `data/db` from the wallabag application directory. + +Images +------ +The images retrieved by wallabag are stored under `data/assets/images` (the images storage will be implemented in wallabag 2.2). diff --git a/docs/en/user/upgrade-2.1.x-2.1.y.rst b/docs/en/user/upgrade-2.1.x-2.1.y.rst index 575f4ba9..62cb7dc0 100644 --- a/docs/en/user/upgrade-2.1.x-2.1.y.rst +++ b/docs/en/user/upgrade-2.1.x-2.1.y.rst @@ -26,7 +26,7 @@ Download the last release of wallabag: wget http://wllbg.org/latest-v2-package && tar xvf latest-v2-package -(md5 hash of the 2.1.1 package: ``9584a3b60a2b2a4de87f536548caac93``) +You will find the `md5 hash of the latest package on our website `_. Extract the archive in your wallabag folder and replace ``app/config/parameters.yml`` with yours. diff --git a/docs/fr/index.rst b/docs/fr/index.rst index 2a265ff3..dbb85910 100644 --- a/docs/fr/index.rst +++ b/docs/fr/index.rst @@ -46,6 +46,7 @@ La documentation est disponible dans d'autres langues : user/filters user/tags user/parameters + user/backup .. _dev-docs: diff --git a/docs/fr/user/backup.rst b/docs/fr/user/backup.rst new file mode 100644 index 00000000..ec4b1f4d --- /dev/null +++ b/docs/fr/user/backup.rst @@ -0,0 +1,26 @@ +Sauvegarde de wallabag +====================== + +Parce que des fois vous faites des erreurs avec votre installation de wallabag et vous perdez des données ou parce que vous souhaitez migrer votre installation sur un autre serveur, vous souhaitez faire une sauvegarde de vos données. +Cette documentation décrit ce que vous devez sauvegarder. + +Configuration +------------- +wallabag stocke quelques paramètres (comme la configuration SMTP ou les infos de bases de données) dans le fichier `app/config/parameters.yml`. + +Base de données +--------------- +Comme wallabag supporte différentes sortes de bases de données, la manière de sauvegarder dépend du type de base de données que vous utilisez, donc vous devez vous en référez à la documentation correspondante. + +Quelques exemples : + +- MySQL: http://dev.mysql.com/doc/refman/5.7/en/backup-methods.html +- PostgreSQL: https://www.postgresql.org/docs/current/static/backup.html + +SQLite +~~~~~~ +Pour sauvegarder une base SQLite, vous devez juste copier le répertoire `data/db` de votre installation wallabag. + +Images +------ +Les images sauvegardées par wallabag sont stockées dans `data/assets/images` (le stockage des images sera implémenté dans wallabag 2.2). diff --git a/docs/fr/user/upgrade-2.1.x-2.1.y.rst b/docs/fr/user/upgrade-2.1.x-2.1.y.rst index c048099f..b6f1a2d0 100644 --- a/docs/fr/user/upgrade-2.1.x-2.1.y.rst +++ b/docs/fr/user/upgrade-2.1.x-2.1.y.rst @@ -26,7 +26,7 @@ Téléchargez la dernière version de wallabag : wget http://wllbg.org/latest-v2-package && tar xvf latest-v2-package -(hash md5 de l'archive 2.1.1 : ``9584a3b60a2b2a4de87f536548caac93``) +Vous trouverez `le hash md5 du dernier package sur notre site `_. Décompressez l'archive dans votre répertoire d'installation et remplacez le fichier ``app/config/parameters.yml`` avec le votre. diff --git a/src/Wallabag/CoreBundle/Command/InstallCommand.php b/src/Wallabag/CoreBundle/Command/InstallCommand.php index 8e438229..857a8b4c 100644 --- a/src/Wallabag/CoreBundle/Command/InstallCommand.php +++ b/src/Wallabag/CoreBundle/Command/InstallCommand.php @@ -364,7 +364,7 @@ class InstallCommand extends ContainerAwareCommand ], [ 'name' => 'piwik_host', - 'value' => 'http://v2.wallabag.org', + 'value' => 'v2.wallabag.org', 'section' => 'analytics', ], [ diff --git a/src/Wallabag/CoreBundle/Controller/EntryController.php b/src/Wallabag/CoreBundle/Controller/EntryController.php index 3b28e635..97bb3d12 100644 --- a/src/Wallabag/CoreBundle/Controller/EntryController.php +++ b/src/Wallabag/CoreBundle/Controller/EntryController.php @@ -330,6 +330,15 @@ class EntryController extends Controller $this->updateEntry($entry, 'entry_reloaded'); + // if refreshing entry failed, don't save it + if ($this->getParameter('wallabag_core.fetching_error_message') === $entry->getContent()) { + $bag = $this->get('session')->getFlashBag(); + $bag->clear(); + $bag->add('notice', 'flashes.entry.notice.entry_reloaded_failed'); + + return $this->redirect($this->generateUrl('view', ['id' => $entry->getId()])); + } + $em = $this->getDoctrine()->getManager(); $em->persist($entry); $em->flush(); diff --git a/src/Wallabag/CoreBundle/Controller/TagController.php b/src/Wallabag/CoreBundle/Controller/TagController.php index 5acc6852..707f3bbe 100644 --- a/src/Wallabag/CoreBundle/Controller/TagController.php +++ b/src/Wallabag/CoreBundle/Controller/TagController.php @@ -143,6 +143,7 @@ class TagController extends Controller 'form' => null, 'entries' => $entries, 'currentPage' => $page, + 'tag' => $tag->getLabel(), ]); } } diff --git a/src/Wallabag/CoreBundle/DataFixtures/ORM/LoadSettingData.php b/src/Wallabag/CoreBundle/DataFixtures/ORM/LoadSettingData.php index 9425f961..a5e1be65 100644 --- a/src/Wallabag/CoreBundle/DataFixtures/ORM/LoadSettingData.php +++ b/src/Wallabag/CoreBundle/DataFixtures/ORM/LoadSettingData.php @@ -122,7 +122,7 @@ class LoadSettingData extends AbstractFixture implements OrderedFixtureInterface ], [ 'name' => 'piwik_host', - 'value' => 'http://v2.wallabag.org', + 'value' => 'v2.wallabag.org', 'section' => 'analytics', ], [ diff --git a/src/Wallabag/CoreBundle/DependencyInjection/Configuration.php b/src/Wallabag/CoreBundle/DependencyInjection/Configuration.php index d8141eea..3a3da024 100644 --- a/src/Wallabag/CoreBundle/DependencyInjection/Configuration.php +++ b/src/Wallabag/CoreBundle/DependencyInjection/Configuration.php @@ -39,6 +39,8 @@ class Configuration implements ConfigurationInterface ->integerNode('cache_lifetime') ->defaultValue(10) ->end() + ->scalarNode('fetching_error_message') + ->end() ->end() ; diff --git a/src/Wallabag/CoreBundle/DependencyInjection/WallabagCoreExtension.php b/src/Wallabag/CoreBundle/DependencyInjection/WallabagCoreExtension.php index 0cbde908..b4992d54 100644 --- a/src/Wallabag/CoreBundle/DependencyInjection/WallabagCoreExtension.php +++ b/src/Wallabag/CoreBundle/DependencyInjection/WallabagCoreExtension.php @@ -23,6 +23,7 @@ class WallabagCoreExtension extends Extension $container->setParameter('wallabag_core.version', $config['version']); $container->setParameter('wallabag_core.paypal_url', $config['paypal_url']); $container->setParameter('wallabag_core.cache_lifetime', $config['cache_lifetime']); + $container->setParameter('wallabag_core.fetching_error_message', $config['fetching_error_message']); $loader = new Loader\YamlFileLoader($container, new FileLocator(__DIR__.'/../Resources/config')); $loader->load('services.yml'); diff --git a/src/Wallabag/CoreBundle/Resources/config/services.yml b/src/Wallabag/CoreBundle/Resources/config/services.yml index a4b727f4..614488a6 100644 --- a/src/Wallabag/CoreBundle/Resources/config/services.yml +++ b/src/Wallabag/CoreBundle/Resources/config/services.yml @@ -40,7 +40,7 @@ services: class: Graby\Graby arguments: - - error_message: "wallabag can't retrieve contents for this article. Please report this issue to us." + error_message: '%wallabag_core.fetching_error_message%' http_client: user_agents: 'lifehacker.com': 'PHP/5.2' diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.da.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.da.yml index bb23b5fe..6ca7e459 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.da.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.da.yml @@ -137,7 +137,7 @@ entry: # starred: 'Starred entries' # archived: 'Archived entries' # filtered: 'Filtered entries' - # filtered_tags: 'Filtered by tags' + # filtered_tags: 'Filtered by tags:' # untagged: 'Untagged entries' list: # number_on_the_page: '{0} There is no entry.|{1} There is one entry.|]1,Inf[ There are %count% entries.' @@ -445,6 +445,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.de.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.de.yml index d1df8669..8fd1d82a 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.de.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.de.yml @@ -137,7 +137,7 @@ entry: starred: 'Favorisierte Einträge' archived: 'Archivierte Einträge' filtered: 'Gefilterte Einträge' - filtered_tags: 'Gefiltert nach Tags' + filtered_tags: 'Gefiltert nach Tags:' untagged: 'Nicht getaggte Einträge' list: number_on_the_page: '{0} Es gibt keine Einträge.|{1} Es gibt einen Eintrag.|]1,Inf[ Es gibt %count% Einträge.' @@ -445,6 +445,9 @@ user: delete_confirm: Bist du sicher? back_to_list: Zurück zur Liste +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.en.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.en.yml index 4a8934b8..02f56535 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.en.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.en.yml @@ -137,7 +137,7 @@ entry: starred: 'Starred entries' archived: 'Archived entries' filtered: 'Filtered entries' - filtered_tags: 'Filtered by tags' + filtered_tags: 'Filtered by tags:' untagged: 'Untagged entries' list: number_on_the_page: '{0} There are no entries.|{1} There is one entry.|]1,Inf[ There are %count% entries.' @@ -445,6 +445,9 @@ user: delete_confirm: Are you sure? back_to_list: Back to list +error: + page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.es.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.es.yml index 29f0676e..42ec8183 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.es.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.es.yml @@ -137,7 +137,7 @@ entry: starred: 'Artículos favoritos' archived: 'Artículos archivados' filtered: 'Artículos filtrados' - # filtered_tags: 'Filtered by tags' + # filtered_tags: 'Filtered by tags:' # untagged: 'Untagged entries' list: number_on_the_page: '{0} No hay artículos.|{1} Hay un artículo.|]1,Inf[ Hay %count% artículos.' @@ -445,6 +445,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.fa.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.fa.yml index 074ab7a8..f82167df 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.fa.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.fa.yml @@ -137,7 +137,7 @@ entry: starred: 'مقاله‌های برگزیده' archived: 'مقاله‌های بایگانی‌شده' filtered: 'مقاله‌های فیلترشده' - # filtered_tags: 'Filtered by tags' + # filtered_tags: 'Filtered by tags:' # untagged: 'Untagged entries' list: number_on_the_page: '{0} هیج مقاله‌ای نیست.|{1} یک مقاله هست.|]1,Inf[ %count% مقاله هست.' @@ -444,6 +444,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.fr.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.fr.yml index 55453b6c..574cc1a7 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.fr.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.fr.yml @@ -137,7 +137,7 @@ entry: starred: 'Articles favoris' archived: 'Articles lus' filtered: 'Articles filtrés' - filtered_tags: 'Articles filtrés par tags' + filtered_tags: 'Articles filtrés par tags :' untagged: 'Article sans tag' list: number_on_the_page: "{0} Il n'y a pas d'articles.|{1} Il y a un article.|]1,Inf[ Il y a %count% articles." @@ -365,7 +365,7 @@ import: how_to: "Choisissez le fichier de sauvegarde de vos marques-page et cliquez sur le bouton pour l'importer. Soyez avertis que le processus peut prendre un temps assez long car tous les articles doivent être récupérés en ligne." instapaper: page_title: 'Import > Instapaper' - description: 'Sur la page des paramètres (`https://www.instapaper.com/user`_), cliquez sur "Download .CSV file" dans la section "Export". Un fichier CSV se téléchargera ("instapaper-export.csv").' + description: 'Sur la page des paramètres (https://www.instapaper.com/user), cliquez sur "Download .CSV file" dans la section "Export". Un fichier CSV se téléchargera ("instapaper-export.csv").' how_to: "Choisissez le fichier de votre export Instapaper et cliquez sur le bouton ci-dessous pour l'importer." developer: @@ -445,6 +445,9 @@ user: delete_confirm: Êtes-vous sûr? back_to_list: Revenir à la liste +error: + page_title: Une erreur est survenue + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.it.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.it.yml index 67205c6d..d679ef00 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.it.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.it.yml @@ -137,7 +137,7 @@ entry: starred: 'Contenuti preferiti' archived: 'Contenuti archiviati' filtered: 'Contenuti filtrati' - # filtered_tags: 'Filtered by tags' + # filtered_tags: 'Filtered by tags:' # untagged: 'Untagged entries' list: number_on_the_page: "{0} Non ci sono contenuti.|{1} C'è un contenuto.|]1,Inf[ Ci sono %count% contenuti." @@ -445,6 +445,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.oc.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.oc.yml index 25e5f05a..af0fba0d 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.oc.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.oc.yml @@ -137,7 +137,7 @@ entry: starred: 'Articles favorits' archived: 'Articles legits' filtered: 'Articles filtrats' - filtered_tags: 'Filtats per etiquetas' + filtered_tags: 'Filtats per etiquetas:' untagged: 'Articles sens etiqueta' list: number_on_the_page: "{0} I a pas cap d'article.|{1} I a un article.|]1,Inf[ I a %count% articles." @@ -445,6 +445,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.pl.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.pl.yml index 392f9c19..bf47b58a 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.pl.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.pl.yml @@ -137,7 +137,7 @@ entry: starred: 'Wpisy oznaczone gwiazdką' archived: 'Zarchiwizowane wpisy' filtered: 'Odfiltrowane wpisy' - filtered_tags: 'Filtrowane po tagach' + filtered_tags: 'Filtrowane po tagach:' untagged: 'Odtaguj wpisy' list: number_on_the_page: '{0} Nie ma wpisów.|{1} Jest jeden wpis.|]1,Inf[ Są %count% wpisy.' @@ -445,6 +445,9 @@ user: delete_confirm: Jesteś pewien? back_to_list: Powrót do listy +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.pt.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.pt.yml new file mode 100644 index 00000000..f10dc9aa --- /dev/null +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.pt.yml @@ -0,0 +1,492 @@ +security: + login: + page_title: 'Bem vindo ao wallabag!' + keep_logged_in: 'Mantenha-me autenticado' + forgot_password: 'Esqueceu a senha?' + submit: 'Login' + register: 'Registre-se' + username: 'Nome de usuário' + password: 'Senha' + cancel: 'Cancelar' + resetting: + description: 'Digite seu endereço de e-mail abaixo e enviaremos instruções para resetar sua senha.' + register: + page_title: 'Criar uma conta' + go_to_account: 'Ir para sua conta' + +menu: + left: + unread: 'Não lido' + starred: 'Destacado' + archive: 'Arquivo' + all_articles: 'Todas as entradas' + config: 'Configurações' + tags: 'Tags' + internal_settings: 'Configurações Internas' + import: 'Importar' + howto: 'How to' + developer: 'Desenvolvedor' + logout: 'Sair' + about: 'Sobre' + search: 'Pesquisa' + save_link: 'Salvar um link' + back_to_unread: 'Voltar para os artigos não lidos' + users_management: 'Gestão de Usuários' + top: + add_new_entry: 'Adicionar uma nova entrada' + search: 'Pesquisa' + filter_entries: 'Filtrar entradas' + export: 'Exportar' + search_form: + input_label: 'Digite aqui sua pesquisa' + +footer: + wallabag: + elsewhere: 'Leve o wallabag com você' + social: 'Social' + powered_by: 'provido por' + about: 'Sobre' + stats: 'Desde %user_creation% você leu %nb_archives% artigos. Isso é %per_day% por dia!' + +config: + page_title: 'Config' + tab_menu: + settings: 'Configurações' + rss: 'RSS' + user_info: 'Informação do Usuário' + password: 'Senha' + rules: 'Regras de tags' + new_user: 'Adicionar um usuário' + form: + save: 'Salvar' + form_settings: + theme_label: 'Tema' + items_per_page_label: 'Itens por página' + language_label: 'Idioma' + reading_speed: + label: 'Velocidade de leitura' + help_message: 'Você pode usar ferramentas online para estimar sua velocidade de leitura:' + 100_word: 'Posso ler ~100 palavras por minuto' + 200_word: 'Posso ler ~200 palavras por minuto' + 300_word: 'Posso ler ~300 palavras por minuto' + 400_word: 'Posso ler ~400 palavras por minuto' + pocket_consumer_key_label: 'Chave do consumidor do Pocket para importar conteúdo' + form_rss: + description: 'Feeds RSS providos pelo wallabag permitem que você leia seus artigos salvos em seu leitor de RSS favorito. Você precisa gerar um token primeiro.' + token_label: 'Token RSS' + no_token: 'Nenhum Token' + token_create: 'Criar seu token' + token_reset: 'Gerar novamente seu token' + rss_links: 'Links RSS' + rss_link: + unread: 'não lido' + starred: 'destacado' + archive: 'arquivado' + rss_limit: 'Número de itens no feed' + form_user: + two_factor_description: 'Habilitar autenticação de dois passos significa que você receberá um e-mail com um código a cada nova conexão desconhecida.' + name_label: 'Nome' + email_label: 'E-mail' + twoFactorAuthentication_label: 'Autenticação de dois passos' + form_password: + old_password_label: 'Senha atual' + new_password_label: 'Nova senha' + repeat_new_password_label: 'Repita a nova senha' + form_rules: + if_label: 'if' + then_tag_as_label: 'então coloque a tag' + delete_rule_label: 'apagar' + edit_rule_label: 'editar' + rule_label: 'Regras' + tags_label: 'Tags' + faq: + title: 'FAQ' + tagging_rules_definition_title: 'O que as « regras de tags » significam?' + tagging_rules_definition_description: 'São regras usadas pelo Wallabag para automaticamente adicionar tags em novos artigos.
Cada vez que um novo artigo é adicionado, todas as regras de tags podem ser usadas para adicionar as tags que você configurou, ajudando-o com o problema de classificar manualmente seus artigos.' + how_to_use_them_title: 'Como eu as utilizo?' + how_to_use_them_description: 'Vamos dizer que você deseja adicionar a tag « leitura rápida » quando o tempo de leitura for menor que 3 minutos.
Neste caso, você deve « readingTime <= 3 » no campo Regra e « leitura rápida » no campo Tags.
Diversas tags podem ser adicionadas simultâneamente separando-as com vírgula: « leitura rápida, precisa ser lido »
Regras complexas podem ser escritas usando os seguintes operadores pré-definidos: if « readingTime >= 5 AND domainName = "github.com" » então adicione a tag « leitura longa, github »' + variables_available_title: 'Quais variáveis e operadores eu posso usar para escrever regras?' + variables_available_description: 'As seguintes variáveis e operadores podem ser usados para criar regras de tags:' + meaning: 'Meaning' + variable_description: + label: 'Variável' + title: 'Título da entrada' + url: 'URL da entrada' + isArchived: 'Se a entrada está arquivada ou não' + isDestacado: 'Se a entrada está destacada ou não' + content: 'O conteúdo da entrada' + language: 'O idioma da entrada' + mimetype: 'O mime-type da entrada' + readingTime: 'O tempo estimado de leitura da entrada, em minutos' + domainName: 'O domínio da entrada' + operator_description: + label: 'Operador' + less_than: 'Menor que...' + strictly_less_than: 'Estritamente menor que...' + greater_than: 'Maior que...' + strictly_greater_than: 'Estritamente maior que...' + equal_to: 'Igual a...' + not_equal_to: 'Diferente de...' + or: 'Uma regra OU outra' + and: 'Uma regra E outra' + matches: 'Testa que um assunto corresponde a uma pesquisa (maiúscula ou minúscula).
Exemplo: título corresponde a "futebol"' + +entry: + page_titles: + unread: 'Entradas não lidas' + starred: 'Entradas destacadas' + archived: 'Entradas arquivadas' + filtered: 'Entradas filtradas' + filtered_tags: 'Filtrar por tags:' + untagged: 'Entradas sem tags' + list: + number_on_the_page: '{0} Não existem entradas.|{1} Existe uma entrada.|]1,Inf[ Existem %count% entradas.' + reading_time: 'tempo estimado de leitura' + reading_time_minutes: 'tempo estimado de leitura: %readingTime% min' + reading_time_less_one_minute: 'tempo estimado de leitura: < 1 min' + number_of_tags: '{1}e uma outra tag|]1,Inf[e %count% outras tags' + reading_time_minutes_short: '%readingTime% min' + reading_time_less_one_minute_short: '< 1 min' + original_article: 'original' + toogle_as_read: 'Marcar como lido' + toogle_as_star: 'Marcar como destacado' + delete: 'Apagar' + export_title: 'Exportar' + filters: + title: 'Filtros' + status_label: 'Status' + archived_label: 'Arquivado' + starred_label: 'Destacado' + unread_label: 'Não Lido' + preview_picture_label: 'Possui uma imagem de preview' + preview_picture_help: 'Imagem de preview' + language_label: 'Idioma' + reading_time: + label: 'Tempo de leitura em minutos' + from: 'de' + to: 'para' + domain_label: 'Nome do domínio' + created_at: + label: 'Data de criação' + from: 'de' + to: 'para' + action: + clear: 'Limpar' + filter: 'Filtro' + view: + left_menu: + back_to_top: 'Voltar ao topo' + back_to_homepage: 'Voltar' + set_as_read: 'Marcar como lido' + set_as_unread: 'Marcar como não lido' + set_as_starred: 'Alternar destaque' + view_original_article: 'Artigo original' + re_fetch_content: 'Recapturar o conteúdo' + delete: 'Apagar' + add_a_tag: 'Adicionar uma tag' + share_content: 'Compartilhar' + share_email_label: 'E-mail' + public_link: 'link público' + delete_public_link: 'apagar link público' + download: 'Download' + print: 'Imprimir' + problem: + label: 'Problemas?' + description: 'este artigo aparece errado?' + edit_title: 'Editar título' + original_article: 'original' + annotations_on_the_entry: '{0} Sem anotações|{1} Uma anotação|]1,Inf[ %nbAnnotations% anotações' + created_at: 'Data de criação' + new: + page_title: 'Salvar nova entrada' + placeholder: 'http://website.com' + form_new: + url_label: Url + edit: + page_title: 'Editar uma entrada' + title_label: 'Título' + url_label: 'Url' + is_public_label: 'Público' + save_label: 'Salvar' + public: + shared_by_wallabag: "Este artigo foi compartilhado pelo wallabag" + +about: + page_title: 'Sobre' + top_menu: + who_behind_wallabag: 'Quem está por trás do wallabag' + getting_help: 'Obtendo ajuda' + helping: 'Ajudando o wallabag' + contributors: 'Contribuidores' + third_party: 'Bibliotecas terceiras' + who_behind_wallabag: + developped_by: 'Desenvolvido por' + website: 'website' + many_contributors: 'E muitos outros contribuidores ♥ no Github' + project_website: 'Website do projeto' + license: 'Licença' + version: 'Versão' + getting_help: + documentation: 'Documentação' + bug_reports: 'Informar bugs' + support: 'Em nosso site de suporte ou no GitHub' + helping: + description: 'wallabag é livre e software livre. Você pode nos ajudar:' + by_contributing: 'contribuindo com o projeto:' + by_contributing_2: 'uma lista de todas as nossas necessidades' + by_paypal: 'via Paypal' + contributors: + description: 'Obrigado por contribuir com a aplicação web wallabag' + third_party: + description: 'Aqui está a lista de bibliotecas terceiras usadas no wallabag (com suas licenças):' + package: 'Pacote' + license: 'Licença' + +howto: + page_title: 'How to' + page_description: 'Existem diferentes formas de salvar um artigo:' + top_menu: + browser_addons: 'Extensões de navegadores' + mobile_apps: "App's móveis" + bookmarklet: 'Bookmarklet' + form: + description: 'Obrigado por este formulário' + browser_addons: + firefox: 'Extensão padrão do Firefox' + chrome: 'Extensão do Chrome' + mobile_apps: + android: + via_f_droid: 'via F-Droid' + via_google_play: 'via Google Play' + ios: 'na iTunes Store' + windows: 'na Microsoft Store' + bookmarklet: + description: 'Arraste e solve este link na sua barra de favoritos:' + +quickstart: + page_title: 'Começo Rápido' + more: 'Mais...' + intro: + title: 'Bem-vindo ao wallabag!' + paragraph_1: 'Nós podemos acompanhar você em sua visita ao wallabag e mostrar algumas funcionalidades que podem lhe interessar.' + paragraph_2: 'Siga-nos!' + configure: + title: 'Configurar a aplicação' + description: 'Para ter uma aplicação que atende você, dê uma olhada na configuração do wallabag.' + language: 'Alterar idioma e design' + rss: 'Habilitar feeds RSS' + tagging_rules: 'Escrever regras para acrescentar tags automaticamente em seus artigos' + admin: + title: 'Administração' + description: 'Como administrador você tem privilégios no wallabag. Você pode:' + new_user: 'Criar um novo usuário' + analytics: 'Configurar o analytics' + sharing: 'habilitar alguns parâmetros para compartilhamento de artigos' + export: 'Configurar exportação' + import: 'Configurar importação' + first_steps: + title: 'Primeiros passos' + description: "Agora o wallabag está bem configurado, é hora de arquivar a web. Você pode clicar no sinal de + no topo a direita para adicionar um link." + new_article: 'Salvar seu primeiro artigo' + unread_articles: 'E classificá-lo!' + migrate: + title: 'Migrar de um serviço existente' + description: 'Você está usando um outro serviço? Nós podemos ajudá-lo a recuperar seus dados para o wallabag.' + pocket: 'Migrar do Pocket' + wallabag_v1: 'Migrar do wallabag v1' + wallabag_v2: 'Migrar do wallabag v2' + readability: 'Migrate from Readability' + instapaper: 'Migrate from Instapaper' + developer: + title: 'Desenvolvedores' + description: 'Nós também agradecemos os desenvolvedores: Docker, API, traduções, etc.' + create_application: 'Criar sua aplicação terceira' + use_docker: 'Usar o Docker para instalar o wallabag' + docs: + title: 'Documentação completa' + description: "Existem muitas funcionalidades no wallabag. Não hesite em ler o manual para conhecê-las e aprender como usá-las." + annotate: 'Anotar seu artigo' + export: 'Converter seu artigo em ePUB ou PDF' + search_filters: 'veja coo você pode encontrar um artigo usanndo o motor de busca e filtros' + fetching_errors: 'O que eu posso fazer quando um artigo encontra erros na recuperação?' + all_docs: 'E outros muitos artigos!' + support: + title: 'Suporte' + description: 'Se você precisa de ajuda, nós estamos aqui.' + github: 'No GitHub' + email: 'Por e-mail' + gitter: 'No Gitter' + +tag: + page_title: 'Tags' + list: + number_on_the_page: '{0} Não existem tags.|{1} Uma tag.|]1,Inf[ Existem %count% tags.' + see_untagged_entries: 'Ver entradas sem tags' + +import: + page_title: 'Importar' + page_description: 'Bem-vindo ao importador do wallabag. Por favo selecione o serviço do qual deseja migrar.' + action: + import_contents: 'Importar conteúdos' + form: + mark_as_read_title: 'Marcar todos como lidos?' + mark_as_read_label: 'Marcar todas as entradas importadas como lidas' + file_label: 'Arquivo' + save_label: 'Carregar arquivo' + pocket: + page_title: 'Importar > Pocket' + description: 'Com este importador você importa todos os seus dados do Pocket. O Pocket não nos permite recuperar o conteúdo de seu serviço, então o conteúdo que pode ser lido é recarregado pelo wallabag.' + config_missing: + description: 'O importador do Pocket não está configurado.' + admin_message: 'Você precisa definir uma %keyurls%a pocket_consumer_key%keyurle%.' + user_message: 'Seu administrador do servidor precisa definir uma chave de API para o Pocket.' + authorize_message: 'Você pode importar seus dados de sua conta do Pocket. Você somente precisa clicar no botão abaixo e autorizar a aplicação a conectar-se ao getpocket.com.' + connect_to_pocket: 'Conecte ao Pocket e importe os dados' + wallabag_v1: + page_title: 'Importar > Wallabag v1' + description: 'Com este importador você importa todos os seus artigos do wallabag v1. Na sua página de configuração, clique em "JSON export" na opção "Export your wallabag data". Você irá criar um arquivo "wallabag-export-1-xxxx-xx-xx.json".' + how_to: 'Por favor, selecione seu exportador wallabag e clique no botão abaixo para carregar e importar.' + wallabag_v2: + page_title: 'Importar > Wallabag v2' + description: 'Com este importador você importa todos os seus artigos do wallabag v2. Vá em Todos os artigos e então, na barra lateral de exportação, clique em "JSON". Você irá criar um arquivo "All articles.json".' + readability: + page_title: 'Importar > Readability' + description: 'Este importador pode importar todos os artigos do Readability. Nas página ferramentas (https://www.readability.com/tools/), clique em "Export your data" na seção "Data Export". Você receberá um e-mail para fazer o download de um json (que de fato não termina com .json).' + how_to: 'Por favor, selecione sua exportação do Readability e clique no botão abaixo para importá-la.' + worker: + enabled: "A importação é feita assíncronamente. Uma vez que a tarefa de importação é iniciada, um trabalho externo pode executar tarefas uma por vez. O serviço atual é:" + firefox: + page_title: 'Importar > Firefox' + description: "Com este importador você importa todos os favoritos de seu Firefox. Somente vá até seus favoritos (Ctrl+Maj+O), e em \"Importar e Backup\" e escolha \"Backup...\". Você terá então um arquivo .json." + how_to: "Por favor, escolha o arquivo de backup dos favoritos e clique no botão abaixo para importá-lo. Note que o processo pode demorar até que todos os artigos tenham sido copiados." + chrome: + page_title: 'Importar > Chrome' + description: "Com este importador você importa todos os favoritos de seu Chrome. A localização do arquivo depende de seu sistema operacional:
  • Em Linux, vá para o diretório ~/.config/chromium/Default/
  • Em Windows, ele deve estar em %LOCALAPPDATA%\\Google\\Chrome\\User Data\\Default
  • Em OS X, ele deve estar em ~/Library/Application Support/Google/Chrome/Default/Bookmarks
Uma vez que você pegou o arquivo, copie-o para algum lugar que você o encontre.
Note que se você possui o Chromium ao invés do Chrome, você precisa corrigir os caminhos.

" + how_to: "Por favor, escolha o arquivo de backup dos favoritos e clique no botão abaixo para importá-lo. Note que o processo pode demorar até que todos os artigos tenham sido copiados." + instapaper: + page_title: 'Importar > Instapaper' + description: 'Este importador pode importar todos os artigos do seu Instapaper. Nas página de configurações (https://www.instapaper.com/user), clique em "Download .CSV file" na seção "Export". Um arquivo CSV será baixado (algo como "instapaper-export.csv").' + how_to: 'Por favor, selecione sua exportação do seu Instapaper e clique no botão abaixo para importá-la.' + +developer: + page_title: 'Desenvolvedor' + welcome_message: 'Bem-vindo a API do wallabag' + documentation: 'Documentação' + how_to_first_app: 'Como criar minha primeira aplicação' + full_documentation: 'Ver a documentação completa da API' + list_methods: 'Lista de métodos da API' + clients: + title: 'Clientes' + create_new: 'Criar um novo cliente' + existing_clients: + title: 'Clientes existentes' + field_id: 'ID do cliente' + field_secret: 'Chave do cliente' + field_uris: 'URIs de redirecionamento' + field_grant_types: 'Tipo permitido' + no_client: 'Nenhum cliente até agora.' + remove: + warn_message_1: 'Você tem permissão pare remover este cliente. Esta ação é IRREVERSÍVEL !' + warn_message_2: 'Se você remover isso, todo o aplicativo configurado com este cliente não poderá se autenticar no seu wallabag.' + action: 'Remover este cliente' + client: + page_title: 'Desenvolvedor > Novo cliente' + page_description: 'Você está prestes a criar um novo cliente. Por favor preencha o campo abaixo para a URI de redirecionamento de sua aplicação.' + form: + name_label: 'Nome do cliente' + redirect_uris_label: 'URIs de redirecionamento' + save_label: 'Criar um novo cliente' + action_back: 'Voltar' + client_parameter: + page_title: 'Desenvolvedor > Parâmetros de clientes' + page_description: 'Aqui estão os parâmetros de seus clientes.' + field_name: 'Nome do cliente' + field_id: 'ID do cliente' + field_secret: 'Chave do cliente' + back: 'Voltar' + read_howto: 'Leia o how-to "Criar minha primeira aplicação"' + howto: + page_title: 'Desenvolvedor > Criar minha primeira aplicação' + description: + paragraph_1: 'Os seguintes comandos fazem uso da biblioteca HTTPie. Tenha certeza que ela está instalada em seu servidor antes de usá-la.' + paragraph_2: 'Você precisa de um token para a comunicação entre sua aplicação terceira e a API do wallabag.' + paragraph_3: 'Para criar este token, você precisa criar um novo cliente.' + paragraph_4: 'Agora, crie seu token (altere client_id, client_secret, username e password com os valores corretos):' + paragraph_5: 'A API pode retornar uma resposta como essa:' + paragraph_6: 'O access_token é utilizável para fazer uma chamada para o endpoint da API. Por exemplo:' + paragraph_7: 'Esta chamada pode retornar todas as entradas de seu usuário.' + paragraph_8: 'Se você deseja ver todos os endpoints da API, dê uma olhada em nossa documentação da API.' + back: 'Voltar' + +user: + page_title: 'Gerenciamento de Usuários' + new_user: 'Criar um novo usuário' + edit_user: 'Editar um usuário existente' + description: 'Aqui você gerencia todos os usuários (cria, edita e apaga)' + list: + actions: 'Ações' + edit_action: 'Editar' + yes: 'Sim' + no: 'Não' + create_new_one: 'Criar um novo usuário' + form: + username_label: 'Nome de Usuário' + name_label: 'Nome' + password_label: 'Senha' + repeat_new_password_label: 'Repita a nova senha' + plain_password_label: '????' + email_label: 'E-mail' + enabled_label: 'Habilitado' + locked_label: 'Travado' + last_login_label: 'Último login' + twofactor_label: 'Autenticação de dois passos' + save: 'Salvar' + delete: 'Apagar' + delete_confirm: 'Tem certeza?' + back_to_list: 'Voltar para a lista' + +flashes: + config: + notice: + config_saved: 'Configiração salva. Alguns parâmetros podem ser considerados depois da desconexão.' + password_updated: 'Senha atualizada' + password_not_updated_demo: 'Em modo de demonstração, você não pode alterar a senha deste usuário.' + user_updated: 'Informação atualizada' + rss_updated: 'Informação de RSS atualizada' + tagging_rules_updated: 'Regras de tags atualizadas' + tagging_rules_deleted: 'Regra de tag apagada' + rss_token_updated: 'Token RSS atualizado' + entry: + notice: + entry_already_saved: 'Entrada já foi salva em %date%' + entry_saved: 'Entrada salva' + entry_saved_failed: 'Failed to save entry' + entry_updated: 'Entrada atualizada' + entry_reloaded: 'Entrada recarregada' + entry_reloaded_failed: 'Falha em recarregar a entrada' + entry_archived: 'Entrada arquivada' + entry_unarchived: 'Entrada desarquivada' + entry_starred: 'Entrada destacada' + entry_unstarred: 'Entrada não destacada' + entry_deleted: 'Entrada apagada' + tag: + notice: + tag_added: 'Tag adicionada' + import: + notice: + failed: 'Importação falhou, por favor tente novamente.' + failed_on_file: 'Erro ao processar a importação. Por favor verifique seu arquivo de importação.' + summary: 'relatório de importação: %imported% importados, %skipped% já existem.' + summary_with_queue: 'Importar sumáario: %queued% agendados.' + error: + redis_enabled_not_installed: 'O Redis está habilitado para importação assíncrona mas parece que não podemos nos conectar nele. Por favor verifique as configurações do Redis.' + rabbit_enabled_not_installed: 'O RabbitMQ está habilitado para importação assíncrona mas parece que não podemos nos conectar nele. Por favor verifique as configurações do RabbitMQ.' + developer: + notice: + client_created: 'Novo cliente criado.' + client_deleted: 'Cliente removido' + user: + notice: + added: 'Usuário "%username%" adicionado' + updated: 'Usuário "%username%" atualizado' + deleted: 'Usuário "%username%" removido' diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.ro.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.ro.yml index 152d5020..875c82e8 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.ro.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.ro.yml @@ -137,7 +137,7 @@ entry: # starred: 'Starred entries' # archived: 'Archived entries' # filtered: 'Filtered entries' - # filtered_tags: 'Filtered by tags' + # filtered_tags: 'Filtered by tags:' # untagged: 'Untagged entries' list: # number_on_the_page: '{0} There is no entry.|{1} There is one entry.|]1,Inf[ There are %count% entries.' @@ -445,6 +445,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/messages.tr.yml b/src/Wallabag/CoreBundle/Resources/translations/messages.tr.yml index a2eca59b..f50f629a 100644 --- a/src/Wallabag/CoreBundle/Resources/translations/messages.tr.yml +++ b/src/Wallabag/CoreBundle/Resources/translations/messages.tr.yml @@ -136,7 +136,7 @@ entry: # starred: 'Starred entries' # archived: 'Archived entries' # filtered: 'Filtered entries' - # filtered_tags: 'Filtered by tags' + # filtered_tags: 'Filtered by tags:' # untagged: 'Untagged entries' list: number_on_the_page: '{0} Herhangi bir makale yok.|{1} Burada bir adet makale var.|]1,Inf[ Burada %count% adet makale var.' @@ -444,6 +444,9 @@ user: # delete_confirm: Are you sure? # back_to_list: Back to list +error: + # page_title: An error occurred + flashes: config: notice: diff --git a/src/Wallabag/CoreBundle/Resources/translations/validators.pt.yml b/src/Wallabag/CoreBundle/Resources/translations/validators.pt.yml new file mode 100644 index 00000000..49890830 --- /dev/null +++ b/src/Wallabag/CoreBundle/Resources/translations/validators.pt.yml @@ -0,0 +1,6 @@ +validator: + password_must_match: 'Os campos de senha devem coincidir.' + password_too_short: 'A senha deve ter pelo menos 8 caracteres' + password_wrong_value: 'A senha atual informada está errada' + item_per_page_too_high: 'Certamente isso pode matar a aplicação' + rss_limit_too_hight: 'Certamente isso pode matar a aplicação' diff --git a/src/Wallabag/CoreBundle/Resources/views/themes/baggy/Entry/entries.html.twig b/src/Wallabag/CoreBundle/Resources/views/themes/baggy/Entry/entries.html.twig index 3af88b23..f19f2922 100644 --- a/src/Wallabag/CoreBundle/Resources/views/themes/baggy/Entry/entries.html.twig +++ b/src/Wallabag/CoreBundle/Resources/views/themes/baggy/Entry/entries.html.twig @@ -1,7 +1,11 @@ {% extends "WallabagCoreBundle::layout.html.twig" %} {% block title %} - {% include "@WallabagCore/themes/common/Entry/_title.html.twig" %} + {% set currentTag = '' %} + {% if tag is defined %} + {% set currentTag = tag %} + {% endif %} + {% include "@WallabagCore/themes/common/Entry/_title.html.twig" with {'currentTag': currentTag} %} {% endblock %} {% block content %} diff --git a/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/_title.html.twig b/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/_title.html.twig index d1c2f203..92cabdd9 100644 --- a/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/_title.html.twig +++ b/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/_title.html.twig @@ -7,7 +7,7 @@ {% elseif currentRoute == 'all' %} {{ 'entry.page_titles.filtered'|trans }} {% elseif currentRoute == 'tag_entries' %} - {{ 'entry.page_titles.filtered_tags'|trans }} + {{ 'entry.page_titles.filtered_tags'|trans }} {{ currentTag }} {% elseif currentRoute == 'untagged' %} {{ 'entry.page_titles.untagged'|trans }} {% else %} diff --git a/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/share.html.twig b/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/share.html.twig index 804adb36..f77264c6 100644 --- a/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/share.html.twig +++ b/src/Wallabag/CoreBundle/Resources/views/themes/common/Entry/share.html.twig @@ -39,7 +39,7 @@ - +
diff --git a/src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entries.html.twig b/src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entries.html.twig index 919f94ec..5c7cfd65 100644 --- a/src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entries.html.twig +++ b/src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entries.html.twig @@ -1,7 +1,11 @@ {% extends "WallabagCoreBundle::layout.html.twig" %} {% block title %} - {% include "@WallabagCore/themes/common/Entry/_title.html.twig" %} + {% set currentTag = '' %} + {% if tag is defined %} + {% set currentTag = tag %} + {% endif %} + {% include "@WallabagCore/themes/common/Entry/_title.html.twig" with {'currentTag': currentTag} %} {% endblock %} {% block content %} diff --git a/src/Wallabag/CoreBundle/Twig/WallabagExtension.php b/src/Wallabag/CoreBundle/Twig/WallabagExtension.php index 783cde3e..a305c53f 100644 --- a/src/Wallabag/CoreBundle/Twig/WallabagExtension.php +++ b/src/Wallabag/CoreBundle/Twig/WallabagExtension.php @@ -138,8 +138,11 @@ class WallabagExtension extends \Twig_Extension implements \Twig_Extension_Globa $interval = $user->getCreatedAt()->diff(new \DateTime('now')); $nbDays = (int) $interval->format('%a') ?: 1; + // force setlocale for date translation + setlocale(LC_TIME, strtolower($user->getConfig()->getLanguage()).'_'.strtoupper(strtolower($user->getConfig()->getLanguage()))); + return $this->translator->trans('footer.stats', [ - '%user_creation%' => $user->getCreatedAt()->format('F jS, Y'), + '%user_creation%' => strftime('%e %B %Y', $user->getCreatedAt()->getTimestamp()), '%nb_archives%' => $nbArchives, '%per_day%' => round($nbArchives / $nbDays, 2), ]); diff --git a/src/Wallabag/ImportBundle/Consumer/AbstractConsumer.php b/src/Wallabag/ImportBundle/Consumer/AbstractConsumer.php index 2b85ad76..b893ea29 100644 --- a/src/Wallabag/ImportBundle/Consumer/AbstractConsumer.php +++ b/src/Wallabag/ImportBundle/Consumer/AbstractConsumer.php @@ -50,9 +50,10 @@ abstract class AbstractConsumer $entry = $this->import->parseEntry($storedEntry); if (null === $entry) { - $this->logger->warning('Unable to parse entry', ['entry' => $storedEntry]); + $this->logger->warning('Entry already exists', ['entry' => $storedEntry]); - return false; + // return true to skip message + return true; } try { diff --git a/src/Wallabag/ImportBundle/Import/BrowserImport.php b/src/Wallabag/ImportBundle/Import/BrowserImport.php index 9d75685b..2ca1683b 100644 --- a/src/Wallabag/ImportBundle/Import/BrowserImport.php +++ b/src/Wallabag/ImportBundle/Import/BrowserImport.php @@ -139,12 +139,24 @@ abstract class BrowserImport extends AbstractImport public function parseEntry(array $importedEntry) { if ((!array_key_exists('guid', $importedEntry) || (!array_key_exists('id', $importedEntry))) && is_array(reset($importedEntry))) { + if ($this->producer) { + $this->parseEntriesForProducer($importedEntry); + + return; + } + $this->parseEntries($importedEntry); return; } if (array_key_exists('children', $importedEntry)) { + if ($this->producer) { + $this->parseEntriesForProducer($importedEntry['children']); + + return; + } + $this->parseEntries($importedEntry['children']); return; diff --git a/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php b/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php index 9b03a519..05113650 100644 --- a/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php +++ b/tests/Wallabag/CoreBundle/Controller/EntryControllerTest.php @@ -359,11 +359,49 @@ class EntryControllerTest extends WallabagCoreTestCase $content = $em ->getRepository('WallabagCoreBundle:Entry') - ->findByUrlAndUserId($this->url, $this->getLoggedInUserId()); + ->find($content->getId()); $this->assertNotEmpty($content->getContent()); } + /** + * @depends testPostNewOk + */ + public function testReloadWithFetchingFailed() + { + $this->logInAs('admin'); + $client = $this->getClient(); + + $em = $client->getContainer() + ->get('doctrine.orm.entity_manager'); + + $content = $em + ->getRepository('WallabagCoreBundle:Entry') + ->findByUrlAndUserId($this->url, $this->getLoggedInUserId()); + + // put a known failed url + $content->setUrl('http://0.0.0.0/failed.html'); + $em->persist($content); + $em->flush(); + + $client->request('GET', '/reload/'.$content->getId()); + + $this->assertEquals(302, $client->getResponse()->getStatusCode()); + + // force EntityManager to clear previous entity + // otherwise, retrieve the same entity will retrieve change from the previous request :0 + $em->clear(); + $newContent = $em + ->getRepository('WallabagCoreBundle:Entry') + ->find($content->getId()); + + $newContent->setUrl($this->url); + $em->persist($newContent); + $em->flush(); + + $this->assertNotEquals($client->getContainer()->getParameter('wallabag_core.fetching_error_message'), $newContent->getContent()); + } + public function testEdit() { $this->logInAs('admin'); diff --git a/tests/Wallabag/ImportBundle/Consumer/RedisEntryConsumerTest.php b/tests/Wallabag/ImportBundle/Consumer/RedisEntryConsumerTest.php index 5e8ee41d..01a92ad2 100644 --- a/tests/Wallabag/ImportBundle/Consumer/RedisEntryConsumerTest.php +++ b/tests/Wallabag/ImportBundle/Consumer/RedisEntryConsumerTest.php @@ -219,7 +219,7 @@ JSON; $res = $consumer->manage($body); - $this->assertFalse($res); + $this->assertTrue($res); $this->assertFalse($consumer->isStopJob($body)); } }