azzmin / cakephp-altcha
Altcha proof-of-work spam protection for CakePHP 5
Package info
github.com/azzmin/cakephp-altcha
Type:cakephp-plugin
pkg:composer/azzmin/cakephp-altcha
Requires
- php: >=8.1
- cakephp/cakephp: ^5.0
Requires (Dev)
- phpunit/phpunit: ^10.0
This package is not auto-updated.
Last update: 2026-04-27 13:14:04 UTC
README
Altcha proof-of-work spam protection for CakePHP 5. Privacy-friendly, no external services, no tracking.
Uses Altcha to generate SHA-256 challenges that are solved client-side. No CAPTCHA images, no Google dependencies.
Install
composer require azzmin/cakephp-altcha
Setup
1. Load the plugin in src/Application.php:
$this->addPlugin('Altcha');
2. In your controller load the component and helper:
public function initialize(): void { parent::initialize(); $this->loadComponent('Altcha.Altcha'); $this->viewBuilder()->addHelper('Altcha.Altcha'); }
3. Verify on POST in your action, before processing the form:
if ($this->request->is('post')) { if (!$this->Altcha->verify($this->request)) { $this->Flash->error('Please complete the verification.'); return null; } // process form... }
4. Render the widget in your template, before the submit button:
<?= $this->Altcha->widget() ?>
That's it. No database, no routes, no configuration required.
Options
Pass an array to widget() to customise:
<?= $this->Altcha->widget(['hidelogo' => true]) ?>
| Option | Type | Description |
|---|---|---|
hidelogo |
true |
Hide the Altcha logo |
hidelabel |
true |
Hide the "I'm not a robot" label |
name |
string |
Hidden input name (default: altcha) |
auto |
string |
Auto-solve mode: onfocus, onload, onsubmit |
If you change name, pass the same value to verify:
$this->Altcha->verify($this->request, 'my_field_name');
Configuration
All optional. Defaults work out of the box using Security.salt from app_local.php.
Add to config/app_local.php to override:
'Altcha' => [ 'hmacKey' => 'your-custom-key', // defaults to Security.salt 'maxNumber' => 100000, // higher = harder for bots 'saltLength' => 12, 'jsUrl' => 'https://cdn.jsdelivr.net/npm/altcha@latest/dist/altcha.js', ],
How it works
- Server generates a SHA-256 challenge with a HMAC signature
- Client solves the proof-of-work in the browser (finds the nonce)
- Solution is submitted as a hidden form field
- Server verifies the hash and HMAC signature
No data sent to third parties. All computation happens in the browser.
Requirements
- PHP 8.1+
- CakePHP 5.0+
License
Apache-2.0