johnpaulmedina / laravel-usps
USPS API for Laravel 10
Installs: 20 557
Dependents: 0
Suggesters: 0
Security: 0
Stars: 19
Watchers: 6
Forks: 29
Open Issues: 0
Requires
- php: ^8.1
- illuminate/support: ^10.0
README
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 10
Installation
Begin by installing this package through Composer. Run this command from the Terminal:
composer require johnpaulmedina/laravel-usps
Laravel integration
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;
Laravel Config
Add your USPS username config in config/services.php
.
'usps' => [ 'username' => "XXXXXXXXXXXX", 'testmode' => false, ],
Example Controller Usage
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 ]); } }
Contributors
@pdbreen @bredmor @scs-ben @daveore090
@VinceG Original README.MD
USPS PHP API
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
Requirements
- PHP >= 8.1
- USPS API Username
-
- Laravel 10
Authors
- Vincent Gabriel http://vadimg.com (Original PHP-Wrapper)