huluti / altcha-bundle
A simple package to help integrate Altcha on Symfony.
Installs: 1 243
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 1
Forks: 1
Open Issues: 4
Type:symfony-bundle
Requires
- php: >=8.1
- altcha-org/altcha: ^0.1
- symfony/form: ^6.4|^7.0
- symfony/framework-bundle: ^6.4|^7.0
- symfony/http-client: ^6.4|^7.0
- symfony/twig-bundle: ^6.4|^7.0
- symfony/validator: ^6.4|^7.0
- symfony/yaml: ^6.4|^7.0
Requires (Dev)
- phpstan/phpstan: ^1.8
- phpstan/phpstan-symfony: ^1.2
- phpunit/phpunit: ^10.5
- rector/rector: ^0.14.5
- symfony/asset-mapper: 6.4 || ^7.0
- symfony/stimulus-bundle: ^2.16
README
This packages integrates ALTCHA, a privacy-friendly Captcha alternative, with Symfony forms.
Simply add an AltchaType
field to your form and this package will automatically check the challenge issue.
ALTCHA uses a proof-of-work mechanism to protect your website, APIs, and online services from spam and unwanted content.
Unlike other solutions, ALTCHA is free, open-source and self-hosted, does not use cookies nor fingerprinting, does not track users, and is fully compliant with GDPR.
Say goodbye to tedious puzzle-solving and improve your website's UX by integrating a fully automated proof-of-work mechanism.
Support
- Symfony 6.4+
- PHP 8.1+
Installation
You can install the package via Composer:
composer require huluti/altcha-bundle
Add bundle into config/bundles.php file :
Huluti\AltchaBundle\HulutiAltchaBundle::class => ['all' => true]
Add a config file config/packages/huluti_altcha.php
:
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator; return static function (ContainerConfigurator $containerConfigurator): void { $containerConfigurator->extension('huluti_altcha', [ 'enable' => true, 'hmacKey' => 'RANDOM_SECRET_KEY', 'floating' => true, 'use_stimulus' => false, 'hide_logo' => false, 'hide_footer' => false ]); if ('test' === $containerConfigurator->env()) { // Disable captcha in test environment $containerConfigurator->extension('huluti_altcha', [ 'enable' => false, ]); } };
Import bundle routes:
$routingConfigurator->import('@HulutiAltchaBundle/config/routes.yml');
Use with your Symfony Form
Create a form type and insert an AltchaType to add the captcha:
<?php namespace App\Form; use App\Entity\Contact; use Huluti\AltchaBundle\Type\AltchaType; use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\Extension\Core\Type\SubmitType; use Symfony\Component\Form\Extension\Core\Type\TextareaType; use Symfony\Component\Form\Extension\Core\Type\TextType; use Symfony\Component\Form\FormBuilderInterface; use Symfony\Component\OptionsResolver\OptionsResolver; class ContactType extends AbstractType { public function buildForm(FormBuilderInterface $builder, array $options): void { $builder ->add('name', TextType::class, ['label' => false, 'attr' => ['placeholder' => 'name']]) ->add('message', TextareaType::class, ['label' => false, 'attr' => ['placeholder' => 'message']]) ->add('security', AltchaType::class, [ 'label' => false, "floating" => true, "hide_logo" => false, "hide_footer" => false, ]) ->add('submit', SubmitType::class) ; } public function configureOptions(OptionsResolver $resolver): void { $resolver->setDefaults([ 'data_class' => Contact::class, ]); } }
Use inside UX Live component
Asset mapper is required to use this package in the UX Live component.
composer require symfony/asset-mapper
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator; return static function (ContainerConfigurator $containerConfigurator): void { $containerConfigurator->extension('huluti_altcha', [ 'enable' => true, 'hmacKey' => 'RANDOM_SECRET_KEY', 'floating' => false, 'use_stimulus' => true ]); };
License
The MIT License (MIT). Please see License File for more information.