Download the PHP package msurguy/honeypot without Composer

On this page you can find all versions of the php package msurguy/honeypot. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package honeypot

Honeypot spam prevention for Laravel applications

How does it work?

"Honeypot" method of spam prevention is a simple and effective way to defer some of the spam bots that come to your site. This technique is based on creating an input field that should be left empty by the real users of the application but will most likely be filled out by spam bots.

This package creates a hidden DIV with two fields in it, honeypot field (like "my_name") and a honeytime field - an encrypted timestamp that marks the moment when the page was served to the user. When the form containing these inputs invisible to the user is submitted to your application, a custom validator that comes with the package checks that the honeypot field is empty and also checks the time it took for the user to fill out the form. If the form was filled out too quickly (i.e. less than 5 seconds) or if there was a value put in the honeypot field, this submission is most likely from a spam bot.

Installation:

In your terminal type : composer require msurguy/honeypot. Or open up composer.json and add the following line under "require":

{
    "require": {
        "msurguy/honeypot": "^1.0"
    }
}

Next, add this line to 'providers' section of the app config file in app/config/app.php:

'Msurguy\Honeypot\HoneypotServiceProvider',

Add the honeypot facade:

'Honeypot' => 'Msurguy\Honeypot\HoneypotFacade'

At this point the package is installed and you can use it as follows.

Usage :

Add the honeypot catcher to your form by inserting Honeypot::generate(..) like this:

Laravel 5 & above:

{!! Form::open('contact') !!}
    ...
    {!! Honeypot::generate('my_name', 'my_time') !!}
    ...
{!! Form::close() !!}

Other Laravel versions:

{{ Form::open('contact') }}
    ...
    {{ Honeypot::generate('my_name', 'my_time') }}
    ...
{{ Form::close() }}

The generate method will output the following HTML markup (my_time field will contain an encrypted timestamp):

<div id="my_name_wrap" style="display:none;">
    <input name="my_name" type="text" value="" id="my_name">
    <input name="my_time" type="text" value="eyJpdiI6IkxoeWhKc3prN2puZllEajRwZ3lrc0I5bU42bUFWbzF1NEVVOEhxbG9WcFE9IiwidmFsdWUiOiJxNEtBT0NpYW5lUjJvWXp6VE45a1U0V3dNbk9Jd2RUNW42NFpiQWtTRllRPSIsIm1hYyI6IjAyMWQ0NWI1NTVkYTBjZTAxMTdhZmJmNTY0ZDI4Nzg4NzU3ODU4MjM1Y2MxNTVkYjAwNmFhNzBmNTdlNmJmMjkifQ==">
</div>

After adding the honeypot fields in the markup with the specified macro add the validation for the honeypot and honeytime fields of the form:

$rules = array(
    'email'     => "required|email",
    ...
    'my_name'   => 'honeypot',
    'my_time'   => 'required|honeytime:5'
);

$validator = Validator::make(Input::get(), $rules);

Please note that "honeytime" takes a parameter specifying number of seconds it should take for the user to fill out the form. If it takes less time than that the form is considered a spam submission.

That's it! Enjoy getting less spam in your inbox. If you need stronger spam protection, consider using Akismet or reCaptcha

Testing

If you want to test the submission of a form using this package, you might want to disable Honeypot so that the validation passes. To do so, simply call the disable() method in your test:

Honeypot::disable();

$this->visit('contact')
    ->type('User', 'name')
    ->type('[email protected]', 'email')
    ->type('Hello World', 'message')
    ->press('submit')
    ->see('Your message has been sent!');

Credits

Based on work originally created by Ian Landsman: https://github.com/ianlandsman/Honeypot

License

This work is MIT-licensed by Maksim Surguy.


All versions of honeypot with dependencies

PHP Build Version
Package Version
Requires php Version >=5.3.0
illuminate/support Version 4.*|5.*|6.*|7.*|8.*|9.*|^10.0
illuminate/config Version 4.*|5.*|6.*|7.*|8.*|9.*|^10.0
illuminate/translation Version 4.*|5.*|6.*|7.*|8.*|9.*|^10.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package msurguy/honeypot contains the following files

Loading the files please wait ....