Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mehdibo/codeigniter-recaptcha
CodeIgniter library to use Google's reCAPTCHA V2
https://github.com/mehdibo/codeigniter-recaptcha
codeigniter-library codeigniter-recaptcha google-recaptcha php recaptcha recaptcha-api recaptcha-verification recaptcha-widget recaptchav2
Last synced: 3 months ago
JSON representation
CodeIgniter library to use Google's reCAPTCHA V2
- Host: GitHub
- URL: https://github.com/mehdibo/codeigniter-recaptcha
- Owner: mehdibo
- License: mit
- Created: 2017-07-13T07:26:17.000Z (over 7 years ago)
- Default Branch: develop
- Last Pushed: 2022-06-15T13:07:06.000Z (over 2 years ago)
- Last Synced: 2024-05-14T15:45:06.985Z (8 months ago)
- Topics: codeigniter-library, codeigniter-recaptcha, google-recaptcha, php, recaptcha, recaptcha-api, recaptcha-verification, recaptcha-widget, recaptchav2
- Language: PHP
- Homepage:
- Size: 54.7 KB
- Stars: 28
- Watchers: 6
- Forks: 20
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Codeigniter-recaptcha
This library makes it easy to use [Google's reCAPTCHA V2](https://developers.google.com/recaptcha/intro)## Contents
* [Installation](#installation)
* [Via composer](#via-composer)
* [Manually](#manually)
* [Documentation](#documentation)
* [Getting the keys](#getting-the-keys)
* [Setting the keys](#setting-the-keys)
* [Loading the library](#loading-the-library)
* [Setting parameters](#setting-parameters)
* [Creating the reCAPTCHA box](#creating-the-recaptcha-box)
* [Validating the reCAPTCHA](#validating-the-recaptcha)
* [Example](#example)
* [Contributing](#contributing)## Installation
### Via composer
If you have composer installed you can run```sh
composer require mehdibo/codeigniter-recaptcha
```Copy the content of [`config/recaptcha.php`](/config/recaptcha.php) to `application/config/recaptcha.php`
**First time using composer**
Open a terminal (commands in windows), the commands here are for linux but you can find the equivalent in windows.
1. First thing you should do is [install composer](https://getcomposer.org/doc/00-intro.md)
2. Go to your application folder: `cd application`
3. Install the library: `composer require mehdibo/codeigniter-recaptcha`
4. Copy the content of [`config/recaptcha.php`](/config/recaptcha.php) to your `application/config/recaptcha.php`
5. Go to `application/config/config.php` and set `composer_autoload` to `TRUE`
6. That's it! check the [Documentation](#documentation) for more details.
### Manually
1. Download the [latest release](https://github.com/mehdibo/Codeigniter-recaptcha/releases).
2. Copy `libraries/Recaptcha.php` to `application/libraries` and `config/recaptcha.php` to `application/config`.
3. Load the library using the Codeigniter loader `$this->load->library('recaptcha')`, check the [example](#example).
4. See the [documentation](#documentation) for usage.
## Documentation
### Getting the keys
To use the reCAPTCHA you need a pair of keys (A secret and site keys), these can be obtained from Google by going to:
https://www.google.com/recaptcha/adminAnd registering a new website, make sure you tick the "reCAPTCHA V2" option.
### Setting the keys
There are three ways to pass the keys to the library
**In the config file**You can set the keys by editing the `config/recaptcha.php` config file
**Using the CodeIgniter loader**
By passing an array of configs to the CodeIgniter loader, more details in the "[Loading the library](#loading-the-library)" section.
**Using the `set_keys` method**
You can pass the keys to the `set_keys` methods (after loading the library) like this:
```php
$this->recaptcha->set_keys('site_key', 'secret_key');
```### Loading the library
You can load the library like any other library:
```php
$this->load->library('recaptcha', $config);
```Or if installed via composer:
```php
$recaptcha = new Recaptcha($config);
```
And you can access the methods like this:
```php
$recaptcha->method_name();
```The `$config` argument is *optional*, It can have an array of configs to the library.
`$config` options are:
* `$config['site_key']` - Site key provided by Google
* `$config['secret_key']` - Secret key provided by Google
* `$config['parameters']` - An associative array of parameters and their value, `'parameter-name' => 'value'`, more details about parameters in the "[Setting parameters](#setting-parameters)" section.### Setting parameters
You can set the parameters ([g-recaptcha tag attributes and grecaptcha.render parameters](https://developers.google.com/recaptcha/docs/display#render_param)) by using the `set_parameter` or `set_parameters` methods.To set a parameter you can do it by calling:
```php
$this->recaptcha->set_parameter('parameter_name', 'value');
```Or by passing an array to `set_parameters`:
```php
$this->recaptcha->set_parameters($params);
```Where `$params` is an associative array of `param_name => value`.
When passing a parameter, omit the `data-` part, for example,
If you want to set the `data-theme` parameter to `dark` you will do it like this:
```php
$this->recaptcha->set_parameter('theme', 'dark');
```### Creating the reCAPTCHA box
To create the reCAPTCHA box's HTML code call the `create_box` method:```php
$this->recaptcha->create_box($attributes)
```This method takes one optional parameter, an array of custom attributes, for example:
```php
$attributes = array(
'class' => 're-box',
'id' => 'an-id'
)
```**Notice:** You need to have the reCAPTCHA JS code included in your code:
```html
```
### Validating the reCAPTCHA
The `is_valid` method can be called to verify that the user passed the reCAPTCHA's puzzle.```php
$this->recaptcha->is_valid($response, $ip)
```
this method takes two optional parameters:`$response` - the response submitted by the user, set to `NULL` so that it'll be taken automatically from the POST data
`$ip` - the user IP to be sent to Google's server
Set to `FALSE` to not send the IP
Set to `NULL` to get the user's IP automatically
And it returns an array:```
'success' => TRUE if the recaptcha was passed,'error' => TRUE if there was an error connecting to the server,
'error_message' => If error is true, this contains the message returned by curl,
'challenge_ts' => timestamp of the challenge load (ISO format yyyy-MM-dd'T'HH:mm:ssZZ)
'hostname' => the hostname of the site where the reCAPTCHA was solved
'error-codes' => error codes returned by Google if there are any
```## Example
Here is a quick example to use the **Codeigniter-recaptcha** library.### Installed via composer
**The Controller**
```php
create_box();// Check if the form is submitted
if($this->input->post('action') === 'submit')
{
/*
Check if the reCAPTCHA was solved
You can pass arguments to the `is_valid` method,
but it should work fine without any.
Check the "Validating the reCAPTCHA" section for more details
*/
$is_valid =$recaptcha->is_valid();if($is_valid['success'])
{
echo "reCAPTCHA solved";
}
else
{
echo "reCAPTCHA not solved/an error occured";
}
}$this->load->view('form', ['recaptcha' => $box]);
}
```### Installed manually
**The Controller**
```php
load->library('recaptcha');/*
Create the reCAPTCHA box.
You can pass an array of attributes to this method.
Check the "Creating the reCAPTCHA box" section for more details
*/
$recaptcha = $this->recaptcha->create_box();// Check if the form is submitted
if($this->input->post('action') === 'submit')
{
/*
Check if the reCAPTCHA was solved
You can pass arguments to the `is_valid` method,
but it should work fine without any.
Check the "Validating the reCAPTCHA" section for more details
*/
$is_valid = $this->recaptcha->is_valid();if($is_valid['success'])
{
echo "reCAPTCHA solved";
}
else
{
echo "reCAPTCHA not solved/an error occured";
}
}$this->load->view('form', ['recaptcha' => $recaptcha]);
}
```
---**The view**
```html
CodeIgniter reCAPTCHA
=$recaptcha?>
Submit
```
## Contributing
All contributions are welcome! Just make sure you read [How to contribute](https://github.com/mehdibo/Codeigniter-recaptcha/blob/master/CONTRIBUTING.md)