定制 undkonsorten/typo3-extbase-honeypot 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

undkonsorten/typo3-extbase-honeypot

最新稳定版本:1.1.0

Composer 安装命令:

composer require undkonsorten/typo3-extbase-honeypot

包简介

Honey pot element for extbase object forms

README 文档

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.

统计信息

  • 总下载量: 1.51k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 4
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: GPL-2.0
  • 更新时间: 2023-12-07