Actions

Plugins - advanced/pl: Difference between revisions

From LimeSurvey Manual

Maren.fritz (talk | contribs)
Created page with "<syntaxhighlight lang="php"> $mySetting = $this->get('mySetting', null, null, 10); // 10 jest wartością domyślną </syntaxhighlight>"
m Text replacement - "http://manual.limesurvey.org" to "https://manual.limesurvey.org"
 
(74 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<languages />
<languages />
<span id="Overview"></span>
== Przegląd ==
== Przegląd ==


Line 10: Line 11:
Wtyczki muszą implementować interfejs [https://github.com/LimeSurvey/LimeSurvey/blob/master/application/libraries/PluginManager/iPlugin.php iPlugin]. Zalecamy rozszerzenie klasy wtyczki z klasy [https://github.com/LimeSurvey/LimeSurvey/blob/master/application/libraries/PluginManager/PluginBase.php PluginBase].  
Wtyczki muszą implementować interfejs [https://github.com/LimeSurvey/LimeSurvey/blob/master/application/libraries/PluginManager/iPlugin.php iPlugin]. Zalecamy rozszerzenie klasy wtyczki z klasy [https://github.com/LimeSurvey/LimeSurvey/blob/master/application/libraries/PluginManager/PluginBase.php PluginBase].  


Wtyczki są opracowywane w oparciu o mechanizm [http://manual.limesurvey.org/Plugin_events event].
Wtyczki są opracowywane w oparciu o mechanizm [https://manual.limesurvey.org/Plugin_events event].


<span id="Plugin_settings"></span>
== Ustawienia wtyczki ==
== Ustawienia wtyczki ==


Line 76: Line 78:
</syntaxhighlight>
</syntaxhighlight>


== Events ==
=== Survey specific plugin settings ===


Plugins subscribe to events and can interact with LimeSurvey when the event is fired. For a list of currently available events check [[Plugin events]].
Two events are used to create survey specific plugin settings:
 
* newSurveySettings
* beforeSurveySettings
 
Example to disable a plugin for a specific survey:
 
<syntaxhighlight lang="php">
 
    public function init()
    {
        $this->subscribe('beforeSurveySettings');
        $this->subscribe('newSurveySettings');
        // Other events...
    }
 
    public function beforeSurveySettings()
    {
    $event = $this->event;
    $surveyId = intval($event->get('survey'));
 
        $event->set(
            "surveysettings.{$this->id}",
            [
                'name' => get_class($this),
                'settings' => [
                    'isActive' => [
                        'type' => 'boolean',
                        'label' => 'isActive',
                        'current' => $this->getIsActive($surveyId),
                        'help' => 'Activate plugin for this survey'
                    ],
                ]
            ]
        );
    }
 
    public function newSurveySettings()
    {
        $event = $this->event;
        foreach ($event->get('settings') as $name => $value)
        {
            $this->set($name, $value, 'Survey', $event->get('survey'), false);
        }
    }
 
    private function getIsActive(int $sid): bool
    {
        return (bool) $this->get('isActive', 'Survey', $sid, false);
    }
</syntaxhighlight>
 
<span id="Events"></span>
== Wydarzenia ==
 
Wtyczki subskrybują zdarzenia i mogą wchodzić w interakcję z LimeSurvey po uruchomieniu zdarzenia. Listę aktualnie dostępnych wydarzeń znajdziesz w [[Wydarzenia wtyczek]].


== API ==
== API ==


Plugins should only extend LimeSurvey via its "public" API. This means that directly using classes found in the source code is a bad practice. Though we can't force you not to, you risk having a broken plugin with every minor update we do.
Wtyczki powinny rozszerzać LimeSurvey wyłącznie poprzez jego „publiczne” API. Oznacza to, że bezpośrednie używanie klas znajdujących się w kodzie źródłowym jest złą praktyką. Chociaż nie możemy Cię do tego zmusić, ryzykujesz uszkodzeniem wtyczki przy każdej drobnej aktualizacji, którą przeprowadzamy.


As much as possible interact with LimeSurvey only via methods described [http://api.limesurvey.org/classes/LimeSurvey.PluginManager.LimesurveyApi.html here]. Same as for events.
W miarę możliwości korzystaj z LimeSurvey wyłącznie metodami opisanymi [http://api.limesurvey.org/classes/LimeSurvey.PluginManager.LimesurveyApi.html tutaj]. Podobnie jak w przypadku wydarzeń.


The API object is available via <code>$this->api</code> when extending from PluginBase, otherwise you can get it from the PluginManager instance that is passed to your plugins' constructor.
Obiekt API jest dostępny poprzez <code>$this->api</code> podczas rozszerzania z PluginBase, w przeciwnym razie można go pobrać z instancji PluginManager, która jest przekazywana do konstruktora wtyczek.


New functions can be added to the API object upon request.
Na życzenie do obiektu API można dodać nowe funkcje.


== Form extension{{NewIn|v=6}} ==
<span id="Form_extension{{NewIn|v=6}}"></span>
== Rozszerzenie formularza{{NewIn|v=6}} ==


=== Introduction ===
<span id="Introduction"></span>
=== Wprowadzenie ===


The form extension system is a more general way to extend forms in core LimeSurvey without adding a new event for each form.
System rozszerzania formularzy to bardziej ogólny sposób rozszerzania formularzy w rdzeniu LimeSurvey bez dodawania nowego zdarzenia dla każdego formularza.


It consists of the following components:
Składa się z następujących elementów:


* A global module called '''FormExtensionService'''
* Globalny moduł o nazwie „FormExtensionService”
* A library of '''input classes''' that plugins can add to above module initialization
* Biblioteka „klas wejściowych”, które wtyczki mogą dodawać do powyższej inicjalizacji modułu
* A '''widget''', together with custom renderers, that are used in the LimeSurvey view files
* „Widżet” wraz z niestandardowe moduły renderujące, które są używane w plikach widoku LimeSurvey


Each form is identified by a '''position string''', like <form name><dot><tab name>. Example: <code>globalsettings.general</code> or <code>globalsettings.security</code>.
Każdy formularz jest identyfikowany przez „ciąg pozycji”, np<form name><dot><tab name> . Przykład: <code>globalsettings.general</code> lub <code>globalsettings.security</code> .


The point behind a class-based system without HTML is to free the plugin authors of the work to update the HTML when the core HTML changes. Still, the author can use the <code>RawHtmlInput</code> type if needed.
Ideą systemu opartego na klasach bez HTML jest umożliwienie autorom wtyczek aktualizacji HTML, gdy zmienia się rdzeń HTML. Mimo to autor może w razie potrzeby użyć typu <code>RawHtmlInput</code> .


One thing you cannot do in this system is to add ''new form tabs''.
Jednej rzeczy, której nie można zrobić w tym systemie, to dodać „nowe karty formularzy”.


=== Example ===
<span id="Example"></span>
=== Przykład ===


To add a new input to a form from a plugin, use the following code from your <code>init()</code> function:
Aby dodać nowe dane wejściowe do formularza z wtyczki, użyj następującego kodu z funkcji <code>init()</code> :


TODO: Save in plugin settings instead of global
DO ZROBIENIA: Zapisz w ustawieniach wtyczki zamiast globalnie


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
// At top of file
// Na górze pliku
use LimeSurvey\Libraries\FormExtension\Inputs\TextInput;
użyj LimeSurvey\Libraries\FormExtension\Inputs\TextInput;
use LimeSurvey\Libraries\FormExtension\SaveFailedException;
użyj LimeSurvey\Libraries\FormExtension\SaveFailedException;


// Inside init()
// Wewnątrz init()
Yii::app()->formExtensionService->add(
Yii::app()->formExtensionService->add(
    'globalsettings.general',
'globalsettings.general',
    new TextInput([
new TextInput([
        'name' => 'myinput',
'name' => 'moje wejście',  
        'label' => 'Label',
'label' => 'Etykieta',
        'disabled' => true,
'disabled' => true,
        'tooltip' => 'Moo moo moo',
'tooltip' => 'Muu moo moo',
        'help' => 'Some help text',
'help' => 'Tekst pomocy',  
        'save' => function($request, $connection) {
'save' => funkcja($żądanie, $połączenie) {
            $value = $request->getPost('myinput');
$wartość = $żądanie->getPost('moje wejście');
            if ($value === 'some invalid value') {
if ($wartość === 'jakaś niepoprawna wartość') {
                throw new SaveFailedException("Could not save custom input 'myinput'");
rzucaj nowy SaveFailedException("Nie można zapisać niestandardowego wejścia 'moje wejście'");
            } else {
} else {
                SettingGlobal::setSetting('myinput', $value);
SettingGlobal::setSetting('moje wejście', $wartość);
            }
}
        },
} ,
        'load' => function () {
'load' => funkcja () {
            return getGlobalSetting('myinput');
return getGlobalSetting('myinput');
        }
}
    ])
])
);
);
</syntaxhighlight>
</syntaxhighlight>


=== Validation ===
<span id="Validation"></span>
=== Walidacja ===


Validation of the input is done in the <code>save</code> function (see example above). If the posted value is invalid, throw a <code>SaveFailedException</code>, and a warning flash message will be shown to the user.
Walidacja danych wejściowych odbywa się w funkcji <code>save</code> (patrz przykład powyżej). Jeśli opublikowana wartość jest nieprawidłowa, zgłoś <code>SaveFailedException</code> , a użytkownikowi zostanie wyświetlony ostrzegawczy komunikat flash.


=== Supported forms ===
<span id="Supported_forms"></span>
=== Obsługiwane formularze ===


The following forms can be extended:
Można rozszerzyć następujące formy:


* globalsettings.general{{NewIn|v=6.0.0}}
* globalsettings.general{{NewIn|v=6.0.0}}


If you want to add support for another core form, you need to apply the following change in a pull-request:
Jeśli chcesz dodać obsługę innego formularza podstawowego, musisz zastosować następującą zmianę w żądaniu ściągnięcia:


In the view file, add:
W pliku widoku dodaj:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
<?php
<?php
use LimeSurvey\Libraries\FormExtension\FormExtensionWidget;
use LimeSurvey\Libraries\FormExtension\FormExtensionWidget;
use LimeSurvey\Libraries\FormExtension\Inputs\DefaultBaseRenderer;
use LimeSurvey\Libraries\FormExtension\Inputs\DefaultBaseRenderer;
?>
?>  
... more HTML
... więcej HTML
<?= FormExtensionWidget::render(
<?= FormExtensionWidget::render(
     App()->formExtensionService->getAll('globalsettings.security'),
     App()-> formExtensionService->getAll('globalsettings.security'),
    new DefaultBaseRenderer()
nowy DefaultBaseRenderer()
); ?>
); ?>
</syntaxhighlight>
</syntaxhighlight>


You might have to create a new renderer class based on <code>DefaultBaseRenderer</code>, if the form HTML is different than other forms. You might also need to extend the default renderer class with input types not yet added.
Być może będziesz musiał utworzyć nową klasę renderującą opartą na <code>DefaultBaseRenderer</code> , jeśli formularz HTML różni się od innych formularzy. Może być także konieczne rozszerzenie domyślnej klasy modułu renderującego o typy danych wejściowych, które nie zostały jeszcze dodane.


The second change you have to do is add a call to the form extension service class in the controller action that saves the form:
Drugą zmianą, którą musisz wykonać, jest dodanie wywołania klasy usługi rozszerzenia formularza w akcji kontrolera, która zapisuje formularz:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
Line 178: Line 240:
</syntaxhighlight>
</syntaxhighlight>


That's it!
Otóż to!


== Localization {{NewIn|v=3}} ==
<span id="Localization_{{NewIn|v=3}}"></span>
== Lokalizacja {{NewIn|v=3}} ==


It's possible for plugins to add their own locale files. File format used is .mo, same as core translations. The files must be stored in
Wtyczki mogą dodawać własne pliki regionalne. Używany format pliku to .mo, taki sam jak w przypadku podstawowych tłumaczeń. Pliki muszą być przechowywane w formacie


  <plugin root folder>/locale/<language>/<language>.mo
  <plugin root folder>/widownia/<language> /<language> .mo


where "<language>" is a two letter word like "de" or "fr".
Gdzie "<language> " to dwuliterowe słowo, takie jak "de" lub "fr".


To use the specific locale file, use the plugin function gT:
Aby użyć określonego pliku ustawień regionalnych, użyj funkcji wtyczki gT:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$this->gT("A plugin text that needs to be translated");
$this->gT("Tekst wtyczki do przetłumaczenia");
</syntaxhighlight>
</syntaxhighlight>


If the given string can't be found in the plugin specific locale file, the function will look in the core locale files. So it's safe to use strings like "Cancel":
Jeśli podanego ciągu nie można znaleźć w pliku ustawień regionalnych wtyczki, funkcja przeszuka podstawowe pliki ustawień regionalnych. Można więc bezpiecznie używać ciągów takich jak „Anuluj”:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$this->gT("Cancel"); // Will be translated even if "Cancel" is not in the plugin locale file
$this->gT("Anuluj"); // Zostanie przetłumaczone, nawet jeśli w pliku ustawień regionalnych wtyczki nie ma opcji „Anuluj”
</syntaxhighlight>
</syntaxhighlight>


If you are using views together with your plugin, you should use
Jeśli używasz widoków razem ze swoją wtyczką, powinieneś użyć


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$plugin->gT("Translate me");
$plugin->gT("Przetłumacz mi");
</syntaxhighlight>
</syntaxhighlight>


to do plugin specific translation in your view.
aby w Twoim widoku wykonać tłumaczenie specyficzne dla wtyczki.


You can use the [https://github.com/LimeSurvey/LimeSurvey/blob/master/locale/_template/limesurvey.pot limesurvey.pot] file as an example of how a pot file can look like. This is imported into your translation tool.
Możesz użyć pliku [https://github.com/LimeSurvey/LimeSurvey/blob/master/locale/_template/limesurvey.pot limesurvey.pot] jako przykładu wyglądu pliku pot. Zostanie to zaimportowane do Twojego narzędzia do tłumaczenia.


=== Tools ===
<span id="Tools"></span>
=== Narzędzia ===


One open-source tool to edit po- and mo-files is [https://poedit.net/ Poedit].
Jednym z narzędzi typu open source do edycji plików po i mo jest [https://poedit.net/Poedit].


== Logging {{NewIn|v=3}} ==
<span id="Logging_{{NewIn|v=3}}"></span>
== Rejestrowanie {{NewIn|v=3}} ==


If you want to log something from your plugin, just write
Jeśli chcesz zalogować coś ze swojej wtyczki, po prostu napisz


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$this->log("Your message");
$this->log("Twoja wiadomość");
</syntaxhighlight>
</syntaxhighlight>


The default logging level is trace, but you can give another log level as an optional second argument:
Domyślny poziom rejestrowania to śledzenie, ale możesz podać inny poziom rejestrowania jako opcjonalny drugi argument:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$this->log("Something went wrong!", CLogger::LEVEL_ERROR);
$this->log("Coś poszło nie tak!", CLogger::LEVEL_ERROR);
</syntaxhighlight>
</syntaxhighlight>


The log file can be found in folder
Plik dziennika można znaleźć w folderze


  <limesurvey root folder>/tmp/runtime/plugin.log
  <limesurvey root folder>/tmp/runtime/plugin.log


Your plugin name is automatically used as category. A nice way to see only the errors from your plugin is using grep (on Linux):
Nazwa Twojej wtyczki zostanie automatycznie użyta jako kategoria. Dobrym sposobem na wyświetlenie tylko błędów z wtyczki jest użycie grep (w systemie Linux):


  $ tail -f tmp/runtime/plugin.log | grep <your plugin name>
$ tail -f tmp/runtime/plugin.log | grep<your plugin name>


More info about configuring logging in Yii 1: [[Optional_settings#Logging_settings]].
Więcej informacji na temat konfiguracji logowania w Yii 1: [[Optional_settings#Logging_settings]].


== Extension updates {{NewIn|v=4}} ==
<span id="Extension_updates_{{NewIn|v=4}}"></span>
== Aktualizacje rozszerzeń {{NewIn|v=4}} ==


Since LimeSurvey version 4.0.0, there's a system in place to deal with plugin and other extension updates. To use this system, your extension config.xml file needs to include updater configuration.
Od wersji LimeSurvey 4.0.0 dostępny jest system obsługujący aktualizacje wtyczek i innych rozszerzeń. Aby móc korzystać z tego systemu, plik rozszerzenia config.xml musi zawierać konfigurację aktualizatora.


<syntaxhighlight lang="xml">
<syntaxhighlight lang="xml">
<updaters>
<updaters>  
    <updater>
<updater>  
        <stable>1</stable>
<stable> 1</stable>  
        <type>rest</type>
<type> odpoczynek</type>  
        <source>https://comfortupdate.limesurvey.org/index.php?r=limestorerest</source>
<source> https://comfortupdate.limesurvey.org/index.php?r=limestorerest</source>  
        <manualUpdateUrl>https://somedownloadlink.com/maybegithub</manualUpdateUrl>
<manualUpdateUrl> https://somedownloadlink.com/maybegithub</manualUpdateUrl>  
    </updater>
</updater>  
</updaters>
</updaters>  
</syntaxhighlight>
</syntaxhighlight>


(The source tag above points to the LimeStore REST API, which will be used for all extensions available in our LimeStore.)
(Powyższy tag źródłowy wskazuje na interfejs API REST LimeStore, który będzie używany we wszystkich rozszerzeniach dostępnych w naszym LimeStore.)


{| class="wikitable"
{| class="wikitable"
|+ Updater tag descriptions
|+ Opisy znaczników aktualizacji
|-
|-
! Tag
! Oznacz
! Description
! Opis
|-
|-
| stable
| stabilny
| "1" if this source only gives you stable version numbers; "0" if the source will also provide unstable versions, like <code>0.3.3-beta</code>.
| „1”, jeśli to źródło podaje tylko stabilne numery wersji; „0”, jeśli źródło będzie również dostarczać wersje niestabilne, np. <code>0.3.3-beta</code> .
|-
|-
| type
| wpisz
| For now, only type <code>rest</code> is supported. It's easy to add new updater types (version checkers), like git, wget, etc.
| Na razie obsługiwany jest tylko typ <code>rest</code> . Dodawanie nowych typów aktualizacji (wersji sprawdzających), takich jak git, wget itp., jest łatwe
|-
|-
| source
| źródło
| The URL to fetch new versions from.
| Adres URL, z którego można pobrać nowe wersje.
|-
|-
| manualUpdateUrl  
| manualUpdateUrl  
| URL which the user can go to to update the latest version of the extension.
| Adres URL, pod który użytkownik może przejść, aby zaktualizować najnowszą wersję rozszerzenia.
|-
|-
| automaticUpdateUrl
| automatycznyUpdateUrl
| TODO
| DO ZROBIENIA
|}
|}


If you don't want to supply an updater, you should put the following text in your config XML file:
Jeśli nie chcesz dostarczać aktualizatora, powinieneś umieścić następujący tekst w pliku konfiguracyjnym XML:


<syntaxhighlight lang="xml">
<syntaxhighlight lang="xml">
<updaters disabled="disabled">
<updaters disabled="disabled">  
</updaters>
</updaters>  
</syntaxhighlight>
</syntaxhighlight>


This way, you tell the system that you purposefully disabled the update system, and didn't just forget to add it.
W ten sposób informujesz system, że celowo wyłączyłeś system aktualizacji i nie zapomniałeś go dodać.


The new plugin '''UpdateCheck''' - installed and activated by default - checks for new updates for ''all'' installed extensions when a super admin logs in, asynchronously, max one time every 24 hours. If any new versions are found, a notification is pushed.
Nowa wtyczka „UpdateCheck” – domyślnie zainstalowana i aktywowana – sprawdza dostępność nowych aktualizacji dla „wszystkich” zainstalowanych rozszerzeń, gdy superadministrator loguje się asynchronicznie, maksymalnie raz na 24 godziny. Jeśli zostaną znalezione nowe wersje, zostanie wyświetlone powiadomienie.


[[File:availableupdates.png||Available updates]]
[[File:availableupdates.png||Dostępne aktualizacje]]


If a new security update is found, the notification will open automatically and be styled in "danger" class.
Jeśli zostanie znaleziona nowa aktualizacja zabezpieczeń, powiadomienie zostanie otwarte automatycznie i będzie oznaczone klasą „niebezpieczeństwo”.


[[File:availablesecurityupdates.png||Available security updates]]
[[File:availablesecurityupdates.png||Dostępne aktualizacje zabezpieczeń]]


You can manually check for updates by going to the plugin manager view and click on "Check updates". Note that this button is only visible if the UpdateCheck plugin is activated.
Możesz ręcznie sprawdzić dostępność aktualizacji, przechodząc do widoku menedżera wtyczek i klikając „Sprawdź aktualizacje”. Pamiętaj, że ten przycisk jest widoczny tylko wtedy, gdy wtyczka UpdateCheck jest aktywna.


[[File:manuallycheckforupdates.png||Manually check for updates]]
[[File:manuallycheckforupdates.png||Ręcznie sprawdź dostępność aktualizacji]]


=== Under the hood ===
<span id="Under_the_hood"></span>
=== Pod maską ===


This section provides a brief overview over the extension updater implementation.
Ta sekcja zawiera krótki przegląd implementacji aktualizatora rozszerzeń.


The extension updater is part of the ExtensionInstaller library. Below is a UML diagram for the classes related to the updater process.
Aktualizator rozszerzeń jest częścią biblioteki ExtensionInstaller. Poniżej znajduje się diagram UML dla klas związanych z procesem aktualizacji.


[[File:extensionupdateruml.png||Extension updater UML diagram]]
[[File:extensionupdateruml.png||Schemat UML aktualizatora rozszerzeń]]


Program flow when Yii starts:
Przebieg programu po uruchomieniu Yii:


<pre>
<pre>
  Yii init
  Yii init
  VersionFetcherServiceLocator->init()
VersionFetcherServiceLocator->init()
    Add REST version fetcher
Dodaj moduł pobierania wersji REST
  ExtensionUpdaterServiceLocator->init()
ExtensionUpdaterServiceLocator->init()
    Add PluginUpdater
Dodaj PluginUpdater
    TODO: Add an updater for each extension type (theme, question template, ...)
DO ZROBIENIA: Dodaj aktualizator dla każdego typu rozszerzenia (motyw, szablon pytania, ...)
</pre>
</pre>


Program flow when running the UpdaterCheck plugin:
Przebieg programu podczas uruchamiania wtyczki UpdaterCheck:


<pre>
<pre>
  Get all updaters from ExtensionUpdaterServiceLocator
  Pobierz wszystkie aktualizacje z ExtensionUpdaterServiceLocator
  Loop each updater
  Zapętlaj każdy aktualizator
  For each updater, loop through version fetchers configured by <updater> XML
Dla każdego aktualizatora przejrzyj moduły pobierania wersji skonfigurowane przez<updater> XML
    For each version fetcher, contact remote source and get version information
W przypadku każdego modułu pobierania wersji skontaktuj się ze zdalnym źródłem i uzyskaj informacje o wersji
  Compose all versions into a notification
  Skomponuj wszystkie wersje w powiadomienie
</pre>
</pre>


The [https://github.com/LimeSurvey/LimeSurvey/blob/develop/application/core/plugins/UpdateCheck/UpdateCheck.php#L130 checkAll] method in the UpdateCheck plugin provides an example of how to query all extensions for new versions.
Metoda [https://github.com/LimeSurvey/LimeSurvey/blob/develop/application/core/plugins/UpdateCheck/UpdateCheck.php#L130 checkAll] we wtyczce UpdateCheck stanowi przykład sprawdzania wszystkich rozszerzeń w celu uzyskania nowych wersji .


==== Adding new version fetchers ====
<span id="Adding_new_version_fetchers"></span>
==== Dodawanie nowych modułów pobierania wersji ====


To add a new custom version fetcher, run this during Yii initialization:
Aby dodać nowy, niestandardowy moduł pobierania wersji, uruchom to podczas inicjalizacji Yii:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$service = \Yii::app()->versionFetcherServiceLocator
$service = \Yii::app()->versionFetcherServiceLocator
$service->addVersionFetcherType(
$service->addVersionFetcherType(
  'myNewVersionFetcherType',
'myNewVersionFetcherType',
  function (\SimpleXMLElement $updaterXml) {
funkcja (\SimpleXMLElement $updaterXml) {
    return new MyNewVersionFetcher($updaterXml);
zwróć nowy MyNewVersionFetcher( $updaterXml);
  }
}
);
);
</syntaxhighlight>
</syntaxhighlight>


Of course, the class <code>MyNewVersionFetcher</code> has to subclass <code>VersionFetcher</code>.
Oczywiście klasa <code>MyNewVersionFetcher</code> musi być podklasą <code>VersionFetcher</code> .


To use your new version fetcher, configure the <code>type</code> tag in the updater XML to use
Aby użyć modułu pobierania nowej wersji, skonfiguruj znacznik <code>type</code> w pliku XML aktualizatora tak, aby używał
<code>myNewVersionFetcherType</code> (instead of e.g. <code>rest</code>).
<code>myNewVersionFetcherType</code> (zamiast np. <code>rest</code> ).


==== Adding new extension updaters ====
<span id="Adding_new_extension_updaters"></span>
==== Dodawanie nowych aktualizacji rozszerzeń ====


To add a new custom extension updater, run this during Yii initialization:
Aby dodać nowy, niestandardowy aktualizator rozszerzeń, uruchom to podczas inicjalizacji Yii:


<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
$service = \Yii::app()->extensionUpdaterServiceLocator;
$service = \Yii::app()->extensionUpdaterServiceLocator;
$service->addUpdaterType(
$service->addUpdaterType(
  'myNewExtensionUpdater',
'myNewExtensionUpdater',
  function () {
funkcja () {
    return MyNewExtensionUpdater::createUpdaters();
return MyNewExtensionUpdater::createUpdaters() ;
  }
}
);
);
</syntaxhighlight>
</syntaxhighlight>


Class <code>MyNewExtensionUpdater</code> has to subclass <code>ExtensionUpdater</code>.
Klasa <code>MyNewExtensionUpdater</code> musi być podklasą <code>ExtensionUpdater</code> .


The top <code>type</code> tag in config.xml ('plugin', 'theme', ...) will control which extension updater are used for this extension. The system is not fully customizable  yet, since you also need to add a custom ExtensionInstaller, menu items, etc. But in theory, and maybe in the future, it should be possible to add a new type of extension this way.
Znacznik najwyższego <code>type</code> w pliku config.xml („wtyczka”, „motyw”, ...) będzie kontrolował, który aktualizator rozszerzenia będzie używany dla tego rozszerzenia. System nie jest jeszcze w pełni konfigurowalny, ponieważ trzeba także dodać niestandardowy ExtensionInstaller, elementy menu itp. Jednak teoretycznie i być może w przyszłości powinno być możliwe dodanie w ten sposób nowego typu rozszerzenia.


== Extension installer ==
<span id="Extension_installer"></span>
== Instalator rozszerzenia ==


The extension installer library consists of two abstract classes:
Biblioteka instalatora rozszerzeń składa się z dwóch klas abstrakcyjnych:


* ExtensionInstaller
* ExtensionInstaller
* FileFetcher
* FileFetcher


The ExtensionInstaller is subclassed for each extension type, like PluginInstaller, QuestionThemeInstaller, etc.
ExtensionInstaller jest podklasą dla każdego typu rozszerzenia, takiego jak PluginInstaller, questionThemeInstaller itp.


The FileFetcher is subclassed for each different way to fetch files. Currently, only uploaded zip files are supported, but in the future, there could be a Github or LimeStore fetcher too.
FileFetcher jest podklasą dla każdego innego sposobu pobierania plików. Obecnie obsługiwane są tylko przesłane pliki ZIP, ale w przyszłości może pojawić się także moduł pobierania Github lub LimeStore.


[[File: extensioninstalleruml.png]]
[[File: extensioninstalleruml.png]]


== Special plugins ==
<span id="Special_plugins"></span>
== Specjalne wtyczki ==


* [[Authentication plugin development]]
* [[Rozwój wtyczki uwierzytelniającej]]
* [[Export plugin development]]
* [[Rozwój wtyczki eksportowej]]


== Available plugins ==
<div class="mw-translate-fuzzy">
* [[Authentication plugins]]
== Dostępne wtyczki ==
* [[Audit log]]
* [[Wtyczki uwierzytelniające]]
* [[Dziennik audytu]]
* [[CintLink]]
* [[CintLink]]
* [[Available third party plugins]]
* [[Dostępne wtyczki innych firm]]
</div>


== Tutorial ==
== Samouczek ==
[https://medium.com/@evently/creating-limesurvey-plugins-adcdf8d7e334 This] step-by-step tutorial shows how to create a plugin that sends a post request on every survey response submission. The tutorial shows you how to create and save global and per-survey settings, how to register events and more.
[https://medium.com/@evently/creating-limesurvey-plugins-adcdf8d7e334 Ten] samouczek krok po kroku pokazuje, jak utworzyć wtyczkę, która wysyła żądanie opublikowania każdej odpowiedzi w ankiecie przedłożona praca. W tym samouczku dowiesz się, jak tworzyć i zapisywać ustawienia globalne i dotyczące poszczególnych ankiet, jak rejestrować zdarzenia i nie tylko.


[[Category:Development]]
[[Kategoria:Rozwój]]
[[Category:Plugins]]
[[Kategoria:Wtyczki]]

Latest revision as of 09:18, 15 October 2024

Przegląd

Począwszy od LimeSurvey 2.05, LimeSurvey będzie oficjalnie wspierać wtyczki. Niektóre wtyczki będą obsługiwane przez zespół LimeSurvey i zostaną włączone do rdzenia. Niektórzy będą wspierani przez innych spoza zespołu LimeSurvey. Aby pomóc je znaleźć, sprawdź Dostępne wtyczki innych firm i dodaj do niej własną wtyczkę!

Wtyczki umożliwiają użytkownikom dostosowanie funkcjonalności ich instalacji, jednocześnie umożliwiając korzystanie z regularnych aktualizacji oprogramowania.

Niniejsza dokumentacja jest przeznaczona dla programistów, którzy rozszerzają LimeSurvey na własny użytek lub dla swoich klientów; ta dokumentacja nie pomoże użytkownikom końcowym.

Wtyczki muszą implementować interfejs iPlugin. Zalecamy rozszerzenie klasy wtyczki z klasy PluginBase.

Wtyczki są opracowywane w oparciu o mechanizm event.

Ustawienia wtyczki

Rozszerzając, zyskujesz wspólną funkcjonalność wymaganą przez wtyczki, które już dla Ciebie wdrożyliśmy. Jedną z takich funkcji jest implementacja funkcji getPluginSettings. Funkcja ta musi zwrócić tablicę opisującą opcje konfiguracyjne dla użytkownika.

Przykładowa wtyczka udostępnia tylko 1 konfigurowalne ustawienie, komunikat, który wyświetli.

protected $settings = array(
 'logo' => array(
 'type' => 'logo',
 'path' => 'assets/logo.png'
 ) ,

'message' => array(
 'type' => 'string',
 'label' => 'Wiadomość'
 )
);

Tablica zawiera nazwę każdego ustawienia jako klucz. Wartości to tablice zawierające wymagane metadane.

Obsługiwane typy to:

  • logo
  • int (liczba całkowita)
  • string (alfanumeryczny)
  • tekst
  • html
  • znaczenie
  • info
  • hasło
  • data
  • wybierz

Oprócz typu dostępnych jest wiele innych klawiszy:

  • label, definiuje etykietę
  • default, definiuje wartość wyświetlaną, jeśli nie określono żadnej wartości (tylko dla ustawień globalnych, nie dla ustawień ankiety)
  • current, definiuje aktualną wartość.
  • readOnly : pokazał ustawienia jako tylko do odczytu
  • htmlOptions, htmlOptions części wejściowej (zobacz podręcznik Yii [[1]])
  • pluginOptions, dla niektóre ustawienia (html lub wybierz): ustaw opcję widgetu
  • labelOptions : htmlOpcje etykiety
  • controlOptions : htmlOpcje opakowania etykiety i danych wejściowych

Przykład wtyczki wykorzystującej wszystkie aktualne ustawienia można znaleźć pod adresem exampleSettings

Odczyt i zapis ustawień wtyczki

Możliwe jest odczytywanie i zapisywanie ustawień wtyczki bezpośrednio z kodu wtyczki.

Przykład:

$mySetting = $this->get('mySetting');
$this->set('mySetting', $mojeSetting + 1);

Możesz uzyskać wartość domyślną, jeśli ustawienie ma wartość null:

$mySetting = $this->get('mySetting', null, null, 10); // 10 jest wartością domyślną

Survey specific plugin settings

Two events are used to create survey specific plugin settings:

  • newSurveySettings
  • beforeSurveySettings

Example to disable a plugin for a specific survey:

   
    public function init()
    {
        $this->subscribe('beforeSurveySettings');
        $this->subscribe('newSurveySettings');
        // Other events...
    }

    public function beforeSurveySettings()
    {
	    $event = $this->event;
	    $surveyId = intval($event->get('survey'));

        $event->set(
            "surveysettings.{$this->id}",
            [
                'name' => get_class($this),
                'settings' => [
                    'isActive' => [
                        'type' => 'boolean',
                        'label' => 'isActive',
                        'current' => $this->getIsActive($surveyId),
                        'help' => 'Activate plugin for this survey'
                    ],
                ]
            ]
        );
    }

    public function newSurveySettings()
    {
        $event = $this->event;
        foreach ($event->get('settings') as $name => $value)
        {
            $this->set($name, $value, 'Survey', $event->get('survey'), false);
        }
    }

    private function getIsActive(int $sid): bool
    {
        return (bool) $this->get('isActive', 'Survey', $sid, false);
    }

Wydarzenia

Wtyczki subskrybują zdarzenia i mogą wchodzić w interakcję z LimeSurvey po uruchomieniu zdarzenia. Listę aktualnie dostępnych wydarzeń znajdziesz w Wydarzenia wtyczek.

API

Wtyczki powinny rozszerzać LimeSurvey wyłącznie poprzez jego „publiczne” API. Oznacza to, że bezpośrednie używanie klas znajdujących się w kodzie źródłowym jest złą praktyką. Chociaż nie możemy Cię do tego zmusić, ryzykujesz uszkodzeniem wtyczki przy każdej drobnej aktualizacji, którą przeprowadzamy.

W miarę możliwości korzystaj z LimeSurvey wyłącznie metodami opisanymi tutaj. Podobnie jak w przypadku wydarzeń.

Obiekt API jest dostępny poprzez $this->api podczas rozszerzania z PluginBase, w przeciwnym razie można go pobrać z instancji PluginManager, która jest przekazywana do konstruktora wtyczek.

Na życzenie do obiektu API można dodać nowe funkcje.

<span id="Form_extension (New in 6 )">

Rozszerzenie formularza (New in 6 )

Wprowadzenie

System rozszerzania formularzy to bardziej ogólny sposób rozszerzania formularzy w rdzeniu LimeSurvey bez dodawania nowego zdarzenia dla każdego formularza.

Składa się z następujących elementów:

  • Globalny moduł o nazwie „FormExtensionService”
  • Biblioteka „klas wejściowych”, które wtyczki mogą dodawać do powyższej inicjalizacji modułu
  • „Widżet” wraz z niestandardowe moduły renderujące, które są używane w plikach widoku LimeSurvey

Każdy formularz jest identyfikowany przez „ciąg pozycji”, np<form name><dot><tab name> . Przykład: globalsettings.general lub globalsettings.security .

Ideą systemu opartego na klasach bez HTML jest umożliwienie autorom wtyczek aktualizacji HTML, gdy zmienia się rdzeń HTML. Mimo to autor może w razie potrzeby użyć typu RawHtmlInput .

Jednej rzeczy, której nie można zrobić w tym systemie, to dodać „nowe karty formularzy”.

Przykład

Aby dodać nowe dane wejściowe do formularza z wtyczki, użyj następującego kodu z funkcji init() :

DO ZROBIENIA: Zapisz w ustawieniach wtyczki zamiast globalnie

// Na górze pliku
użyj LimeSurvey\Libraries\FormExtension\Inputs\TextInput;
użyj LimeSurvey\Libraries\FormExtension\SaveFailedException;

// Wewnątrz init()
Yii::app()->formExtensionService->add(
 'globalsettings.general',
 new TextInput([
 'name' => 'moje wejście', 
 'label' => 'Etykieta',
 'disabled' => true,
 'tooltip' => 'Muu moo moo',
 'help' => 'Tekst pomocy', 
 'save' => funkcja($żądanie, $połączenie) {
 $wartość = $żądanie->getPost('moje wejście');
 if ($wartość === 'jakaś niepoprawna wartość') {
 rzucaj nowy SaveFailedException("Nie można zapisać niestandardowego wejścia 'moje wejście'");
 } else {
 SettingGlobal::setSetting('moje wejście', $wartość);
 }
 } ,
 'load' => funkcja () {
 return getGlobalSetting('myinput');
 }
 ])
);

Walidacja

Walidacja danych wejściowych odbywa się w funkcji save (patrz przykład powyżej). Jeśli opublikowana wartość jest nieprawidłowa, zgłoś SaveFailedException , a użytkownikowi zostanie wyświetlony ostrzegawczy komunikat flash.

Obsługiwane formularze

Można rozszerzyć następujące formy:

  • globalsettings.general (New in 6.0.0 )

Jeśli chcesz dodać obsługę innego formularza podstawowego, musisz zastosować następującą zmianę w żądaniu ściągnięcia:

W pliku widoku dodaj:

 <?php
use LimeSurvey\Libraries\FormExtension\FormExtensionWidget;
use LimeSurvey\Libraries\FormExtension\Inputs\DefaultBaseRenderer;
?> 
... więcej HTML
<?= FormExtensionWidget::render(
    App()-> formExtensionService->getAll('globalsettings.security'),
 nowy DefaultBaseRenderer()
); ?>

Być może będziesz musiał utworzyć nową klasę renderującą opartą na DefaultBaseRenderer , jeśli formularz HTML różni się od innych formularzy. Może być także konieczne rozszerzenie domyślnej klasy modułu renderującego o typy danych wejściowych, które nie zostały jeszcze dodane.

Drugą zmianą, którą musisz wykonać, jest dodanie wywołania klasy usługi rozszerzenia formularza w akcji kontrolera, która zapisuje formularz:

$request = App()->request;
Yii::app()->formExtensionService->applySave('globalsettings', $request);

Otóż to!

<span id="Localization_ (New in 3 )">

Lokalizacja (New in 3 )

Wtyczki mogą dodawać własne pliki regionalne. Używany format pliku to .mo, taki sam jak w przypadku podstawowych tłumaczeń. Pliki muszą być przechowywane w formacie

<plugin root folder>/widownia/<language> /<language> .mo

Gdzie "<language> " to dwuliterowe słowo, takie jak "de" lub "fr".

Aby użyć określonego pliku ustawień regionalnych, użyj funkcji wtyczki gT:

$this->gT("Tekst wtyczki do przetłumaczenia");

Jeśli podanego ciągu nie można znaleźć w pliku ustawień regionalnych wtyczki, funkcja przeszuka podstawowe pliki ustawień regionalnych. Można więc bezpiecznie używać ciągów takich jak „Anuluj”:

$this->gT("Anuluj"); // Zostanie przetłumaczone, nawet jeśli w pliku ustawień regionalnych wtyczki nie ma opcji „Anuluj”

Jeśli używasz widoków razem ze swoją wtyczką, powinieneś użyć

$plugin->gT("Przetłumacz mi");

aby w Twoim widoku wykonać tłumaczenie specyficzne dla wtyczki.

Możesz użyć pliku limesurvey.pot jako przykładu wyglądu pliku pot. Zostanie to zaimportowane do Twojego narzędzia do tłumaczenia.

Narzędzia

Jednym z narzędzi typu open source do edycji plików po i mo jest [2].

<span id="Logging_ (New in 3 )">

Rejestrowanie (New in 3 )

Jeśli chcesz zalogować coś ze swojej wtyczki, po prostu napisz

$this->log("Twoja wiadomość");

Domyślny poziom rejestrowania to śledzenie, ale możesz podać inny poziom rejestrowania jako opcjonalny drugi argument:

$this->log("Coś poszło nie tak!", CLogger::LEVEL_ERROR);

Plik dziennika można znaleźć w folderze

<limesurvey root folder>/tmp/runtime/plugin.log

Nazwa Twojej wtyczki zostanie automatycznie użyta jako kategoria. Dobrym sposobem na wyświetlenie tylko błędów z wtyczki jest użycie grep (w systemie Linux):

$ tail -f tmp/runtime/plugin.log | grep<your plugin name>

Więcej informacji na temat konfiguracji logowania w Yii 1: Optional_settings#Logging_settings.

<span id="Extension_updates_ (New in 4 )">

Aktualizacje rozszerzeń (New in 4 )

Od wersji LimeSurvey 4.0.0 dostępny jest system obsługujący aktualizacje wtyczek i innych rozszerzeń. Aby móc korzystać z tego systemu, plik rozszerzenia config.xml musi zawierać konfigurację aktualizatora.

<updaters> 
<updater> 
<stable> 1</stable> 
<type> odpoczynek</type> 
<source> https://comfortupdate.limesurvey.org/index.php?r=limestorerest</source> 
<manualUpdateUrl> https://somedownloadlink.com/maybegithub</manualUpdateUrl> 
</updater> 
</updaters>

(Powyższy tag źródłowy wskazuje na interfejs API REST LimeStore, który będzie używany we wszystkich rozszerzeniach dostępnych w naszym LimeStore.)

Opisy znaczników aktualizacji
Oznacz Opis
stabilny „1”, jeśli to źródło podaje tylko stabilne numery wersji; „0”, jeśli źródło będzie również dostarczać wersje niestabilne, np. 0.3.3-beta .
wpisz Na razie obsługiwany jest tylko typ rest . Dodawanie nowych typów aktualizacji (wersji sprawdzających), takich jak git, wget itp., jest łatwe
źródło Adres URL, z którego można pobrać nowe wersje.
manualUpdateUrl Adres URL, pod który użytkownik może przejść, aby zaktualizować najnowszą wersję rozszerzenia.
automatycznyUpdateUrl DO ZROBIENIA

Jeśli nie chcesz dostarczać aktualizatora, powinieneś umieścić następujący tekst w pliku konfiguracyjnym XML:

<updaters disabled="disabled"> 
</updaters>

W ten sposób informujesz system, że celowo wyłączyłeś system aktualizacji i nie zapomniałeś go dodać.

Nowa wtyczka „UpdateCheck” – domyślnie zainstalowana i aktywowana – sprawdza dostępność nowych aktualizacji dla „wszystkich” zainstalowanych rozszerzeń, gdy superadministrator loguje się asynchronicznie, maksymalnie raz na 24 godziny. Jeśli zostaną znalezione nowe wersje, zostanie wyświetlone powiadomienie.

Dostępne aktualizacje

Jeśli zostanie znaleziona nowa aktualizacja zabezpieczeń, powiadomienie zostanie otwarte automatycznie i będzie oznaczone klasą „niebezpieczeństwo”.

Dostępne aktualizacje zabezpieczeń

Możesz ręcznie sprawdzić dostępność aktualizacji, przechodząc do widoku menedżera wtyczek i klikając „Sprawdź aktualizacje”. Pamiętaj, że ten przycisk jest widoczny tylko wtedy, gdy wtyczka UpdateCheck jest aktywna.

Ręcznie sprawdź dostępność aktualizacji

Pod maską

Ta sekcja zawiera krótki przegląd implementacji aktualizatora rozszerzeń.

Aktualizator rozszerzeń jest częścią biblioteki ExtensionInstaller. Poniżej znajduje się diagram UML dla klas związanych z procesem aktualizacji.

Schemat UML aktualizatora rozszerzeń

Przebieg programu po uruchomieniu Yii:

 Yii init
 VersionFetcherServiceLocator->init()
 Dodaj moduł pobierania wersji REST
 ExtensionUpdaterServiceLocator->init()
 Dodaj PluginUpdater
 DO ZROBIENIA: Dodaj aktualizator dla każdego typu rozszerzenia (motyw, szablon pytania, ...)

Przebieg programu podczas uruchamiania wtyczki UpdaterCheck:

 Pobierz wszystkie aktualizacje z ExtensionUpdaterServiceLocator
 Zapętlaj każdy aktualizator
 Dla każdego aktualizatora przejrzyj moduły pobierania wersji skonfigurowane przez<updater> XML
 W przypadku każdego modułu pobierania wersji skontaktuj się ze zdalnym źródłem i uzyskaj informacje o wersji
 Skomponuj wszystkie wersje w powiadomienie

Metoda checkAll we wtyczce UpdateCheck stanowi przykład sprawdzania wszystkich rozszerzeń w celu uzyskania nowych wersji .

Dodawanie nowych modułów pobierania wersji

Aby dodać nowy, niestandardowy moduł pobierania wersji, uruchom to podczas inicjalizacji Yii:

$service = \Yii::app()->versionFetcherServiceLocator
$service->addVersionFetcherType(
 'myNewVersionFetcherType',
 funkcja (\SimpleXMLElement $updaterXml) {
 zwróć nowy MyNewVersionFetcher( $updaterXml);
 }
);

Oczywiście klasa MyNewVersionFetcher musi być podklasą VersionFetcher .

Aby użyć modułu pobierania nowej wersji, skonfiguruj znacznik type w pliku XML aktualizatora tak, aby używał

myNewVersionFetcherType (zamiast np. rest ).

Dodawanie nowych aktualizacji rozszerzeń

Aby dodać nowy, niestandardowy aktualizator rozszerzeń, uruchom to podczas inicjalizacji Yii:

$service = \Yii::app()->extensionUpdaterServiceLocator;
$service->addUpdaterType(
 'myNewExtensionUpdater',
 funkcja () {
 return MyNewExtensionUpdater::createUpdaters() ;
 }
);

Klasa MyNewExtensionUpdater musi być podklasą ExtensionUpdater .

Znacznik najwyższego type w pliku config.xml („wtyczka”, „motyw”, ...) będzie kontrolował, który aktualizator rozszerzenia będzie używany dla tego rozszerzenia. System nie jest jeszcze w pełni konfigurowalny, ponieważ trzeba także dodać niestandardowy ExtensionInstaller, elementy menu itp. Jednak teoretycznie i być może w przyszłości powinno być możliwe dodanie w ten sposób nowego typu rozszerzenia.

Instalator rozszerzenia

Biblioteka instalatora rozszerzeń składa się z dwóch klas abstrakcyjnych:

  • ExtensionInstaller
  • FileFetcher

ExtensionInstaller jest podklasą dla każdego typu rozszerzenia, takiego jak PluginInstaller, questionThemeInstaller itp.

FileFetcher jest podklasą dla każdego innego sposobu pobierania plików. Obecnie obsługiwane są tylko przesłane pliki ZIP, ale w przyszłości może pojawić się także moduł pobierania Github lub LimeStore.

Specjalne wtyczki

Samouczek

Ten samouczek krok po kroku pokazuje, jak utworzyć wtyczkę, która wysyła żądanie opublikowania każdej odpowiedzi w ankiecie przedłożona praca. W tym samouczku dowiesz się, jak tworzyć i zapisywać ustawienia globalne i dotyczące poszczególnych ankiet, jak rejestrować zdarzenia i nie tylko.

Kategoria:Rozwój Kategoria:Wtyczki