funkwhale/docs/locales/gettext/developers/plugins.pot

174 wiersze
5.8 KiB
Plaintext

# SOME DESCRIPTIVE TITLE.
# Copyright (C) 2022, The Funkwhale Collective
# This file is distributed under the same license as the funkwhale package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: funkwhale 1.2.3\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2022-04-04 09:00+0200\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
#: ../../developers/plugins.rst:2
msgid "Funkwhale plugins"
msgstr ""
#: ../../developers/plugins.rst:4
msgid "Starting with Funkwhale 1.0, it is now possible to implement new features via plugins."
msgstr ""
#: ../../developers/plugins.rst:7
msgid "Some plugins are maintained by the Funkwhale team (e.g. this is the case of the ``scrobbler`` plugin), or by third-parties."
msgstr ""
#: ../../developers/plugins.rst:11
msgid "Installing a plugin"
msgstr ""
#: ../../developers/plugins.rst:13
msgid "To install a plugin, ensure its directory is present in the ``FUNKWHALE_PLUGINS_PATH`` directory."
msgstr ""
#: ../../developers/plugins.rst:15
msgid "Then, add its name to the ``FUNKWHALE_PLUGINS`` environment variable, like this::"
msgstr ""
#: ../../developers/plugins.rst:19
msgid "We provide a command to make it easy to install third-party plugins::"
msgstr ""
#: ../../developers/plugins.rst:25
msgid "If you use the command, you will still need to append the plugin name to ``FUNKWHALE_PLUGINS``"
msgstr ""
#: ../../developers/plugins.rst:29
msgid "Types of plugins"
msgstr ""
#: ../../developers/plugins.rst:31
msgid "There are two types of plugins:"
msgstr ""
#: ../../developers/plugins.rst:33
msgid "Plugins that are accessible to end-users, a.k.a. user-level plugins. This is the case of our Scrobbler plugin"
msgstr ""
#: ../../developers/plugins.rst:34
msgid "Pod-level plugins that are configured by pod admins and are not tied to a particular user"
msgstr ""
#: ../../developers/plugins.rst:36
msgid "Additionally, user-level plugins can be regular plugins or source plugins. A source plugin provides a way to import files from a third-party service, e.g via webdav, FTP or something similar."
msgstr ""
#: ../../developers/plugins.rst:40
msgid "Hooks and filters"
msgstr ""
#: ../../developers/plugins.rst:42
msgid "Funkwhale includes two kind of entrypoints for plugins to use: hooks and filters. B"
msgstr ""
#: ../../developers/plugins.rst:44
msgid "Hooks should be used when you want to react to some change. For instance, the ``LISTENING_CREATED`` hook notify each registered callback that a listening was created. Our ``scrobbler`` plugin has a callback registered to this hook, so that it can notify Last.fm properly:"
msgstr ""
#: ../../developers/plugins.rst:57
msgid "Filters work slightly differently, and expect callbacks to return a value that will be used by Funkwhale."
msgstr ""
#: ../../developers/plugins.rst:59
msgid "For instance, the ``PLUGINS_DEPENDENCIES`` filter can be used as a way to install additional dependencies needed by your plugin:"
msgstr ""
#: ../../developers/plugins.rst:72
msgid "To sum it up, hooks are used when you need to react to something, and filters when you need to alter something."
msgstr ""
#: ../../developers/plugins.rst:75
msgid "Writing a plugin"
msgstr ""
#: ../../developers/plugins.rst:77
msgid "Regardless of the type of plugin you want to write, lots of concepts are similar."
msgstr ""
#: ../../developers/plugins.rst:79
msgid "First, a plugin need three files:"
msgstr ""
#: ../../developers/plugins.rst:81
msgid "a ``__init__.py`` file, since it's a Python package"
msgstr ""
#: ../../developers/plugins.rst:82
msgid "a ``funkwhale_startup.py`` file, that is loaded during Funkwhale initialization"
msgstr ""
#: ../../developers/plugins.rst:83
msgid "a ``funkwhale_ready.py`` file, that is loaded when Funkwhale is configured and ready"
msgstr ""
#: ../../developers/plugins.rst:85
msgid "So your plugin directory should look like this::"
msgstr ""
#: ../../developers/plugins.rst:92
msgid "Now, let's write our plugin!"
msgstr ""
#: ../../developers/plugins.rst:94
msgid "``funkwhale_startup.py`` is where you declare your plugin and it's configuration options:"
msgstr ""
#: ../../developers/plugins.rst:114
msgid "Now that our plugin is declared and configured, let's implement actual functionality in ``funkwhale_ready.py``:"
msgstr ""
#: ../../developers/plugins.rst:149
msgid "And that's pretty much it. Now, login, visit https://yourpod.domain/settings/plugins, set a value in the ``greeting`` field and enable the plugin."
msgstr ""
#: ../../developers/plugins.rst:151
msgid "After that, you should be greeted properly if you go to https://yourpod.domain/greeting."
msgstr ""
#: ../../developers/plugins.rst:154
msgid "Hooks reference"
msgstr ""
#: ../../docstring of config.plugins.LISTENING_CREATED:1
msgid "Called when a track is being listened"
msgstr ""
#: ../../developers/plugins.rst:159
msgid "Filters reference"
msgstr ""
#: ../../docstring of config.plugins.PLUGINS_DEPENDENCIES:1
msgid "Called with an empty list, use this filter to append pip dependencies to the list for installation."
msgstr ""
#: ../../docstring of config.plugins.PLUGINS_APPS:1
msgid "Called with an empty list, use this filter to append apps to INSTALLED_APPS"
msgstr ""
#: ../../docstring of config.plugins.MIDDLEWARES_BEFORE:1
msgid "Called with an empty list, use this filter to prepend middlewares to MIDDLEWARE"
msgstr ""
#: ../../docstring of config.plugins.MIDDLEWARES_AFTER:1
msgid "Called with an empty list, use this filter to append middlewares to MIDDLEWARE"
msgstr ""
#: ../../docstring of config.plugins.URLS:1
msgid "Called with an empty list, use this filter to register new urls and views"
msgstr ""