Generate a different output for controller actions using the render
method.
The filter has two additional variations to allow targeting a specific controller and controller action without the need for additional checks.
-
render_{name}
-
render_{name}_{action}
Where {name}
is the controller name and {action}
is the controller method.
Parameters
$output
(string) return non-empty string to use as the output for the request
$params
(array) associative array with contextual data
$instance
(MyController) instance of current controller class
You need to have a working knowledge of Hooks before you get started.
Boilerplate Code
Use the boilerplate code to start using the filter, and add your own logic to modify the first argument and return it.
Clickfwd\Hook\Filter::add('render', function($output, $params, $instance)
{
// Uncomment line below to view available data passed into hook
// For JReviews 3.x and earlier use dd instead of fwd_dd
// fwd_dd($output, $params, $instance);
return $output;
});
Development & Support
Customizations are not included with support. We provide this information to make it easier for developers to extend the functionality. From time to time we may have some availability for custom work. Get in touch to see if there's an opportunity to work together.
Examples
Build a read-only REST API
Restrict listing detail visibility to owner and certain groups
Clickfwd\Hook\Filter::add('render_com_content_com_content_view', function($output, $params)
{
// Change IDs to restricted category IDs
$restrictedCatIds = [1,2,3];
// Change IDs to authorized group IDs
$authorizedUserGroups = [1,2,3];
$user = S2App::make('auth');
$listing = $params['viewVars']['listing'];
$catId = $listing['Category']['cat_id'] ?? null;
if (!in_array($catId, $restrictedCatIds)) {
return $output;
}
// Checks current user against listing owner or user group to grant read-access
if ($user->matchesUserId($listing['User']['user_id']) || $user->belongsToGroups($authorizedUserGroups)) {
return $output;
}
// What you do here is up to you. Show a message, redirect, etc.
// And it will affect how search engines view or don't view the page
// Joomla - uncomment line below for redirect, and change URL and status as needed
// Joomla\CMS\Factory::getApplication()->redirect('/', 403);
// WordPress - uncomment line below for redirect, and change URL and status as needed
// wp_redirect('/', 403);
// die;
return 'No access';
});
Restrict listing detail visibility to logged in users
Similar to the above example, but we render the signup template for guests instead of the listing detail page.
Clickfwd\Hook\Filter::add('render_com_content_com_content_view', function($output, $params)
{
// Change IDs to restricted category IDs
$restrictedCatIds = [1,2,3];
$user = S2App::make('auth');
$listing = $params['viewVars']['listing'];
$catId = $listing['Category']['cat_id'] ?? null;
if (!in_array($catId, $restrictedCatIds)) {
return $output;
}
// Logged in users can see the listing detail page
if ($user->connected) {
return $output;
}
// To pass additional variables to the view
$instance->set(['foo'=>'bar']);
// To read the current view suffix
$suffix = $instance->viewSuffix();
// To change the view suffix
// $instance->viewSuffix('_products');
// Render view from elements/_sign up template
// To change the layout, you can pass a 3rd parameter with the layout name
return $instance->view('elements', '_signup');
});
Source
-
/controllers/my_controller.php