| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | # Getting started
 | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ## Requirements
 | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | Smarty can be run with PHP 7.2 to PHP 8.2. | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Installation
 | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | Smarty can be installed with [Composer](https://getcomposer.org/). | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | To get the latest stable version of Smarty use: | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | ```shell | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | composer require smarty/smarty | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | To get the latest, unreleased version, use: | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | ```shell | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | composer require smarty/smarty:dev-master | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | To get the previous stable version of Smarty, Smarty 3, use: | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | ```shell | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | composer require smarty/smarty:^3 | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Here's how you create an instance of Smarty in your PHP scripts: | 
					
						
							|  |  |  | ```php | 
					
						
							|  |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require 'vendor/autoload.php'; | 
					
						
							| 
									
										
										
										
											2023-02-06 15:18:47 +01:00
										 |  |  | use Smarty\Smarty; | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty = new Smarty(); | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | Now that the library files are in place, it's time to set up the Smarty | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | directories for your application. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-07 00:14:54 +02:00
										 |  |  | Smarty requires four directories which are by default named `templates`, `configs`, `templates_c` and `cache`  | 
					
						
							|  |  |  | relative to the current working directory. | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | The defaults can be changed as follows: | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ```php | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2023-02-06 15:18:47 +01:00
										 |  |  | use Smarty\Smarty; | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty = new Smarty(); | 
					
						
							|  |  |  | $smarty->setTemplateDir('/some/template/dir'); | 
					
						
							|  |  |  | $smarty->setConfigDir('/some/config/dir'); | 
					
						
							|  |  |  | $smarty->setCompileDir('/some/compile/dir'); | 
					
						
							|  |  |  | $smarty->setCacheDir('/some/cache/dir'); | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The compile dir and cache dir need to be writable for the user running the PHP script. | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | > **Note**
 | 
					
						
							|  |  |  | > | 
					
						
							|  |  |  | > This is usually user "nobody" and group "nobody". For OS X users, the
 | 
					
						
							|  |  |  | > default is user "www" and group "www". If you are using Apache, you
 | 
					
						
							|  |  |  | > can look in your `httpd.conf` file to see what user and group are
 | 
					
						
							|  |  |  | > being used.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | chown nobody:nobody /web/www.example.com/guestbook/templates_c/ | 
					
						
							|  |  |  | chmod 770 /web/www.example.com/guestbook/templates_c/ | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | chown nobody:nobody /web/www.example.com/guestbook/cache/ | 
					
						
							|  |  |  | chmod 770 /web/www.example.com/guestbook/cache/ | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | You can verify if your system has the correct access rights for | 
					
						
							|  |  |  |     these directories with [`testInstall()`](./programmers/api-functions/api-test-install.md): | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ```php | 
					
						
							| 
									
										
										
										
											2023-02-06 15:18:47 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | use Smarty\Smarty; | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty = new Smarty(); | 
					
						
							|  |  |  | $smarty->setTemplateDir('/some/template/dir'); | 
					
						
							|  |  |  | $smarty->setConfigDir('/some/config/dir'); | 
					
						
							|  |  |  | $smarty->setCompileDir('/some/compile/dir'); | 
					
						
							|  |  |  | $smarty->setCacheDir('/some/cache/dir'); | 
					
						
							|  |  |  | $smarty->testInstall(); | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | Now, let's create the `index.tpl` file that Smarty will display. This | 
					
						
							|  |  |  | needs to be located in the [`$template_dir`](./programmers/api-variables/variable-template-dir.md). | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-03 17:54:00 +01:00
										 |  |  | ```smarty | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | {* Smarty *} | 
					
						
							|  |  |  | Hello {$name}, welcome to Smarty! | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | > **Note**
 | 
					
						
							|  |  |  | > | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | > `{* Smarty *}` is a template [comment](./designers/language-basic-syntax/language-syntax-comments.md). It
 | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | > is not required, but it is good practice to start all your template
 | 
					
						
							|  |  |  | > files with this comment. It makes the file easy to recognize
 | 
					
						
							|  |  |  | > regardless of the file extension. For example, text editors could
 | 
					
						
							|  |  |  | > recognize the file and turn on special syntax highlighting.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | Now lets edit our php file. We'll create an instance of Smarty, | 
					
						
							|  |  |  | [`assign()`](./programmers/api-functions/api-assign.md) a template variable and | 
					
						
							|  |  |  | [`display()`](./programmers/api-functions/api-display.md) the `index.tpl` file. | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ```php | 
					
						
							|  |  |  | <?php | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | require 'vendor/autoload.php'; | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-06 15:18:47 +01:00
										 |  |  | use Smarty\Smarty; | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty = new Smarty(); | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty->setTemplateDir('/web/www.example.com/guestbook/templates/'); | 
					
						
							|  |  |  | $smarty->setCompileDir('/web/www.example.com/guestbook/templates_c/'); | 
					
						
							|  |  |  | $smarty->setConfigDir('/web/www.example.com/guestbook/configs/'); | 
					
						
							|  |  |  | $smarty->setCacheDir('/web/www.example.com/guestbook/cache/'); | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty->assign('name', 'Ned'); | 
					
						
							|  |  |  | $smarty->display('index.tpl'); | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | > **Note**
 | 
					
						
							|  |  |  | > | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | > In our example, we are setting absolute paths to all the Smarty
 | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | > directories. If `/web/www.example.com/guestbook/` is within your PHP
 | 
					
						
							|  |  |  | > include\_path, then these settings are not necessary. However, it is
 | 
					
						
							|  |  |  | > more efficient and (from experience) less error-prone to set them to
 | 
					
						
							|  |  |  | > absolute paths. This ensures that Smarty is getting files from the
 | 
					
						
							|  |  |  | > directories you intended.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | Now, run your PHP file. You should see *"Hello Ned, welcome to Smarty!"* | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | You have completed the basic setup for Smarty! | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | ## Extended Setup
 | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | This is a continuation of the [basic installation](#installation), please read that first! | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | A slightly more flexible way to set up Smarty is to extend the Smarty | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | class and initialize your Smarty | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | environment. So instead of repeatedly setting directory paths, assigning | 
					
						
							|  |  |  | the same vars, etc., we can do that in one place. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ```php | 
					
						
							|  |  |  | <?php | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-22 22:38:37 +01:00
										 |  |  | use Smarty\Smarty; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class My_GuestBook extends Smarty { | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  |    public function __construct() | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  |         $this->setTemplateDir('/web/www.example.com/guestbook/templates/'); | 
					
						
							|  |  |  |         $this->setCompileDir('/web/www.example.com/guestbook/templates_c/'); | 
					
						
							|  |  |  |         $this->setConfigDir('/web/www.example.com/guestbook/configs/'); | 
					
						
							|  |  |  |         $this->setCacheDir('/web/www.example.com/guestbook/cache/'); | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  |         $this->caching = Smarty::CACHING_LIFETIME_CURRENT; | 
					
						
							|  |  |  |         $this->assign('app_name', 'Guest Book'); | 
					
						
							|  |  |  |    } | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | } | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2021-12-03 11:59:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-22 22:38:37 +01:00
										 |  |  | Now, we can use `My_GuestBook` instead of `Smarty` in our scripts: | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | ```php | 
					
						
							| 
									
										
										
										
											2023-02-05 23:14:10 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | $smarty = new Smarty_GuestBook(); | 
					
						
							|  |  |  | $smarty->assign('name', 'Ned'); | 
					
						
							| 
									
										
										
										
											2021-12-03 16:51:08 +01:00
										 |  |  | $smarty->display('index.tpl'); | 
					
						
							|  |  |  | ``` |