aboodma/aramex-integration 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

aboodma/aramex-integration

最新稳定版本:1.0.1

Composer 安装命令:

composer require aboodma/aramex-integration

包简介

Integration With Aramex Services (Tracking / Shipment / Rate Calculator)

README 文档

README

This PHP library allows for easy integration with the Aramex shipping API. It provides a set of models and a client to interact with the API for creating shipments, generating labels, and more.

Requirements

  • PHP 8 or higher
  • Composer

Installation

Install the library using Composer:

composer require aboodma/aramex-integration

Usage

Configuration

Create a configuration object with your Aramex account details:

use Aboodma\AramexIntegration\Config;

$config = (new Config())
    ->setUsername("your_username")
    ->setPassword("your_password")
    ->setVersion("v1.0")
    ->setAccountNumber("your_account_number")
    ->setAccountPin("your_account_pin")
    ->setAccountEntity("your_account_entity")
    ->setAccountCountryCode("your_account_country_code")
    ->setSource(24);

Creating a Shipment

use Aboodma\AramexIntegration\Models\Address;
use Aboodma\AramexIntegration\Models\Contact;
use Aboodma\AramexIntegration\Models\Party;
use Aboodma\AramexIntegration\Models\Dimensions;
use Aboodma\AramexIntegration\Models\Weight;
use Aboodma\AramexIntegration\Models\Amount;
use Aboodma\AramexIntegration\Models\ShipmentDetails;
use Aboodma\AramexIntegration\Models\Shipment;
use Aboodma\AramexIntegration\Models\LabelInfo;
use Aboodma\AramexIntegration\Models\ClientInfo;
use Aboodma\AramexIntegration\AramexClient;
use Aboodma\AramexIntegration\Exceptions\AramexException;

// Shipper details
$shipperAddress = (new Address())
    ->setLine1("Test Shipper Address Line1")
    ->setLine2("Test Shipper Address Line2")
    ->setCity("Dubai")
    ->setPostCode("000000")
    ->setCountryCode("AE");

$shipperContact = (new Contact())
    ->setPersonName("Test Shipper Name")
    ->setCompanyName("Test Shipper Company Name")
    ->setPhoneNumber1("048707766")
    ->setCellPhone("971556893100")
    ->setEmailAddress("test@aramex.com");

$shipper = (new Party())
    ->setReference1("Shipper Reference")
    ->setAccountNumber("45796")
    ->setPartyAddress($shipperAddress)
    ->setContact($shipperContact);

// Consignee details
$consigneeAddress = (new Address())
    ->setLine1("Test Consignee Address Line1")
    ->setLine2("Test Consignee Address Line2")
    ->setLine3("Test Consignee Address Line3")
    ->setCity("Dubai")
    ->setStateOrProvinceCode("FU")
    ->setCountryCode("AE");

$consigneeContact = (new Contact())
    ->setPersonName("Test Consignee Name")
    ->setCompanyName("Test Consignee Company Name")
    ->setPhoneNumber1("048707766")
    ->setCellPhone("971556893100")
    ->setEmailAddress("tets@hotmail.com");

$consignee = (new Party())
    ->setAccountNumber("0")
    ->setPartyAddress($consigneeAddress)
    ->setContact($consigneeContact);

// Shipment details
$dimensions = (new Dimensions())
    ->setLength(0)
    ->setWidth(0)
    ->setHeight(0)
    ->setUnit("CM");

$actualWeight = (new Weight())
    ->setUnit("KG")
    ->setValue(0.1);

$chargeableWeight = (new Weight())
    ->setUnit("KG")
    ->setValue(0);

$amount = (new Amount())
    ->setCurrencyCode("AED")
    ->setValue(10);

$details = (new ShipmentDetails())
    ->setDimensions($dimensions)
    ->setActualWeight($actualWeight)
    ->setChargeableWeight($chargeableWeight)
    ->setDescriptionOfGoods("Items")
    ->setGoodsOriginCountry("AE")
    ->setNumberOfPieces(1)
    ->setProductGroup("DOM")
    ->setProductType("ONP")
    ->setPaymentType("P")
    ->setPaymentOptions("ACCT")
    ->setCustomsValueAmount($amount);

$shipment = (new Shipment())
    ->setShipper($shipper)
    ->setConsignee($consignee)
    ->setDetails($details)
    ->setReference1("Shipment Reference");

// Label info
$labelInfo = (new LabelInfo())
    ->setReportID(9729)
    ->setReportType("URL");

// Client info
$clientInfo = (new ClientInfo())
    ->setUserName("testingapi@aramex.com")
    ->setPassword('R123456789$r')
    ->setVersion("v1.0")
    ->setAccountNumber("45796")
    ->setAccountPin("116216")
    ->setAccountEntity("DXB")
    ->setAccountCountryCode("AE")
    ->setSource(24);

// Initialize AramexClient and make the request
$client = new AramexClient($config);

try {
    $response = $client->createShipment($shipment, $labelInfo, $clientInfo);
    echo json_encode($response, JSON_PRETTY_PRINT);
} catch (AramexException $e) {
    echo 'Error: ' . $e->getMessage() . PHP_EOL;
    echo 'HTTP Status Code: ' . $e->getHttpStatusCode() . PHP_EOL;
    echo 'Error Details: ' . print_r($e->getErrorDetails(), true);
}

Models

Address

Represents an address.

  • setLine1(string $line1): self
  • setLine2(string $line2): self
  • setLine3(string $line3): self
  • setCity(string $city): self
  • setStateOrProvinceCode(string $stateOrProvinceCode): self
  • setPostCode(string $postCode): self
  • setCountryCode(string $countryCode): self

Contact

Represents a contact.

  • setPersonName(string $personName): self
  • setCompanyName(string $companyName): self
  • setPhoneNumber1(string $phoneNumber1): self
  • setPhoneNumber1Ext(string $phoneNumber1Ext): self
  • setPhoneNumber2(string $phoneNumber2): self
  • setPhoneNumber2Ext(string $phoneNumber2Ext): self
  • setFaxNumber(string $faxNumber): self
  • setCellPhone(string $cellPhone): self
  • setEmailAddress(string $emailAddress): self
  • setType(string $type): self

Party

Represents a party involved in the shipment (shipper or consignee).

  • setReference1(string $reference1): self
  • setReference2(string $reference2): self
  • setAccountNumber(string $accountNumber): self
  • setPartyAddress(Address $partyAddress): self
  • setContact(Contact $contact): self

Dimensions

Represents the dimensions of a shipment.

  • setLength(float $length): self
  • setWidth(float $width): self
  • setHeight(float $height): self
  • setUnit(string $unit): self

Weight

Represents the weight of a shipment.

  • setUnit(string $unit): self
  • setValue(float $value): self

Amount

Represents a monetary amount.

  • setCurrencyCode(string $currencyCode): self
  • setValue(float $value): self

ShipmentDetails

Represents the details of a shipment.

  • setDimensions(Dimensions $dimensions): self
  • setActualWeight(Weight $actualWeight): self
  • setChargeableWeight(Weight $chargeableWeight): self
  • setDescriptionOfGoods(string $descriptionOfGoods): self
  • setGoodsOriginCountry(string $goodsOriginCountry): self
  • setNumberOfPieces(int $numberOfPieces): self
  • setProductGroup(string $productGroup): self
  • setProductType(string $productType): self
  • setPaymentType(string $paymentType): self
  • setPaymentOptions(string $paymentOptions): self
  • setCustomsValueAmount(Amount $customsValueAmount): self
  • setCashOnDeliveryAmount(Amount $cashOnDeliveryAmount): self
  • setInsuranceAmount(Amount $insuranceAmount): self
  • setCashAdditionalAmount(Amount $cashAdditionalAmount): self
  • setCashAdditionalAmountDescription(string $cashAdditionalAmountDescription): self
  • setCollectAmount(Amount $collectAmount): self
  • setServices(string $services): self
  • setItems(array $items): self
  • setDeliveryInstructions(string $deliveryInstructions): self
  • setAdditionalProperties(string $additionalProperties): self
  • setContainsDangerousGoods(bool $containsDangerousGoods): self

Shipment

Represents a shipment.

  • setReference1(string $reference1): self
  • setReference2(string $reference2): self
  • setReference3(string $reference3): self
  • setShipper(Party $shipper): self
  • setConsignee(Party $consignee): self
  • setThirdParty(Party $thirdParty): self
  • setShippingDateTime(\DateTime $shippingDateTime): self
  • setDueDate(\DateTime $dueDate): self
  • setComments(string $comments): self
  • setPickupLocation(string $pickupLocation): self
  • setOperationsInstructions(string $operationsInstructions): self
  • setAccountingInstructions(string $accountingInstructions): self
  • setDetails(ShipmentDetails $details): self
  • setAttachments(array $attachments): self
  • setForeignHAWB(string $foreignHAWB): self
  • setTransportType(string $transportType): self
  • setPickupGUID(string $pickupGUID): self
  • setNumber(string $number): self
  • setScheduledDelivery(\DateTime $scheduledDelivery): self

LabelInfo

Represents label information for the shipment.

  • setReportID(int $reportID): self
  • setReportType(string $reportType): self

ClientInfo

Represents client information.

  • setUserName(string $userName): self
  • setPassword(string $password): self
  • setVersion(string $version): self
  • setAccountNumber(string $accountNumber): self
  • setAccountPin(string $accountPin): self
  • setAccountEntity(string $accountEntity): self
  • setAccountCountryCode(string $accountCountryCode): self
  • setSource(int $source): self

Error Handling

If the API request fails, an AramexException will be thrown. This exception contains the error message, HTTP status code, and error details returned by the API.

try {
    $response = $client->createShipment($shipment, $labelInfo, $clientInfo);
    echo json_encode($response, JSON_PRETTY_PRINT);
} catch (AramexException $e) {
    echo 'Error: ' . $e->getMessage() . PHP_EOL;
    echo 'HTTP Status Code: ' . $e->getHttpStatusCode() . PHP_EOL;
    echo 'Error Details: ' . print_r($e->getErrorDetails(), true);
}

Logging

The library logs request payloads, response payloads, and error responses to log files for debugging purposes.

Contributing

Please submit issues and pull requests on the GitHub repository.

License

This project is licensed under the MIT License.

统计信息

  • 总下载量: 34
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-07-08