Skip to content

mbpcoder/world

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

67 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🌍 World - PHP & Laravel Package for Geographical Data

World is a powerful PHP and Laravel package for retrieving structured geographical data, including continents, countries, provinces, and cities. This package is lightweight, optimized for performance, and seamlessly integrates with Laravel applications.


🚀 Features

✔ Get all continents, countries, provinces, and cities
✔ Filter countries by continent
✔ Retrieve provinces and cities for any country
✔ Optimized for high performance with caching
✔ Compatible with Laravel and PHP
✔ Includes migrations and seeding for easy setup
✔ includes a Laravel Facade for simpler usage!


📦 Installation

Install via Composer:

composer require thecoder/world

If auto-discovery is not working, manually add the service provider in config/app.php:

TheCoder\World\WorldServiceProvider::class,

🔧 Publish Configuration & Migrations for Greater Flexibility

php artisan vendor:publish --provider="TheCoder\World\WorldServiceProvider"

This will publish:
config/world.php (configuration file)
✅ Database migration files

🛠 Migrate the Database

php artisan migrate

🌍 Seed Geographical Data

php artisan world:seed

This will populate the database with continents, countries, provinces, and cities.


🔍 Usage

1️⃣ Using the Built-in World Facade (Recommended)

The package now includes a World Facade, making it easier to access data:

use World;

$continents = World::continents()->get();  // Get all continents
$countries = World::countries()->get();  // Get all countries

2️⃣ Manually Instantiate the Class

use TheCoder\World;

$world = new World();

$continents = $world->continents()->get();  
$countries = $world->countries()->get();  

Get Locations

$location = World::byId(1)->first();

$location = World::byEnglishName('Asia')->first();

$locations = World::byIds([1,2])->get();

$locations = World::byEnglishNames(['Iraq', 'Iran'])->get();

$location = World::count();  

Get Countries by Continent

$asia = World::continents('Asia')->first();

$asia = World::continents()->byEnglishName('Asia')->first();  

$asiaCountries = World::continents()->byEnglishName('Asia')->countries()->get();  

Get Provinces & Cities

$iranProvinces = World::countries('Iran')->provinces()->get();

$iranProvinces = World::countries()->byEnglishName('Iran')->provinces()->get();

$gilanCities = World::provinces('Gilan')->cities()->get();  
  
$gilanCities = World::provinces()->byEnglishName('Gilan')->cities()->get();  

⚡Caching for Maximum Performance

Since the World database is static and never changes, this package supports permanent caching to eliminate redundant database queries and significantly improve performance.

Enable Caching

You can enable caching in the config/world.php file:

  'cache' => [
      'enabled' => true,
      'prefix' => 'thecoder-world-',
      'tag' => 'thecoder-world',
      'ttl' => null, // Store cache forever
  ],

Setting ttl to null ensures that data is cached forever.

Use Cached Data in Queries

If caching is enabled, queries will automatically store results in the cache forever.

Manually Clear Cache (If Needed)

To clear the cache manually, run:

  php artisan cache:clear

Or in code:

World::clearCache();

🏗 Package-Integrated Laravel Facade

The package now provides a World Facade out-of-the-box, meaning Laravel users don't need to set it up manually.

No need to register aliases
Works automatically in Laravel

Just install the package and start using it:

use World;

$continents = World::continents()->get();

🧪Testing

Ensure you have the necessary dependencies installed:

composer install --dev

⚠️ Database Configuration for Testing

Due to special columns in the database, SQLite is not supported for testing.

Instead, configure MySQL in phpunit.xml:

    <php>
        <env name="DB_CONNECTION" value="mysql"/>
        <env name="DB_HOST" value="127.0.0.1"/>
        <env name="DB_PORT" value="3306"/>
        <env name="DB_DATABASE" value="world_test_database"/>
        <env name="DB_USERNAME" value="root"/>
        <env name="DB_PASSWORD" value=""/>
    </php>

▶️ Running tests

vendor/bin/phpunit

🗄 Database Schema

This package provides a locations table designed to store structured geographic data with hierarchical relationships.

Column Type Description
id Integer (PK) Unique identifier
continent_id Integer (FK) Parent continent (nullable)
country_id Integer (FK) Parent country (nullable)
province_id Integer (FK) Parent province (nullable)
iso_code String (3) ISO country code (e.g., "US")
type Enum continent, country, province, city
english_name String Location name in English
native_name String Local name (optional)
timezone String Time zone (e.g., "Asia/Tehran")
is_capital Boolean Marks capital cities (default: false)
priority Integer Sort priority (default: 0)
center POINT Geographic coordinates
area MULTIPOLYGON Spatial data for regions

Indexed for fast queries
Supports geographic coordinates & boundaries


❓ FAQ

🔹 What is this package used for?

It helps developers retrieve geographical data (continents, countries, provinces, and cities) for Laravel & PHP applications.

🔹 Is this package compatible with Laravel?

Yes! It fully supports Laravel and can also be used in vanilla PHP projects.

🔹 How can I filter countries by continent?

World::continents('Europe')->countries()->get();

🔹 Can I get cities of a specific province?

World::provinces('California')->cities()->get();

⭐ Contribute & Support

🔹 GitHub Repository: thecoder/world
🔹 Issues & Features: Submit Here
🔹 Contribute: Fork, star ⭐, and submit PRs

💡 Need more features? Open an issue or contribute to the project!

About

World - PHP & Laravel Package for Geographical Data

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Languages