Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
1 | <?php |
||
25 | class PermissionResolverTest extends BaseTest |
||
26 | { |
||
27 | /** |
||
28 | * Test for the getCurrentUser() method. |
||
29 | * |
||
30 | * @see \eZ\Publish\API\Repository\PermissionResolver::getCurrentUserReference() |
||
31 | */ |
||
32 | public function testGetCurrentUserReferenceReturnsAnonymousUserReference() |
||
58 | |||
59 | /** |
||
60 | * Test for the setCurrentUser() method. |
||
61 | * |
||
62 | * @see \eZ\Publish\API\Repository\PermissionResolver::setCurrentUserReference() |
||
63 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
64 | */ |
||
65 | View Code Duplication | public function testSetCurrentUserReference() |
|
100 | |||
101 | /** |
||
102 | * Test for the hasAccess() method. |
||
103 | * |
||
104 | * @see \eZ\Publish\API\Repository\PermissionResolver::hasAccess() |
||
105 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
106 | */ |
||
107 | public function testHasAccessWithAnonymousUserNo() |
||
130 | |||
131 | /** |
||
132 | * Test for the hasAccess() method. |
||
133 | * |
||
134 | * @see \eZ\Publish\API\Repository\PermissionResolver::hasAccess() |
||
135 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
136 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessWithAnonymousUserNo |
||
137 | */ |
||
138 | View Code Duplication | public function testHasAccessForCurrentUserNo() |
|
164 | |||
165 | /** |
||
166 | * Test for the hasAccess() method. |
||
167 | * |
||
168 | * @see \eZ\Publish\API\Repository\PermissionResolver::hasAccess() |
||
169 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
170 | */ |
||
171 | public function testHasAccessWithAdministratorUser() |
||
192 | |||
193 | /** |
||
194 | * Test for the hasAccess() method. |
||
195 | * |
||
196 | * @see \eZ\Publish\API\Repository\PermissionResolver::hasAccess() |
||
197 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
198 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testSetCurrentUserReference |
||
199 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessWithAdministratorUser |
||
200 | */ |
||
201 | View Code Duplication | public function testHasAccessForCurrentUserYes() |
|
225 | |||
226 | /** |
||
227 | * Test for the hasAccess() method. |
||
228 | * |
||
229 | * @see \eZ\Publish\API\Repository\PermissionResolver::hasAccess() |
||
230 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
231 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testSetCurrentUserReference |
||
232 | */ |
||
233 | View Code Duplication | public function testHasAccessLimited() |
|
256 | |||
257 | /** |
||
258 | * Test for the canUser() method. |
||
259 | * |
||
260 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
261 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
262 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
263 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessForCurrentUserNo |
||
264 | * @expectedException \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
265 | */ |
||
266 | public function testCanUserForAnonymousUserNo() |
||
301 | |||
302 | /** |
||
303 | * Test for the canUser() method. |
||
304 | * |
||
305 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
306 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
307 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
308 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessForCurrentUserYes |
||
309 | * @expectedException \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
310 | */ |
||
311 | View Code Duplication | public function testCanUserForAdministratorUser() |
|
312 | { |
||
313 | $repository = $this->getRepository(); |
||
314 | |||
315 | $administratorUserId = $this->generateId('user', 14); |
||
316 | $homeId = $this->generateId('object', 57); |
||
317 | |||
318 | /* BEGIN: Use Case */ |
||
319 | // $administratorUserId contains the ID of the administrator user |
||
320 | // $homeId contains the ID of the "Home" frontpage |
||
321 | |||
322 | $contentService = $repository->getContentService(); |
||
323 | $userService = $repository->getUserService(); |
||
324 | $permissionResolver = $repository->getPermissionResolver(); |
||
325 | |||
326 | // Load administrator user |
||
327 | $administratorUser = $userService->loadUser($administratorUserId); |
||
328 | |||
329 | // Set administrator user as current user reference |
||
330 | $permissionResolver->setCurrentUserReference($administratorUser); |
||
331 | |||
332 | // Load the ContentInfo for "Home" frontpage |
||
333 | $contentInfo = $contentService->loadContentInfo($homeId); |
||
334 | |||
335 | // This call will return true |
||
336 | $canUser = $permissionResolver->canUser('content', 'remove', $contentInfo); |
||
337 | |||
338 | // Performing an action having necessary permissions will succeed |
||
339 | $contentService->deleteContent($contentInfo); |
||
340 | /* END: Use Case */ |
||
341 | |||
342 | $this->assertTrue($canUser); |
||
343 | $contentService->loadContent($homeId); |
||
344 | } |
||
345 | |||
346 | /** |
||
347 | * Test for the canUser() method. |
||
348 | * |
||
349 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
350 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
351 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
352 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
353 | */ |
||
354 | View Code Duplication | public function testCanUserWithLimitationYes() |
|
381 | |||
382 | /** |
||
383 | * Test for the canUser() method. |
||
384 | * |
||
385 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
386 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
387 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
388 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
389 | * @expectedException \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
390 | */ |
||
391 | View Code Duplication | public function testCanUserWithLimitationNo() |
|
392 | { |
||
393 | $repository = $this->getRepository(); |
||
394 | |||
395 | $administratorUserId = $this->generateId('user', 14); |
||
396 | |||
397 | /* BEGIN: Use Case */ |
||
398 | // $administratorUserId contains the ID of the administrator user |
||
399 | |||
400 | $user = $this->createUserVersion1(); |
||
401 | |||
402 | $permissionResolver = $repository->getPermissionResolver(); |
||
403 | |||
404 | // Set created user as current user reference |
||
405 | $permissionResolver->setCurrentUserReference($user); |
||
406 | |||
407 | $userService = $repository->getUserService(); |
||
408 | |||
409 | // Load administrator user using UserService, this does not check for permissions |
||
410 | $administratorUser = $userService->loadUser($administratorUserId); |
||
411 | |||
412 | // This call will return false as user with Editor role does not have |
||
413 | // permission to read "Users" subtree |
||
414 | $canUser = $permissionResolver->canUser('content', 'read', $administratorUser); |
||
415 | |||
416 | $contentService = $repository->getContentService(); |
||
417 | |||
418 | // Performing an action without necessary permissions will fail with "UnauthorizedException" |
||
419 | if (!$canUser) { |
||
420 | $content = $contentService->loadContent($administratorUserId); |
||
421 | } |
||
422 | /* END: Use Case */ |
||
423 | } |
||
424 | |||
425 | /** |
||
426 | * Test for the canUser() method. |
||
427 | * |
||
428 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
429 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
430 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentTypeService |
||
431 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testSetCurrentUserReference |
||
432 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
433 | * @expectedException \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
434 | */ |
||
435 | View Code Duplication | public function testCanUserThrowsInvalidArgumentException() |
|
436 | { |
||
437 | $repository = $this->getRepository(); |
||
438 | |||
439 | $userGroupContentTypeId = $this->generateId('type', 3); |
||
440 | |||
441 | /* BEGIN: Use Case */ |
||
442 | // $userGroupContentTypeId contains the ID of the "UserGroup" ContentType |
||
443 | |||
444 | $user = $this->createUserVersion1(); |
||
445 | |||
446 | $permissionResolver = $repository->getPermissionResolver(); |
||
447 | |||
448 | // Set created user as current user reference |
||
449 | $permissionResolver->setCurrentUserReference($user); |
||
450 | |||
451 | $contentTypeService = $repository->getContentTypeService(); |
||
452 | |||
453 | // Load the "UserGroup" ContentType |
||
454 | $userGroupContentType = $contentTypeService->loadContentType($userGroupContentTypeId); |
||
455 | |||
456 | // This call will throw "InvalidArgumentException" because $userGroupContentType |
||
457 | // is an instance of \eZ\Publish\API\Repository\Values\ContentType\ContentType, |
||
458 | // which can not be checked for user access |
||
459 | $canUser = $permissionResolver->canUser('content', 'create', $userGroupContentType); |
||
460 | /* END: Use Case */ |
||
461 | } |
||
462 | |||
463 | /** |
||
464 | * Test for the canUser() method. |
||
465 | * |
||
466 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
467 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
468 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
469 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentTypeService |
||
470 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
471 | */ |
||
472 | View Code Duplication | public function testCanUserWithTargetYes() |
|
523 | |||
524 | /** |
||
525 | * Test for the canUser() method. |
||
526 | * |
||
527 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
528 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
529 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
530 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentTypeService |
||
531 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
532 | * @expectedException \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
533 | */ |
||
534 | View Code Duplication | public function testCanUserWithTargetNo() |
|
535 | { |
||
536 | $repository = $this->getRepository(); |
||
537 | |||
538 | $homeLocationId = $this->generateId('location', 2); |
||
539 | |||
540 | /* BEGIN: Use Case */ |
||
541 | // $homeLocationId contains the ID of the "Home" frontpage location |
||
542 | |||
543 | $user = $this->createUserVersion1(); |
||
544 | |||
545 | $permissionResolver = $repository->getPermissionResolver(); |
||
546 | |||
547 | // Set created user as current user reference |
||
548 | $permissionResolver->setCurrentUserReference($user); |
||
549 | |||
550 | $contentTypeService = $repository->getContentTypeService(); |
||
551 | |||
552 | $contentType = $contentTypeService->loadContentTypeByIdentifier('forum'); |
||
553 | |||
554 | $contentService = $repository->getContentService(); |
||
555 | |||
556 | $contentCreateStruct = $contentService->newContentCreateStruct($contentType, 'eng-US'); |
||
557 | $contentCreateStruct->setField('name', 'My awesome forum'); |
||
558 | $contentCreateStruct->remoteId = 'abcdef0123456789abcdef0123456789'; |
||
559 | $contentCreateStruct->alwaysAvailable = true; |
||
560 | |||
561 | $locationService = $repository->getLocationService(); |
||
562 | $locationCreateStruct = $locationService->newLocationCreateStruct($homeLocationId); |
||
563 | |||
564 | // This call will return false because user with Editor role has permission to |
||
565 | // create "forum" type content only under "folder" type content. |
||
566 | $canUser = $permissionResolver->canUser( |
||
567 | 'content', |
||
568 | 'create', |
||
569 | $contentCreateStruct, |
||
570 | [$locationCreateStruct] |
||
571 | ); |
||
572 | |||
573 | // Performing an action without necessary permissions will fail with "UnauthorizedException" |
||
574 | if (!$canUser) { |
||
575 | $contentDraft = $contentService->createContent( |
||
576 | $contentCreateStruct, |
||
577 | [$locationCreateStruct] |
||
578 | ); |
||
579 | } |
||
580 | /* END: Use Case */ |
||
581 | } |
||
582 | |||
583 | /** |
||
584 | * Test for the canUser() method. |
||
585 | * |
||
586 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
587 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
588 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
589 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentTypeService |
||
590 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
591 | */ |
||
592 | View Code Duplication | public function testCanUserWithMultipleTargetsYes() |
|
644 | |||
645 | /** |
||
646 | * Test for the canUser() method. |
||
647 | * |
||
648 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
649 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
650 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
651 | * @depends eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentTypeService |
||
652 | * @depends eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessLimited |
||
653 | * @expectedException \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
654 | */ |
||
655 | View Code Duplication | public function testCanUserWithMultipleTargetsNo() |
|
704 | |||
705 | /** |
||
706 | * Test for the canUser() method. |
||
707 | * |
||
708 | * @see \eZ\Publish\API\Repository\PermissionResolver::canUser() |
||
709 | * @expectedException \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
710 | */ |
||
711 | public function testCanUserThrowsBadStateException() |
||
717 | |||
718 | /** |
||
719 | * Test PermissionResolver::canUser for Users with different Limitations. |
||
720 | * |
||
721 | * @covers \eZ\Publish\API\Repository\PermissionResolver::canUser |
||
722 | * |
||
723 | * @dataProvider getDataForTestCanUserWithLimitations |
||
724 | * |
||
725 | * @param \eZ\Publish\API\Repository\Values\User\Limitation $limitation |
||
726 | * @param string $module |
||
727 | * @param string $function |
||
728 | * @param \eZ\Publish\API\Repository\Values\ValueObject $object |
||
729 | * @param array $targets |
||
730 | * @param bool $expectedResult expected result of canUser check |
||
731 | * |
||
732 | * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
733 | * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
734 | */ |
||
735 | public function testCanUserWithLimitations( |
||
766 | |||
767 | /** |
||
768 | * Data provider for testCanUserWithLimitations. |
||
769 | * @see testCanUserWithLimitations |
||
770 | * |
||
771 | * @return array |
||
772 | * |
||
773 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
774 | */ |
||
775 | public function getDataForTestCanUserWithLimitations() |
||
822 | |||
823 | /** |
||
824 | * Test for the lookupLimitations() method. |
||
825 | * |
||
826 | * @see \eZ\Publish\API\Repository\PermissionResolver::lookupLimitations() |
||
827 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
828 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
829 | * @depends \eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessForCurrentUserNo |
||
830 | */ |
||
831 | View Code Duplication | public function testLookupLimitationsForAnonymousUserHasNoAccess(): void |
|
866 | |||
867 | /** |
||
868 | * Test for the lookupLimitations() method. |
||
869 | * |
||
870 | * @see \eZ\Publish\API\Repository\PermissionResolver::lookupLimitations() |
||
871 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
872 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
873 | * @depends \eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessForCurrentUserYes |
||
874 | */ |
||
875 | View Code Duplication | public function testLookupLimitationsForAdministratorUser(): void |
|
907 | |||
908 | /** |
||
909 | * When one of policy pass then all limitation should be returned. |
||
910 | * |
||
911 | * @see \eZ\Publish\API\Repository\PermissionResolver::lookupLimitations() |
||
912 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
913 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
914 | * @depends \eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessForCurrentUserYes |
||
915 | * |
||
916 | * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
917 | * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
918 | * @throws \eZ\Publish\API\Repository\Exceptions\LimitationValidationException |
||
919 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
920 | * @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
921 | */ |
||
922 | public function testLookupLimitationsWithLimitations(): void |
||
968 | |||
969 | /** |
||
970 | * When one of policy pass then only filtered limitation should be returned. |
||
971 | * |
||
972 | * @see \eZ\Publish\API\Repository\PermissionResolver::lookupLimitations() |
||
973 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetUserService |
||
974 | * @depends \eZ\Publish\API\Repository\Tests\RepositoryTest::testGetContentService |
||
975 | * @depends \eZ\Publish\API\Repository\Tests\PermissionResolverTest::testHasAccessForCurrentUserYes |
||
976 | * |
||
977 | * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
978 | * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
979 | * @throws \eZ\Publish\API\Repository\Exceptions\LimitationValidationException |
||
980 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
981 | * @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
982 | */ |
||
983 | public function testLookupLimitationsWithFilteredLimitations(): void |
||
1028 | |||
1029 | /** |
||
1030 | * If the role limitation is set it should be taken into account. In this case, role limitation |
||
1031 | * will pass and ContentTypeLimitation should be returned. |
||
1032 | * |
||
1033 | * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
1034 | * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
1035 | * @throws \eZ\Publish\API\Repository\Exceptions\LimitationValidationException |
||
1036 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
1037 | * @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
1038 | */ |
||
1039 | public function testLookupLimitationsWithRoleLimitationsHasAccess(): void |
||
1082 | |||
1083 | /** |
||
1084 | * If the role limitation is set and policy limitation is not set it should be taken into account. |
||
1085 | * In this case, role limitation will pass and SectionLimitation should be returned as role limitation |
||
1086 | * and limitations in LookupPolicyLimitations should be an empty array. |
||
1087 | * |
||
1088 | * @see https://jira.ez.no/browse/EZP-30728 |
||
1089 | * |
||
1090 | * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
1091 | * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
1092 | * @throws \eZ\Publish\API\Repository\Exceptions\LimitationValidationException |
||
1093 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
1094 | * @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
1095 | */ |
||
1096 | public function testLookupLimitationsWithRoleLimitationsWithoutPolicyLimitationsHasAccess(): void |
||
1142 | |||
1143 | /** |
||
1144 | * If the role limitation is set it should be taken into account. In this case, role limitation |
||
1145 | * will not pass and ContentTypeLimitation should not be returned. |
||
1146 | * |
||
1147 | * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException |
||
1148 | * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException |
||
1149 | * @throws \eZ\Publish\API\Repository\Exceptions\LimitationValidationException |
||
1150 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
1151 | * @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException |
||
1152 | */ |
||
1153 | public function testLookupLimitationsWithRoleLimitationsHasNoAccess(): void |
||
1191 | |||
1192 | /** |
||
1193 | * @param \eZ\Publish\API\Repository\Repository $repository |
||
1194 | * @param string $contentTypeIdentifier |
||
1195 | * @param string $mainLanguageCode |
||
1196 | * @param int $sectionId |
||
1197 | * |
||
1198 | * @return \eZ\Publish\API\Repository\Values\Content\ContentCreateStruct |
||
1199 | * |
||
1200 | * @throws \eZ\Publish\API\Repository\Exceptions\NotFoundException |
||
1201 | */ |
||
1202 | private function getContentCreateStruct( |
||
1216 | } |
||
1217 |
This method has been deprecated. The supplier of the class has supplied an explanatory message.
The explanatory message should give you some clue as to whether and when the method will be removed from the class and what other method or class to use instead.