Skip to content

A Cloudflare's Turnstile captcha adapter for Laravel

License

Notifications You must be signed in to change notification settings

StudioLambda/Turnstile

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Turnstile (Cloudflare Captcha)

Quick and easy implementation of Turnstile for Laravel.

Example request validation

Route::post('/test', function (Request $request) {
    $request->validate([
        'cf-turnstile-response' => [
          'required',
          'string',
          app(\LambdaStudio\Turnstile\Rules\ValidTurnstile::class),
        ],
    ]);

    dd($request->input('name'));
});

Just apply the rule to the cf-turnstile-response field.

Example frontend implementation

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <form method="POST" action="{{ url('/test') }}">
    @csrf
    <input type="text" name="name" placeholder="Name">
    <div class="cf-turnstile" data-sitekey="{{ config('turnstile.site_key') }}"></div>
    <input type="submit" value="Submit">
  </form>
  <ul>
    @foreach ($errors->all() as $error)
      <li>{{ $error }}</li>
    @endforeach
  </ul>
  <script src="https://challenges.cloudflare.com/turnstile/v0/api.js" async defer></script>
</body>

</html>

Todo

  • Add blade macros
    • @turnstile(): Adds the turnstile division with the site_key on it.
    • @turnstyleScript(): Adds the turnstile script tag.

About

A Cloudflare's Turnstile captcha adapter for Laravel

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages