Loading...
 
Skip to main content

History: Extending Tiki

Preview of version: 29

Extending Tiki

Tiki, from a software engineering standpoint, is a monolithic application. We have strong opinions on the advantages of this approach to avoid development fragmentation and to ease refactoring. Please see: http://pluginproblems.com/ and Versions.

Currently available extension mechanisms

Tiki has various mechanisms to allow extensions and customisations. In fact, more ways than most modular software.

If you are new to Tiki, before you start down this list, keep in mind that Tiki is extremely flexible. In most cases where you'd use a plugin or write code in another system, in Tiki you are expected to configure one of the 2000+ preferences, use an existing Wiki plugin or setup a tracker.

Themes; to cleanly change the look and feel

In Tiki, the visual theme affects only appearance, not functionality, so a theme can't introduce a security risk.

Customization; quick and dirty changes to look and feel and behavior

Using the Look and feel administration panel, you can add snippets of code, which will be stored in the database, and survive upgrades:

  • Custom HTML in the HTML header
  • Custom JavaScript
  • Custom CSS

Simpler than writing a theme if you have few things to customize.

Profiles; bootstrapping Tiki configurations for some specific purpose

In Tiki terminology, a "profile" is a set of site configuration preferences and website item creation instructions that are applied as a group. They only add or edit content in the site's database. Some profiles are simple, like a contact form, and some are more complex.

Packages; managing PHP software libraries within the Tiki admin panel

Also called the Composer Web Installer, and introduced in Tiki18, this feature is for the installation and management of external software packages using Composer. Its main reason to exist is to facilitate installation of PHP lib dependencies that the Tiki community can't or prefers not to bundle. Ex.: incompatible licence, too big, too niche, etc. Please note that the code that uses these libraries remains managed in the main code base. To illustrate: The mPDF library is fetched as a Package, but all the other code is in Tiki.

  • Packages helped deprecate Mods, which were formerly used partly for this purpose. Mods had all the code for the functionality, whether it depended on an external library or not.

System configuration; using files to override preferences

Allows system administrators to set some preferences using ini files in the file system to override the preferences in the Tiki database.

Path structure; using files to add and override arbitrary code

Arbitrary PHP code can override parts of Tiki by dropping it in the Path structure, For instance Custom php file (as of Tiki18) _custom/setup/custom.php

Wiki Plugins; adding "macros", stuff to display in wiki pages

Wiki plugins are used to embed features and interactive data and functions in any wiki text area in the Tiki site, including in wiki pages, blogs, articles, forums, and so on. Importantly, although they are called "plugins", they are not third-party or aftermarket additions to Tiki - they are included with the Tiki installation.

  • You can Create a new wiki plugin, and hopefully contribute them back to Tiki.
  • You can make a Plugin Alias to make new plugins based on previously existing plugins in your tiki site. Stored in the database, they survive upgrades.

Modules; adding "blocks", stuff you can display in a layout area

Probably poorly named, in Tiki a module is a box of content that can be placed in layout areas (eg: topbar, left, right, bottom, etc) and also in text areas (eg: wiki pages). Other software tend to call them blocks, or boxes. All modules are included with the default Tiki installation.

  • You can create custom modules, which are stored in the database and survive upgrades.
  • Creating a new module is easy. Please do contribute!

DEPRECATED extensions mechanism

  • Mods used to provide themes and functionality
    • Most mods were not actively maintained so they became dead / useless code
    • Anything relevant was moved to core
  • Arbitrary PHP code in language files. Replaced with Path structure

Addons; other software's "apps" or "plugins"

A way of packaging Profiles, Smarty Templates and other building blocks of application functionality. There are few of them, because it is part of the Tiki philosophy that ANY reusable and generic functionality should be swallowed in core as soon as possible. They are slated to be removed in Tiki20, and any useful functionality to be add elsehwere: Addons Cleanup

History

Advanced
Information Version
Marc Laporte One more 33
Marc Laporte Fix link 32
Nelson Ko 31
Nelson Ko Change wrong path to where it was looking for _custom/lib/setup/custom.php 30
Marc Laporte 29
Marc Laporte 28
Marc Laporte 27
Marc Laporte 26
Marc Laporte 25
Marc Laporte 24
Marc Laporte 23
Marc Laporte 22
Marc Laporte 21
Marc Laporte Addons don't work yet so they can't replace mods 20
Marc Laporte 19
Marc Laporte 18
Marc Laporte 17
Marc Laporte 16
Marc Laporte 15
Marc Laporte 14
Marc Laporte 13
Marc Laporte 12
Marc Laporte 11
Marc Laporte 10
Marc Laporte 9
Marc Laporte 8
Marc Laporte 7
Marc Laporte Page renamed from ExtendingTiki to Extending Tiki. Semantic alias redirect created 6
Benoit Grégoire Add Wik plugins and Modules, extension mechanism 8 and 9 ;) 5
Marc Laporte 4
Marc Laporte 3
Benoit Grégoire 2
Benoit Grégoire Initial list 1