Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added missing segments API calls (v11) #178

Merged
merged 51 commits into from
Dec 8, 2023
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
739bbe5
added segments api calls
rcerljenko Nov 29, 2023
f1b309e
php cs fixer fix
rcerljenko Nov 29, 2023
d37c6bc
moved to phpdoc payload array
rcerljenko Nov 30, 2023
32cde31
fix erros
rcerljenko Nov 30, 2023
21b93b9
fix errors
rcerljenko Nov 30, 2023
7bf3d11
introduce dto
rcerljenko Nov 30, 2023
0ce5531
introduce dto
rcerljenko Nov 30, 2023
87924c6
introduce dto
rcerljenko Nov 30, 2023
bd3440a
fixes
rcerljenko Nov 30, 2023
15ce5cb
removed general purpose pagination dto
rcerljenko Nov 30, 2023
2cbd763
requested changes
rcerljenko Nov 30, 2023
88a9a0d
requested changes
rcerljenko Nov 30, 2023
45ce096
requested changes
rcerljenko Nov 30, 2023
30f411a
requested changes
rcerljenko Nov 30, 2023
310f776
requested changes
rcerljenko Nov 30, 2023
2b73275
requested changes
rcerljenko Nov 30, 2023
59b8b9d
Merge branch 'master' into feature/segments
rcerljenko Nov 30, 2023
ec753de
removed []
rcerljenko Nov 30, 2023
c40dfe9
Merge branch 'feature/segments' of https://github.com/rcerljenko/ones…
rcerljenko Nov 30, 2023
ae0120e
added filters dto
rcerljenko Nov 30, 2023
a9ef92b
added filters dto
rcerljenko Nov 30, 2023
4b00629
added filters dto
rcerljenko Nov 30, 2023
9b52286
fixes
rcerljenko Nov 30, 2023
6285d84
added missing relation key
rcerljenko Dec 1, 2023
177f1a8
moved value to extra params
rcerljenko Dec 1, 2023
95d5307
added relation constants
rcerljenko Dec 1, 2023
19a01fc
introduce separate dtos for every filter type
rcerljenko Dec 1, 2023
079542e
renamed filters
rcerljenko Dec 1, 2023
d039ac9
change request
rcerljenko Dec 4, 2023
171a390
change request
rcerljenko Dec 4, 2023
22b53da
namespace change to singular
rcerljenko Dec 4, 2023
e3c5be8
namespace change to singular
rcerljenko Dec 4, 2023
4e8157f
move operands to abstract class
rcerljenko Dec 4, 2023
7dec6e5
null check filters
rcerljenko Dec 4, 2023
4b26aaf
fix
rcerljenko Dec 4, 2023
72c928e
added response objects
rcerljenko Dec 5, 2023
71ba641
added response objects
rcerljenko Dec 5, 2023
9abc5e3
added exception handling
rcerljenko Dec 5, 2023
3f75b40
added exception handling
rcerljenko Dec 5, 2023
ec9ad0d
added exception handling
rcerljenko Dec 5, 2023
e0587b5
added request and response to exception
rcerljenko Dec 5, 2023
5fb5974
added request and response to exception - fixes
rcerljenko Dec 5, 2023
2a91971
added separate makeRequest method
rcerljenko Dec 5, 2023
3566e53
added separate makeRequest method
rcerljenko Dec 5, 2023
e67cd5d
added separate makeRequest method
rcerljenko Dec 5, 2023
c721474
added separate makeRequest method
rcerljenko Dec 5, 2023
2337167
added list and delete segments tests
rcerljenko Dec 8, 2023
1d81fca
added requested changes
rcerljenko Dec 8, 2023
4d5caf6
removed unused method
rcerljenko Dec 8, 2023
ccc897d
changes
rcerljenko Dec 8, 2023
0886d6e
added test for create segment
rcerljenko Dec 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions src/OneSignal.php
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,10 @@ public function api(string $name)
case 'notifications':
$api = new Notifications($this, $this->resolverFactory);

break;
case 'segments':
$api = new Segments($this);

break;
default:
throw new InvalidArgumentException("Undefined api instance called: '$name'.");
Expand Down
77 changes: 77 additions & 0 deletions src/Segments.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
<?php

declare(strict_types=1);

namespace OneSignal;

class Segments extends AbstractApi
{
public function __construct(OneSignal $client)
{
parent::__construct($client);
}

/**
* Get information about all segments.
*
* Application authentication key and ID must be set.
*
* @param int $limit How many segments to return (max 50)
* @param int $offset Results offset
*/
public function getAll(int $limit = null, int $offset = null): array
rcerljenko marked this conversation as resolved.
Show resolved Hide resolved
{
$app_id = $this->client->getConfig()->getApplicationId();

$query = [];

if ($limit !== null) {
$query['limit'] = $limit;
}

if ($offset !== null) {
$query['offset'] = $offset;
}

$request = $this->createRequest('GET', '/apps/'.$app_id.'/segments?'.http_build_query($query));
$request = $request->withHeader('Authorization', "Basic {$this->client->getConfig()->getApplicationAuthKey()}");

return $this->client->sendRequest($request);
rcerljenko marked this conversation as resolved.
Show resolved Hide resolved
}

/**
* Create new segment with provided data.
*
* Application authentication key and ID must be set.
*
* @param array{name: string, filters: array<int, array>} $data Payload
*/
public function add(array $data): array
rcerljenko marked this conversation as resolved.
Show resolved Hide resolved
{
$app_id = $this->client->getConfig()->getApplicationId();

$request = $this->createRequest('POST', '/apps/'.$app_id.'/segments');
rcerljenko marked this conversation as resolved.
Show resolved Hide resolved
$request = $request->withHeader('Authorization', "Basic {$this->client->getConfig()->getApplicationAuthKey()}");
$request = $request->withHeader('Content-Type', 'application/json');
$request = $request->withBody($this->createStream($data));

return $this->client->sendRequest($request);
}

/**
* Delete segment.
*
* Application authentication key and ID must be set.
*
* @param string $id Segment ID
rcerljenko marked this conversation as resolved.
Show resolved Hide resolved
*/
public function delete(string $id): array
{
$app_id = $this->client->getConfig()->getApplicationId();

$request = $this->createRequest('DELETE', '/apps/'.$app_id.'/segments/'.$id);
rcerljenko marked this conversation as resolved.
Show resolved Hide resolved
$request = $request->withHeader('Authorization', "Basic {$this->client->getConfig()->getApplicationAuthKey()}");

return $this->client->sendRequest($request);
}
}