yooogi / dellinsdk
PHP SDK for Business Lines
0.1.3
2024-05-31 11:24 UTC
Requires
- php: >=8.1
- ext-intl: *
- ext-json: *
- ext-mbstring: *
- ext-soap: *
- guzzlehttp/guzzle: ^7.5
- psr/log: ^1.1
Requires (Dev)
- phpunit/phpunit: *
- vimeo/psalm: ^4.22
README
安装
composer require yooogi/dellinsdk
配置
require_once '../vendor/autoload.php'; use GuzzleHttp\Client; use Yooogi\DellinSDK\DellinClient; $client = new Client(); $dellin = new DellinClient('YOUR_APP_KEY', $client);
需要 PHP 8.1 或更高版本
需要 PSR-18 客户端
认证
您可以使用现有的认证会话 ID
$auth = new AuthResponse('YOUR_SESSION_ID');
或从 Dellin 获取新的认证会话 ID
$authRequest = AuthRequest::create('YOUR_DELLIN_ACCOUNT', 'YOUR_DELLIN_PASSWORD'); $auth = $dellin->authorization->auth($authRequest); echo $auth->getSessionId();
以使用带认证的方法
$sessionInfoRequest = SessionInfoRequest::create('YOUR_SESSION_ID') ->withAuth($auth); $sessionInfoResponse = $dellin->authorization->info($sessionInfoRequest);
示例
计算
/* Погрузочные работы */ $handling = Handling::create(false, null, null); /* Время */ $time = Time::create('10:00', '23:00', '11:00', '12:00', false); /* Требуемые условия погрузки */ $requirements = RequirementsCollection::create(); $requirements[] = TransportRequirements::UNCOVER; /* Адрес */ $address = Address::create(AddressType::SEARCH, 'Москва, Малая Тульская 2/1 корп 2 кв 355'); /* Информация по месту отправителя */ $derival = DerivalArrival::create($date, TransportType::ADDRESS) ->setProduceDate($date) ->setTime($time) ->setRequirements($requirements) ->setAddress($address); /* Информация по месту получателя */ $arrival = DerivalArrival::create($date, TransportType::TERMINAL) ->setTerminalId(6) ->setTime($time); /* Упаковка */ $packages = PackageCollection::create([PackageType::BUBBLE]); $packages->addPackage(PackageType::CRATE); $packages->setQuantity(PackageType::BUBBLE, 1); /* Груз */ $cargoItem = CargoItem::create(130, 0.1, 0.1, 0.2, 4000); $cargos = CargoItemsCollection::create([$cargoItem]); $cargo = Cargo::create($cargos) ->setInsurance(true) ->setTermInsurance(true) ->setPayerInsurance(PayerType::SENDER) ->setFreightName('Мебель'); /* Заказчик */ $requester = Requester::create(RequesterType::SENDER); /* Калькулятор */ $calculationRequest = CalculationRequest::create(DeliveryType::AUTO, $derival, $arrival, $cargo) ->setPackages($packages) ->setRequester($requester) ->withAuth($auth); $calc = $dellin->calculations->calculate($calculationRequest);
异步计算
请使用 Guzzle Client 7.5
$calculationResponse = $dellin->calculations->asyncCalculate( ['AUTO' => $calculationRequest,'AVIA' => $calculationRequest2] );
创建订单
/* Сопроводительные документы */ $acdoc = AccompanyingDocumentsCollection::create([AcDoc::SEND, AcDoc::RETURN]); $acdoc->setPayer(AcDoc::SEND, PayerType::SENDER); /* Товар */ $product = Product::create('PRODUCT_NAME', 1, 344.3) ->setVATRate(VATType::VAT10); /* Наложенный платеж */ $cashOnDelivery = CashOnDelivery::create(false) ->setOrderNumber('1234567') ->setOrderDate(new DateTimeImmutable('2042-04-20')) ->setCashOnDeliveryPaymentType(CashOnDeliveryPaymentType::CASH) ->setProducts([$product]); /* Оплата */ $payment = Payment::create(PaymentType::CASH, PayerType::SENDER); //->setCashOnDelivery($cashOnDelivery) $customForm = CustomForm::create('CUSTOM_FORM_NAME', 'COUNTRY_ID', false); $document = Document::create(DocumentType::PASSPORT, 'NUMBER', 'NUMBER'); $counterAgent = Counteragent::create('YOUR_COUNTERAGENT_ID') ->setDocument($document) ->setForm('0xa3e714bceb061db84f91842983ef5abc') ->setInn('YOUR_INN_NUMBER'); //->setJuridicalAddress($address); $phone = PhoneNumber::create('79110000000'); $contactPerson = ContactPerson::create('YOUR_CONTACT_PERSON_NAME'); $dataForReceipt = DataForReceipt::create(true)->setPhone('+79110000000'); $member = Member::create($counterAgent) ->setPhoneNumbers([$phone]) ->setContactPersons([$contactPerson]) ->setDataForReceipt($dataForReceipt); //->setPhoneIDs(['123123']) //->setContactIDs(['123132']) //->setCounteragentID(123); /* Участники перевозки */ $members = Members::create($requester, $member, $member); /* Создание заказа */ $orderRequest = OrderRequest::create(DeliveryType::AUTO, $derival, $arrival, $members, $cargo, $payment) ->setInOrder(false) ->setAccompanyingDocuments($acdoc) ->setPackages($packages) ->withAuth($auth); $orderResponse = $dellin->orders->create($orderRequest);
获取发货方交易对手
/* Контрагенты отправителя */ $counterAgentRequest = SenderCounteragentsRequest::create()->setFullInfo(true)->withAuth($auth); $getCounterAgents = $dellin->services->getCounteragents($counterAgentRequest); $getCounterAgents->getCounteragents();
获取订单日志
/* Журнал заказов*/ $orderLogRequest = OrdersLogRequest::create()->setDocIds(['YOUR_REQUEST_ID']) ->setStates(StatusesCollection::create([Statuses::INWAY, Statuses::PICKUP])) ->setOrderDatesAdditional(true) ->withAuth($auth); $getOrderLogInfo = $dellin->ordersInfo->getLog($orderLogRequest);
打印请求
/* Печать заявок заказу*/ $ordersPrintPickUpRequest = OrderPrintRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $ordersPrintPickUp = $dellin->ordersInfo->printPickUp($ordersPrintPickUpRequest);
打印文档
/* Печать документов к заказу*/ $ordersPrintDocumentsRequest = OrderPrintDocumentsRequest::create('YOUR_DOCUMENT_UID', PrintModeType::ORDER)->withAuth($auth); $ordersPrintDocuments = $dellin->ordersInfo->printDocuments($ordersPrintDocumentsRequest);
获取订单历史记录
/* История по заказу*/ $orderHistoryRequest = OrderHistoryRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $orderHistory = $dellin->ordersInfo->getHistory($orderHistoryRequest);
按参数搜索订单
/* Поиск заказа по параметрам*/ $requestMember = Member::create()->setInn('INN_NUMBER'); $orderSearchRequest = OrderSearchRequest::create(new DateTimeImmutable('2022-06-15'), new DateTimeImmutable('2022-07-22')) ->setReceiver($requestMember) ->setSender($requestMember) ->withAuth($auth); $orderSearch = $dellin->ordersInfo->search($orderSearchRequest);
获取条件
/* Проверка ограничений */ $conditionsRequest = ConditionsRequest::create(DeliveryType::AUTO, '7701700000000000000000000', '3400000100000000000000000', 0.01, 1, 1, 1) ->setArrivalDoor(true) ->setDerivalDoor(true) ->withAuth($auth); $conditionsResponse = $dellin->services->getConditions($conditionsRequest);
获取发货日期
/* Даты отправления */ $dispatchDatesRequest = DispatchDateRequest::create(DeliveryType::AUTO, $derival, $cargo)->withAuth($auth); $dispatchDatesResponse = $dellin->services->getDispatchDates($dispatchDatesRequest);
获取发货时间
/* Время отправления */ $dispatchTimeRequest = DispatchTimeRequest::create(DeliveryType::AUTO, $derival2, $cargo)->withAuth($auth); $dispatchTimeResponse = $dellin->services->getDispatchTimeInterval($dispatchTimeRequest);
获取交付时间
/* Время доставки */ $deliveryDatesRequest = DeliveryTimeRequest::create('YOUR_REQUEST_ID', $arrival)->withAuth($auth); $deliveryDatesResponse = $dellin->services->getDeliveryTimeInterval($deliveryDatesRequest);
获取可用包裹
/* Доступные упаковки */ $availablePackageRequest = AvailablePackagesRequest::createFromCargo('7700000000000000000000000', '100400003400000000000000', $cargo)->withAuth($auth); $availablePackageResponse = $dellin->services->getAvailablePackages($availablePackageRequest);
重复订单
/* Повтор заказа */ $repeatOrderRequest = RepeatOrderRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $repeatOrderResponse = $dellin->manageOrders->repeatOrder($repeatOrderRequest);
订单的可用更改
/* Доступные изменения */ $changeAvailableRequest = ChangeAvailableRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $changeAvailableResponse = $dellin->manageOrders->getChangeAvailable($changeAvailableRequest);
更改收件人
/* Изменение получателя */ $changeReceiverRequest = ChangeReceiverRequest::create('YOUR_REQUEST_ID', $member, true, PayerType::RECEIVER)->withAuth($auth); $changeReceiverResponse = $dellin->manageOrders->changeReceiver($changeReceiverRequest);
更改付款人
/* Изменение плательщика */ $changePayerRequest = ChangePayerRequest::create('YOUR_REQUEST_ID', third: $counterAgent, member: $member)->withAuth($auth); $changePayerResponse = $dellin->manageOrders->changePayer($changePayerRequest);
更改联系数据
/* Изменение контактных данных*/ $changeContactsRequest = ChangeContactsRequest::create('YOUR_REQUEST_ID', $members)->withAuth($auth); $changeContactsResponse = $dellin->manageOrders->changeContacts($changeContactsRequest);
更改发货地址和时间
/* Изменение адреса и времени отправки */ $changePickUpRequest = ChangePickUpRequest::create('YOUR_REQUEST_ID', $derival, $member)->withAuth($auth); $changePickUpResponse = $dellin->manageOrders->changePickUp($changePickUpRequest);
更改交付地址和时间
/* Изменение адреса и времени доставки */ $changeDeliveryRequest = ChangeDeliveryRequest::create('YOUR_REQUEST_ID', $arrival, $members, RequesterType::PAYER)->withAuth($auth); $changeDeliveryResponse = $dellin->manageOrders->changeDelivery($changeDeliveryRequest);
取消取货
/* Отмена доставки от адреса отправителя */ $cancelPickUpRequest = CancelRequest::create('YOUR_REQUEST_ID', $member)->withAuth($auth); $cancelPickUpResponse = $dellin->manageOrders->cancelPickUp($cancelPickUpRequest);
取消交付
/* Отмена доставки до адреса отправителя */ $cancelDeliveryRequest = CancelDeliveryRequest::create('YOUR_REQUEST_ID', $member, RequesterType::CUSTOMER)->withAuth($auth); $cancelDeliveryResponse = $dellin->manageOrders->cancelDelivery($cancelDeliveryRequest);
恢复订单
/* Возобновление выдачи груза */ $resumeOrderRequest = ResumeOrderRequest::create('YOUR_REQUEST_ID', new DateTimeImmutable('2022-07-30'))->withAuth($auth); $resumeOrderResponse = $dellin->manageOrders->resumeOrder($resumeOrderRequest);
暂停订单
/* Приостановка выдачи груза */ $suspendOrderRequest = SuspendOrderRequest::create('YOUR_REQUEST_ID', new DateTimeImmutable('2022-07-30'))->withAuth($auth); $suspendOrderResponse = $dellin->manageOrders->suspendOrder($suspendOrderRequest);
添加到收藏
/* Добавление в избранное */ $addFavoriteOrderRequest = AddFavoriteOrderRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $addFavoriteOrderResponse = $dellin->manageOrders->addFavoriteOrder($addFavoriteOrderRequest);
从收藏中删除
/* Удаление из избранного */ $deleteFavoriteOrderRequest = DeleteFavoriteOrderRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $deleteFavoriteOrderResponse = $dellin->manageOrders->deleteFavoriteOrder($deleteFavoriteOrderRequest);
计算到地址的交付
/* Расчет стоимости доставки до адреса */ $deliveryRequest = DeliveryRequest::create('7700000000000000000000000', 'YOUR_REQUEST_ID', new DateTimeImmutable('2042-04-20')) ->setHandling($handling)->withAuth($auth); $deliveryResponse = $dellin->calculations->delivery($deliveryRequest);
从簿中获取交易对手
/* Получить контрагента из книги */ $bookCounterAgentsRequests = BookCounterAgentsRequest::create()->withAuth($auth); $bookCounterAgents = $dellin->book->getCounterAgents($bookCounterAgentsRequests);
对货位进行标记
/* Запрос на создание этикеток к местам*/ $cargoPlace = CargoPlace::create('CARGO_PLACE_NAME'); $cargoPlaces = CargoPlacesCollection::create([$cargoPlace]); $makeShippingLabelsRequest = MakeShippingLabelsRequest::create('YOUR_REQUEST_ID', $cargoPlaces)->withAuth($auth); $makeShippingLabelsResponse = $dellin->marking->makeShippingLabels($makeShippingLabelsRequest);
获取货位标记
/* Получение этиекток на груз*/ $getShippingLabelsRequest = GetShippingLabelsRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $getShippingLabelsResponse = $dellin->marking->getShippingLabels($getShippingLabelsRequest);
获取随附文件标记
/* Получение этиекток на сопроводительные документы */ $getAcDocShippingLabelsRequest = GetAcDocShippingLabelsRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $getAcDocShippingLabelsResponse = $dellin->marking->getAcDocShippingLabels($getAcDocShippingLabelsRequest);
获取货位状态
/* Получение статусов грузомест*/ $getCargoStatusesRequest = GetCargoStatusesRequest::create('YOUR_REQUEST_ID')->withAuth($auth); $getCargoStatusesResponse = $dellin->marking->getCargoStatuses($getCargoStatusesRequest);
获取处理标记目录
/* Получение справочника этикеток с манипуляционными знаками */ $getHandlingMarksCatalogRequest = GetHandlingMarksCatalogRequest::create()->withAuth($auth); $getHandlingMarksCatalogResponse = $dellin->marking->getHandlingMarksCatalog($getHandlingMarksCatalogRequest);
获取处理标记
/* Получение этикеток с манипуляционными знаками */ $handlingMark = HandlingMark::create(HandlingMarkName::BEACON, 2, ShippingLabelFormat::LARGE); $getHandlingMarksRequest = GetHandlingMarksRequest::create([$handlingMark], false, ShippingLabelType::PDF)->withAuth($auth); $getHandlingMarksResponse = $dellin->marking->getHandlingMarks($getHandlingMarksRequest);
获取包装标记目录
/* Получение справочника этикеток с типами упаковки */ $getPackagingMarksCatalogRequest = GetPackagingMarksCatalogRequest::create()->withAuth($auth); $getPackagingMarksCatalogResponse = $dellin->marking->getPackagingMarksCatalog($getPackagingMarksCatalogRequest);
获取包装标记
/* Получение этикеток с типами упаковки */ $packagingMark = PackagingMark::create(PackagingMarkName::CRATE, 2, ShippingLabelFormat::SMALL); $getPackagingMarksRequest = GetPackagingMarksRequest::create([$packagingMark], true, ShippingLabelType::PDF)->withAuth($auth_test); $getPackagingMarksResponse = $dellin->marking->getPackagingMarks($getPackagingMarksRequest);
功能
- 认证
- 用户认证
- 交易对手列表
- 执行计算
- 成本和期限计算器
- 服务 Delivery 计算器
- 预计期限和成本
- 申请表单处理
- 散货运输
- 长途欧式箱式车运输
- 轻型运输
- 按小时租车
- 补充订单配送
- 多订单
- 包订单 Pre-Alert
- 订单信息
- 订单日志
- 按运输参数搜索
- 订单更改历史记录
- 打印表单
- 报告
- 订单管理
- 重复订单
- 可用更改
- 更改收件人
- 更改付款人
- 更改联系信息
- 更改发货地址和时间
- 更改交付地址和时间
- 取消订单和货物交付
- 暂停和恢复发放
- 添加到收藏
- 自动标记
- 标记货位
- 搬运标记
- 包装标记
- 地址簿
- 交易对手
- 联系信息
- 地址
- 删除对象
- 支付
- 相互结算
- 相互结算周期
- 获取付款链接
- 终端
- 终端目录
- 搜索终端
- 终端地图
- 位置
- 地理目录
- 搜索地理对象
- 搜索 КЛАДР
- 参考方法
- 选择发货日期
- 选择交付日期
- 选择司机到达时间
- 检查限制
- 可用包装
- 超尺寸货物参数
- 搜索 ОПФ
- 搜索货物性质
- 目录
- 自行标记货物
- 标记货位
- 搬运标记
- 包装标记