mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00

Conflicts: CHANGELOG.md bin/console bin/developer bin/setup bower.json composer.json composer.lock features/bootstrap/FeatureContext.php features/bootstrap/GuiContext.php lib/Alchemy/Phrasea/Authentication/Token/TokenValidator.php lib/Alchemy/Phrasea/Command/BuildMissingSubdefs.php lib/Alchemy/Phrasea/Command/CreateCollection.php lib/Alchemy/Phrasea/Command/Developer/JavascriptBuilder.php lib/Alchemy/Phrasea/Controller/Admin/Collection.php lib/Alchemy/Phrasea/Controller/Admin/Databoxes.php lib/Alchemy/Phrasea/Controller/Admin/TaskManager.php lib/Alchemy/Phrasea/Controller/Api/V1.php lib/Alchemy/Phrasea/Controller/Client/Baskets.php lib/Alchemy/Phrasea/Controller/Client/Root.php lib/Alchemy/Phrasea/Controller/Prod/Basket.php lib/Alchemy/Phrasea/Controller/Prod/Export.php lib/Alchemy/Phrasea/Controller/Prod/Property.php lib/Alchemy/Phrasea/Controller/Prod/Records.php lib/Alchemy/Phrasea/Controller/Prod/Tools.php lib/Alchemy/Phrasea/Controller/Prod/Upload.php lib/Alchemy/Phrasea/Controller/Root/Login.php lib/Alchemy/Phrasea/Controller/Thesaurus/Thesaurus.php lib/Alchemy/Phrasea/Core/Event/ApiLoadEndEvent.php lib/Alchemy/Phrasea/Core/Event/ApiLoadStartEvent.php lib/Alchemy/Phrasea/Core/Provider/TaskManagerServiceProvider.php lib/Alchemy/Phrasea/Core/Version.php lib/Alchemy/Phrasea/Exception/XMLParseErrorException.php lib/Alchemy/Phrasea/Helper/DatabaseHelper.php lib/Alchemy/Phrasea/Helper/User/Edit.php lib/Alchemy/Phrasea/SearchEngine/Phrasea/PhraseaEngine.php lib/Alchemy/Phrasea/SearchEngine/SearchEngineOptions.php lib/Doctrine/Entities/AuthFailure.php lib/Doctrine/Entities/Basket.php lib/Doctrine/Entities/BasketElement.php lib/Doctrine/Entities/LazaretAttribute.php lib/Doctrine/Entities/LazaretCheck.php lib/Doctrine/Entities/LazaretFile.php lib/Doctrine/Entities/LazaretSession.php lib/Doctrine/Entities/Session.php lib/Doctrine/Entities/SessionModule.php lib/Doctrine/Entities/StoryWZ.php lib/Doctrine/Entities/UsrList.php lib/Doctrine/Entities/UsrListEntry.php lib/Doctrine/Entities/UsrListOwner.php lib/Doctrine/Entities/ValidationData.php lib/Doctrine/Entities/ValidationParticipant.php lib/Doctrine/Entities/ValidationSession.php lib/Doctrine/Logger/MonologSQLLogger.php lib/Doctrine/Repositories/BasketRepository.php lib/Doctrine/Repositories/ValidationParticipantRepository.php lib/Doctrine/Types/Binary.php lib/Doctrine/Types/Blob.php lib/Doctrine/Types/Enum.php lib/Doctrine/Types/LongBlob.php lib/Doctrine/Types/VarBinary.php lib/classes/API/OAuth2/Account.php lib/classes/API/OAuth2/Application.php lib/classes/API/OAuth2/Application/OfficePlugin.php lib/classes/API/OAuth2/AuthCode.php lib/classes/API/OAuth2/RefreshToken.php lib/classes/API/OAuth2/Token.php lib/classes/API/V1/Abstract.php lib/classes/API/V1/Interface.php lib/classes/API/V1/adapter.php lib/classes/API/V1/exception/abstract.php lib/classes/API/V1/exception/badrequest.php lib/classes/API/V1/exception/forbidden.php lib/classes/API/V1/exception/internalservererror.php lib/classes/API/V1/exception/maintenance.php lib/classes/API/V1/exception/methodnotallowed.php lib/classes/API/V1/exception/notfound.php lib/classes/API/V1/exception/unauthorized.php lib/classes/API/V1/result.php lib/classes/Exception/Feed/EntryNotFound.php lib/classes/Exception/Feed/ItemNotFound.php lib/classes/Exception/Feed/PublisherNotFound.php lib/classes/Feed/Abstract.php lib/classes/Feed/Adapter.php lib/classes/Feed/Aggregate.php lib/classes/Feed/Collection.php lib/classes/Feed/CollectionInterface.php lib/classes/Feed/Entry/Adapter.php lib/classes/Feed/Entry/Collection.php lib/classes/Feed/Entry/CollectionInterface.php lib/classes/Feed/Entry/Interface.php lib/classes/Feed/Entry/Item.php lib/classes/Feed/Entry/ItemInterface.php lib/classes/Feed/Interface.php lib/classes/Feed/Link.php lib/classes/Feed/LinkInterface.php lib/classes/Feed/Publisher/Adapter.php lib/classes/Feed/Publisher/Interface.php lib/classes/Feed/Token.php lib/classes/Feed/TokenAggregate.php lib/classes/Feed/XML/Abstract.php lib/classes/Feed/XML/Atom.php lib/classes/Feed/XML/Cooliris.php lib/classes/Feed/XML/Interface.php lib/classes/Feed/XML/RSS.php lib/classes/Feed/XML/RSS/Image.php lib/classes/Feed/XML/RSS/ImageInterface.php lib/classes/User/Adapter.php lib/classes/User/Interface.php lib/classes/appbox/register.php lib/classes/connection.php lib/classes/connection/abstract.php lib/classes/connection/interface.php lib/classes/connection/pdo.php lib/classes/connection/pdoStatementDebugger.php lib/classes/deprecated/countries.php lib/classes/deprecated/inscript.api.php lib/classes/eventsmanager/event/test.php lib/classes/ftpclient.php lib/classes/http/request.php lib/classes/media/subdef.php lib/classes/module/console/schedulerStart.php lib/classes/module/console/schedulerState.php lib/classes/module/console/schedulerStop.php lib/classes/module/console/taskState.php lib/classes/module/console/tasklist.php lib/classes/module/console/taskrun.php lib/classes/patch/320alpha4b.php lib/classes/patch/3715alpha1a.php lib/classes/patch/379alpha1a.php lib/classes/patch/380alpha10a.php lib/classes/patch/380alpha11a.php lib/classes/patch/380alpha13a.php lib/classes/patch/380alpha14a.php lib/classes/patch/380alpha15a.php lib/classes/patch/380alpha16a.php lib/classes/patch/380alpha17a.php lib/classes/patch/380alpha18a.php lib/classes/patch/380alpha3a.php lib/classes/patch/380alpha4a.php lib/classes/patch/380alpha6a.php lib/classes/patch/380alpha8a.php lib/classes/patch/380alpha9a.php lib/classes/patch/381alpha1b.php lib/classes/patch/381alpha2a.php lib/classes/patch/381alpha3a.php lib/classes/patch/381alpha4a.php lib/classes/patch/383alpha1a.php lib/classes/patch/383alpha2a.php lib/classes/patch/383alpha3a.php lib/classes/patch/383alpha4a.php lib/classes/record/adapter.php lib/classes/record/preview.php lib/classes/recordutils.php lib/classes/recordutils/audio.php lib/classes/recordutils/document.php lib/classes/recordutils/map.php lib/classes/recordutils/video.php lib/classes/registry.php lib/classes/registryInterface.php lib/classes/set/order.php lib/classes/system/url.php lib/classes/task/Scheduler.php lib/classes/task/appboxAbstract.php lib/classes/task/databoxAbstract.php lib/classes/task/manager.php lib/classes/task/period/RecordMover.php lib/classes/task/period/apibridge.php lib/classes/task/period/apiwebhooks.php lib/classes/task/period/archive.php lib/classes/task/period/cindexer.php lib/classes/task/period/emptyColl.php lib/classes/task/period/ftp.php lib/classes/task/period/ftpPull.php lib/classes/task/period/subdef.php lib/classes/task/period/test.php lib/classes/task/period/writemeta.php lib/conf.d/PhraseaFixture/AbstractWZ.php lib/conf.d/PhraseaFixture/Basket/LoadFiveBaskets.php lib/conf.d/PhraseaFixture/Basket/LoadOneBasket.php lib/conf.d/PhraseaFixture/Basket/LoadOneBasketEnv.php lib/conf.d/PhraseaFixture/Lazaret/LoadOneFile.php lib/conf.d/PhraseaFixture/Story/LoadOneStory.php lib/conf.d/PhraseaFixture/UsrLists/ListAbstract.php lib/conf.d/PhraseaFixture/UsrLists/UsrList.php lib/conf.d/PhraseaFixture/UsrLists/UsrListEntry.php lib/conf.d/PhraseaFixture/UsrLists/UsrListOwner.php lib/conf.d/PhraseaFixture/ValidationParticipant/LoadOneParticipant.php lib/conf.d/PhraseaFixture/ValidationParticipant/LoadParticipantWithSession.php lib/conf.d/PhraseaFixture/ValidationSession/LoadOneValidationSession.php templates/web/admin/collection/collection.html.twig templates/web/common/dialog_export.html.twig templates/web/common/menubar.html.twig templates/web/prod/actions/Tools/index.html.twig templates/web/prod/index.html.twig templates/web/prod/upload/upload-flash.html.twig templates/web/prod/upload/upload.html.twig templates/web/report/report_layout_child.html.twig templates/web/setup/step2.html.twig templates/web/thesaurus/new-synonym-dialog.html.twig templates/web/thesaurus/properties.html.twig templates/web/thesaurus/search.html.twig tests/Alchemy/Tests/Phrasea/Application/ApiAbstract.php tests/Alchemy/Tests/Phrasea/Cache/FactoryTest.php tests/Alchemy/Tests/Phrasea/Controller/Admin/AdminCollectionTest.php tests/Alchemy/Tests/Phrasea/Controller/Client/RootTest.php
416 lines
10 KiB
PHP
416 lines
10 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2015 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
use Alchemy\Phrasea\Application;
|
|
use Alchemy\Phrasea\Exception\RuntimeException;
|
|
use Alchemy\Phrasea\Model\Manipulator\TokenManipulator;
|
|
use Doctrine\DBAL\DBALException;
|
|
use Guzzle\Http\Url;
|
|
|
|
class media_Permalink_Adapter implements media_Permalink_Interface, cache_cacheableInterface
|
|
{
|
|
/**
|
|
*
|
|
* @var databox
|
|
*/
|
|
protected $databox;
|
|
|
|
/**
|
|
*
|
|
* @var media_subdef
|
|
*/
|
|
protected $media_subdef;
|
|
|
|
/**
|
|
*
|
|
* @var int
|
|
*/
|
|
protected $id;
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $token;
|
|
|
|
/**
|
|
*
|
|
* @var boolean
|
|
*/
|
|
protected $is_activated;
|
|
|
|
/**
|
|
*
|
|
* @var DateTime
|
|
*/
|
|
protected $created_on;
|
|
|
|
/**
|
|
*
|
|
* @var DateTime
|
|
*/
|
|
protected $last_modified;
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $label;
|
|
protected $app;
|
|
|
|
/**
|
|
*
|
|
* @param databox $databox
|
|
* @param media_subdef $media_subdef
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
protected function __construct(Application $app, databox $databox, media_subdef $media_subdef)
|
|
{
|
|
$this->app = $app;
|
|
$this->databox = $databox;
|
|
$this->media_subdef = $media_subdef;
|
|
|
|
$this->load();
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return int
|
|
*/
|
|
public function get_id()
|
|
{
|
|
return $this->id;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_token()
|
|
{
|
|
return $this->token;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public function get_is_activated()
|
|
{
|
|
return $this->is_activated;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return DateTime
|
|
*/
|
|
public function get_created_on()
|
|
{
|
|
return $this->created_on;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return DateTime
|
|
*/
|
|
public function get_last_modified()
|
|
{
|
|
return $this->last_modified;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_label()
|
|
{
|
|
return $this->label;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return Url
|
|
*/
|
|
public function get_url()
|
|
{
|
|
$label = $this->get_label() . '.' . pathinfo($this->media_subdef->get_file(), PATHINFO_EXTENSION);
|
|
|
|
return Url::factory($this->app->url('permalinks_permalink', [
|
|
'sbas_id' => $this->media_subdef->get_sbas_id(),
|
|
'record_id' => $this->media_subdef->get_record_id(),
|
|
'subdef' => $this->media_subdef->get_name(),
|
|
/** @Ignore */
|
|
'label' => $label,
|
|
'token' => $this->get_token(),
|
|
]));
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_page()
|
|
{
|
|
return $this->app->url('permalinks_permaview', [
|
|
'sbas_id' => $this->media_subdef->get_sbas_id(),
|
|
'record_id' => $this->media_subdef->get_record_id(),
|
|
'subdef' => $this->media_subdef->get_name(),
|
|
'token' => $this->get_token(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $token
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
protected function set_token($token)
|
|
{
|
|
$this->token = $token;
|
|
|
|
$sql = 'UPDATE permalinks SET token = :token, last_modified = NOW()
|
|
WHERE id = :id';
|
|
$stmt = $this->databox->get_connection()->prepare($sql);
|
|
$stmt->execute([':token' => $this->token, ':id' => $this->get_id()]);
|
|
$stmt->closeCursor();
|
|
|
|
$this->delete_data_from_cache();
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $is_activated
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
public function set_is_activated($is_activated)
|
|
{
|
|
$this->is_activated = ! ! $is_activated;
|
|
|
|
$sql = 'UPDATE permalinks SET activated = :activated, last_modified = NOW()
|
|
WHERE id = :id';
|
|
$stmt = $this->databox->get_connection()->prepare($sql);
|
|
|
|
$params = [
|
|
':activated' => $this->is_activated,
|
|
':id' => $this->get_id()
|
|
];
|
|
|
|
$stmt->execute($params);
|
|
$stmt->closeCursor();
|
|
|
|
$this->delete_data_from_cache();
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $label
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
public function set_label($label)
|
|
{
|
|
$label = trim($label) ? trim($label) : 'untitled';
|
|
while (strpos($label, ' ') !== false)
|
|
$label = str_replace(' ', ' ', $label);
|
|
|
|
$this->label = $this->app['unicode']->remove_nonazAZ09(
|
|
str_replace(' ', '-', $label)
|
|
);
|
|
|
|
$sql = 'UPDATE permalinks SET label = :label, last_modified = NOW()
|
|
WHERE id = :id';
|
|
$stmt = $this->databox->get_connection()->prepare($sql);
|
|
$stmt->execute([':label' => $this->label, ':id' => $this->get_id()]);
|
|
$stmt->closeCursor();
|
|
|
|
$this->delete_data_from_cache();
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
protected function load()
|
|
{
|
|
try {
|
|
$datas = $this->get_data_from_cache();
|
|
$this->id = $datas['id'];
|
|
$this->token = $datas['token'];
|
|
$this->is_activated = $datas['is_activated'];
|
|
$this->created_on = $datas['created_on'];
|
|
$this->last_modified = $datas['last_modified'];
|
|
$this->label = $datas['label'];
|
|
|
|
return $this;
|
|
} catch (\Exception $e) {
|
|
|
|
}
|
|
|
|
$sql = '
|
|
SELECT p.id, p.token, p.activated, p.created_on, p.last_modified, p.label
|
|
FROM permalinks p
|
|
WHERE p.subdef_id = :subdef_id';
|
|
$stmt = $this->databox->get_connection()->prepare($sql);
|
|
$stmt->execute([':subdef_id' => $this->media_subdef->get_subdef_id()]);
|
|
$row = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
|
|
if (!$row) {
|
|
throw new Exception_Media_SubdefNotFound ();
|
|
}
|
|
|
|
$this->id = (int) $row['id'];
|
|
$this->token = $row['token'];
|
|
$this->is_activated = ! ! $row['activated'];
|
|
$this->created_on = new DateTime($row['created_on']);
|
|
$this->last_modified = new DateTime($row['last_modified']);
|
|
$this->label = $row['label'];
|
|
|
|
$datas = [
|
|
'id' => $this->id,
|
|
'token' => $this->token,
|
|
'is_activated' => $this->is_activated,
|
|
'created_on' => $this->created_on,
|
|
'last_modified' => $this->last_modified,
|
|
/** @Ignore */
|
|
'label' => $this->label,
|
|
];
|
|
|
|
$this->set_data_to_cache($datas);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param Application $app
|
|
* @param databox $databox
|
|
* @param media_subdef $media_subdef
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
public static function getPermalink(Application $app, databox $databox, media_subdef $media_subdef)
|
|
{
|
|
try {
|
|
return new self($app, $databox, $media_subdef);
|
|
} catch (\Exception $e) {
|
|
|
|
}
|
|
|
|
return self::create($app, $databox, $media_subdef);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param Application $app
|
|
* @param databox $databox
|
|
* @param media_subdef $media_subdef
|
|
* @return media_Permalink_Adapter
|
|
*/
|
|
public static function create(Application $app, databox $databox, media_subdef $media_subdef)
|
|
{
|
|
$sql = 'INSERT INTO permalinks
|
|
(id, subdef_id, token, activated, created_on, last_modified, label)
|
|
VALUES (null, :subdef_id, :token, :activated, NOW(), NOW(), "")';
|
|
|
|
$params = [
|
|
':subdef_id' => $media_subdef->get_subdef_id()
|
|
, ':token' => $app['random.medium']->generateString(64, TokenManipulator::LETTERS_AND_NUMBERS)
|
|
, ':activated' => '1'
|
|
];
|
|
|
|
$error = null;
|
|
$stmt = $databox->get_connection()->prepare($sql);
|
|
try {
|
|
$stmt->execute($params);
|
|
} catch (DBALException $e) {
|
|
$error = $e;
|
|
}
|
|
$stmt->closeCursor();
|
|
|
|
if ($error) {
|
|
throw new RuntimeException('Permalink already exists', $e->getCode(), $e);
|
|
}
|
|
|
|
$permalink = self::getPermalink($app, $databox, $media_subdef);
|
|
$permalink->set_label(strip_tags($media_subdef->get_record()->get_title(false, null, true)));
|
|
|
|
return $permalink;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param Application $app
|
|
* @param databox $databox
|
|
* @param string $token
|
|
* @param int $record_id
|
|
* @param string $name
|
|
* @return record_adapter
|
|
*/
|
|
public static function challenge_token(Application $app, databox $databox, $token, $record_id, $name)
|
|
{
|
|
$sql = 'SELECT p.id
|
|
FROM permalinks p
|
|
INNER JOIN subdef s
|
|
ON (s.subdef_id = p.subdef_id)
|
|
WHERE s.record_id = :record_id
|
|
AND s.name = :name
|
|
AND activated = "1"
|
|
AND token = :token';
|
|
|
|
$params = [
|
|
':record_id' => $record_id
|
|
, ':token' => $token
|
|
, ':name' => $name
|
|
];
|
|
|
|
$stmt = $databox->get_connection()->prepare($sql);
|
|
$stmt->execute($params);
|
|
|
|
$row = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
|
|
$stmt->closeCursor();
|
|
unset($stmt);
|
|
|
|
if ($row) {
|
|
return new record_adapter($app, $databox->get_sbas_id(), $record_id);
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
public function get_cache_key($option = null)
|
|
{
|
|
return 'permalink_' . $this->media_subdef->get_subdef_id() . ($option ? '_' . $option : '');
|
|
}
|
|
|
|
public function get_data_from_cache($option = null)
|
|
{
|
|
return $this->databox->get_data_from_cache($this->get_cache_key($option));
|
|
}
|
|
|
|
public function set_data_to_cache($value, $option = null, $duration = 0)
|
|
{
|
|
return $this->databox->set_data_to_cache($value, $this->get_cache_key($option), $duration);
|
|
}
|
|
|
|
public function delete_data_from_cache($option = null)
|
|
{
|
|
return $this->databox->delete_data_from_cache($this->get_cache_key($option));
|
|
}
|
|
}
|