GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Completed
Pull Request — master (#25)
by
unknown
06:31
created

ObjectService::cache()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 1
Metric Value
c 1
b 0
f 1
dl 0
loc 5
ccs 3
cts 3
cp 1
rs 9.4285
cc 1
eloc 3
nc 1
nop 2
crap 1
1
<?php
2
namespace Dkd\PhpCmis\Bindings\Browser;
3
4
/**
5
 * This file is part of php-cmis-lib.
6
 *
7
 * (c) Sascha Egerer <[email protected]>
8
 *
9
 * For the full copyright and license information, please view the LICENSE
10
 * file that was distributed with this source code.
11
 */
12
13
use Dkd\PhpCmis\Constants;
14
use Dkd\PhpCmis\Data\AclInterface;
15
use Dkd\PhpCmis\Data\AllowableActionsInterface;
16
use Dkd\PhpCmis\Data\BulkUpdateObjectIdAndChangeTokenInterface;
17
use Dkd\PhpCmis\Data\ExtensionDataInterface;
18
use Dkd\PhpCmis\Data\FailedToDeleteDataInterface;
19
use Dkd\PhpCmis\Data\ObjectDataInterface;
20
use Dkd\PhpCmis\Data\PropertiesInterface;
21
use Dkd\PhpCmis\Data\RenditionDataInterface;
22
use Dkd\PhpCmis\Enum\IncludeRelationships;
23
use Dkd\PhpCmis\Enum\UnfileObject;
24
use Dkd\PhpCmis\Enum\VersioningState;
25
use Dkd\PhpCmis\Exception\CmisInvalidArgumentException;
26
use Dkd\PhpCmis\ObjectServiceInterface;
27
use Dkd\PhpCmis\PropertyIds;
28
use Dkd\PhpCmis\SessionParameter;
29
use GuzzleHttp\Post\PostFile;
30
use GuzzleHttp\Stream\LimitStream;
31
use GuzzleHttp\Message\Response;
32
use GuzzleHttp\Stream\StreamInterface;
33
34
/**
35
 * Object Service Browser Binding client.
36
 */
37
class ObjectService extends AbstractBrowserBindingService implements ObjectServiceInterface
38
{
39
    /**
40
     * L1 cache for objects. Fills with two levels:
41
     *
42
     * - First level key is the object ID, path or other singular identifier of object(s)
43
     * - Second level key is a hash of context arguments used to retrieve the object(s)
44
     *
45
     * @var array
46
     */
47
    protected $objectCache = array();
48
49
    /**
50
     * Appends the content stream to the content of the document.
51
     *
52
     * The stream in contentStream is consumed but not closed by this method.
53
     *
54
     * @param string $repositoryId the identifier for the repository
55
     * @param string $objectId The identifier for the object. The repository might return a different/new object id
56
     * @param StreamInterface $contentStream The content stream to append
57
     * @param boolean $isLastChunk Indicates if this content stream is the last chunk
58
     * @param string|null $changeToken The last change token of this object that the client received.
59
     *      The repository might return a new change token (default is <code>null</code>)
60
     * @param ExtensionDataInterface|null $extension
61
     */
62
    public function appendContentStream(
63
        $repositoryId,
64
        & $objectId,
65
        StreamInterface $contentStream,
66
        $isLastChunk,
67
        & $changeToken = null,
68
        ExtensionDataInterface $extension = null
69
    ) {
70
        // TODO: Implement appendContentStream() method.
71
    }
72
73
    /**
74
     * Updates properties and secondary types of one or more objects.
75
     *
76
     * @param string $repositoryId the identifier for the repository
77
     * @param BulkUpdateObjectIdAndChangeTokenInterface[] $objectIdsAndChangeTokens
78
     * @param PropertiesInterface $properties
79
     * @param string[] $addSecondaryTypeIds the secondary types to apply
80
     * @param string[] $removeSecondaryTypeIds the secondary types to remove
81
     * @param ExtensionDataInterface|null $extension
82
     * @return BulkUpdateObjectIdAndChangeTokenInterface[]
83
     */
84
    public function bulkUpdateProperties(
85
        $repositoryId,
86
        array $objectIdsAndChangeTokens,
87
        PropertiesInterface $properties,
88
        array $addSecondaryTypeIds,
89
        array $removeSecondaryTypeIds,
90
        ExtensionDataInterface $extension = null
91
    ) {
92
        // TODO: Implement bulkUpdateProperties() method.
93
    }
94
95
    /**
96
     * @param string $action
97
     * @param PropertiesInterface $properties
98
     * @param string[] $policies
99
     * @param AclInterface $addAces
0 ignored issues
show
Documentation introduced by
Should the type for parameter $addAces not be null|AclInterface?

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
100
     * @param AclInterface $removeAces
0 ignored issues
show
Documentation introduced by
Should the type for parameter $removeAces not be null|AclInterface?

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
101
     * @param ExtensionDataInterface $extension
0 ignored issues
show
Documentation introduced by
Should the type for parameter $extension not be null|ExtensionDataInterface?

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
102
     * @return array
103
     */
104 9
    protected function createQueryArray(
105
        $action,
106
        PropertiesInterface $properties,
107
        array $policies = array(),
108
        AclInterface $addAces = null,
109
        AclInterface $removeAces = null,
110
        ExtensionDataInterface $extension = null
0 ignored issues
show
Unused Code introduced by
The parameter $extension is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
111
    ) {
112 9
        $queryArray = array_replace(
113
            array(
114 9
                Constants::CONTROL_CMISACTION => $action,
115 9
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false',
116 9
            ),
117 9
            $this->convertPropertiesToQueryArray($properties),
118 9
            $this->convertPolicyIdArrayToQueryArray($policies)
119 9
        );
120 9
        if (!empty($removeAces)) {
121 5
            $queryArray = array_replace($queryArray, $this->convertAclToQueryArray(
122 5
                $removeAces,
123 5
                Constants::CONTROL_REMOVE_ACE_PRINCIPAL,
124
                Constants::CONTROL_REMOVE_ACE_PERMISSION
125 5
            ));
126 5
        }
127 9 View Code Duplication
        if (!empty($addAces)) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
128 5
            $queryArray = array_replace($queryArray, $this->convertAclToQueryArray(
129 5
                $addAces,
130 5
                Constants::CONTROL_ADD_ACE_PRINCIPAL,
131
                Constants::CONTROL_ADD_ACE_PERMISSION
132 5
            ));
133 5
        }
134 9
        return $queryArray;
135
    }
136
137
    /**
138
     * Creates a document object of the specified type (given by the cmis:objectTypeId property)
139
     * in the (optionally) specified location.
140
     *
141
     * @param string $repositoryId the identifier for the repository
142
     * @param PropertiesInterface $properties the property values that must be applied to the newly
143
     *      created document object
144
     * @param string|null $folderId if specified, the identifier for the folder that must be the parent
145
     *      folder for the newly created document object
146
     * @param StreamInterface|null $contentStream the content stream that must be stored for the newly
147
     *      created document object
148
     * @param VersioningState|null $versioningState specifies what the versioning state of the newly created object
149
     *      must be (default is <code>VersioningState::MAJOR</code>)
150
     * @param string[] $policies a list of policy IDs that must be applied to the newly created document object
151
     * @param AclInterface|null $addAces a list of ACEs that must be added to the newly created document object,
152
     *      either using the ACL from folderId if specified, or being applied if no folderId is specified
153
     * @param AclInterface|null $removeAces a list of ACEs that must be removed from the newly created document object,
154
     *      either using the ACL from folderId if specified, or being ignored if no folderId is specified
155
     * @param ExtensionDataInterface|null $extension
156
     * @return string|null Returns the new object id or <code>null</code> if the repository sent an empty
157
     *      result (which should not happen)
158
     */
159 3
    public function createDocument(
160
        $repositoryId,
161
        PropertiesInterface $properties,
162
        $folderId = null,
163
        StreamInterface $contentStream = null,
164
        VersioningState $versioningState = null,
165
        array $policies = array(),
166
        AclInterface $addAces = null,
167
        AclInterface $removeAces = null,
168
        ExtensionDataInterface $extension = null
169
    ) {
170 3 View Code Duplication
        if ($folderId === null) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
171 1
            $url = $this->getRepositoryUrl($repositoryId);
172 1
        } else {
173 2
            $url = $this->getObjectUrl($repositoryId, $folderId);
174
        }
175
176
        // Guzzle gets the mime type for a file by the filename extension. Sometimes the filename does not contain
177
        // the correct filename extension for example when a file is uploaded in php it gets a temporary name without
178
        // a file extension. If the filename does not contain a file extension we use the given 'cmis:name' property
179
        // as filename. See also https://github.com/guzzle/guzzle/issues/571
180 3
        if ($contentStream !== null && pathinfo($contentStream->getMetadata('uri'), PATHINFO_EXTENSION) === '') {
181 1
            $contentStream = new PostFile(
0 ignored issues
show
Coding Style introduced by
Consider using a different name than the parameter $contentStream. This often makes code more readable.
Loading history...
182 1
                'content',
183 1
                $contentStream,
184 1
                $properties->getProperties()['cmis:name']->getFirstValue()
185 1
            );
186 1
        }
187
188 3
        $queryArray = $this->createQueryArray(
189 3
            Constants::CMISACTION_CREATE_DOCUMENT,
190 3
            $properties,
191 3
            $policies,
192 3
            $addAces,
193 3
            $removeAces,
194
            $extension
195 3
        );
196 3
        if ($versioningState !== null) {
197 2
            $queryArray[Constants::PARAM_VERSIONING_STATE] = (string) $versioningState;
198 2
        }
199
200 3
        $responseData = $this->post(
201 3
            $url,
202
            $queryArray
203 3
        )->json();
204
205 3
        $newObject = $this->getJsonConverter()->convertObject($responseData);
206
207 3
        if ($newObject) {
208 3
            $newObjectId = $newObject->getId();
209 3
            if ($contentStream) {
210 2
                if ($contentStream instanceof PostFile) {
211 1
                    $contentStream = $contentStream->getContent();
0 ignored issues
show
Coding Style introduced by
Consider using a different name than the parameter $contentStream. This often makes code more readable.
Loading history...
212 1
                }
213 2
                $this->setContentStream($repositoryId, $newObjectId, $contentStream);
214 2
            }
215 3
            return $newObjectId;
216
        }
217
        return null;
218
    }
219
220
    /**
221
     * Creates a document object as a copy of the given source document in the (optionally) specified location.
222
     *
223
     * @param string $repositoryId the identifier for the repository
224
     * @param string $sourceId the identifier for the source document
225
     * @param PropertiesInterface $properties the property values that must be applied to the newly
226
     *      created document object
227
     * @param string|null $folderId if specified, the identifier for the folder that must be the parent folder for the
228
     *      newly created document object
229
     * @param VersioningState|null $versioningState specifies what the versioning state of the newly created object
230
     *      must be (default is <code>VersioningState::MAJOR</code>)
231
     * @param string[] $policies a list of policy IDs that must be applied to the newly created document object
232
     * @param AclInterface|null $addAces a list of ACEs that must be added to the newly created document object,
233
     *      either using the ACL from folderId if specified, or being applied if no folderId is specified
234
     * @param AclInterface|null $removeAces a list of ACEs that must be removed from the newly created document object,
235
     *      either using the ACL from folderId if specified, or being ignored if no folderId is specified
236
     * @param ExtensionDataInterface|null $extension
237
     * @return string|null Returns the new object id or <code>null</code> if the repository sent an empty
238
     *      result (which should not happen)
239
     */
240 2
    public function createDocumentFromSource(
241
        $repositoryId,
242
        $sourceId,
243
        PropertiesInterface $properties,
244
        $folderId = null,
245
        VersioningState $versioningState = null,
246
        array $policies = array(),
247
        AclInterface $addAces = null,
248
        AclInterface $removeAces = null,
249
        ExtensionDataInterface $extension = null
250
    ) {
251 2 View Code Duplication
        if ($folderId === null) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
252
            $url = $this->getRepositoryUrl($repositoryId);
253
        } else {
254 2
            $url = $this->getObjectUrl($repositoryId, $folderId);
255
        }
256
257 2
        $queryArray = $this->createQueryArray(
258 2
            Constants::CMISACTION_CREATE_DOCUMENT_FROM_SOURCE,
259 2
            $properties,
260 2
            $policies,
261 2
            $addAces,
262 2
            $removeAces,
263
            $extension
264 2
        );
265 2
        $queryArray[Constants::PARAM_SOURCE_ID] = (string) $sourceId;
266 2
        if ($versioningState !== null) {
267 1
            $queryArray[Constants::PARAM_VERSIONING_STATE] = (string) $versioningState;
268 1
        }
269 2
        $responseData = $this->post($url, $queryArray)->json();
270
271 2
        $newObject = $this->getJsonConverter()->convertObject($responseData);
272
273 2
        return ($newObject === null) ? null : $newObject->getId();
274
    }
275
276
    /**
277
     * Creates a folder object of the specified type (given by the cmis:objectTypeId property) in
278
     * the specified location.
279
     *
280
     * @param string $repositoryId the identifier for the repository
281
     * @param PropertiesInterface $properties the property values that must be applied to the newly
282
     *      created document object
283
     * @param string $folderId if specified, the identifier for the folder that must be the parent folder for the
284
     *      newly created document object
285
     * @param string[] $policies a list of policy IDs that must be applied to the newly created document object
286
     * @param AclInterface|null $addAces a list of ACEs that must be added to the newly created document object,
287
     *      either using the ACL from folderId if specified, or being applied if no folderId is specified
288
     * @param AclInterface|null $removeAces a list of ACEs that must be removed from the newly created document object,
289
     *      either using the ACL from folderId if specified, or being ignored if no folderId is specified
290
     * @param ExtensionDataInterface|null $extension
291
     * @return string|null Returns the new object id or <code>null</code> if the repository sent an empty
292
     *      result (which should not happen)
293
     */
294 2 View Code Duplication
    public function createFolder(
295
        $repositoryId,
296
        PropertiesInterface $properties,
297
        $folderId,
298
        array $policies = array(),
299
        AclInterface $addAces = null,
300
        AclInterface $removeAces = null,
301
        ExtensionDataInterface $extension = null
302
    ) {
303 2
        $url = $this->getObjectUrl($repositoryId, $folderId);
304 2
        $queryArray = $this->createQueryArray(
305 2
            Constants::CMISACTION_CREATE_FOLDER,
306 2
            $properties,
307 2
            $policies,
308 2
            $addAces,
309 2
            $removeAces,
310
            $extension
311 2
        );
312
313 2
        $responseData = $this->post($url, $queryArray)->json();
314
315 2
        $newObject = $this->getJsonConverter()->convertObject($responseData);
316
317 2
        return ($newObject === null) ? null : $newObject->getId();
318
    }
319
320
    /**
321
     * Creates an item object of the specified type (given by the cmis:objectTypeId property).
322
     *
323
     * @param string $repositoryId The identifier for the repository
324
     * @param PropertiesInterface $properties The property values that must be applied to the newly
325
     *      created document object
326
     * @param string|null $folderId If specified, the identifier for the folder that must be the parent folder for the
327
     *      newly created document object
328
     * @param string[] $policies A list of policy IDs that must be applied to the newly created document object
329
     * @param AclInterface|null $addAces A list of ACEs that must be added to the newly created document object,
330
     *      either using the ACL from folderId if specified, or being applied if no folderId is specified
331
     * @param AclInterface|null $removeAces A list of ACEs that must be removed from the newly created document object,
332
     *      either using the ACL from folderId if specified, or being ignored if no folderId is specified
333
     * @param ExtensionDataInterface|null $extension
334
     * @return string|null Returns the new item id or <code>null</code> if the repository sent an empty
335
     *      result (which should not happen)
336
     */
337 2
    public function createItem(
338
        $repositoryId,
339
        PropertiesInterface $properties,
340
        $folderId = null,
341
        array $policies = array(),
342
        AclInterface $addAces = null,
343
        AclInterface $removeAces = null,
344
        ExtensionDataInterface $extension = null
345
    ) {
346 2
        if ($folderId === null) {
347
            $url = $this->getRepositoryUrl($repositoryId);
348
        } else {
349 2
            $url = $this->getObjectUrl($repositoryId, $folderId);
350
        }
351
352 2
        $queryArray = $this->createQueryArray(
353 2
            Constants::CMISACTION_CREATE_ITEM,
354 2
            $properties,
355 2
            $policies,
356 2
            $addAces,
357 2
            $removeAces,
358
            $extension
359 2
        );
360
361 2
        $responseData = $this->post($url, $queryArray)->json();
362
363 2
        $newObject = $this->getJsonConverter()->convertObject($responseData);
364
365 2
        return ($newObject === null) ? null : $newObject->getId();
366
    }
367
368
    /**
369
     * Creates a policy object of the specified type (given by the cmis:objectTypeId property).
370
     *
371
     * @param string $repositoryId The identifier for the repository
372
     * @param PropertiesInterface $properties The property values that must be applied to the newly
373
     *      created document object
374
     * @param string|null $folderId If specified, the identifier for the folder that must be the parent folder for the
375
     *      newly created document object
376
     * @param string[] $policies A list of policy IDs that must be applied to the newly created document object
377
     * @param AclInterface|null $addAces A list of ACEs that must be added to the newly created document object,
378
     *      either using the ACL from folderId if specified, or being applied if no folderId is specified
379
     * @param AclInterface|null $removeAces A list of ACEs that must be removed from the newly created document object,
380
     *      either using the ACL from folderId if specified, or being ignored if no folderId is specified
381
     * @param ExtensionDataInterface|null $extension
382
     * @return string The id of the newly-created policy.
383
     */
384
    public function createPolicy(
385
        $repositoryId,
386
        PropertiesInterface $properties,
387
        $folderId = null,
388
        array $policies = array(),
389
        AclInterface $addAces = null,
390
        AclInterface $removeAces = null,
391
        ExtensionDataInterface $extension = null
392
    ) {
393
        // TODO: Implement createPolicy() method.
394
    }
395
396
    /**
397
     * Creates a relationship object of the specified type (given by the cmis:objectTypeId property).
398
     *
399
     * @param string $repositoryId the identifier for the repository
400
     * @param PropertiesInterface $properties the property values that must be applied to the newly
401
     *      created document object
402
     * @param string[] $policies a list of policy IDs that must be applied to the newly created document object
403
     * @param AclInterface|null $addAces a list of ACEs that must be added to the newly created document object,
404
     *      either using the ACL from folderId if specified, or being applied if no folderId is specified
405
     * @param AclInterface|null $removeAces a list of ACEs that must be removed from the newly created document object,
406
     *      either using the ACL from folderId if specified, or being ignored if no folderId is specified
407
     * @param ExtensionDataInterface|null $extension
408
     * @return string|null Returns the new item id of the relationship object or <code>null</code> if the repository
409
     *      sent an empty result (which should not happen)
410
     */
411 View Code Duplication
    public function createRelationship(
412
        $repositoryId,
413
        PropertiesInterface $properties,
414
        array $policies = array(),
415
        AclInterface $addAces = null,
416
        AclInterface $removeAces = null,
417
        ExtensionDataInterface $extension = null
418
    ) {
419
        $url = $this->getRepositoryUrl($repositoryId);
420
421
        $queryArray = $this->createQueryArray(
422
            Constants::CMISACTION_CREATE_RELATIONSHIP,
423
            $properties,
424
            $policies,
425
            $addAces,
426
            $removeAces,
427
            $extension
428
        );
429
430
        $responseData = $this->post($url, $queryArray)->json();
431
432
        $newObject = $this->getJsonConverter()->convertObject($responseData);
433
434
        return ($newObject === null) ? null : $newObject->getId();
435
    }
436
437
    /**
438
     * Deletes the content stream for the specified document object.
439
     *
440
     * @param string $repositoryId the identifier for the repository
441
     * @param string $objectId the identifier for the object. The repository might return a different/new object id
442
     * @param string|null $changeToken the last change token of this object that the client received.
443
     *      The repository might return a new change token (default is <code>null</code>)
444
     * @param ExtensionDataInterface|null $extension
445
     * @throws CmisInvalidArgumentException If $objectId is empty
446
     */
447 3
    public function deleteContentStream(
448
        $repositoryId,
449
        & $objectId,
450
        & $changeToken = null,
451
        ExtensionDataInterface $extension = null
452
    ) {
453 3
        if (empty($objectId)) {
454
            throw new CmisInvalidArgumentException('Object id must not be empty!');
455
        }
456
457 3
        $this->flushCached($objectId);
0 ignored issues
show
Unused Code introduced by
The call to ObjectService::flushCached() has too many arguments starting with $objectId.

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress.

In this case you can add the @ignore PhpDoc annotation to the duplicate definition and it will be ignored.

Loading history...
458
459 3
        $url = $this->getObjectUrl($repositoryId, $objectId);
460
461 3
        $url->getQuery()->modify(
462
            array(
463 3
                Constants::CONTROL_CMISACTION => Constants::CMISACTION_DELETE_CONTENT,
464 3
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false'
465 3
            )
466 3
        );
467
468 3 View Code Duplication
        if ($changeToken !== null && !$this->getSession()->get(SessionParameter::OMIT_CHANGE_TOKENS, false)) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
469 1
            $url->getQuery()->modify(array(Constants::PARAM_CHANGE_TOKEN => $changeToken));
470 1
        }
471
472 3
        $responseData = $this->post($url)->json();
473 3
        $newObject = $this->getJsonConverter()->convertObject($responseData);
474
475
        // $objectId was passed by reference. The value is changed here to new object id
476 3
        $objectId = null;
477 3 View Code Duplication
        if ($newObject !== null) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
478 3
            $objectId = $newObject->getId();
479 3
            $newObjectProperties = $newObject->getProperties()->getProperties();
480 3
            if ($changeToken !== null && count($newObjectProperties) > 0) {
481 2
                $newChangeToken = $newObjectProperties[PropertyIds::CHANGE_TOKEN];
482
                // $changeToken was passed by reference. The value is changed here
483 2
                $changeToken = $newChangeToken === null ? null : $newChangeToken->getFirstValue();
484 2
            }
485 3
        }
486 3
    }
487
488
    /**
489
     * Deletes the specified object.
490
     *
491
     * @param string $repositoryId the identifier for the repository
492
     * @param string $objectId the identifier for the object
493
     * @param boolean $allVersions If <code>true</code> then delete all versions of the document, otherwise delete only
494
     *      the document object specified (default is <code>true</code>)
495
     * @param ExtensionDataInterface|null $extension
496
     */
497 2
    public function deleteObject(
498
        $repositoryId,
499
        $objectId,
500
        $allVersions = true,
501
        ExtensionDataInterface $extension = null
502
    ) {
503 2
        $url = $this->getObjectUrl($repositoryId, $objectId);
504 2
        $url->getQuery()->modify(
505
            array(
506 2
                Constants::CONTROL_CMISACTION => Constants::CMISACTION_DELETE,
507 2
                Constants::PARAM_ALL_VERSIONS => $allVersions ? 'true' : 'false',
508
            )
509 2
        );
510
511 2
        $this->post($url);
512 2
        $this->flushCached($objectId);
0 ignored issues
show
Unused Code introduced by
The call to ObjectService::flushCached() has too many arguments starting with $objectId.

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress.

In this case you can add the @ignore PhpDoc annotation to the duplicate definition and it will be ignored.

Loading history...
513 2
    }
514
515
    /**
516
     * Deletes the specified folder object and all of its child- and descendant-objects.
517
     *
518
     * @param string $repositoryId the identifier for the repository
519
     * @param string $folderId the identifier for the folder
520
     * @param boolean $allVersions If <code>true</code> then delete all versions of the document, otherwise delete only
521
     *      the document object specified (default is <code>true</code>)
522
     * @param UnfileObject|null $unfileObjects defines how the repository must process file-able child- or
523
     *      descendant-objects (default is <code>UnfileObject::DELETE</code>)
524
     * @param boolean $continueOnFailure If <code>true</code>, then the repository should continue attempting to
525
     *      perform this operation even if deletion of a child- or descendant-object in the specified folder cannot
526
     *      be deleted
527
     * @param ExtensionDataInterface|null $extension
528
     * @return FailedToDeleteDataInterface Returns a list of object ids that could not be deleted
529
     */
530 4
    public function deleteTree(
531
        $repositoryId,
532
        $folderId,
533
        $allVersions = true,
534
        UnfileObject $unfileObjects = null,
535
        $continueOnFailure = false,
536
        ExtensionDataInterface $extension = null
537
    ) {
538 4
        $url = $this->getObjectUrl($repositoryId, $folderId);
539 4
        $url->getQuery()->modify(
540
            array(
541 4
                Constants::CONTROL_CMISACTION => Constants::CMISACTION_DELETE_TREE,
542 4
                Constants::PARAM_FOLDER_ID => $folderId,
543 4
                Constants::PARAM_ALL_VERSIONS => $allVersions ? 'true' : 'false',
544 4
                Constants::PARAM_CONTINUE_ON_FAILURE => $continueOnFailure ? 'true' : 'false'
545 4
            )
546 4
        );
547
548 4
        if ($unfileObjects !== null) {
549 1
            $url->getQuery()->modify(array(Constants::PARAM_UNFILE_OBJECTS => (string) $unfileObjects));
550 1
        }
551
552 4
        $response = $this->post($url);
553
554 4
        return $this->getJsonConverter()->convertFailedToDelete((array) $response->json());
555
    }
556
557
    /**
558
     * Gets the list of allowable actions for an object.
559
     *
560
     * @param string $repositoryId the identifier for the repository
561
     * @param string $objectId the identifier for the object
562
     * @param ExtensionDataInterface|null $extension
563
     * @return AllowableActionsInterface
564
     */
565
    public function getAllowableActions($repositoryId, $objectId, ExtensionDataInterface $extension = null)
566
    {
567
        // TODO: Implement getAllowableActions() method.
568
    }
569
570
    /**
571
     * Gets the content stream for the specified document object, or gets a rendition stream for
572
     * a specified rendition of a document or folder object.
573
     *
574
     * @param string $repositoryId the identifier for the repository
575
     * @param string $objectId the identifier for the object
576
     * @param string|null $streamId The identifier for the rendition stream, when used to get a rendition stream.
577
     *      For documents, if not provided then this method returns the content stream. For folders,
578
     *      it MUST be provided.
579
     * @param integer|null $offset
580
     * @param integer|null $length
581
     * @param ExtensionDataInterface|null $extension
582
     * @return StreamInterface|null
583
     * @throws CmisInvalidArgumentException If object id is empty
584
     */
585 3
    public function getContentStream(
586
        $repositoryId,
587
        $objectId,
588
        $streamId = null,
589
        $offset = null,
590
        $length = null,
591
        ExtensionDataInterface $extension = null
592
    ) {
593 3
        if (empty($objectId)) {
594
            throw new CmisInvalidArgumentException('Object id must not be empty!');
595
        }
596
597 3
        $url = $this->getObjectUrl($repositoryId, $objectId, Constants::SELECTOR_CONTENT);
598
599 3
        if ($streamId !== null) {
600 1
            $url->getQuery()->modify(array(Constants::PARAM_STREAM_ID => $streamId));
601 1
        }
602
603
        /** @var Response $response */
604 3
        $response = $this->getHttpInvoker()->get($url);
605
606 3
        $contentStream = $response->getBody();
607 3
        if (!$contentStream instanceof StreamInterface) {
608
            return null;
609
        }
610
611 3
        if ($offset !== null) {
612 1
            $contentStream = new LimitStream($contentStream, $length !== null ? $length : - 1, $offset);
613 1
        }
614
615 3
        return $contentStream;
616
    }
617
618
    /**
619
     * Gets the specified information for the object specified by id.
620
     *
621
     * @param string $repositoryId the identifier for the repository
622
     * @param string $objectId the identifier for the object
623
     * @param string|null $filter a comma-separated list of query names that defines which properties must be
624
     *      returned by the repository (default is repository specific)
625
     * @param boolean $includeAllowableActions if <code>true</code>, then the repository must return the allowable
626
     *      actions for the object (default is <code>false</code>)
627
     * @param IncludeRelationships|null $includeRelationships indicates what relationships in which the objects
628
     *      participate must be returned (default is <code>IncludeRelationships::NONE</code>)
629
     * @param string $renditionFilter indicates what set of renditions the repository must return whose kind
630
     *      matches this filter (default is "cmis:none")
631
     * @param boolean $includePolicyIds if <code>true</code>, then the repository must return the policy ids for
632
     *      the object (default is <code>false</code>)
633
     * @param boolean $includeAcl if <code>true</code>, then the repository must return the ACL for the object
634
     *      (default is <code>false</code>)
635
     * @param ExtensionDataInterface|null $extension
636
     * @return ObjectDataInterface|null Returns object of type ObjectDataInterface or <code>null</code>
637
     *     if the repository response was empty
638
     */
639 3 View Code Duplication
    public function getObject(
640
        $repositoryId,
641
        $objectId,
642
        $filter = null,
643
        $includeAllowableActions = false,
644
        IncludeRelationships $includeRelationships = null,
645
        $renditionFilter = Constants::RENDITION_NONE,
646
        $includePolicyIds = false,
647
        $includeAcl = false,
648
        ExtensionDataInterface $extension = null
649
    ) {
650 3
        $cacheKey = $this->createCacheKey(
651 3
            $objectId,
652
            array(
653 3
                $repositoryId,
654 3
                $filter,
655 3
                $includeAllowableActions,
656 3
                $includeRelationships,
657 3
                $renditionFilter,
658 3
                $includePolicyIds,
659 3
                $includeAcl,
660 3
                $extension,
661 3
                $this->getSuccinct()
662 3
            )
663 3
        );
664 3
        if ($this->isCached($cacheKey)) {
665
            return $this->getCached($cacheKey);
666
        }
667 3
        $url = $this->getObjectUrl($repositoryId, $objectId, Constants::SELECTOR_OBJECT);
668 3
        $url->getQuery()->modify(
669
            array(
670 3
                Constants::PARAM_ALLOWABLE_ACTIONS => $includeAllowableActions ? 'true' : 'false',
671 3
                Constants::PARAM_RENDITION_FILTER => $renditionFilter,
672 3
                Constants::PARAM_POLICY_IDS => $includePolicyIds ? 'true' : 'false',
673 3
                Constants::PARAM_ACL => $includeAcl ? 'true' : 'false',
674 3
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false',
675 3
                Constants::PARAM_DATETIME_FORMAT => (string) $this->getDateTimeFormat()
676 3
            )
677 3
        );
678
679 3
        if (!empty($filter)) {
680 2
            $url->getQuery()->modify(array(Constants::PARAM_FILTER => (string) $filter));
681 2
        }
682
683 3
        if ($includeRelationships !== null) {
684 2
            $url->getQuery()->modify(array(Constants::PARAM_RELATIONSHIPS => (string) $includeRelationships));
685 2
        }
686
687 3
        $responseData = $this->read($url)->json();
688
689 3
        return $this->cache(
690 3
            $cacheKey,
691 3
            $this->getJsonConverter()->convertObject($responseData)
692 3
        );
693
    }
694
695
    /**
696
     * Gets the specified information for the object specified by path.
697
     *
698
     * @param string $repositoryId the identifier for the repository
699
     * @param string $path the path to the object
700
     * @param string|null $filter a comma-separated list of query names that defines which properties must be
701
     *      returned by the repository (default is repository specific)
702
     * @param boolean $includeAllowableActions if <code>true</code>, then the repository must return the allowable
703
     *      actions for the object (default is <code>false</code>)
704
     * @param IncludeRelationships|null $includeRelationships indicates what relationships in which the objects
705
     *      participate must be returned (default is <code>IncludeRelationships::NONE</code>)
706
     * @param string $renditionFilter indicates what set of renditions the repository must return whose kind
707
     *      matches this filter (default is "cmis:none")
708
     * @param boolean $includePolicyIds if <code>true</code>, then the repository must return the policy ids for
709
     *      the object (default is <code>false</code>)
710
     * @param boolean $includeAcl if <code>true</code>, then the repository must return the ACL for the object
711
     *      (default is <code>false</code>)
712
     * @param ExtensionDataInterface|null $extension
713
     * @return ObjectDataInterface|null Returns object of type <code>ObjectDataInterface</code> or <code>null</code>
714
     *      if the repository response was empty
715
     */
716 3 View Code Duplication
    public function getObjectByPath(
717
        $repositoryId,
718
        $path,
719
        $filter = null,
720
        $includeAllowableActions = false,
721
        IncludeRelationships $includeRelationships = null,
722
        $renditionFilter = Constants::RENDITION_NONE,
723
        $includePolicyIds = false,
724
        $includeAcl = false,
725
        ExtensionDataInterface $extension = null
726
    ) {
727 3
        $cacheKey = $this->createCacheKey(
728 3
            $path,
729
            array(
730 3
                $repositoryId,
731 3
                $filter,
732 3
                $includeAllowableActions,
733 3
                $includeRelationships,
734 3
                $renditionFilter,
735 3
                $includePolicyIds,
736 3
                $includeAcl,
737 3
                $extension,
738 3
                $this->getSuccinct()
739 3
            )
740 3
        );
741 3
        if ($this->isCached($cacheKey)) {
742
            return $this->getCached($cacheKey);
743
        }
744
745 3
        $url = $this->getPathUrl($repositoryId, $path, Constants::SELECTOR_OBJECT);
746 3
        $url->getQuery()->modify(
747
            array(
748 3
                Constants::PARAM_ALLOWABLE_ACTIONS => $includeAllowableActions ? 'true' : 'false',
749 3
                Constants::PARAM_RENDITION_FILTER => $renditionFilter,
750 3
                Constants::PARAM_POLICY_IDS => $includePolicyIds ? 'true' : 'false',
751 3
                Constants::PARAM_ACL => $includeAcl ? 'true' : 'false',
752 3
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false',
753 3
                Constants::PARAM_DATETIME_FORMAT => (string) $this->getDateTimeFormat()
754 3
            )
755 3
        );
756
757 3
        if (!empty($filter)) {
758 2
            $url->getQuery()->modify(array(Constants::PARAM_FILTER => (string) $filter));
759 2
        }
760
761 3
        if ($includeRelationships !== null) {
762 2
            $url->getQuery()->modify(array(Constants::PARAM_RELATIONSHIPS => (string) $includeRelationships));
763 2
        }
764
765 3
        $responseData = $this->read($url)->json();
766
767 3
        return $this->cache(
768 3
            $cacheKey,
769 3
            $this->getJsonConverter()->convertObject($responseData)
770 3
        );
771
    }
772
773
    /**
774
     * Gets the list of properties for an object.
775
     *
776
     * @param string $repositoryId the identifier for the repository
777
     * @param string $objectId the identifier for the object
778
     * @param string|null $filter a comma-separated list of query names that defines which properties must be
779
     *      returned by the repository (default is repository specific)
780
     * @param ExtensionDataInterface|null $extension
781
     * @return PropertiesInterface
782
     */
783 2
    public function getProperties(
784
        $repositoryId,
785
        $objectId,
786
        $filter = null,
787
        ExtensionDataInterface $extension = null
788
    ) {
789 2
        $cacheKey = $this->createCacheKey(
790 2
            $objectId,
791
            array(
792 2
                $repositoryId,
793 2
                $filter,
794 2
                $extension,
795 2
                $this->getSuccinct()
796 2
            )
797 2
        );
798
799 2
        if ($this->isCached($cacheKey)) {
800
            return $this->getCached($cacheKey);
801
        }
802
803 2
        $url = $this->getObjectUrl($repositoryId, $objectId, Constants::SELECTOR_PROPERTIES);
804 2
        $url->getQuery()->modify(
805
            array(
806 2
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false',
807 2
                Constants::PARAM_DATETIME_FORMAT => (string) $this->getDateTimeFormat()
808 2
            )
809 2
        );
810
811 2
        if (!empty($filter)) {
812 1
            $url->getQuery()->modify(array(Constants::PARAM_FILTER => (string) $filter));
813 1
        }
814
815 2
        $responseData = $this->read($url)->json();
816
817 2
        if ($this->getSuccinct()) {
818
            $objectData = $this->getJsonConverter()->convertSuccinctProperties($responseData);
819
        } else {
820 2
            $objectData = $this->getJsonConverter()->convertProperties($responseData);
821
        }
822
823 2
        return $this->cache(
824 2
            $cacheKey,
825
            $objectData
826 2
        );
827
    }
828
829
    /**
830
     * Gets the list of associated renditions for the specified object.
831
     * Only rendition attributes are returned, not rendition stream.
832
     *
833
     * @param string $repositoryId the identifier for the repository
834
     * @param string $objectId the identifier for the object
835
     * @param string $renditionFilter indicates what set of renditions the repository must return whose kind
836
     *      matches this filter (default is "cmis:none")
837
     * @param integer|null $maxItems the maximum number of items to return in a response
838
     *       (default is repository specific)
839
     * @param integer $skipCount number of potential results that the repository MUST skip/page over before
840
     *      returning any results (default is 0)
841
     * @param ExtensionDataInterface|null $extension
842
     * @return RenditionDataInterface[]
843
     * @throws CmisInvalidArgumentException If object id is empty or skip count not of type integer
844
     */
845 2
    public function getRenditions(
846
        $repositoryId,
847
        $objectId,
848
        $renditionFilter = Constants::RENDITION_NONE,
849
        $maxItems = null,
850
        $skipCount = 0,
851
        ExtensionDataInterface $extension = null
852
    ) {
853 2
        if (empty($objectId)) {
854
            throw new CmisInvalidArgumentException('Object id must not be empty!');
855
        }
856
857 2
        if (!is_int($skipCount)) {
858
            throw new CmisInvalidArgumentException('Skip count must be of type integer!');
859
        }
860
861 2
        $url = $this->getObjectUrl($repositoryId, $objectId, Constants::SELECTOR_RENDITIONS);
862 2
        $url->getQuery()->modify(
863
            array(
864 2
                Constants::PARAM_RENDITION_FILTER => $renditionFilter,
865 2
                Constants::PARAM_SKIP_COUNT => (string) $skipCount,
866
            )
867 2
        );
868
869 2
        if ($maxItems !== null) {
870 1
            $url->getQuery()->modify(array(Constants::PARAM_MAX_ITEMS => (string) $maxItems));
871 1
        }
872
873 2
        $responseData = $this->read($url)->json();
874
875 2
        return $this->getJsonConverter()->convertRenditions($responseData);
876
    }
877
878
    /**
879
     * Moves the specified file-able object from one folder to another.
880
     *
881
     * @param string $repositoryId the identifier for the repository
882
     * @param string $objectId the identifier for the object. The repository might return a different/new object id
883
     * @param string $targetFolderId the identifier for the target folder
884
     * @param string $sourceFolderId the identifier for the source folder
885
     * @param ExtensionDataInterface|null $extension
886
     * @return ObjectDataInterface|null Returns object of type ObjectDataInterface or <code>null</code>
887
     *     if the repository response was empty
888
     */
889 1
    public function moveObject(
890
        $repositoryId,
891
        & $objectId,
892
        $targetFolderId,
893
        $sourceFolderId,
894
        ExtensionDataInterface $extension = null
895
    ) {
896 1
        $this->flushCached($objectId);
0 ignored issues
show
Unused Code introduced by
The call to ObjectService::flushCached() has too many arguments starting with $objectId.

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress.

In this case you can add the @ignore PhpDoc annotation to the duplicate definition and it will be ignored.

Loading history...
897
898 1
        $url = $this->getObjectUrl($repositoryId, $objectId);
899 1
        $url->getQuery()->modify(
900
            array(
901 1
                Constants::CONTROL_CMISACTION => Constants::CMISACTION_MOVE,
902 1
                Constants::PARAM_TARGET_FOLDER_ID => $targetFolderId,
903 1
                Constants::PARAM_SOURCE_FOLDER_ID => $sourceFolderId,
904 1
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false'
905 1
            )
906 1
        );
907
908 1
        $responseData = $this->post($url)->json();
909 1
        $newObject = $this->getJsonConverter()->convertObject($responseData);
910
911
        // $objectId was passed by reference. The value is changed here to new object id
912 1
        $objectId = ($newObject === null) ? null : $newObject->getId();
913
914 1
        return $newObject;
915
    }
916
917
    /**
918
     * Sets the content stream for the specified document object.
919
     *
920
     * @param string $repositoryId The identifier for the repository
921
     * @param string $objectId The identifier for the object. The repository might return a different/new object id
922
     * @param StreamInterface $contentStream The content stream
923
     * @param boolean $overwriteFlag If <code>true</code>, then the repository must replace the existing content stream
924
     *      for the object (if any) with the input content stream. If <code>false</code>, then the repository must
925
     *      only set the input content stream for the object if the object currently does not have a content stream
926
     *      (default is <code>true</code>)
927
     * @param string|null $changeToken The last change token of this object that the client received.
928
     *      The repository might return a new change token (default is <code>null</code>)
929
     * @param ExtensionDataInterface|null $extension
930
     * @throws CmisInvalidArgumentException If object id is empty
931
     */
932 3
    public function setContentStream(
933
        $repositoryId,
934
        & $objectId,
935
        StreamInterface $contentStream,
936
        $overwriteFlag = true,
937
        & $changeToken = null,
938
        ExtensionDataInterface $extension = null
939
    ) {
940 3
        if (empty($objectId)) {
941
            throw new CmisInvalidArgumentException('Object id must not be empty!');
942
        }
943
944 3
        $this->flushCached($objectId);
0 ignored issues
show
Unused Code introduced by
The call to ObjectService::flushCached() has too many arguments starting with $objectId.

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress.

In this case you can add the @ignore PhpDoc annotation to the duplicate definition and it will be ignored.

Loading history...
945
946 3
        $url = $this->getObjectUrl($repositoryId, $objectId);
947
948 3
        $url->getQuery()->modify(
949
            array(
950 3
                Constants::CONTROL_CMISACTION => Constants::CMISACTION_SET_CONTENT,
951 3
                Constants::PARAM_OVERWRITE_FLAG => $overwriteFlag ? 'true' : 'false',
952 3
                Constants::PARAM_SUCCINCT => $this->getSuccinct() ? 'true' : 'false'
953 3
            )
954 3
        );
955
956 3 View Code Duplication
        if ($changeToken !== null && !$this->getSession()->get(SessionParameter::OMIT_CHANGE_TOKENS, false)) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
957 1
            $url->getQuery()->modify(array(Constants::PARAM_CHANGE_TOKEN => $changeToken));
958 1
        }
959
960 3
        $responseData = $this->post(
961 3
            $url,
962 3
            array('content' => $contentStream)
963 3
        )->json();
964
965 3
        $newObject = $this->getJsonConverter()->convertObject($responseData);
966
967
        // $objectId was passed by reference. The value is changed here to new object id
968 3
        $objectId = null;
969 3 View Code Duplication
        if ($newObject !== null) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
970 3
            $objectId = $newObject->getId();
971 3
            $newObjectProperties = $newObject->getProperties()->getProperties();
972 3
            if ($changeToken !== null && count($newObjectProperties) > 0) {
973 2
                $newChangeToken = $newObjectProperties[PropertyIds::CHANGE_TOKEN];
974
                // $changeToken was passed by reference. The value is changed here
975 2
                $changeToken = $newChangeToken === null ? null : $newChangeToken->getFirstValue();
976 2
            }
977 3
        }
978 3
    }
979
980
    /**
981
     * Updates properties of the specified object.
982
     *
983
     * @param string $repositoryId The identifier for the repository
984
     * @param string $objectId The identifier for the object. The repository might return a different/new object id
985
     * @param PropertiesInterface $properties The updated property values that must be applied to the object
986
     * @param string|null $changeToken The last change token of this object that the client received.
987
     *      The repository might return a new change token (default is <code>null</code>)
988
     * @param ExtensionDataInterface|null $extension
989
     * @throws CmisInvalidArgumentException If $objectId is empty
990
     */
991 3
    public function updateProperties(
992
        $repositoryId,
993
        & $objectId,
994
        PropertiesInterface $properties,
995
        & $changeToken = null,
996
        ExtensionDataInterface $extension = null
997
    ) {
998 3
        if (empty($objectId)) {
999
            throw new CmisInvalidArgumentException('Object id must not be empty!');
1000
        }
1001
1002 3
        $this->flushCached($objectId);
0 ignored issues
show
Unused Code introduced by
The call to ObjectService::flushCached() has too many arguments starting with $objectId.

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress.

In this case you can add the @ignore PhpDoc annotation to the duplicate definition and it will be ignored.

Loading history...
1003
1004 3
        $url = $this->getObjectUrl($repositoryId, $objectId);
1005
1006 3 View Code Duplication
        if ($changeToken !== null && !$this->getSession()->get(SessionParameter::OMIT_CHANGE_TOKENS, false)) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
1007 1
            $url->getQuery()->modify(array(Constants::PARAM_CHANGE_TOKEN => $changeToken));
1008 1
        }
1009
1010 3
        $queryArray = $this->convertPropertiesToQueryArray($properties);
1011 3
        $queryArray[Constants::CONTROL_CMISACTION] = Constants::CMISACTION_UPDATE_PROPERTIES;
1012 3
        $queryArray[Constants::PARAM_SUCCINCT] = $this->getSuccinct() ? 'true' : 'false';
1013 3
        $responseData = $this->post($url, $queryArray)->json();
1014 3
        $newObject = $this->getJsonConverter()->convertObject($responseData);
1015
1016
        // $objectId was passed by reference. The value is changed here to new object id
1017 3
        $objectId = null;
1018 3 View Code Duplication
        if ($newObject !== null) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
1019 3
            $objectId = $newObject->getId();
1020 3
            $newObjectProperties = $newObject->getProperties()->getProperties();
1021 3
            if ($changeToken !== null && count($newObjectProperties) > 0) {
1022 2
                $newChangeToken = $newObjectProperties[PropertyIds::CHANGE_TOKEN];
1023
                // $changeToken was passed by reference. The value is changed here
1024 2
                $changeToken = $newChangeToken === null ? null : $newChangeToken->getFirstValue();
1025 2
            }
1026 3
        }
1027 3
    }
1028
1029
    /**
1030
     * @param string $identifier
1031
     * @param mixed $additionalHashValues
1032
     * @return array
1033
     */
1034 8
    protected function createCacheKey($identifier, $additionalHashValues)
1035
    {
1036
        return array(
1037 8
            $identifier,
1038 8
            sha1(is_array($additionalHashValues) ? serialize($additionalHashValues) : $additionalHashValues)
1039 8
        );
1040
    }
1041
1042
    /**
1043
     * Returns TRUE if an object with cache key $identifier is currently cached.
1044
     *
1045
     * @param array $identifier
1046
     * @return boolean
1047
     */
1048 8
    protected function isCached(array $identifier)
1049
    {
1050 8
        return isset($this->objectCache[$identifier[0]][$identifier[1]]);
1051
    }
1052
1053
    /**
1054
     * Gets the cached object with cache key $identifier.
1055
     *
1056
     * @param string $identifier
0 ignored issues
show
Documentation introduced by
Should the type for parameter $identifier not be array? Also, consider making the array more specific, something like array<String>, or String[].

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive. In addition it looks for parameters that have the generic type array and suggests a stricter type like array<String>.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
1057
     * @return mixed
1058
     */
1059
    protected function getCached(array $identifier)
1060
    {
1061
        if ($this->isCached($identifier)) {
1062
            return $this->objectCache[$identifier[0]][$identifier[1]];
1063
        }
1064
        return null;
1065
    }
1066
1067
	/**
1068
     * Gets the cached object with cache key $identifier.
1069
     *
1070
     * @param string $identifier
0 ignored issues
show
Documentation introduced by
Should the type for parameter $identifier not be array? Also, consider making the array more specific, something like array<String>, or String[].

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive. In addition it looks for parameters that have the generic type array and suggests a stricter type like array<String>.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
1071
     * @param mixed $object
1072
     * @return mixed
1073
     */
1074 8
    protected function cache(array $identifier, $object)
1075
    {
1076 8
        $this->objectCache[$identifier[0]][$identifier[1]] = $object;
1077 8
        return $object;
1078
    }
1079
1080
	/**
1081
	 * Flushes all cached entries. This is implemented as a flush-all with
1082
	 * no way to flush individual entries due to the way CMIS object data
1083
	 * gets returned from CMIS. Two widely different object data sets may
1084
	 * contain a reference to the same item and even with extensive cross
1085
	 * referencing it would be technically unfeasible to selectively clear
1086
	 * or reload an object by identifier. Such flushing would be inevitably
1087
	 * flawed with edge cases of incomplete flushing or become so complex
1088
	 * that it defeats the purpose of caching in the first place.
1089
	 *
1090
	 * Note that cache flushing only happens when modifying the repository
1091
	 * contents - which should limit the negative impact. The cache is also
1092
	 * not persistent and will only affect the current request. As such, it
1093
	 * is implemented to optimise requests where the same object, type,
1094
	 * policy etc. gets accessed multiple times.
1095
	 *
1096
	 * @return void
1097
	 */
1098 12
	protected function flushCached()
1099
	{
1100 12
		$this->objectCache = array();
1101 12
	}
1102
}
1103