albums: redirect public to local link
parent
f3bdccb1ce
commit
0b62dc4aee
|
@ -5,12 +5,15 @@ namespace OCA\Memories\Controller;
|
||||||
use OCA\Memories\Db\TimelineQuery;
|
use OCA\Memories\Db\TimelineQuery;
|
||||||
use OCP\App\IAppManager;
|
use OCP\App\IAppManager;
|
||||||
use OCP\AppFramework\Controller;
|
use OCP\AppFramework\Controller;
|
||||||
|
use OCP\AppFramework\Http\RedirectResponse;
|
||||||
use OCP\AppFramework\Http\Template\PublicTemplateResponse;
|
use OCP\AppFramework\Http\Template\PublicTemplateResponse;
|
||||||
use OCP\AppFramework\Http\TemplateResponse;
|
use OCP\AppFramework\Http\TemplateResponse;
|
||||||
use OCP\AppFramework\Services\IInitialState;
|
use OCP\AppFramework\Services\IInitialState;
|
||||||
use OCP\EventDispatcher\IEventDispatcher;
|
use OCP\EventDispatcher\IEventDispatcher;
|
||||||
use OCP\IConfig;
|
use OCP\IConfig;
|
||||||
use OCP\IDBConnection;
|
use OCP\IDBConnection;
|
||||||
|
use OCP\IURLGenerator;
|
||||||
|
use OCP\IUserSession;
|
||||||
use OCP\Util;
|
use OCP\Util;
|
||||||
|
|
||||||
class PublicAlbumController extends Controller
|
class PublicAlbumController extends Controller
|
||||||
|
@ -21,6 +24,8 @@ class PublicAlbumController extends Controller
|
||||||
protected IAppManager $appManager;
|
protected IAppManager $appManager;
|
||||||
protected IConfig $config;
|
protected IConfig $config;
|
||||||
protected IDBConnection $connection;
|
protected IDBConnection $connection;
|
||||||
|
protected IUserSession $userSession;
|
||||||
|
protected IURLGenerator $urlGenerator;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
string $appName,
|
string $appName,
|
||||||
|
@ -28,7 +33,9 @@ class PublicAlbumController extends Controller
|
||||||
IInitialState $initialState,
|
IInitialState $initialState,
|
||||||
IAppManager $appManager,
|
IAppManager $appManager,
|
||||||
IConfig $config,
|
IConfig $config,
|
||||||
IDBConnection $connection
|
IDBConnection $connection,
|
||||||
|
IUserSession $userSession,
|
||||||
|
IURLGenerator $urlGenerator
|
||||||
) {
|
) {
|
||||||
$this->appName = $appName;
|
$this->appName = $appName;
|
||||||
$this->eventDispatcher = $eventDispatcher;
|
$this->eventDispatcher = $eventDispatcher;
|
||||||
|
@ -36,6 +43,8 @@ class PublicAlbumController extends Controller
|
||||||
$this->appManager = $appManager;
|
$this->appManager = $appManager;
|
||||||
$this->config = $config;
|
$this->config = $config;
|
||||||
$this->connection = $connection;
|
$this->connection = $connection;
|
||||||
|
$this->userSession = $userSession;
|
||||||
|
$this->urlGenerator = $urlGenerator;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -43,10 +52,8 @@ class PublicAlbumController extends Controller
|
||||||
*
|
*
|
||||||
* @NoCSRFRequired
|
* @NoCSRFRequired
|
||||||
*/
|
*/
|
||||||
public function showShare(string $token): TemplateResponse
|
public function showShare(string $token)
|
||||||
{
|
{
|
||||||
\OC_User::setIncognitoMode(true);
|
|
||||||
|
|
||||||
// Validate token exists
|
// Validate token exists
|
||||||
$timelineQuery = new TimelineQuery($this->connection);
|
$timelineQuery = new TimelineQuery($this->connection);
|
||||||
$album = $timelineQuery->getAlbumByLink($token);
|
$album = $timelineQuery->getAlbumByLink($token);
|
||||||
|
@ -54,6 +61,23 @@ class PublicAlbumController extends Controller
|
||||||
return new TemplateResponse('core', '404', [], 'guest');
|
return new TemplateResponse('core', '404', [], 'guest');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if the current user has access to the album
|
||||||
|
// Just redirect to the user's page if the user is the owner or a collaborator
|
||||||
|
if ($user = $this->userSession->getUser()) {
|
||||||
|
$uid = $user->getUID();
|
||||||
|
$albumId = (int) $album['album_id'];
|
||||||
|
|
||||||
|
if ($uid === $album['user'] || $timelineQuery->userIsAlbumCollaborator($uid, $albumId)) {
|
||||||
|
$idStr = $album['user'].'/'.$album['name'];
|
||||||
|
$url = $this->urlGenerator->linkToRoute('memories.Page.albums', ['id' => $idStr]);
|
||||||
|
|
||||||
|
return new RedirectResponse($url);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Browse anonymously if the album is accessed as a link
|
||||||
|
\OC_User::setIncognitoMode(true);
|
||||||
|
|
||||||
// Scripts
|
// Scripts
|
||||||
Util::addScript($this->appName, 'memories-main');
|
Util::addScript($this->appName, 'memories-main');
|
||||||
PageController::provideCommonInitialState($this->initialState);
|
PageController::provideCommonInitialState($this->initialState);
|
||||||
|
|
|
@ -207,18 +207,34 @@ trait TimelineQueryAlbums
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check in collaborators instead
|
// Check in collaborators instead
|
||||||
|
$albumNumId = (int) $album['album_id'];
|
||||||
|
if ($this->userIsAlbumCollaborator($uid, $albumNumId)) {
|
||||||
|
return $album;
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if user is a collaborator by numeric ID.
|
||||||
|
* Also checks if a group is a collaborator.
|
||||||
|
* Does not check if the user is the owner.
|
||||||
|
*
|
||||||
|
* @param string $uid User ID
|
||||||
|
* @param int $albumId Album ID (numeric)
|
||||||
|
*/
|
||||||
|
public function userIsAlbumCollaborator(string $uid, int $albumId): bool
|
||||||
|
{
|
||||||
$query = $this->connection->getQueryBuilder();
|
$query = $this->connection->getQueryBuilder();
|
||||||
$ids = $this->getSelfCollaborators($uid);
|
$ids = $this->getSelfCollaborators($uid);
|
||||||
$query->select('album_id')->from($this->collaboratorsTable())->where(
|
$query->select('album_id')->from($this->collaboratorsTable())->where(
|
||||||
$query->expr()->andX(
|
$query->expr()->andX(
|
||||||
$query->expr()->eq('album_id', $query->createNamedParameter($album['album_id'])),
|
$query->expr()->eq('album_id', $query->createNamedParameter($albumId, IQueryBuilder::PARAM_INT)),
|
||||||
$query->expr()->in('collaborator_id', $query->createNamedParameter($ids, IQueryBuilder::PARAM_STR_ARRAY)),
|
$query->expr()->in('collaborator_id', $query->createNamedParameter($ids, IQueryBuilder::PARAM_STR_ARRAY)),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (false !== $query->executeQuery()->fetchOne()) {
|
return false !== $query->executeQuery()->fetchOne();
|
||||||
return $album;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue