Chapter: Developping plugins
|« Overloading module files
|^ Advanced development
|Dive into configuration »
− Table of content
Different types of plugins exists for Jelix. Each categories modify or add functionality to differents parts of Jelix. There are coordinator plugins, jDb drivers, jAuth drivers, jTpl plugins and url engines.
All plugins are located in plugins repositories.
Adding a plugins repository ¶
You can add one or more plugins repositories. It consists of a directory with a strict
subtree structure. Each plugins repository must be added to
pluginsPath of your
application configuration. Its default value is:
pluginsPath = lib:jelix-plugins/,app:plugins/
Different repositories are divided by a comma. Default value indicate two repositories :
/lib/jelix-plugins directory and your plugins application directory.
Jelix also loads an implicit repository
lib/jelix/plugins: it contains all plugins
bundled with Jelix. It also loads all
plugins/ directories found into modules.
lib: is a shortcut indicating base
lib/ directory and
app: is a
shortcut for your application directory. You can also use an absolute path but beware to
check if you migrate your application from one host to another. A relative path is also
permitted. it has to be relative to your entry point script (
Repository structure and plugins creation ¶
Such a repository has one sub-directory for each plugin type. And within each sub-directory, each plugin has its own folder.
Below is the list of plugins type and their respective directory:
- coordinator plugins:
- plugins for jLog:
- jAuth drivers:
- jAcl2 drivers:
- jDb drivers:
- templates plugins:
- url engines:
- jForms generators:
- jKVDb drivers:
- jCache drivers:
- plugins for the debugbar:
- plugins for jResponseHtml:
Plugins development ¶
Jelix comes with a bunch of plugins within the standard package. They are located in
lib/jelix/plugins/. However, it is often useful to create your own plugins to
fulfill specific needs. And If your plugin is generic or useful enough, you're likely to
push it to the developers team :-).