madkhix / tr-address
A Laravel package for Turkey's provinces, districts, neighborhoods, and postal codes.
Requires
- php: >=8.0
- illuminate/support: >=8.0
This package is auto-updated.
Last update: 2025-07-01 11:26:09 UTC
README
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.
Installation
composer require madkhix/tr-address
Publishing Migrations, Seeders, and Config
php artisan vendor:publish --provider="TrAddress\TrAddressServiceProvider" --tag="migrations" php artisan migrate php artisan vendor:publish --provider="TrAddress\TrAddressServiceProvider" --tag="seeders" php artisan vendor:publish --provider="TrAddress\TrAddressServiceProvider" --tag="traddress-config"
After running the Python scraper, copy the generated
tr-address-data.json
file to your Laravel project root (where theartisan
file is located). You can also use the following artisan command to copy it automatically:php artisan traddress:publish-json
You can change the JSON data file path in
config/traddress.php
if needed.
Migration Structure
Each table has its own migration file:
cities
districts
subdistricts
neighborhoods
postcodes
You can run all migrations at once:
php artisan migrate
Or migrate a specific table (advanced usage):
php artisan migrate --path=src/database/migrations/2024_01_03_000000_create_subdistricts_table.php
Seeder Structure
Each table has its own seeder:
CitySeeder
DistrictSeeder
SubdistrictSeeder
(independent, only seeds subdistricts)NeighborhoodSeeder
(does not create subdistricts, only links to them)PostcodeSeeder
TrAddressSeeder
(runs all in order)
Seed all data:
php artisan db:seed --class=Database\Seeders\TrAddressSeeder
Or seed a specific table:
php artisan db:seed --class=Database\Seeders\SubdistrictSeeder php artisan db:seed --class=Database\Seeders\NeighborhoodSeeder
Note:
- Run
SubdistrictSeeder
beforeNeighborhoodSeeder
if you seed them separately.NeighborhoodSeeder
will not create subdistricts, only link to existing ones.
Usage
use TrAddress\Models\City; use TrAddress\Models\Subdistrict; use TrAddress\Models\Neighborhood; $cities = City::all(); $subdistricts = Subdistrict::where('district_id', $districtId)->get(); $neighborhoods = Neighborhood::where('subdistrict_id', $subdistrictId)->get();
Data Structure
The package uses a normalized structure:
subdistricts
table for quarters (semt), linked to districtsneighborhoods
table 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.
Updating Address Data (Fetching from PTT)
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
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-data.json
file. - Copy this file to your Laravel project root (where
artisan
is located). - Import the data using the package's artisan command:
php artisan traddress:import tr-address-data.json
This approach keeps the PHP package clean and dependency-free, while still allowing advanced users to update the address data as needed.
License
MIT