LaravelPackages.net
Acme Inc.
Toggle sidebar
codersstudio/dadata-api

Laravel package for Dadata API - address suggestions, cleaning, company and bank data lookup

17
0
1.0
About codersstudio/dadata-api

codersstudio/dadata-api is a Laravel package for laravel package for dadata api - address suggestions, cleaning, company and bank data lookup. It currently has 0 GitHub stars and 17 downloads on Packagist (latest version 1.0). Install it with composer require codersstudio/dadata-api. Discover more Laravel packages by codersstudio or browse all Laravel packages to compare alternatives.

Last updated

Laravel Dadata API

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

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);
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;
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.

Star History Chart