An open API service indexing awesome lists of open source software.

https://github.com/theinvoicingcompany/econnect-psb-php

A reference implementation meant as an example how to use the PSB api using PHP.
https://github.com/theinvoicingcompany/econnect-psb-php

econnect peppol

Last synced: 6 months ago
JSON representation

A reference implementation meant as an example how to use the PSB api using PHP.

Awesome Lists containing this project

README

          

# PHP Client

A reference implementation meant as an example how to use the PSB api using PHP.

## Requirements

- PHP 7.2 or greater

## Install

- Install library using [`composer`][0].

```sh
composer require everbinding/econnect-psb-php
```

Then include composer autoloader.

```php
require __DIR__ . '/vendor/autoload.php';
```

## Configure

```php
$config = \EConnect\Psb\Configuration::getDefaultConfiguration();

$config
->setUsername("{username}")
->setPassword("{password}");
->setClientId("{clientId}")
->setClientSecret("{clientSecret}")
->setHost("https://psb.econnect.eu")
->setApiKey('Subscription-Key', '{subscription key}');
```

## Login

Login using the default configuration.

```php
$config = \EConnect\Psb\Configuration::getDefaultConfiguration();

$authN = new \EConnect\Psb\Authentication($config);
$authN->login();
```

## Use api

Use the api using the default configuration after a successful login.
In this example we are calling the send sales invoice api. The user must have send permission on the provide sender [`partyId`][7]. Also make sure the UBL is valid, otherwise it will be block for sending. The receiver [`partyId`][7] is optional, the PSB will use the best possible route we no receiver partyId is provided.

```php
$config = \EConnect\Psb\Configuration::getDefaultConfiguration();

$salesInvoiceApi = new EConnect\Psb\Api\SalesInvoiceApi(
new GuzzleHttp\Client();
$config
);

$yourPartyId = "senderPartyId";
$filePath = "./Ubl.xml";
$receiverPartyId = null;

$salesInvoiceApi->sendSalesInvoice($yourPartyId, $filePath, $receiverPartyId);
```

## Example client

There is a [`simple example php client`][1] that you can run on a php webserver. With the example you can [`send an invoice via Peppol`][8].
Also there is a [`webhook receiver example`][2] that you need to have in order to [`receive invoices from Peppol`][9].

## Build your own source

Instead of using this code, you could also generate the php code yourself using the [`openapi-generator-cli`][3].

```sh
openapi-generator-cli generate -g php -i https://psb.econnect.eu/v1/swagger.json?subscriptionKey={your-subscription} -o C:\temp --additional-properties=invokerPackage=EConnect\Psb
```

And use [`Jumbojett\OpenIDConnectClient`][4] to get the access token.
You can also copy the code from: [`Authentication.php`][5]

```php
use Jumbojett\OpenIDConnectClient;

$oidc = new OpenIDConnectClient('https://identity.econnect.eu',
'{clientId}',
'{clientSecret}');

$oidc->addScope('ap');

// Add username and password
$oidc->addAuthParam(array('username'=>'{username}'));
$oidc->addAuthParam(array('password'=>'{password}'));

// to validate the JWT and whether the acces_token property is present
$token = $oidc->requestResourceOwnerToken(TRUE)->access_token;
```

## Read more

If you want to know more about Peppol e-procurement or other procurement network the go to the [`Procurement Service Bus introduction page`][6].

[0]: https://getcomposer.org/
[1]: ./ExampleSendInvoice.php
[2]: ./ExampleWebhookReceiver.php
[3]: https://github.com/OpenAPITools/openapi-generator-cli
[4]: https://github.com/jumbojett/OpenID-Connect-PHP#example-5-request-resource-owners-token-with-client-auth
[5]: ./lib/Authentication.php
[6]: https://psb.econnect.eu/introduction/overview.html
[7]: https://psb.econnect.eu/misc/partyIds.html
[8]: https://psb.econnect.eu/introduction/sendInvoice.html
[9]: https://psb.econnect.eu/introduction/receiveInvoice.html