PageEndpoint::update()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 2
dl 0
loc 5
rs 10
c 0
b 0
f 0
1
<?php
2
namespace CodeCloud\Bundle\ShopifyBundle\Api\Endpoint;
3
4
use CodeCloud\Bundle\ShopifyBundle\Api\Request\DeleteParams;
5
use CodeCloud\Bundle\ShopifyBundle\Api\Request\GetJson;
6
use CodeCloud\Bundle\ShopifyBundle\Api\Request\PostJson;
7
use CodeCloud\Bundle\ShopifyBundle\Api\Request\PutJson;
8
use CodeCloud\Bundle\ShopifyBundle\Api\GenericResource;
9
10
class PageEndpoint extends AbstractEndpoint
11
{
12
    /**
13
     * @param array $query
14
     * @return array|GenericResource
15
     */
16
    public function findAll(array $query = array())
17
    {
18
        $request = new GetJson('/admin/pages.json', $query);
19
        $response = $this->sendPaged($request, 'pages');
20
        return $this->createCollection($response->get('pages'));
21
    }
22
23
    /**
24
     * @param array $query
25
     * @return array
26
     */
27
    public function countAll(array $query = array())
28
    {
29
        $request = new GetJson('/admin/pages.json', $query);
30
        $response = $this->send($request);
31
        return $response->get('count');
0 ignored issues
show
Bug Best Practice introduced by
The expression return $response->get('count') also could return the type string which is incompatible with the documented return type array.
Loading history...
32
    }
33
34
    /**
35
     * @param int $pageId
36
     * @param array $fields
37
     * @return GenericResource
38
     */
39
    public function findOne($pageId, array $fields = array())
40
    {
41
        $params = $fields ? array('fields' => implode(',', $fields)) : array();
42
        $request = new GetJson('/admin/pages/' . $pageId . '.json', $params);
43
        $response = $this->send($request);
44
        return $this->createEntity($response->get('page'));
0 ignored issues
show
Bug introduced by
It seems like $response->get('page') can also be of type string; however, parameter $data of CodeCloud\Bundle\Shopify...ndpoint::createEntity() does only seem to accept array, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

44
        return $this->createEntity(/** @scrutinizer ignore-type */ $response->get('page'));
Loading history...
45
    }
46
47
    /**
48
     * @param GenericResource $page
49
     * @return GenericResource
50
     */
51
    public function create(GenericResource $page)
52
    {
53
        $request = new PostJson('/admin/pages.json', array('page' => $page->toArray()));
54
        $response = $this->send($request);
55
        return $this->createEntity($response->get('page'));
0 ignored issues
show
Bug introduced by
It seems like $response->get('page') can also be of type string; however, parameter $data of CodeCloud\Bundle\Shopify...ndpoint::createEntity() does only seem to accept array, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

55
        return $this->createEntity(/** @scrutinizer ignore-type */ $response->get('page'));
Loading history...
56
    }
57
58
    /**
59
     * @param int $pageId
60
     * @param GenericResource $page
61
     * @return GenericResource
62
     */
63
    public function update($pageId, GenericResource $page)
64
    {
65
        $request = new PutJson('/admin/pages/' . $pageId. '.json', array('page' => $page->toArray()));
66
        $response = $this->send($request);
67
        return $this->createEntity($response->get('page'));
0 ignored issues
show
Bug introduced by
It seems like $response->get('page') can also be of type string; however, parameter $data of CodeCloud\Bundle\Shopify...ndpoint::createEntity() does only seem to accept array, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

67
        return $this->createEntity(/** @scrutinizer ignore-type */ $response->get('page'));
Loading history...
68
    }
69
70
    /**
71
     * @param int $pageId
72
     */
73
    public function delete($pageId)
74
    {
75
        $request = new DeleteParams('/admin/pages/' . $pageId . '.json');
76
        $this->send($request);
77
    }
78
}
79