Merge branch 'master' of https://github.com/alchemy-fr/Phraseanet into PHRAS-2122-subview-setup-default-path

This commit is contained in:
aina-esokia
2018-07-20 17:44:58 +04:00
15 changed files with 2127 additions and 1954 deletions

View File

@@ -8,7 +8,7 @@ install_composer:
composer install composer install
install_asset_dependencies: install_asset_dependencies:
yarn yarn upgrade
./node_modules/.bin/gulp build ./node_modules/.bin/gulp build
install_assets: install_assets:

View File

@@ -12,6 +12,7 @@ namespace Alchemy\Phrasea\Controller;
use Alchemy\Phrasea\Application; use Alchemy\Phrasea\Application;
use Alchemy\Phrasea\Core\Configuration\StructureTemplate; use Alchemy\Phrasea\Core\Configuration\StructureTemplate;
use Alchemy\Phrasea\SearchEngine\Elastic\ElasticsearchOptions;
use Alchemy\Phrasea\Setup\RequirementCollectionInterface; use Alchemy\Phrasea\Setup\RequirementCollectionInterface;
use Alchemy\Phrasea\Setup\Requirements\BinariesRequirements; use Alchemy\Phrasea\Setup\Requirements\BinariesRequirements;
use Alchemy\Phrasea\Setup\Requirements\FilesystemRequirements; use Alchemy\Phrasea\Setup\Requirements\FilesystemRequirements;
@@ -82,6 +83,7 @@ class SetupController extends Controller
'locale' => $this->app['locale'], 'locale' => $this->app['locale'],
'available_locales' => Application::getAvailableLanguages(), 'available_locales' => Application::getAvailableLanguages(),
'available_templates' => $st->getNames(), 'available_templates' => $st->getNames(),
'elasticOptions' => ElasticsearchOptions::fromArray([]),
'warnings' => $warnings, 'warnings' => $warnings,
'error' => $request->query->get('error'), 'error' => $request->query->get('error'),
'current_servername' => $request->getScheme() . '://' . $request->getHttpHost() . '/', 'current_servername' => $request->getScheme() . '://' . $request->getHttpHost() . '/',
@@ -106,6 +108,20 @@ class SetupController extends Controller
$appbox_name = $request->request->get('ab_name'); $appbox_name = $request->request->get('ab_name');
$databox_name = $request->request->get('db_name'); $databox_name = $request->request->get('db_name');
$elastic_settings = $request->request->get('elasticsearch_settings');
$elastic_settings = [
'host' => (string) $elastic_settings['host'],
'port' => (int) $elastic_settings['port'],
'index' => (string) (isset($elastic_settings['index_name']) ? $elastic_settings['index_name'] : ''),
'shards' => (int) $elastic_settings['shards'],
'replicas' => (int) $elastic_settings['replicas'],
'minScore' => (int) $elastic_settings['min_score'],
'highlight' => (bool) (isset($elastic_settings['highlight']) ? $elastic_settings['highlight'] : false)
];
$elastic_settings = ElasticsearchOptions::fromArray($elastic_settings);
try { try {
$abInfo = [ $abInfo = [
'host' => $database_host, 'host' => $database_host,
@@ -181,6 +197,12 @@ class SetupController extends Controller
$this->app->getAuthenticator()->openAccount($user); $this->app->getAuthenticator()->openAccount($user);
if(empty($elastic_settings->getHost())){
$elastic_settings = ElasticsearchOptions::fromArray([]);
}
$this->app['conf']->set(['main', 'search-engine', 'options'], $elastic_settings->toArray());
return $this->app->redirectPath('admin', [ return $this->app->redirectPath('admin', [
'section' => 'taskmanager', 'section' => 'taskmanager',
'notice' => 'install_success', 'notice' => 'install_success',

View File

@@ -23,7 +23,7 @@ use Silex\ServiceProviderInterface;
class V1 extends Api implements ControllerProviderInterface, ServiceProviderInterface class V1 extends Api implements ControllerProviderInterface, ServiceProviderInterface
{ {
const VERSION = '1.5.0'; const VERSION = '2.0.0';
public static $extendedContentTypes = [ public static $extendedContentTypes = [
'json' => ['application/vnd.phraseanet.record-extended+json'], 'json' => ['application/vnd.phraseanet.record-extended+json'],

View File

@@ -94,8 +94,8 @@ class FtpPullJob extends AbstractJob
} }
$ftp = $app['phraseanet.ftp.client']($host, $port, 90, $ssl, $proxy, $proxyport); $ftp = $app['phraseanet.ftp.client']($host, $port, 90, $ssl, $proxy, $proxyport);
$ftp->passive($passive);
$ftp->login($user, $password); $ftp->login($user, $password);
$ftp->passive($passive);
$ftp->chdir($ftpPath); $ftp->chdir($ftpPath);
$list_1 = $ftp->list_directory(true); $list_1 = $ftp->list_directory(true);

View File

@@ -401,6 +401,10 @@ class ftpclient
$current_dir = $this->pwd(); $current_dir = $this->pwd();
$contents = ftp_rawlist($this->connexion, $current_dir, ! ! $recursive); $contents = ftp_rawlist($this->connexion, $current_dir, ! ! $recursive);
if($contents === false){
throw new Exception('Vérifier les paramètres ftp ou mettre en mode passive');
}
$list = []; $list = [];
foreach ($contents as $content) { foreach ($contents as $content) {

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2"> <xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2">
<file date="2018-06-13T12:45:59Z" source-language="en" target-language="de" datatype="plaintext" original="not.available"> <file date="2018-07-17T10:18:46Z" source-language="en" target-language="de" datatype="plaintext" original="not.available">
<header> <header>
<tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/> <tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/>
<note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note> <note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note>
@@ -10,8 +10,8 @@
<source>Please provide the same passwords.</source> <source>Please provide the same passwords.</source>
<target state="translated">Bitte geben Sie diesselbe Passwörter ein.</target> <target state="translated">Bitte geben Sie diesselbe Passwörter ein.</target>
<jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file> <jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
<jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file> <jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
</trans-unit> </trans-unit>
<trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore" approved="yes"> <trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore" approved="yes">
<source>The token provided is not valid anymore</source> <source>The token provided is not valid anymore</source>

View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2"> <xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2">
<file date="2018-06-13T12:46:41Z" source-language="en" target-language="en" datatype="plaintext" original="not.available"> <file date="2018-07-17T10:20:28Z" source-language="en" target-language="en" datatype="plaintext" original="not.available">
<header> <header>
<tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/> <tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/>
<note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note> <note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note>
@@ -10,8 +10,8 @@
<source>Please provide the same passwords.</source> <source>Please provide the same passwords.</source>
<target state="translated">Please provide the same passwords.</target> <target state="translated">Please provide the same passwords.</target>
<jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file> <jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
<jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file> <jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
</trans-unit> </trans-unit>
<trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore" approved="yes"> <trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore" approved="yes">
<source>The token provided is not valid anymore</source> <source>The token provided is not valid anymore</source>

View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2"> <xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2">
<file date="2018-06-13T12:47:30Z" source-language="en" target-language="fr" datatype="plaintext" original="not.available"> <file date="2018-07-17T10:22:17Z" source-language="en" target-language="fr" datatype="plaintext" original="not.available">
<header> <header>
<tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/> <tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/>
<note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note> <note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note>
@@ -10,8 +10,8 @@
<source>Please provide the same passwords.</source> <source>Please provide the same passwords.</source>
<target state="translated">Veuillez indiquer des mots de passe identiques.</target> <target state="translated">Veuillez indiquer des mots de passe identiques.</target>
<jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file> <jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
<jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file> <jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
</trans-unit> </trans-unit>
<trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore" approved="yes"> <trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore" approved="yes">
<source>The token provided is not valid anymore</source> <source>The token provided is not valid anymore</source>

View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2"> <xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:jms="urn:jms:translation" version="1.2">
<file date="2018-06-13T12:48:25Z" source-language="en" target-language="nl" datatype="plaintext" original="not.available"> <file date="2018-07-17T10:24:11Z" source-language="en" target-language="nl" datatype="plaintext" original="not.available">
<header> <header>
<tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/> <tool tool-id="JMSTranslationBundle" tool-name="JMSTranslationBundle" tool-version="1.1.0-DEV"/>
<note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note> <note>The source node in most cases contains the sample message as written by the developer. If it looks like a dot-delimitted string such as "form.label.firstname", then the developer has not provided a default message.</note>
@@ -10,8 +10,8 @@
<source>Please provide the same passwords.</source> <source>Please provide the same passwords.</source>
<target state="new">Please provide the same passwords.</target> <target state="new">Please provide the same passwords.</target>
<jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file> <jms:reference-file line="44">Form/Login/PhraseaRecoverPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
<jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file> <jms:reference-file line="36">Form/Login/PhraseaRenewPasswordForm.php</jms:reference-file>
<jms:reference-file line="49">Form/Login/PhraseaRegisterForm.php</jms:reference-file>
</trans-unit> </trans-unit>
<trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore"> <trans-unit id="90b8c9717bb7ed061dbf20fe1986c8b8593d43d4" resname="The token provided is not valid anymore">
<source>The token provided is not valid anymore</source> <source>The token provided is not valid anymore</source>

View File

@@ -375,7 +375,7 @@
<div class="PNB10 wrapper_left"> <div class="PNB10 wrapper_left">
<div class="PNB10 section_title"> <div class="PNB10 section_title">
<h2> <h2>
1/5 {{ 'Executables externes' | trans }} 1/6 {{ 'Executables externes' | trans }}
</h2> </h2>
</div> </div>
<div class="PNB10" style="top:50px;overflow-x:hidden;"> <div class="PNB10" style="top:50px;overflow-x:hidden;">
@@ -440,7 +440,7 @@
<div class="wrapper"> <div class="wrapper">
<div class="PNB10 wrapper_left"> <div class="PNB10 wrapper_left">
<div class="PNB10 section_title"> <div class="PNB10 section_title">
<h2>2/5 <h2>2/6
{{ 'Creation de votre compte' | trans }} {{ 'Creation de votre compte' | trans }}
</h2> </h2>
</div> </div>
@@ -536,7 +536,7 @@
<div class="PNB10 wrapper_left"> <div class="PNB10 wrapper_left">
<div class="PNB10 section_title"> <div class="PNB10 section_title">
<h2> <h2>
3/5 3/6
{% trans %}setup::Configuration de la base de compte ApplicationBox{% endtrans %} {% trans %}setup::Configuration de la base de compte ApplicationBox{% endtrans %}
</h2> </h2>
</div> </div>
@@ -637,13 +637,78 @@
</div> </div>
<div class="steps">
<div class="wrapper">
<div class="PNB10 wrapper_left">
<div class="PNB10 section_title">
<h2>4/6
{{ 'SearchEngine settings' | trans }}
</h2>
</div>
<div class="PNB10" style="top:50px;overflow-x:hidden;">
<table class="main_content_wrapper">
<tr>
<td>
<table class="main_content_table">
<tr>
<td><label>{{ 'ElasticSearch server host' | trans }}</label></td>
<td><input class="" type="text" name="elasticsearch_settings[host]" value="{{ elasticOptions.host }}" /></td>
</tr>
<tr>
<td><label>{{ 'ElasticSearch service port' | trans }}</label></td>
<td><input class="" type="number" name="elasticsearch_settings[port]" value="{{ elasticOptions.port }}" /></td>
</tr>
<tr>
<td><label>{{ 'Use an existing index' | trans }}</label></td>
<td><input class="" type="checkbox" name="elasticsearch_settings[use_existing_index]" value="" /></td>
</tr>
<tr>
<td><label>{{ 'ElasticSearch index name' | trans }}</label></td>
<td><input class="" disabled="disabled" type="text" name="elasticsearch_settings[index_name]" value="{{ elasticOptions.indexName }}" /></td>
</tr>
<tr>
<td><label>{{ 'Number of shards' | trans }}</label></td>
<td><input class="" type="number" name="elasticsearch_settings[shards]" value="{{ elasticOptions.shards }}" /></td>
</tr>
<tr>
<td><label>{{ 'Number of replicas' | trans }}</label></td>
<td><input class="" type="number" name="elasticsearch_settings[replicas]" value="{{ elasticOptions.replicas }}" /></td>
</tr>
<tr>
<td><label>{{ 'Thesaurus Min score' | trans }}</label></td>
<td><input class="" type="number" name="elasticsearch_settings[min_score]" value="{{ elasticOptions.minScore }}" /></td>
</tr>
<tr>
<td><label>{{ 'Activate highlight' | trans }}</label></td>
<td><input class="" type="checkbox" name="elasticsearch_settings[highlight]" value="{{ elasticOptions.highlight }}" {% if elasticOptions.highlight %} checked="checked" {% endif %}/></td>
</tr>
</table>
</td>
</tr>
</table>
</div>
</div>
</div>
<div class="buttons">
<table>
<tr>
<td>
<button class="previous">{{ 'boutton::precedent' | trans }}</button>
</td>
<td style="text-align:right;">
<button class="next">{{ 'boutton::suivant' | trans }}</button>
</td>
</tr>
</table>
</div>
</div>
<div class="steps"> <div class="steps">
<div class="wrapper"> <div class="wrapper">
<div class="PNB10 wrapper_left"> <div class="PNB10 wrapper_left">
<div class="PNB10 section_title"> <div class="PNB10 section_title">
<h2>4/5 <h2>5/6
{{ 'setup::Configuration des repertoires de stockage' | trans }} {{ 'setup::Configuration des repertoires de stockage' | trans }}
</h2> </h2>
</div> </div>
@@ -702,7 +767,7 @@
<div class="wrapper"> <div class="wrapper">
<div class="PNB10 wrapper_left"> <div class="PNB10 wrapper_left">
<div class="PNB10 section_title"> <div class="PNB10 section_title">
<h2>5/5 <h2>6/6
{% trans %}setup::Configuration de la base de stockage DataBox{% endtrans %} {% trans %}setup::Configuration de la base de stockage DataBox{% endtrans %}
</h2> </h2>
</div> </div>
@@ -739,7 +804,7 @@
<td> <td>
<select name="db_template" class="databox_creation_input"> <select name="db_template" class="databox_creation_input">
{% for name in available_templates %} {% for name in available_templates %}
<option value="{{ name|escape('js') }}">{{ name }}</option> <option value="{{ name|escape }}">{{ name }}</option>
{% endfor %} {% endfor %}
</select> </select>
</td> </td>

View File

@@ -58,7 +58,7 @@
<tr style="vertical-align:bottom;"> <tr style="vertical-align:bottom;">
<td> <td>
<h1> <h1>
PHRASEANET Phraseanet
<span class="version_name">{{ app['phraseanet.version'].getName() }}</span> <span class="version_name">{{ app['phraseanet.version'].getName() }}</span>
<span class="version_number">- v{{ app['phraseanet.version'].getNumber() }}</span> <span class="version_number">- v{{ app['phraseanet.version'].getNumber() }}</span>
</h1> </h1>