Skip to content

Commit

Permalink
+runAsSuperSession
Browse files Browse the repository at this point in the history
Signed-off-by: Maxence Lange <maxence@artificial-owl.com>
  • Loading branch information
ArtificialOwl committed Mar 29, 2022
1 parent 69c2f79 commit ac8c37a
Showing 1 changed file with 38 additions and 6 deletions.
44 changes: 38 additions & 6 deletions lib/CirclesManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@

namespace OCA\Circles;

use OCA\Circles\Tools\Exceptions\InvalidItemException;
use OCA\Circles\Exceptions\CircleNotFoundException;
use OCA\Circles\Exceptions\ContactAddressBookNotFoundException;
use OCA\Circles\Exceptions\ContactFormatException;
Expand Down Expand Up @@ -62,6 +61,7 @@
use OCA\Circles\Service\FederatedUserService;
use OCA\Circles\Service\MemberService;
use OCA\Circles\Service\MembershipService;
use OCA\Circles\Tools\Exceptions\InvalidItemException;
use OCP\IUserSession;

/**
Expand Down Expand Up @@ -133,7 +133,9 @@ public function __construct(
* @throws UserTypeNotFoundException
*/
public function getFederatedUser(string $federatedId, int $type = Member::TYPE_SINGLE): FederatedUser {
return $this->federatedUserService->getFederatedUser($federatedId, $type);
$result = $this->federatedUserService->getFederatedUser($federatedId, $type);

return $result;
}


Expand Down Expand Up @@ -161,6 +163,28 @@ public function startSuperSession(): void {
}


/**
* Run a single method as Super, then Super level will be removed
*/
public function runAsSuperSession(string $method, array $params = []) {
$currentUser = $this->federatedUserService->getCurrentUser();
$this->startSuperSession();

$result = call_user_func_array([$this, $method], $params);
if (is_null($currentUser)) {
return $result;
}

$this->federatedUserService->bypassCurrentUserCondition(false);
try {
$this->federatedUserService->setCurrentUser($currentUser);
} catch (FederatedUserException $e) {
}

return $result;
}


/**
* $userId - userId to emulate as initiator (can be empty)
* $userType - specify if userIs not a singleId
Expand Down Expand Up @@ -286,7 +310,9 @@ public function getCircles(?CircleProbe $probe = null): array {
->filterBackendCircles();
}

return $this->circleService->getCircles($probe);
$result = $this->circleService->getCircles($probe);

return $result;
}


Expand All @@ -300,7 +326,9 @@ public function getCircles(?CircleProbe $probe = null): array {
* @throws RequestBuilderException
*/
public function getCircle(string $singleId, ?CircleProbe $probe = null): Circle {
return $this->circleService->getCircle($singleId, $probe);
$result = $this->circleService->getCircle($singleId, $probe);

return $result;
}


Expand Down Expand Up @@ -392,7 +420,9 @@ public function removeMember(string $memberId): void {
* @throws RequestBuilderException
*/
public function getLink(string $circleId, string $singleId, bool $detailed = false): Membership {
return $this->membershipService->getMembership($circleId, $singleId, $detailed);
$result = $this->membershipService->getMembership($circleId, $singleId, $detailed);

return $result;
}


Expand All @@ -402,7 +432,9 @@ public function getLink(string $circleId, string $singleId, bool $detailed = fal
* @return string
*/
public function getDefinition(IEntity $circle): string {
return $this->circleService->getDefinition($circle);
$result = $this->circleService->getDefinition($circle);

return $result;
}


Expand Down

0 comments on commit ac8c37a

Please sign in to comment.