gdinko / prim
Laravel Prim API Wrapper
Installs: 1 968
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/gdinko/prim
Requires
- php: ^7.4|^8.0|^8.1|^8.2|^8.3
- guzzlehttp/guzzle: ^7.4
- illuminate/support: ^8.0|^9.0|^10.0|^11.0
Requires (Dev)
- nunomaduro/collision: ^5.11
- nunomaduro/larastan: ^1.0
- orchestra/testbench: ^6.0
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.2
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.1
- phpunit/phpunit: ^9.0
README
Installation
You can install the package via composer:
composer require gdinko/prim
If you plan to use database for storing request / error logs:
php artisan migrate --step
If you need to export configuration file:
php artisan vendor:publish --tag=prim-config
If you need to export migrations:
php artisan vendor:publish --tag=prim-migrations
If you need to export models:
php artisan vendor:publish --tag=prim-models
If you need to export commands:
php artisan vendor:publish --tag=prim-commands
Configuration
Add this to .env file:
PRIM_API_TOKEN= #Get API token from prim.bg PRIM_API_BASE_URL= #Get API Base URL from prim.bg PRIM_API_TIMEOUT= #default 30 PRIM_ENABLE_REQUEST_LOG=true/false #default false | log every request/response in database PRIM_ENABLE_ERROR_LOG=true/false #default true | log every error response in database
Usage
Runtime Setup
Prim::setApiToken('token'); Prim::getApiToken(); Prim::setBaseUrl('endpoint'); Prim::getBaseUrl(); Prim::setTimeout(99); Prim::getTimeout(); Prim::enableRequestLog(); Prim::disableRequestLog(); Prim::enableErrorLog(); Prim::disableErrorLog();
Methods
//list all API methods and params Prim::getAllMethods(): array //get info about method params Prim::getMethodParams($method, $verb): array //auto generate validation rules for API method Prim::getValidationRules($method, $verb): array //make call to custom METHOD Prim::public function customMethod(string $methodName, PrimRequestInterface $request, string $verb = 'post', $wantAll = false) /** * getAccounts * * Prim Endpoint: RPC.common.Api.Accounts.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getAccounts(PrimRequestInterface $request, $wantAll = false): array /** * setAddresses * * Prim Endpoint: RPC.common.Api.Addresses.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setAddresses(PrimRequestInterface $request, $wantAll = false): array /** * getExpenseAllocations * * Prim Endpoint: RPC.common.Api.Allocations.getExpense * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getExpenseAllocations(PrimRequestInterface $request, $wantAll = false): array /** * getAvailabilities * * Prim Endpoint: RPC.common.Api.Availabilities.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getAvailabilities(PrimRequestInterface $request, $wantAll = false): array /** * getAvailabilitiesByLabels * * Prim Endpoint: RPC.common.Api.AvailabilitiesByLabels.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getAvailabilitiesByLabels(PrimRequestInterface $request, $wantAll = false): array /** * getBlanks * * Prim Endpoint: RPC.common.Api.Blanks.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getBlanks(PrimRequestInterface $request, $wantAll = false): array /** * getBonusPoints * * Prim Endpoint: RPC.common.Api.BonusPoints.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getBonusPoints(PrimRequestInterface $request, $wantAll = false): array /** * setBrands * * Prim Endpoint: RPC.common.Api.Brands.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setBrands(PrimRequestInterface $request, $wantAll = false): array /** * getClientTypes * * Prim Endpoint: RPC.common.Api.ClientTypes.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getClientTypes(PrimRequestInterface $request, $wantAll = false): array /** * setContacts * * Prim Endpoint: RPC.common.Api.Contacts.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setContacts(PrimRequestInterface $request, $wantAll = false): array /** * getCurrencies * * Prim Endpoint: RPC.common.Api.Currencies.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getCurrencies(PrimRequestInterface $request, $wantAll = false): array /** * getDeliveryTypes * * Prim Endpoint: RPC.common.Api.DeliveryTypes.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getDeliveryTypes(PrimRequestInterface $request, $wantAll = false): array /** * getDocInfo * * Prim Endpoint: RPC.common.Api.DocInfo.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getDocInfo(PrimRequestInterface $request, $wantAll = false): array /** * getFiles * * Prim Endpoint: RPC.common.Api.Files.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getFiles(PrimRequestInterface $request, $wantAll = false): array /** * annulFinDocFinDoc * * Prim Endpoint: RPC.common.Api.FinDoc.annulFinDoc * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::annulFinDocFinDoc(PrimRequestInterface $request, $wantAll = false): array /** * setGroups * * Prim Endpoint: RPC.common.Api.Groups.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setGroups(PrimRequestInterface $request, $wantAll = false): array /** * getInterationSystems * * Prim Endpoint: RPC.common.Api.InterationSystems.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getInterationSystems(PrimRequestInterface $request, $wantAll = false): array /** * setInvoice * * Prim Endpoint: RPC.common.Api.Invoice.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setInvoice(PrimRequestInterface $request, $wantAll = false): array /** * setItems * * Prim Endpoint: RPC.common.Api.Items.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setItems(PrimRequestInterface $request, $wantAll = false): array /** * getListOperation * * Prim Endpoint: RPC.common.Api.ListOperation.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getListOperation(PrimRequestInterface $request, $wantAll = false): array /** * setMeasures * * Prim Endpoint: RPC.common.Api.Measures.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setMeasures(PrimRequestInterface $request, $wantAll = false): array /** * getOperations * * Prim Endpoint: RPC.common.Api.Operations.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getOperations(PrimRequestInterface $request, $wantAll = false): array /** * getParams * * Prim Endpoint: RPC.common.Api.Params.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getParams(PrimRequestInterface $request, $wantAll = false): array /** * setPartners * * Prim Endpoint: RPC.common.Api.Partners.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setPartners(PrimRequestInterface $request, $wantAll = false): array /** * getPayTypes * * Prim Endpoint: RPC.common.Api.PayTypes.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getPayTypes(PrimRequestInterface $request, $wantAll = false): array /** * fullAnnulPoPo * * Prim Endpoint: RPC.common.Api.Po.fullAnnulPo * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::fullAnnulPoPo(PrimRequestInterface $request, $wantAll = false): array /** * getPos * * Prim Endpoint: RPC.common.Api.Pos.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getPos(PrimRequestInterface $request, $wantAll = false): array /** * setPrices * * Prim Endpoint: RPC.common.Api.Prices.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setPrices(PrimRequestInterface $request, $wantAll = false): array /** * getPricesLists * * Prim Endpoint: RPC.common.Api.PricesLists.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getPricesLists(PrimRequestInterface $request, $wantAll = false): array /** * setServices * * Prim Endpoint: RPC.common.Api.Services.set * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::setServices(PrimRequestInterface $request, $wantAll = false): array /** * getSoInvoicePdfSo * * Prim Endpoint: RPC.common.Api.So.getSoInvoicePdf * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getSoInvoicePdfSo(PrimRequestInterface $request, $wantAll = false): array /** * getSoOrderTypes * * Prim Endpoint: RPC.common.Api.SoOrderTypes.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getSoOrderTypes(PrimRequestInterface $request, $wantAll = false): array /** * deleteStoreIn * * Prim Endpoint: RPC.common.Api.StoreIn.delete * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::deleteStoreIn(PrimRequestInterface $request, $wantAll = false): array /** * deleteStoreOut * * Prim Endpoint: RPC.common.Api.StoreOut.delete * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::deleteStoreOut(PrimRequestInterface $request, $wantAll = false): array /** * getStores * * Prim Endpoint: RPC.common.Api.Stores.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getStores(PrimRequestInterface $request, $wantAll = false): array /** * getTaxDeals * * Prim Endpoint: RPC.common.Api.TaxDeals.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getTaxDeals(PrimRequestInterface $request, $wantAll = false): array /** * getTaxInstances * * Prim Endpoint: RPC.common.Api.TaxInstances.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getTaxInstances(PrimRequestInterface $request, $wantAll = false): array /** * getVendorTypes * * Prim Endpoint: RPC.common.Api.VendorTypes.get * * * @param \Gdinko\Prim\Interfaces\PrimRequestInterface $request * @param boolean $wantAll * @return array * * @throws \Gdinko\Prim\Exceptions\PrimException * @throws \Gdinko\Prim\Exceptions\PrimValidationException */ Prim::getVendorTypes(PrimRequestInterface $request, $wantAll = false): array
Commands
#get prim api status (use -h to view options) #need to run migrations for this command to store data php artisan prim:api-status
Models
PrimApiStatus PrimLog PrimErrorLog
Events
PrimHookEvent
Interfaces
If you need to make custom PrimRequest you need to implement this interface
PrimRequestInterface
Requests
Implements PrimRequestInterface
PrimRequest PrimNoValidationRequest //no client site data validation PrimCustomRequest //used for GET request, with no data wrapping
Request Example
$pr = new PrimRequest( ['code' => 'Code', 'name' => 'Name'], //request data false, //get all | true / false Prim::getValidationRules('RPC.common.Api.Accounts', 'get'), // auto generate validation rules | or skip this param | or pass custom validation rules true, //by default data will be wrapped in additional [] | true / false )
Listen for Prim Hook Event
- In Prim Dashboard subscribe for Hook and set YOUR API HOOK URL: [your domain]/api/prim/hook?api_token=[laravel:sanctum:token]
//subscribe to PrimHookEvent in EventServiceProvider->boot method //https://laravel.com/docs/9.x/events Event::listen(function (PrimHookEvent $event) { //do something cool with prim payload dd($event->payload); });
Examples
Get All Prim API Methods
use Gdinko\Prim\Facades\Prim; use Gdinko\Prim\Exceptions\PrimException; use Gdinko\Prim\Exceptions\PrimValidationException; try { $methods = Prim::getAllMethods(); dd($methods); } catch (PrimException | PrimValidationException $pe) { echo class_basename($pe) . '<br />'; echo $pe->getCode() . '<br />'; echo $pe->getMessage() . '<br />'; dd($pe->getErrors()); } catch (\Exception $e) { echo class_basename($e) . '<br />'; echo $e->getCode() . '<br />'; echo $e->getMessage() . '<br />'; }
Get All Accounts
*This example usage is valid for all methods
use Gdinko\Prim\Facades\Prim; use Gdinko\Prim\Exceptions\PrimException; use Gdinko\Prim\Exceptions\PrimValidationException; use Gdinko\Prim\Requests\PrimRequest; try { $accounts = Prim::getAccounts( new PrimRequest( [], //empty params true, //get all flag ) ); dd($accounts); } catch (PrimException | PrimValidationException $pe) { echo class_basename($pe) . '<br />'; echo $pe->getCode() . '<br />'; echo $pe->getMessage() . '<br />'; dd($pe->getErrors()); } catch (\Exception $e) { echo class_basename($e) . '<br />'; echo $e->getCode() . '<br />'; echo $e->getMessage() . '<br />'; }
Get All Accounts with no client site validation request and get all prim response, not only result fields
*This example usage is valid for all methods
use Gdinko\Prim\Facades\Prim; use Gdinko\Prim\Exceptions\PrimException; use Gdinko\Prim\Exceptions\PrimValidationException; use Gdinko\Prim\Requests\PrimNoValidationRequest; try { $accounts = Prim::getAccounts( new PrimNoValidationRequest( [], //empty params, no client site validation only prim validation true, //get all flag ), true ); dd($accounts); } catch (PrimException $pe) { echo class_basename($pe) . '<br />'; echo $pe->getCode() . '<br />'; echo $pe->getMessage() . '<br />'; dd($pe->getErrors()); } catch (\Exception $e) { echo class_basename($e) . '<br />'; echo $e->getCode() . '<br />'; echo $e->getMessage() . '<br />'; }
Search for Accounts with autogenerated request validation rules
*This example usage is valid for all methods
use Gdinko\Prim\Facades\Prim; use Gdinko\Prim\Exceptions\PrimException; use Gdinko\Prim\Exceptions\PrimValidationException; use Gdinko\Prim\Requests\PrimRequest; try { $accounts = Prim::getAccounts( new PrimRequest( ['code' => 'CoDe', 'name' => 'NaMe'], //request params false, //dot not return all Prim::getValidationRules('RPC.common.Api.Accounts', 'get') //auto generate validation rules ) ); dd($accounts); } catch (PrimException | PrimValidationException $pe) { echo class_basename($pe) . '<br />'; echo $pe->getCode() . '<br />'; echo $pe->getMessage() . '<br />'; dd($pe->getErrors()); } catch (\Exception $e) { echo class_basename($e) . '<br />'; echo $e->getCode() . '<br />'; echo $e->getMessage() . '<br />'; }
Testing
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email dinko359@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.