mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-14 07:02:34 +01:00
19080933b6
Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions. You may customize the code style applied by adding a [PHP CS Fixer][1] or [PHP CodeSniffer][2] ruleset to your project root. Feel free to use [Shift's Laravel ruleset][3] to help you get started. For more information on customizing the code style applied by Shift, [watch this short video][4]. [1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer [2]: https://github.com/squizlabs/PHP_CodeSniffer [3]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200 [4]: https://laravelshift.com/videos/shift-code-style
55 lines
1.7 KiB
PHP
55 lines
1.7 KiB
PHP
<?php
|
|
/**
|
|
* Invoice Ninja (https://invoiceninja.com).
|
|
*
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
*
|
|
* @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com)
|
|
*
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
|
*/
|
|
|
|
namespace App\Utils\Traits;
|
|
|
|
use GuzzleHttp\RequestOptions;
|
|
|
|
/**
|
|
* Class SubscriptionHooker.
|
|
*/
|
|
trait SubscriptionHooker
|
|
{
|
|
public function sendLoad($subscription, $body)
|
|
{
|
|
$headers = [
|
|
'Content-Type' => 'application/json',
|
|
'X-Requested-With' => 'XMLHttpRequest',
|
|
];
|
|
|
|
if (count($subscription->webhook_configuration['post_purchase_headers']) >= 1) {
|
|
$headers = array_merge($headers, $subscription->webhook_configuration['post_purchase_headers']);
|
|
}
|
|
|
|
$client = new \GuzzleHttp\Client(
|
|
[
|
|
'headers' => $headers,
|
|
]);
|
|
|
|
nlog('method name must be a string');
|
|
nlog($subscription->webhook_configuration['post_purchase_rest_method']);
|
|
nlog($subscription->webhook_configuration['post_purchase_url']);
|
|
|
|
$post_purchase_rest_method = (string) $subscription->webhook_configuration['post_purchase_rest_method'];
|
|
$post_purchase_url = (string) $subscription->webhook_configuration['post_purchase_url'];
|
|
|
|
try {
|
|
$response = $client->{$post_purchase_rest_method}($post_purchase_url, [
|
|
RequestOptions::JSON => ['body' => $body], RequestOptions::ALLOW_REDIRECTS => false,
|
|
]);
|
|
|
|
return array_merge($body, json_decode($response->getBody(), true));
|
|
} catch (\Exception $e) {
|
|
return array_merge($body, ['message' => $e->getMessage(), 'status_code' => 500]);
|
|
}
|
|
}
|
|
}
|