Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/s00d/no-captcha
https://github.com/s00d/no-captcha
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/s00d/no-captcha
- Owner: s00d
- License: mit
- Created: 2021-11-10T14:05:35.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-07-25T15:35:23.000Z (5 months ago)
- Last Synced: 2024-10-15T22:22:32.053Z (3 months ago)
- Language: PHP
- Size: 13.7 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
No CAPTCHA reCAPTCHA
==========[![Build Status](https://travis-ci.org/s00d/no-captcha.svg?branch=master&style=flat-square)](https://travis-ci.org/s00d/no-captcha)
[![Latest Stable Version](https://poser.pugx.org/s00d/no-captcha/v/stable)](https://packagist.org/packages/s00d/no-captcha)
[![Total Downloads](https://poser.pugx.org/s00d/no-captcha/downloads)](https://packagist.org/packages/s00d/no-captcha)
[![Latest Unstable Version](https://poser.pugx.org/s00d/no-captcha/v/unstable)](https://packagist.org/packages/s00d/no-captcha)
[![License](https://poser.pugx.org/s00d/no-captcha/license)](https://packagist.org/packages/s00d/no-captcha)![recaptcha_anchor 2x](https://cloud.githubusercontent.com/assets/1529454/5291635/1c426412-7b88-11e4-8d16-46161a081ece.gif)
> For Laravel 4 use [v1](https://github.com/s00d/no-captcha/tree/v1) branch.
## Installation
```
composer require s00d/no-captcha
```## Laravel 5 and above
### Setup
**_NOTE_** This package supports the auto-discovery feature of Laravel 5.5 and above, So skip these `Setup` instructions if you're using Laravel 5.5 and above.
In `app/config/app.php` add the following :
1- The ServiceProvider to the providers array :
```php
s00d\NoCaptcha\NoCaptchaServiceProvider::class,
```2- The class alias to the aliases array :
```php
'NoCaptcha' => s00d\NoCaptcha\Facades\NoCaptcha::class,
```3- Publish the config file
```ssh
php artisan vendor:publish --provider="s00d\NoCaptcha\NoCaptchaServiceProvider"
```### Configuration
Add `NOCAPTCHA_SECRET` and `NOCAPTCHA_SITEKEY` in **.env** file :
```
NOCAPTCHA_SECRET=secret-key
NOCAPTCHA_SITEKEY=site-key
```(You can obtain them from [here](https://www.google.com/recaptcha/admin))
### Usage
#### Init js source
With default options :
```php
{!! NoCaptcha::renderJs() !!}
```With [language support](https://developers.google.com/recaptcha/docs/language) or [onloadCallback](https://developers.google.com/recaptcha/docs/display#explicit_render) option :
```php
{!! NoCaptcha::renderJs('fr', true, 'recaptchaCallback') !!}
```#### Display reCAPTCHA
Default widget :
```php
{!! NoCaptcha::display() !!}
```With [custom attributes](https://developers.google.com/recaptcha/docs/display#render_param) (theme, size, callback ...) :
```php
{!! NoCaptcha::display(['data-theme' => 'dark']) !!}
```Invisible reCAPTCHA using a [submit button](https://developers.google.com/recaptcha/docs/invisible):
```php
{!! NoCaptcha::displaySubmit('my-form-id', 'submit now!', ['data-theme' => 'dark']) !!}
```
Notice that the id of the form is required in this method to let the autogenerated
callback submit the form on a successful captcha verification.#### Validation
Add `'g-recaptcha-response' => 'required|captcha'` to rules array :
```php
$validate = Validator::make(Input::all(), [
'g-recaptcha-response' => 'required|captcha'
]);```
##### Custom Validation Message
Add the following values to the `custom` array in the `validation` language file :
```php
'custom' => [
'g-recaptcha-response' => [
'required' => 'Please verify that you are not a robot.',
'captcha' => 'Captcha error! try again later or contact site admin.',
],
],
```Then check for captcha errors in the `Form` :
```php
@if ($errors->has('g-recaptcha-response'))
{{ $errors->first('g-recaptcha-response') }}
@endif
```### Testing
When using the [Laravel Testing functionality](http://laravel.com/docs/5.5/testing), you will need to mock out the response for the captcha form element.
So for any form tests involving the captcha, you can do this by mocking the facade behavior:
```php
// prevent validation error on captcha
NoCaptcha::shouldReceive('verifyResponse')
->once()
->andReturn(true);// provide hidden input for your 'required' validation
NoCaptcha::shouldReceive('display')
->zeroOrMoreTimes()
->andReturn('');
```You can then test the remainder of your form as normal.
When using HTTP tests you can add the `g-recaptcha-response` to the request body for the 'required' validation:
```php
// prevent validation error on captcha
NoCaptcha::shouldReceive('verifyResponse')
->once()
->andReturn(true);// POST request, with request body including g-recaptcha-response
$response = $this->json('POST', '/register', [
'g-recaptcha-response' => '1',
'name' => 'John',
'email' => '[email protected]',
'password' => '123456',
'password_confirmation' => '123456',
]);
```## Without Laravel
Checkout example below:
```php
verifyResponse($_POST['g-recaptcha-response']));
exit();
}?>
display(); ?>
SubmitrenderJs(); ?>
```## Contribute
https://github.com/s00d/no-captcha/pulls