%PDF- %PDF-
| Direktori : /www/varak.net/nextcloud.varak.net/apps_old/apps/circles/lib/ |
| Current File : /www/varak.net/nextcloud.varak.net/apps_old/apps/circles/lib/IFederatedItemShareManagement.php |
<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCA\Circles;
use OCA\Circles\Model\Federated\FederatedEvent;
/**
* Interface IFederatedItemShareManagement
*
* @package OCA\Circles
*/
interface IFederatedItemShareManagement {
/**
* /!\ un Item est sharable a un Federated Circle seulement depuis l'instance qui lock l'Item.
*
*
* | Instance A | Instance B | Instance C | Instance D | Instance E |
* | | | | | |
* | --- Circle A --- | ---------------- | | | |
* | | ---------------- | --- Circle C --- | ---------------- | |
* | ---------------- | --- Circle B --- | ---------------- | | |
* | | ---------------- | ---------------- | --- Circle D --- | ---------------- |
* | | | | | |
* | | | | | |
* | Create Item1 | | | | |
* | Lock Item1 | | | | |
* | Share I1, Ca | Lock I1, Ia, Ca | | | |
* | get I1 local | get I1 on Ia | | | | OK: Get Item1 pour Circle A sur Instance A
* | | | | | |
* | Reshare I1, Cb | Lock I1, Ia, Cb | Lock I1, Ia, Cb | | |
* | get I1 local | get I1 on Ia | | | | OK: Get Item1 pour Circle B sur Instance A, via Instance B
* | | | | | |
* | Create Item2 | | | | |
* | Lock Item2 | | | | |
* | Share I2, CB | Lock I2, Ia, Cb | Lock I2, Ia, Cb | | |
* | get I2 local | get I2 on Ia | get I2 on Ia | | | OK: Get Item2 pour Circle B sur Instance A, via Instance B
* | | | | | |
* | Create Item3 | | | | |
* | Lock Item3 | | | | |
* | Share I3, Ca | | | | |
* | get I3 local | get I3 on Ia | | | | OK: Get Item3 pour Circle A sur Instance A
* | | | | | |
* | | Reshare I3, Cb | | | | ERROR
* | | Reshare I2, Cc | | | | ERROR
* | | | | | |
* | | | | | Create Item1 | (spoof, as Item must be unique)
* | | | | | Lock Item1 |
* | | I1 already exist | I1 already exist | Lock I1, Ie, Cd | Share I1, Cd | fail on Ib
* | | ERROR | ERROR | get I1 on Ie | get I1 local |
* | | | | | |
* | | | | * Join Circle B | |
* | ---------------- | --- Circle B --- | ---------------- | ---------------- | |
* | | | | shares from Ib | |
* | | | | I1 already exist | | fail on I1
* | | | | Lock I2, Ia, Cb | | OK: Get Item2 pour Circle B sur Instance A, via Instance B
* | | | | | |
* | | | | | |
* | | | | | |
* | | | | | |
*
*
*
*
*
* (on all instances) ShareLocks: itemId, singleId, instanceId, appId, circleId
*
* FederatedItem implements shareCreate(), shareUpdate(), shareDelete()
* FederatedEvent have isSharable()
*
*
* ////
* ////
* ///
* seulement aux circles qui on un membre dont on ne peut pas reshare un object deja share a un federated circle,
* si le owner de l'item n'est pas sur la meme instance
*
* instance A cree un circle A et invite instance B et instance C
* instance B cree un circle B et invite instance A et instance C
* instance C cree un item et le share a Circle A et a Circle B
* instance A et instance B possede chacun 2 locks vers instance C pour le meme item via 2 Circles.
*
* instance A cree un circle A2 et invite instance B et instance D
* instance A reshare item vers Circle A2 et cree un 3eme lock vers instance C via Circle A2.
*
* instance D tente de reshare et request instance A qui request instance C
*
*
*/
/**
* @param FederatedEvent $event
*/
public function shareCreate(FederatedEvent $event): void;
/**
* @param FederatedEvent $event
*/
public function shareUpdate(FederatedEvent $event): void;
/**
* @param FederatedEvent $event
*/
public function shareDelete(FederatedEvent $event): void;
}