esi / simple_tpl
Simple TPL - A Simple Template Engine
                                    Fund package maintenance!
                                                                            
                                                                                                                                        Ko Fi
                                                                                    
                                                                            
                                                                                                                                        ericsizemore
                                                                                    
                                                                
Installs: 4
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 2
pkg:composer/esi/simple_tpl
Requires
- php: ^8.1 <8.5
Requires (Dev)
- phpstan/phpstan: ^1.11
- phpstan/phpstan-phpunit: ^1.3
- phpstan/phpstan-strict-rules: ^1.5
- phpunit/phpunit: ^10.4
This package is auto-updated.
Last update: 2025-10-24 12:56:17 UTC
README
Simple Template Engine is a small, simple text-based template parsing engine that works on text replacement.
Important
The master branch currently holds the work-in-progress version 3.x, which is a break from the backward compatibility promise.
This will be resolved once 3.0.0 is released. Since 3.x is under development, it is not recommended to use in a production environment.
The public API, implementations, etc., can (and will likely) change.
Installation
Compatible with PHP >= 8.2 and can be installed with Composer.
$ composer require esi/simple_tpl:^3.0
Usage
Storage
There are two storage implementations available: Storage\FilesystemStorage and Storage\DatabaseStorage.
Both storage implementations implement the Storage\StorageInterface interface, with only one defined method: loadTemplate().
NOTE: If you wish to have a system for editing/saving, deleting or updating the templates themselves, you would need to implement this on your own.
This library only searches for templates that have already been created, by name, then parses them with a key => value associative array of variables.
Filesystem Storage
The FilesystemStorage implementation allows you to use regular files for your templates.
Your template files are expected to end with the .tpl extension. I plan to allow the ability to use different extensions later.
- Create a FilesystemStorageinstance with the path/directory to where your templates are located.
- Pass this instance to the Templateclass when creating it.
Let's say you had a template called example_template.tpl within the ./templates/ directory.
Template file:
<!DOCTYPE HTML> <html lang="en"> <head> <meta http-equiv="content-type" content="text/html" /> <title>{title}</title> </head> <body> <p>{content}</p> </body> </html>
PHP to parse the template:
use Esi\SimpleTpl\Template; use Esi\SimpleTpl\Storage\FilesystemStorage; $templateStorage = new FilesystemStorage('./templates/'); $template = new Template($templateStorage); $template->setTplVars([ 'title' => 'Hello, World!', 'content' => 'This is a simple template engine.' ]); echo $template->parse('example_template');
When calling display() or parse(), you only need to provide the file name without extension.
For example, if your template file is mytemplate.tpl, you would call either of these methods with mytemplate.
Database Storage
The DatabaseStorage implementation allows you to use a database for your templates.
- Create a PDOinstance with your database details to create a connection.
- Create a DatabaseStorageConfigwith your template tablestableName,nameField, andcontentField.
- Create a DatabaseStorageinstance and pass thePDOandDatabaseStorageConfiginstances to it.
- Pass the DatabaseStorageinstance to theTemplateclass when creating it.
Let's say the content of the example_template is the same as in the filesystem example, and your
database table structure is:
CREATE TABLE IF NOT EXISTS `templates` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT, `name` VARCHAR(255) NOT NULL, `content` MEDIUMTEXT NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `name` (`name`) )
Then your code would look something like:
use Esi\SimpleTpl\Template; use Esi\SimpleTpl\Storage\DatabaseStorage; use Esi\SimpleTpl\Storage\DatabaseStorageConfig; use PDO; $pdo = new PDO('mysql:host=localhost;dbname=templates', 'user', 'password'); $storageConfig = new DatabaseStorageConfig(); // with the example table structure above, the config defaults to 'templates', 'name', 'content' $templateStorage = new DatabaseTemplateStorage($pdo, $storageConfig); $template = new Template($templateStorage); $template->setTplVars([ 'title' => 'Hello, World!', 'content' => 'This is a simple template engine.' ]); echo $template->parse('example_template');
Caching
If you would like to utilize caching for templates, you will need to provide the library a PSR-6 cache implementation. You can view a list of packages that provide this implementation on Packagist.
Whether you use FilesystemStorage or DatabaseStorage, you can use caching for either by passing an object that implements \Psr\Cache\CacheItemPoolInterface.
For example:
$ composer require symfony/cache:^7.2
use Esi\SimpleTpl\Template; use Esi\SimpleTpl\Storage\FilesystemStorage; use Symfony\Component\Cache\Adapter\AbstractAdapter; $templateStorage = new FilesystemStorage('/path/to/templates'); $template = new Template( $templateStorage, /** * Symfony's AbstractAdapter::createSystemCache() returns the best possible adapter that your runtime supports. * Generally, it will create a cache via PHP files (Opcache must be enabled via opcache.enable in php.ini), and chain that with APCu if your system supports it. * * For more information on symfony/cache's available cache pool (PSR-6) adapters: * @see https://symfony.com/doc/current/components/cache/cache_pools.html */ AbstractAdapter::createSystemCache(namespace: 'simple_tpl', defaultLifetime: 300, version: '', directory: sys_get_temp_dir()) ); // ... assign vars, parse /display template, etc ...
About
Requirements
- SimpleTpl works with PHP 8.2.0 or above.
Credits
- Author: Eric Sizemore
- Thanks to all Contributors.
Contributing
See CONTRIBUTING for more information.
Bugs and feature requests are tracked on GitHub.
Contributor Covenant Code of Conduct
Backward Compatibility Promise
See backward-compatibility.md for more information on Backwards Compatibility.
Changelog
See the CHANGELOG for more information on what has changed recently.
License
Simple Template Engine's license depends on the version you are using:
- v3.0.0and later is licensed under- The MIT License.
- v2.0.1and earlier is licensed under the- GNU GPL v3 License.
See the LICENSE for more information on the license that applies to this project.
Security
See SECURITY for more information on the security disclosure process.