Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/terminal42/contao-inserttags
This is a Contao Open Source CMS extension which allows you to define your own insert tags in the back end.
https://github.com/terminal42/contao-inserttags
Last synced: 23 days ago
JSON representation
This is a Contao Open Source CMS extension which allows you to define your own insert tags in the back end.
- Host: GitHub
- URL: https://github.com/terminal42/contao-inserttags
- Owner: terminal42
- License: mit
- Created: 2012-01-06T20:07:37.000Z (about 13 years ago)
- Default Branch: main
- Last Pushed: 2024-01-29T12:22:17.000Z (11 months ago)
- Last Synced: 2024-11-17T15:20:47.866Z (about 2 months ago)
- Language: PHP
- Homepage: https://www.terminal42.ch
- Size: 111 KB
- Stars: 10
- Watchers: 7
- Forks: 7
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# terminal42/contao-inserttags
Adds a back end module to define your custom insert tags. You can limit an insert tag to certain pages,
show it to guests only, or restrict it to certain logged in front end member groups.For more complex use cases, the extension also supports [Contao's Simple Token syntax](https://docs.contao.org/dev/reference/services/#simpletokenparser),
which allows for more powerful and dynamic replacements.## Example token
- Insert tag: `phone`
- Replacement: `+48 123 456 789`
- Usage: `{{custom::phone}}`
- Output: `+48 123 456 789`## Supported Simple Tokens
The Simple Tokens are split into two types:
### Evaluation tokens
The evaluation tokens are meant to be used in the conditional statements and have a format of `token.property`.
Here is a list of supported evaluation tokens:
1. `member.*` – current member properties, if logged in. Caution, it can be `null` if no member is logged in!
2. `page.*` – current page properties.Examples:
```
{if member and 456 in member.groups}
This content is visible explicitly to the members of group ID 456.
{endif}{if page and 123 in page.trail}
I am a subpage of page ID 123!
{endif}{if page and page_language in ["de_DE", "pl_PL"]}
German and Polish
{else}
All other languages
{endif}{if page and page_language matches "^de"}
German
{else}
Not German
{endif}
```Note: Always check for `page` and `member` before doing comparisons. If you are in the Contao back end, none of them
are set.### Replacement tokens
The replacement tokens are meant to be used to output the data and have a format of `##token_property##`.
Here is a list of supported replacement tokens:
1. `##member_*##` – current member properties, if logged in.
2. `##page_*##` – current page properties.Examples:
```
{if member}
Hello ##member_firstname## ##member_lastname##!
{else}
Hello anonymous!
{endif}You current page language is: ##page_language##
```### Comments
From version 2.1.0 you can use comments to describe the replacements:
```
# Show content only to the logged in users
{if member}
Hello ##member_firstname## ##member_lastname##!
{endif}
```If you would like to use a hash as the first character of the line, you can escape it as follows: `\#`.
## Security concerns
**Q: Why there are two types of token?**
A: The evaluation tokens refer to the real objects. However, the objects should NEVER be used as replacement tokens
due to security reasons. For that, we introduced the replacement tokens which contain the plain string data.**Q: Why there is no support for the `request`?**
A: The request may contain malicious data that is provided e.g., as a query parameter, and it could be dangerous
to allow users to display it in the frontend.**Q: Why there is no support for tag parameters like `{{custom::my_tag::my_param_1::my_param_2}}`?**
A: The tag parameters cannot be validated which is potentially dangerous.
## Upgrade from version 1.x
Some options present in version 1.x have been removed. All changes are described below.
### Removed "timing"
The timing feature has been removed completely, because it would kill HTTP caching. If you need a replacement,
please consider a JavaScript solution.### Removed "limitLanguages"
This option has been removed completely, use the limiting insert tags to certain pages feature instead.
### Removed "useCondition"
This option has been removed completely as this too, would make HTTP caching impossible.
### Removed "useCounter"
This option has been removed completely as this too, would make HTTP caching impossible.
### Removed "mode"
This option has been removed completely, as insert tags are only present in the front end.
### Removed "cacheOutput"
This option has been removed completely as it is not required in version 2 anymore.
## License
This bundle is released under the [MIT license](LICENSE)