A Laravel package for Turkey's provinces, districts, subdistricts (quarters), neighborhoods, and postal codes. Easily import, query, and keep up-to-date address data from PTT's official source.
composer require madkhix/tr-address-pttphp artisan vendor:publish --provider="TrAddressPtt\TrAddressServiceProvider" --tag="migrations"
php artisan migrate
php artisan vendor:publish --provider="TrAddressPtt\TrAddressServiceProvider" --tag="seeders"
php artisan vendor:publish --provider="TrAddressPtt\TrAddressServiceProvider" --tag="traddressptt-config"After running the Python scraper, copy the generated
tr-address-ptt-data.jsonfile to your Laravel project root (where theartisanfile is located). You can also use the following artisan command to copy it automatically:php artisan traddress-ptt:publish-json
You can change the JSON data file path in
config/traddressptt.phpif needed.
Each table has its own migration file:
citiesdistrictssubdistrictsneighborhoodspostcodes
You can run all migrations at once:
php artisan migrateOr migrate a specific table (advanced usage):
php artisan migrate --path=src/database/migrations/2024_01_03_000000_create_subdistricts_table.phpEach table has its own seeder:
CitySeederDistrictSeederSubdistrictSeeder(independent, only seeds subdistricts)NeighborhoodSeeder(does not create subdistricts, only links to them)PostcodeSeederTrAddressSeeder(runs all in order)
Seed all data:
php artisan db:seed --class=Database\Seeders\TrAddressPttSeederOr seed a specific table:
php artisan db:seed --class=Database\Seeders\SubdistrictSeeder
php artisan db:seed --class=Database\Seeders\NeighborhoodSeederNote:
- Run
SubdistrictSeederbeforeNeighborhoodSeederif you seed them separately.NeighborhoodSeederwill not create subdistricts, only link to existing ones.
use TrAddressPtt\Models\City;
use TrAddressPtt\Models\Subdistrict;
use TrAddressPtt\Models\Neighborhood;
$cities = City::all();
$subdistricts = Subdistrict::where('district_id', $districtId)->get();
$neighborhoods = Neighborhood::where('subdistrict_id', $subdistrictId)->get();The package uses a normalized structure:
subdistrictstable for quarters (semt), linked to districtsneighborhoodstable links to subdistricts viasubdistrict_id
If your JSON data contains entries like:
{
"name": "BEYAZEVLER MAH / MAHFESIĞMAZ / 01170"
}name→ "BEYAZEVLER MAH"subdistrict→ "MAHFESIĞMAZ" (stored in subdistricts table)postcode→ "01170"
The seeders will automatically parse and store these fields in the correct tables and columns.
This package does not include the Python data fetcher script by default. To update the address data from the official PTT source, use the separate Python script available at:
https://github.com/madkhix/tr-address-fetcher-ptt
Usage:
- Clone or download the script from the repository above.
- Run the script in your terminal:
python fetch_tr_address_data.py
- The script will generate a
tr-address-ptt-data.jsonfile. - Copy this file to your Laravel project root (where
artisanis located). - Import the data using the package's artisan command:
php artisan traddress-ptt:import-ptt tr-address-ptt-data.json
MIT