undkonsorten/typo3-extbase-honeypot

Honey pot element for extbase object forms

1.0.0 2023-12-07 13:47 UTC

This package is auto-updated.

Last update: 2024-04-07 14:37:30 UTC


README

What does it do?

This extension allows you to add a simple honeypot field to an extbase extension. It can reduce SPAM for a given form but won‘t be able to exclude all bots.

Installation

Just require via composer:

composer require undkonsorten/typo3-extbase-honeypot

Activate the extension for TYPO3 versions prior to 11.

Usage

Controller

Inject \Undkonsorten\HoneyPot\Service\HoneyPotService in your controller, eg a $honeyPotService.

Then add a call to it before the action that receives the form you want to protect:

    public function initializeCreateAction(): void
    {
        $this->honeyPotService->configureHoneyPotForArgument($this->arguments->getArgument('dto'), $this->request->getArgument('dto'), '_hp');
    }

    public function createAction(DTO $dto): ResponseInterface

where the createAction is the appropriated form action and dto is the name of your argument and _hp is the name of the fake property for your honeypot field. Just be sure to avoid collisions with existing properties.

Template

Now add the field to your template like this:

    <f:render partial="Field/HoneyPot" section="Main" arguments="{field:'_hp'}" />

where _hp is the name you chose in your controller. What‘s now left to do is configure your view to look in the right place for the partial, e.g. via TypoScript:

plugin.tx_myext {
    view.partialRootPaths.42 = EXT:extbase_honeypot/Resources/Private/Partials/
}

For showing error message if the field was filled, you can use the example in locallang files: typo3-extbase-honeypot/Resources/Private/Language/locallang.xlf Copy the lines with the proper error code to your extensions/site-packge/whatever and change property name if you not use the default _hp.

Add f:translate snippet to the used action template.

<f:if condition="{validationResults.flattenedErrors}">
    <ul class="formerror">
        <f:for each="{validationResults.flattenedErrors}" key="propertyPath" as="errors">
            <f:for each="{errors}" as="error"><li>
                <f:translate key="error.{error.code}.{propertyPath}" arguments="{0:propertyPath}" />
            </li></f:for>
        </f:for>
    </ul>
</f:if>

Configuration

No further configuration is needed - all you need is now in your code. You can make things like the field name configurable, of course.