2017 © Pedro Peláez
 

library pesel

Sprawdzanie poprawności numeru PESEL

image

kkszymanowski/pesel

Sprawdzanie poprawności numeru PESEL

  • Monday, June 20, 2016
  • by KKSzymanowski
  • Repository
  • 2 Watchers
  • 1 Stars
  • 73 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 16 % Grown

The README.md

PESEL

Build Status Coverage Status StyleCI Latest Stable Version License, (*1)

Paczka do łatwej walidacji numeru PESEL., (*2)

Instalacja

Composer:, (*3)

composer require kkszymanowski/pesel

Upgrade guide

2.* -> 3.*

Wersja 3 jest wstecznie kompatybilna z wersją 2, ale wymaga PHP >=7.3. Poza podniesieniem wersji PHP żadne zmiany nie są konieczne., (*4)

Zalecana jest natomiast zmiana łapanego wyjątku InvalidArgumentException na wyjątki odpowiadające konkretnym błędom walidacji: - Pesel\Exceptions\InvalidLengthException - Błędna długość - Pesel\Exceptions\InvalidCharactersException - Znaki inne niż cyfry - Pesel\Exceptions\InvalidChecksumException - Błędna suma kontrolna, (*5)

lub po prostu na Pesel\Exceptions\PeselValidationException aby złapać wszystkie błędy walidacji., (*6)

3.* -> 4.*

W wersji 4 zmieniona została walidacja numeru PESEL, aby dobrze identyfikować numery takie jak 00000000000 i 44444444444 jako niepoprawne. Wersja 4 jest zatem niekompatybilna z wersją 3 w tych przypadkach brzegowych, ale nie powinno być problemów z kompatybilnością w większości przypadków., (*7)

Od wersji 4 w przypadku nieprawidłowej daty urodzenia w numerze PESEL rzucany jest nowy wyjątek - Pesel\Exceptions\InvalidBirthDateException., (*8)

Użycie

Tworzenie obiektu
$pesel = new Pesel($number);

lub, (*9)

$pesel = Pesel::create($number);

Powyższe metody są równoważne., (*10)

Podczas tworzenia obiektu sprawdzana jest poprawność numeru PESEL. - Powinien mieć 11 znaków. - Powinien zawierać wyłącznie cyfry. - Suma kontrolna powinna być poprawna. - Powinien zawierać prawidłową datę urodzenia: - rok >= 1800 i < 2300. - miesiąc >= 1 i <= 12. - dzień >= 1 i nie większy niż liczba dni w danym miesiącu i danym roku., (*11)

Jeżeli przynajmniej jeden z tych warunków nie zostanie spełniony, zostanie rzucony odpowiedni wyjątek: - Pesel\Exceptions\InvalidLengthException - Błędna długość - Pesel\Exceptions\InvalidCharactersException - Znaki inne niż cyfry - Pesel\Exceptions\InvalidChecksumException - Błędna suma kontrolna - Pesel\Exceptions\InvalidChecksumException - Błędna data urodzenia, (*12)

try {
    Pesel::create($number);

    echo('Numer PESEL jest poprawny');
} catch(Pesel\Exceptions\InvalidLengthException $e) {
    echo('Numer PESEL ma nieprawidłową długość');
} catch(Pesel\Exceptions\InvalidCharactersException $e) {
    echo('Numer PESEL zawiera nieprawidłowe znaki');
} catch(Pesel\Exceptions\InvalidChecksumException $e) {
    echo('Numer PESEL zawiera błędną sumę kontrolną');
} catch(Pesel\Exceptions\InvalidBirthDateException $e) {
    echo('Numer PESEL zawiera nieprawdiłową datę urodzenia');
}

Wszystkie powyższe wyjątki dziedziczą z Pesel\Exceptions\PeselValidationException więc jeżeli niepotrzebne jest rozróżnienie na konkretne błędy walidacji można zastosować jedną klauzulę catch:, (*13)

try {
    Pesel::create($number);

    echo('Numer PESEL jest poprawny');
} catch(\Pesel\Exceptions\PeselValidationException $e) {
    echo('Numer PESEL jest błędny');
}
Pobieranie zawartości numeru PESEL:
$pesel = new Pesel($number);

$pesel->getNumber();    // Zwraca string

$pesel->getBirthDate(); // Zwraca DateTime

$pesel->getGender();    // Zwraca Pesel::GENDER_MALE lub Pesel::GENDER_FEMALE
Sprawdzenie poprawności:
Pesel::isValid($pesel); // Zwraca bool, nie rzuca wyjątku
Sprawdzenie daty urodzenia:

Parametr $birthDate jest instancją wbudowanej w PHP klasy DateTime, (*14)

PeselValidator::hasBirthDate(Pesel::create($pesel), $birthDate);
Sprawdzenie płci
PeselValidator::hasGender(Pesel::create($pesel), Pesel::GENDER_MALE);

PeselValidator::hasGender(Pesel::create($pesel), Pesel::GENDER_FEMALE);

The Versions

20/06 2016

dev-master

9999999-dev

Sprawdzanie poprawności numeru PESEL

  Sources   Download

MIT

The Requires

  • php >=5.3.3

 

The Development Requires

by Kuba Szymanowski

pesel poprawność numeru

17/06 2016

2.1.0

2.1.0.0

Sprawdzanie poprawności numeru PESEL

  Sources   Download

MIT

The Requires

  • php >=5.3.3

 

The Development Requires

by Kuba Szymanowski

pesel poprawność numeru

17/06 2016

2.0.1

2.0.1.0

Sprawdzanie poprawności numeru PESEL

  Sources   Download

MIT

The Requires

  • php >=5.3.3

 

The Development Requires

by Kuba Szymanowski

pesel poprawność numeru

17/06 2016

2.0.0

2.0.0.0

Sprawdzanie poprawności numeru PESEL

  Sources   Download

MIT

The Requires

  • php >=5.3.3

 

The Development Requires

by Kuba Szymanowski

pesel poprawność

16/06 2016

1.0.0

1.0.0.0

Sprawdzanie poprawności numeru PESEL

  Sources   Download

MIT

The Requires

 

The Development Requires

by Kuba Szymanowski

pesel poprawność