Actions

Làm cho plugin của bạn tương thích với LS4

From LimeSurvey Manual

Revision as of 09:20, 9 January 2024 by Maren.fritz (talk | contribs) (Created page with "Tệp XML này là bắt buộc trong LimeSurvey 4. Nó phải nằm trong thư mục gốc của plugin. Để biết thêm thông tin, hãy kiểm tra quá trình phát tri...")


Thay đổi kỹ thuật

Tệp cấu hình XML mới

Kể từ LimeSurvey 4.0, các plugin cần có tệp cấu hình XML để chạy trong ứng dụng.

Lý do cho điều này là khả năng lưu trữ thông tin siêu dữ liệu như tác giả plugin, email hỗ trợ hoặc thông tin cập nhật.

Tệp XML này là bắt buộc trong LimeSurvey 4. Nó phải nằm trong thư mục gốc của plugin. Để biết thêm thông tin, hãy kiểm tra quá trình phát triển plugin plugins

Ví dụ:

The new plugin directory

The plugin directory is changed in LimeSurvey 4. For security reasons, the plugin directory is now located in the upload directory (/upload/plugins) due to the new plugin manager (Plugin uploader). For manual uploads, we recommend to upload your files to the new directory to avoid software malfunctioning.

Make sure to change or add the new directory if it is hard-coded in your plugin.

Example:



The new plugin events

Some plugin events from LS3 were deprecated. Use the new plugin events introduced in LS4 to replace the old plugin events. For more information check our development manual on plugin events.

Deprecated functions and methods

Since the code base or structure of LimeSurvey 4 changed, there are a lot of methods or functions that are not used anymore. To fix this problem, you need to enable the debug mode on the config.php file first and then go to the plugin page. Any method that does not exit anymore will be shown on the error page.

Some of the methods are renamed in LS4 or are not used anymore. To be sure that your plugin works for both LS3 & LS4, check the version of LS before calling the method you need.


Example:



Best Practice

Avoid SVG files

For security (XSS) reasons, the upload of SVG Files is not possible. The Plugin uploader will ignore SVG files. Replace them by PNG or JPEG files. The upload of SVG files is possible only if you have access to the installation directory via ftp or other server tools (Upload any files at your own risks).


Avoid global constants

Avoid the use of global constants that can collapse with variables of the core application or other plugins like „ROOT_PATH“. Don‘t use global constant in general for plugin development.

Use Namespaces

Use namespace for better organization by grouping classes that work together to perform a task in your plugin. In that way you avoid using classes that are being used already in the core application.


Example: