Laravel-USPS is a composer package that allows you to integrate the USPS Address / Shipping API / Rates Calculator. This package is ported from @author Vincent Gabriel https://github.com/VinceG/USPS-php-api
- Requires a valid USPS API Username
- Tested on Laravel 11
Begin by installing this package through Composer. Run this command from the Terminal:
composer require johnpaulmedina/laravel-usps
For Laravel 5.5 and later, this package will be auto discovered and registered.
To wire this up in your Laravel 5.4 project you need to add the service provider.
Open config/app.php
, and add a new item to the providers array.
Johnpaulmedina\Usps\UspsServiceProvider::class,
Then you must also specify the alias in config/app.php
. Add a new item to the Aliases array.
'Usps' => Johnpaulmedina\Usps\Facades\Usps::class,
This will allow integration by adding the Facade Use Usps;
Add your USPS username config in config/services.php
.
'usps' => [
'username' => "XXXXXXXXXXXX",
'testmode' => false,
],
The only method completed for Laravel is the Usps::validate
, Usps::rate
which is defined in vendor/johnpaulmedina/laravel-usps/src/Usps/Usps.php
. As this package was developed for internal use I did not bring over all the features but you are more than welcome to contribute the methods you need and I will merge them. I suggest looking at the original PHP-Wrapper by @VinceG USPS PHP-Api as I ported those clases and autoloaded them to use in the Usps.php
file.
<?php
namespace App\Http\Controllers;
use App\Http\Requests;
use Illuminate\Support\Facades\Request;
use Johnpaulmedina\Usps;
class USPSController extends Controller
{
public function index() {
return response()->json(
Usps::validate(
Request::input('Address'),
Request::input('Zip'),
Request::input('Apartment'),
Request::input('City'),
Request::input('State')
)
);
}
public function trackConfirm() {
return response()->json(
Usps::trackConfirm(
Request::input('id')
)
);
}
public function trackConfirmRevision1() {
return response()->json(
Usps::trackConfirm(
Request::input('id'),
'Acme, Inc'
)
);
}
public function rate(Request $request) {
$usps_rate = Usps::rate(
[
'Service' => $request->input('Service', 'PRIORITY COMMERCIAL'),
'FirstClassMailType' => $request->input('FirstClassMailType', ''),
'ZipOrigination' => $request->input('ZipOrigination', '91601'),
'ZipDestination' => $request->input('ZipDestination', $zipcode),
'Pounds' => $request->input('Pounds', $weight),
'Ounces' => $request->input('Ounces', 0),
'Container' => $request->input('Container', 'VARIABLE'),
'Machinable' => $request->input('Machinable', 'True'),
]
);
$usps_return_rate = Arr::get($usps_rate, 'rate.RateV4Response.Package.Postage.Rate');
$usps_return_weight = Arr::get($usps_rate, 'rate.RateV4Response.Package.Pounds');
return response()->json([
'rate' => $usps_return_rate,
'weight'=> $usps_return_weight,
'usps' => $usps_rate
]);
}
}
@pdbreen @bredmor @scs-ben @daveore090
@VinceG Original README.MD
This wrapper allows you to perform some basic calls to the USPS api. Some of the features currently supported are:
- Rate Calculator (Both domestic and international)
- Zip code lookup by address
- City/State lookup by zip code
- Verify address
- Create Priority Shipping Labels
- Create Open & Distribute Shipping Labels
- Create International Shipping Labels (Express, Priority, First Class)
- Service Delivery Calculator
- Confirm Tracking
- PHP >= 8.2
- USPS API Username
-
- Laravel 11
- Vincent Gabriel http://vadimg.com (Original PHP-Wrapper)