palauaandsons / cloudflare-geoip
Cloudflare GeoIP helper with Laravel
Installs: 2 804
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- illuminate/http: ^9.0|^10.0|^11.0
- illuminate/support: ^9.0|^10.0|^11.0
Requires (Dev)
- laravel/pint: ^1.13
- orchestra/testbench: ^8.0|^9.0
- pestphp/pest: ^2.34
This package is auto-updated.
Last update: 2024-11-03 18:43:10 UTC
README
Get the geographical localtion of visitor based off Cloudflare headers.
Caution
Make sure Visitor Location & IP Geolocation are enabled in Cloudflare Dashboard.
Installation
composer require palauaandsons/cloudflare-geoip
Configuration
Run the following command to publish configuration. Be sure to modify the configuration file specifically the default location to use if the cloudflare headers are absent.
php artisan vendor:publish --tag=cloudflare-geoip-config
Usage
<?php namespace App\Http\Controllers; use PalauaAndSons\CloudflareGeoIp\Facades\GeoIp; use App\Models\Users; class RegisterController extends Controller { public function __invoke(): User { $location = GeoIp::getLocation(); return User::create([ 'register_ip' => $location->ip ]); } }
Location Object
\PalauaAndSons\CloudflareGeoIp\Location { +ip: "192.182.88.29" +city: "New Haven" +country: "US" +continent: "NA" +latitude: 41.31 +longitude: -72.92 +postalCode: "06510" +region: "Connecticut" +regionCode: "CT" +timezone: "America/New_York" // pseudo fields +iso_code: 'US' // same as country +isoCode: 'US' // same as country +state: 'CT' // same as regionCode +state_name: 'Connecticut' // same as region +stateName: 'Connecticut' // same as region +postal_code: '06510' // same as postal_code +lat: '41.31' // same as latitude +lon: -72.92 // same as longitude +toArray(): array }