deligoez / tckimlikno
Turkish Identification Number Verification & Validation Package for Laravel
Requires
- php: ^8.1 | ^8.2 | ^8.3 | ^8.4
- guzzlehttp/guzzle: ^7.2.0
- illuminate/support: ^9.0 | ^10.0 | ^11.0 | ^12.0
- ricorocks-digital-agency/soap: ^1.6 | 2.* | 3.*
Requires (Dev)
- fakerphp/faker: ^1.19
- mockery/mockery: ^1.5
- orchestra/testbench: ^7.5 | ^8.0 | ^9.0 | ^10.0
- phpunit/phpunit: ^9.5 | ^10.5 | ^11.0
- dev-master
- v5.1.0
- v5.0.0
- 4.1.0
- 4.0.0
- 3.2.0
- 3.1.0
- 3.0.0
- 2.1.0
- 2.0.0
- 1.5.0
- 1.4.1
- 1.4.0
- 1.3.0
- 1.2.0
- 1.1.1
- 1.1.0
- v1.0.0
- dev-laravel-12
- dev-30-birthday-and-birth-month-check-api-now-requires-mandatory-captcha-check
- dev-feature/laravel-8-upgrade
- dev-feature/laravel-7-support
- dev-feature/add-php-7-4-tests-to-travis
- dev-feature/add-type-hints-to-tests
This package is auto-updated.
Last update: 2026-03-02 14:47:28 UTC
README
⚠️ This project is no longer maintained. The NVI public verification services at tckimlik.nvi.gov.tr were discontinued as of 30.09.2025. The
validate()method that relied on the NVI API no longer works. The offlineverify()method (algorithm-based) still functions, but this package will not receive further updates.
TCKimlikNo
Turkish Identification Number Verification & Validation Package for Laravel.
Installation
Via Composer
$ composer require deligoez/tckimlikno
If you are using Laravel 5.5+, the package will automatically register the service provider for you.
Usage
use Deligoez\TCKimlikNo\TCKimlikNo;
// Verifies Citizenship Number According to it's Algorithm.
// Returns Boolean
TCKimlikNo::verify('12345678901'); // Returns false
TCKimlikNo::verify('10000000146'); // Returns true
// Verifies Parameters and validates all using nvi.gov.tr API
// Returns Boolean
TCKimlikNo::validate('10000000146', 'Yunus Emre', 'Deligöz', '1900')
// Auto Uppercase Disabled
TCKimlikNo::validate('10000000146', 'YUNUS EMRE', 'DELİGÖZ', '1900', false)
Available Laravel Validation Rules
TCKimlikNoVerify
// In a Form Request Class
public function rules()
{
return [
'tckimlikno' => ['required', new TCKimlikNoVerify()],
];
}
// In a Controller
use Deligoez\TCKimlikNo\Rules\TCKimlikNoVerify;
/**
* Store a tckn.
*
* @param Request $request
* @return Response
*/
public function store(Request $request)
{
$validatedData = $request->validate([
'tckn' => ['bail', 'required', new TCKimlikNoVerify()],
]);
// tckn is valid...
}
TCKimlikNoValidate
// In a Form Request Class
public function rules()
{
return [
'tckimlikno' => ['required', new TCKimlikNoValidate(
$name,
$surname,
$birthYear,
$autoUppercase // Optional, defaults to true
)],
];
}
Faker Provider
use Deligoez\TCKimlikNo\Provider\TCKimlikNoFakerProvider;
$faker = Faker\Factory::create();
$faker->addProvider(new TCKimlikNoFakerProvider($faker));
// a Random Valid TCKN
$tckn = $faker->tckn; // 60174067810
Changelog
Please see the changelog for more information on what has changed recently.
Testing
$ composer test
Contributing
Please see contributing.md for details and a todo list.
Security
If you discover any security related issues, please email ye@deligoz.me instead of using the issue tracker.
Credits
License
MIT. Please see the license file for more information.