actengage/sanitize

A collection of common sanitizer functions.

Maintainers

👁 actengage

Package info

github.com/ActiveEngagement/sanitize

pkg:composer/actengage/sanitize

Statistics

Installs: 2 296

Dependents: 0

Suggesters: 0

Stars: 1

Open Issues: 0

v3.0.0 2026-03-17 19:08 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT 1892d8e19ed6686f33bd7eb8b3a103ef90932f29

  • Justin Kimbrell <jkimbrell.woop@actengage.com>

validationphonesanitizezipemails

This package is auto-updated.

Last update: 2026-06-17 19:38:24 UTC


README

A collection of classes used to sanitize common inputs like email addresses, phone numbers, and zip codes.

Installation

composer require actengage/sanitize

Basic Usage

use Actengage\Sanitize\Facades\Sanitize;

Sanitize::email(' JOHN.doe @gmail.com '); // johndoe@gmail.com
Sanitize::phone('(888) 123-1234'); // 8881231234
Sanitize::zip('12345'); // 12345

Attribute Casts

You can cast Eloquent attributes as sanitized values.

use Actengage\Sanitize\Casts\Email;
use Actengage\Sanitize\Casts\Phone;
use Actengage\Sanitize\Casts\Zip;

class User extends Model
{
 protected $guarded = [];

 protected $casts = [
 'email' => Email::class,
 'phone' => Phone::class,
 'zip' => Zip::class,
 ];
}

$user = User::create([
 'email' => ' john.doe@gmail.com ',
 'phone' => '1-800-567-1234',
 'zip' => '1234',
]);

$user->email; // johndoe@gmail.com
$user->phone; // 8005671234
$user->zip; // 01234

Validation Rules

Validation rules are included for each sanitizer.

use Actengage\Sanitize\Rules\Email;
use Actengage\Sanitize\Rules\Phone;
use Actengage\Sanitize\Rules\Zip;

$request->validate([
 'email' => ['required', new Email],
 'phone' => ['required', new Phone],
 'zip' => ['required', new Zip],
]);

Middleware

The SanitizeInputs middleware automatically sanitizes matching request fields.

use Actengage\Sanitize\Http\Middleware\SanitizeInputs;

Route::middleware(SanitizeInputs::class)->group(function () {
 // Request inputs for email, phone, and zip are sanitized automatically
});

Custom Sanitizer Macros

You can add additional sanitizer functions using macros.

use Actengage\Sanitize\Facades\Sanitize;

Sanitize::macro('number', function (?string $value) {
 return is_numeric($value) ? $value : null;
});

Sanitize::number('123'); // "123"
Sanitize::number('abc'); // null

Publishing a New Release

This package uses changesets for automated versioning and releases.

  1. Create a branch and make your changes
  2. Add a changeset describing the change:
    pnpm changeset
    
    Select the bump level (patch, minor, or major) and write a summary. See the changeset skill for semver rules specific to this package.
  3. Open a PR — CI runs Pint, PHPStan, Rector, and Pest
  4. Merge the PR — the release workflow creates a "Version Packages" PR that bumps the version in package.json and updates CHANGELOG.md
  5. Review and merge the "Version Packages" PR — a git tag and GitHub Release are created automatically