| Package Data | |
|---|---|
| Maintainer Username: | emiliopedrollo | 
| Maintainer Contact: | najm@njeim.net (Najm Njeim) | 
| Package Create Date: | 2022-04-07 | 
| Package Last Update: | 2022-04-18 | 
| Home Page: | |
| Language: | PHP | 
| License: | MIT | 
| Last Refreshed: | 2025-10-21 15:00:57 | 
| Package Statistics | |
|---|---|
| Total Downloads: | 11 | 
| Monthly Downloads: | 0 | 
| Daily Downloads: | 0 | 
| Total Stars: | 0 | 
| Total Watchers: | 0 | 
| Total Forks: | 0 | 
| Total Open Issues: | 0 | 
The World is a Laravel package which provides a list of the countries, states, cities, timezones, currencies and languages.
It can be consumed with the World Facade or the defined Api routes.
composer require nnjeim/world
php artisan vendor:publish --tag=world
php artisan migrate
php artisan db:seed --class=WorldSeeder (requires ~15min)
php artisan vendor:publish --tag=world --force
world.php config file.Please read CHANGELOG for more information of what was changed recently.
Please read CONTRIBUTING for more details.
Please feel free to query https://laravel-world.com
Examples
https://laravel-world.com/api/countries
https://laravel-world.com/api/states?filters[country_id]=182&fields=cities
Use the World facade
use Nnjeim\World\World;
$action =  World::countries();
if ($action->success) {
	$countries = $action->data;
}
response 
{
	"success": true,
	"message": "countries",
	"data": [
		{
			"id": 1,
			"name": "Afghanistan"
		},
		{
			"id": 2,
			"name": "Åland Islands"
		},
		.
		.
		.
	],
}
Use the Api countries endpoint
https://myDomain.local/api/countries
Use the World facade
use Nnjeim\World\World;
$action =  World::countries([
	'fields' => 'states,cities',
	'filters' => [
		'iso2' => 'FR',
	]
]);
if ($action->success) {
	$countries = $action->data;
}
response 
{
	"success": true,
	"message": "countries",
	"data": [
		"id": 77,
		"name": "France",
		"states": [
			 {
				"id": 1271,
				"name": "Alo"
			},
			{
				"id": 1272,
				"name": "Alsace"
			},
			.
			.
			.
		],
		"cities": [
			{
				"id": 25148,
				"name": "Abondance"
			},
			{
				"id": 25149,
				"name": "Abrest"
			},
			.
			.
			.
		]
	],
}
Use the Api countries endpoint
https://myDomain.local/api/countries?fields=states,cities&filters[iso2]=FR
use Nnjeim\World\WorldHelper;
protected $world;
public function __construct(WorldHelper $world) {
	$this->world = $world;
}
$action = $this->world->cities([
	'filters' => [
		'country_id' => 182,
	],
]);
if ($action->success) {
	$cities = $action->data;
}
Use the Api cities endpoint
https://myDomain.local/api/cities?filters[country_id]=182
| Name | Description | |:-----------|:------------------------------| | countries | lists all the world countries | | states | lists all the states | | cities | lists all the cities | | timezones | lists all the timezones | | currencies | lists all the currencies | | languages | lists all the languages |
An action response is formed as below:
All routes can be prefixed by any string. Ex admin, api, api ...
| | |
| :--- | :--- |
| Method | GET |
| Route | /{prefix}/countries |
| Parameters* | comma seperated fields(countries table fields in addition to states, cities, currency and timezones), array filters |
| Example | /api/countries?fields=iso2,cities&filters[phone_code]=44 |
| response | success, message, data |
| | |
| :--- | :--- |
| Method | GET |
| Route | /{prefix}/states |
| Parameters* | comma seperated fields(states table fields in addition to country and cities), array filters |
| Example | /api/states?fields=country,cities&filters[country_id]=182 |
| response | success, message, data |
| | |
| :--- | :--- |
| Method | GET |
| Route | /{prefix}/cities |
| Parameters* | comma seperated fields(states table fields in addition to country and state), array filters |
| Example | /api/cities?fields=country,state&filters[country_id]=182 |
| response | success, message, data |
| | |
| :--- | :--- |
| Method | GET |
| Route | /{prefix}/timezones |
| Parameters* | comma seperated fields(states table fields in addition to the country), array filters |
| Example | /api/timezones?fields=country&filters[country_id]=182 |
| response | success, message, data |
| |                                                                                       |
| :--- |:--------------------------------------------------------------------------------------|
| Method | GET                                                                                   |
| Route | /{prefix}/currencies                                                                  |
| Parameters* | comma seperated fields(states table fields in addition to the country), array filters |
| Example | /api/timezones?fields=country&filters[country_id]=182                                  |
| response | success, message, data                                                                |
| |                          |
| :--- |:-------------------------|
| Method | GET                      |
| Route | /{prefix}/languages      |
| Parameters* | comma seperated fields
| Example | /api/languages?fields=dir |
| response | success, message, data   |
The available locales are ar, bn, br, de, en, es, fr, ja, kr, pl, pt, ro, ru and zh.
The default locale is en.
Include in the request header
accept-language=locale
Alternativley, you can use specific locale with the World Facade setLocale('locale') helper method. Example:
World::setLocale('zh')->countries();
Requirements
Browse to the package root folder and run:
composer install //installs the package dev dependencies
composer test
* optional