yebto/laravel-geoip-api
最新稳定版本:v1.0.0
Composer 安装命令:
composer require yebto/laravel-geoip-api
包简介
Laravel SDK wrapper for the YEB GeoIP API. Fetch City, country or ASN information from any IP, with emoji flags.
README 文档
README
Official Laravel SDK for the YEB GeoIP API by NETOX Ltd. — a lightweight wrapper for fast and accurate IP geolocation (City, Country, ASN) in Laravel applications.
Table of Contents
- Installation
- Usage
- Available Methods
- Parameters Reference
- Configuration
- Features
- Free Tier Access
- Troubleshooting
- Support
- License
Installation
Install the package using Composer:
composer require yebto/laravel-geoip-api
Publish the configuration file:
php artisan vendor:publish --tag=geoipapi-config
Add your API key to your .env file:
YEB_KEY_ID=your_api_key_here
Usage
Import the facade and start making API calls:
use GeoIPAPI;
Examples
1) City Lookup
$city = GeoIPAPI::city('21.85.7.138'); // Sample shape: // $city['data'] => [ // 'ip', 'hostname', 'city', 'region', 'country', 'loc', 'org', 'postal', 'timezone', ... // ]
2) Country Lookup
$country = GeoIPAPI::country('85.85.7.138'); // Sample shape: // $country['data'] => [ // 'ip', 'country', 'country_name', 'isEU', 'country_flag', // 'continent' => ['code', 'name'], // ]
3) ASN Lookup
$asn = GeoIPAPI::asn('55.85.7.138'); // Sample shape: // $asn['data'] => [ 'ip', 'org', 'asn', 'network' ]
4) Generic Query
$response = GeoIPAPI::query('city', '77.85.7.138'); // Supported databases: 'city', 'country', 'asn'
💡 If the IP is omitted (e.g.
GeoIPAPI::city();), the backend uses the requester's IP automatically viaRequest::ip().
5) Error Handling
try { $city = GeoIPAPI::city('67.85.7.138'); } catch (\RuntimeException $e) { // Log or handle the error \Log::error($e->getMessage()); }
Available Methods
GeoIPAPI::city(?string $ip = null)– API DocsGeoIPAPI::country(?string $ip = null)– API DocsGeoIPAPI::asn(?string $ip = null)– API DocsGeoIPAPI::query(string $db, ?string $ip = null)– API Docs
Parameters Reference
| Helper | Required | Optional |
|---|---|---|
city |
ip (when not auto-detected) |
– |
country |
ip (when not auto-detected) |
– |
asn |
ip (when not auto-detected) |
– |
query |
db (city | country | asn) |
ip (when not auto-detected) |
💡 All methods accept additional parameters supported by the API, which will be forwarded transparently.
Configuration
The SDK uses a single environment variable:
YEB_KEY_ID=your_api_key_here
You may customize other configuration settings via config/geoipapi.php after publishing:
return [ 'base_url' => 'https://api.yeb.to/v1/', // default 'key' => env('YEB_KEY_ID'), 'curl' => [ CURLOPT_TIMEOUT => 3, CURLOPT_USERAGENT => 'Laravel-GeoIP-Client', // Add more cURL options as needed ], ];
Features
- Simple, expressive API via a Laravel Facade
- City, Country, and ASN lookups
- Auto-detects the requester IP when omitted
- Small footprint — no local databases to maintain
- Customizable cURL options (timeouts, user agent, etc.)
- Clean error handling with
RuntimeExceptionon failed requests - Built for Laravel; zero-config auto-discovery
Free Tier Access
🎁 Get 1,000+ free API requests by registering on yeb.to using your Google account.
Steps:
- Visit https://yeb.to
- Click Login with Google
- Retrieve your API key and add it to
.envasYEB_KEY_ID
No credit card required!
Troubleshooting
- Ensure your API key is correct and active (
YEB_KEY_ID) - Double-check that the config file is published (
php artisan vendor:publish --tag=geoipapi-config) - Validate parameters against the API reference
- Check for typos in method names or required fields
- Consider adjusting
CURLOPT_TIMEOUTinconfig/geoipapi.phpfor slower networks - Inspect your application/network firewall rules if requests time out
Support
- 📘 API Documentation: https://yeb.to/api/geoip
- 📧 Email: support@yeb.to
- 🐛 Issues: https://github.com/yebto/laravel-geoip-api/issues
License
© NETOX Ltd. Licensed under a proprietary or custom license unless stated otherwise in the repository.
💬 Have a feature request or improvement idea? Reach out at support@yeb.to — we’d love to hear from you!
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-08-17