2017 © Pedro Peláez
 

library zip-code-validator

Constraint class for international zipcode validation

image

barbieswimcrew/zip-code-validator

Constraint class for international zipcode validation

  • Wednesday, May 2, 2018
  • by barbieswimcrew
  • Repository
  • 2 Watchers
  • 31 Stars
  • 58,351 Installations
  • PHP
  • 0 Dependents
  • 1 Suggesters
  • 13 Forks
  • 0 Open issues
  • 16 Versions
  • 18 % Grown

The README.md

Constraint Class for international Zipcode Validation

Build Status Downloads Latest stable version PHP from Packagist GitHub stars MIT licensed, (*1)

Installation

This package uses Composer, please checkout the composer website for more information., (*2)

The following command will install zip-code-validator into your project. It will also add a new entry in your composer.json and update the composer.lock as well., (*3)

$ composer require barbieswimcrew/zip-code-validator

This package follows the PSR-4 convention names for its classes, which means you can easily integrate zip-code-validator classes loading in your own autoloader., (*4)

What now?

For validating a zip code you need to instantiate a new ZipCode class provided by this package to set it as a constraint to your form field, for example:, (*5)

<?php
//...
$form = $this->createFormBuilder($address)
    ->add('zipcode', TextType::class, [
        'constraints' => [
            new ZipCodeValidator\Constraints\ZipCode([
                'iso' => 'DE'
            ])
        ]
    ])
    ->add('save', SubmitType::class, ['label' => 'Create Task'])
    ->getForm();

Another way would be to use the constraint as an annotation of a class property, for example:, (*6)

<?php

use ZipCodeValidator\Constraints\ZipCode;

class Address
{
    /**
     * @ZipCode(iso="DE")
     */
    protected $zipCode;
}

You can also use it as a PHP8 Attribute, with parameters passed as an array of options, for example:, (*7)

<?php

use ZipCodeValidator\Constraints\ZipCode;

class Address
{
    #[ZipCode(['iso'=>'DE'])
    protected $zipCode;
}

Please consider to inject a valid ISO 3166 2-letter country code (e.g. DE, US, FR)!, (*8)

NOTE: This library validates against known zip code regex patterns and does not validate the existence of a zipcode., (*9)

Use a getter to inject the country code dynamically

If you have a form, in which the user can select a country, you may want to validate the zip code dynamically. In this case you can use the getter option instead:, (*10)

<?php

use ZipCodeValidator\Constraints\ZipCode;

class Address
{
    /**
     * @ZipCode(getter="getCountry")
     */
    protected $zipCode;

    protected $country;

    public function getCountry()
    {
        return $this->country;
    }
}

To disable that the validator throws an exception, when the zip code pattern is not available for a country, you can set the strict option to FALSE., (*11)

/**
 * @ZipCode(getter="getCountry", strict=false)
 */
protected $zipCode;

The validator will not validate empty strings and null values. To disallow them use the Symfony stock NotNull or NotBlank constraint in addition to ZipCode., (*12)

/**
 * @ZipCode(getter="getCountry")
 * @NotBlank 
 */
protected $zipCode;

Case insensitive zip code matching

In case you want to match the zip code in a case insensitive way you have to pass a caseSensitiveCheck parameter with false value via the constructor:, (*13)

$constraint = new ZipCode([
    'iso' => 'GB', 
    'caseSensitiveCheck' => false
]);

By the default the library is using case sensitive zip code matching., (*14)

Copying / License

This repository is distributed under the MIT License (MIT). You can find the whole license text in the LICENSE file., (*15)

The Versions

02/05 2018

dev-master

9999999-dev

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

The Development Requires

by Martin Schindler

form validator validation symfony2 symfony3 symfony postal code zipcode constraints postalcode constraint zip code

02/05 2018

v1.2.0

1.2.0.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

The Development Requires

by Martin Schindler

form validator validation symfony2 symfony3 symfony postal code zipcode constraints postalcode constraint zip code

26/01 2018

v1.1.4

1.1.4.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

The Development Requires

by Martin Schindler

form validator validation symfony2 symfony3 symfony postal code zipcode constraints postalcode constraint zip code

06/12 2017

v1.1.3

1.1.3.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

The Development Requires

by Martin Schindler

form validator validation symfony2 symfony3 symfony postal code zipcode constraints postalcode constraint zip code

13/10 2017

dev-add-code-of-conduct-1

dev-add-code-of-conduct-1

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

21/09 2017

v1.1.2

1.1.2.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

30/06 2017

v1.1.1

1.1.1.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

06/06 2017

v1.1.0

1.1.0.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

06/06 2017

v1.0.9

1.0.9.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

05/04 2017

v1.0.8

1.0.8.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

18/10 2016

v1.0.7

1.0.7.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

05/10 2016

v1.0.6

1.0.6.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

12/09 2016

v1.0.5

1.0.5.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

16/08 2016

v1.0.4

1.0.4.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

05/08 2016

1.0.2

1.0.2.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code

05/08 2016

1.0.0

1.0.0.0

Constraint class for international zipcode validation

  Sources   Download

MIT

The Requires

 

by Martin Schindler

form validator validation symfony2 symfony postal code zipcode constraints postalcode constraint zip code