Specbee: How to create custom tokens in Drupal
What are Tokens
Tokens in Drupal are primarily used for dynamically inserting data into content, such as user information, node details, or site settings. They make content more personalized and automated without manual intervention, streamlining the editing process and enhancing user experiences. For example, they can be used while sending emails during webform submissions or content moderation.
Before creating custom tokens you need to have the Drupal tokens module installed on your Drupal site. This contributed module already comes with some predefined tokens. These defined tokens can be used globally.
Steps to Create Custom Tokens
Step 1: Create a custom moduleTo create a custom token in Drupal, we either need to develop a new custom module or incorporate it into an existing one. For example, let’s name the module “Custom Token,” and the corresponding directory would be named “custom_token.” After creating this folder, we should generate a “custom_token.info.yml” file, where we’ll specify the module details.
name: Custom token
type: module
description: Provides custom tokens.
package: tokens
core_version_requirement: ^10Step 2: Clear the cacheAfter adding this code, clear the cache and refresh the page to apply the changes. Next, search for the custom token module and install it.
Step 3: Create the custom tokenOnce the module is installed, create a file named “custom_token.tokens.inc” within the folder. Inside this file, we’ll define the custom tokens. In the given scenario, there’s a webform for reviewing article content, and a link to this webform is added to the detailed page of articles. Now, the URL to the webform appears as follows:‘webform/contact_new/test?article=1’. The article field is also auto-filled based on the token.
Here, the article author is a hidden field that should auto-fill after form submission. Additionally, the article author is a field within the article content type. To dynamically retrieve this data, we need to create a custom token.
The code that will be added inside the “tokens.inc” file is provided below.
<?php
/**
* @file
* File to add custom token.
*/
use DrupalCoreRenderBubbleableMetadata;
/**
* Implements hook_token_info().
*/
function custom_token_token_info() {
$types[‘article’] = [
‘name’ => t(‘Custom token’),
‘description’ => t(‘Define custom tokens.’),
];
$tokens[‘article_title’] = [
‘name’ => t(‘Article title’),
‘description’ => t(‘Token to get current article title.’),
];
$tokens[‘article_author’] = [
‘name’ => t(‘Article author’),
‘description’ => t(‘Token to get current article author.’),
];
return [
‘types’ => $types,
‘tokens’ => [‘article’ => $tokens],
];
}
/**
* Implements hook_tokens().
*/
function custom_token_tokens($type, $tokens, array $data, array $options, BubbleableMetadata $bubbleable_metadata) {
$replacements = [];
if ($type == ‘article’) {
$nid = Drupal::request()->query->get(‘article’);
if ($nid) {
$node_details = Drupal::entityTypeManager()->getStorage(‘node’)->load($nid);
}
foreach ($tokens as $name => $original) {
// Find the desired token by name.
switch ($name) {
case ‘article_author’:
if ($node_details) {
$user_id = $node_details->field_author->target_id;
if ($user_id) {
$user_details = Drupal::entityTypeManager()->getStorage(‘user’)->load($user_id);
$replacements[$original] = $user_details->name->value;
}
}
break;
case ‘article_title’:
if ($node_details) {
$replacements[$original] = $node_details->label();
}
break;
}
}
}
return $replacements;
}And this is how we can craft custom tokens to suit our specific needs. Once implemented, the webform results will seamlessly display the auto-filled value.
Final Thoughts
Drupal’s power lies not just in its functionality, but in its adaptability and ease of use. Tokens are an example of this versatility, since they offer a way to dynamically retrieve data as well as personalize content. Tokens streamline processes and improve user experience, whether they are used for user information, node details, or site settings.
20 years since “and we’re just starting”: undeadly.org turns 20 (2024-04-09)
At that point in our history, we had been enjoying frequent updates to the OpenBSD Journal at the deadly.org site for more than four years, and most of us thought it was an April’s Fool prank when the the editors announced that they were ceasing publication, effective immediately on April 1st, 2004.
Fortunately, Daniel Hartmeier quickly realized the announcement was not a joke, and went to work on a functionally equivalent CGI binary written in C and negotiated to take over the archive of existing articles. The rescued (resurrected?) site went live at undeadly.org on April 9th, 2004.
At the time, the eagerly anticipated upcoming release was OpenBSD 3.5 (which we covered on April 30th of that year). As the release song strongly hints, the introduction of the CARP redundancy protocol was a major item in that release. The release also introduced the OpenBSD/amd64 platform, and included a number of improvements in hardware support and security, with privilege separation introduced in several daemons and important utilities. All the details can be had at the OpenBSD 3.5 release page.
It’s been 20 years, what have we got to show for it?
We hope you have been enjoying the site’s updates, and we hope that undeadly.org has been a positive factor in promoting all things OpenBSD. The site and its editors have every intention of going on running the site.
If you want to help out, please submit items about OpenBSD that you find noteworthy.
We value your submissions even more than your comments.
All the best from the undeadly.org editors.