codersstudio / dadata-api
Laravel package for Dadata API - address suggestions, cleaning, company and bank data lookup
1.0
2020-06-26 14:41 UTC
Requires
Requires (Dev)
- mockery/mockery: ^1.1
- orchestra/testbench: ~3.0
- phpunit/phpunit: ~7.0
- sempro/phpunit-pretty-print: ^1.0
This package is auto-updated.
Last update: 2026-04-21 18:13:14 UTC
README
Laravel package for working with Dadata API - address suggestions, data cleaning, company and bank information lookup.
Features
- Address suggestions with FIAS support
- Address cleaning and standardization
- Phone number cleaning
- Company search by INN
- Bank search by BIC/SWIFT
- Delivery point IDs (CDEK, Boxberry, DPD)
- Full DTO support for type-safe data handling
Requirements
- PHP 8.3+
- Laravel 12.0+
- imjonos/laravel-base-dto package
- Dadata account (register)
Installation
composer require imjonos/laravel-dadata-api
Configuration
Publish the configuration file:
php artisan vendor:publish --tag=dadataapi.config
Add your Dadata credentials to .env:
DADATA_TOKEN=your_api_token DADATA_SECRET=your_secret_key
You can find your credentials in your Dadata profile.
Usage
Address Suggestions
use Nos\DadataApi\Facades\DadataApi; // Get city suggestions $collection = DadataApi::suggestCity('Москва'); foreach ($collection as $suggestion) { echo $suggestion->value; echo $suggestion->data->fiasId; } // Filter by country $collection = DadataApi::suggestCity('London', ['GB']); // Street suggestions (requires city FIAS ID) $collection = DadataApi::suggestStreet('Ленина', $cityFiasId); // House suggestions (requires street FIAS ID) $collection = DadataApi::suggestHouse('10', $streetFiasId);
Company Search
use Nos\DadataApi\Facades\DadataApi; // Search company by INN $collection = DadataApi::suggestCompany('7707083893'); $company = $collection->first(); echo $company->value; // Company name echo $company->data->inn; echo $company->data->ogrn;
Bank Search
use Nos\DadataApi\Facades\DadataApi; $collection = DadataApi::suggestBank('Сбербанк'); $bank = $collection->first(); echo $bank->value; echo $bank->data->bic; echo $bank->data->swift;
Address Cleaning
use Nos\DadataApi\Facades\DadataApi; $address = DadataApi::cleanAddress('москва сухонская 11/-89'); echo $address->result; // г Москва, ул Сухонская, д 11, кв 89 echo $address->postalCode; // 127642 echo $address->geoLat; // 55.8783089 echo $address->geoLon; // 37.6537862
Phone Cleaning
use Nos\DadataApi\Facades\DadataApi; $phone = DadataApi::cleanPhone('8(495)123-45-67'); echo $phone->phone; // +7 495 123-45-67 echo $phone->countryCode; // +7 echo $phone->timezone; // UTC+3
Delivery Points
use Nos\DadataApi\Facades\DadataApi; // Get CDEK, Boxberry, DPD IDs by KLADR ID $collection = DadataApi::suggestDeliveryId('3100400100000'); $delivery = $collection->first(); echo $delivery->data->cdekId; echo $delivery->data->boxberryId; echo $delivery->data->dpdId;
Available Methods
All suggestion methods return SuggestionCollection:
| Method | Parameters | Description |
|---|---|---|
suggestCity |
$query, $countryCodeISO, $count |
City suggestions |
suggestStreet |
$query, $fiasId, $count |
Street suggestions |
suggestHouse |
$query, $streetFiasId, $count |
House suggestions |
suggestCountry |
$query, $count |
Country suggestions |
suggestAddress |
$query, $fiasId? |
General address search |
suggestBank |
$query |
Bank search |
suggestCompany |
$inn |
Company by INN |
suggestDeliveryId |
$kladrId |
Delivery point IDs |
suggestAddressById |
$fiasId |
Address by FIAS ID |
Clean methods return DTO objects:
| Method | Parameters | Returns |
|---|---|---|
cleanAddress |
$address |
AddressDTO |
cleanPhone |
$phone |
PhoneDTO |
DTO Classes
AddressDTO
Represents cleaned address with all details:
$address->result; // Formatted address $address->postalCode; $address->region; $address->city; $address->street; $address->house; $address->flat; $address->geoLat; $address->geoLon; $address->fiasId; $address->qc; // Quality code
PhoneDTO
Represents cleaned phone number:
$phone->phone; // Formatted phone $phone->countryCode; $phone->cityCode; $phone->provider; $phone->timezone; $phone->qc; // Quality code
SuggestionDTO
Represents suggestion from search methods:
$suggestion->value; // Display value $suggestion->unrestrictedValue; // Full value $suggestion->data; // SuggestionDataDTO
SuggestionCollection
Collection of suggestions with utility methods:
$collection->count(); $collection->first(); $collection->map(fn($item) => ...); $collection->filter(fn($item) => ...); $collection->each(fn($item) => ...);
License
MIT License. See license.md for more information.