Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormattpiwik <matthieu.aubry@gmail.com>2011-01-03 08:49:45 +0300
committermattpiwik <matthieu.aubry@gmail.com>2011-01-03 08:49:45 +0300
commit956c25213d771f37f7ed51bd56b0788be05e6603 (patch)
tree83533901bd264f738f77350755112e9b304efe6e
parent97d410fd5c78155ea744a1b0fe6aae074e5f72bb (diff)
Various code cleanups and small improvements:
* Live! widget shows IP for all users except anonymous * Widgetize displays full URL to the widget + preview link below widget * Live! visitors text change from "Today" to "Last 24 hours" in preview * remove data_push feature introduced in r1330 + removing campaign redirect feature since they are not used * all errors should now display the Piwik header when applicable (or if a php error, prefixed with a sentence suggesting to submit error in piwik forums) * fixing bug with cookie update when a visitor manually converts the same goal in the same second * fixing XML output not valid in Chrome (HTML entities not valid, must use XML entities) * simplifying + refactoring the truncation code in datatables.js (move from JS to small smarty template - hopefully we can fix this truncation and make it nice soon) * removing unnecessary line breaks from translations * refactoring duplicate code in renderers git-svn-id: http://dev.piwik.org/svn/trunk@3565 59fd770c-687e-43c8-a1e3-f5a4ff64c105
-rw-r--r--core/API/ResponseBuilder.php2
-rw-r--r--core/Archive/Array.php19
-rw-r--r--core/Archive/Array/IndexedByDate.php2
-rw-r--r--core/Archive/Array/IndexedBySite.php5
-rw-r--r--core/Common.php3
-rw-r--r--core/Controller.php2
-rw-r--r--core/DataTable/Renderer.php23
-rw-r--r--core/DataTable/Renderer/Console.php4
-rw-r--r--core/DataTable/Renderer/Csv.php4
-rw-r--r--core/DataTable/Renderer/Html.php21
-rw-r--r--core/DataTable/Renderer/Json.php6
-rw-r--r--core/DataTable/Renderer/Php.php10
-rw-r--r--core/DataTable/Renderer/Rss.php19
-rw-r--r--core/DataTable/Renderer/Xml.php32
-rw-r--r--core/FrontController.php4
-rw-r--r--core/Log.php6
-rw-r--r--core/Log/Error.php10
-rw-r--r--core/Piwik.php31
-rw-r--r--core/SmartyPlugins/function.url.php2
-rw-r--r--core/SmartyPlugins/modifier.escape.php2
-rw-r--r--core/SmartyPlugins/modifier.urlRewriteBasicView.php2
-rw-r--r--core/SmartyPlugins/modifier.urlRewriteWithParameters.php2
-rw-r--r--core/Tracker.php64
-rw-r--r--core/Tracker/Visit.php23
-rw-r--r--core/Url.php3
-rw-r--r--core/View.php12
-rw-r--r--core/ViewDataTable.php23
-rw-r--r--core/ViewDataTable/Cloud.php1
-rw-r--r--core/ViewDataTable/GenerateGraphData.php1
-rw-r--r--core/ViewDataTable/GenerateGraphData/ChartEvolution.php11
-rw-r--r--core/ViewDataTable/GenerateGraphHTML.php9
-rw-r--r--core/testMinimumPhpVersion.php1
-rw-r--r--libs/PiwikTracker/PiwikTracker.php4
-rw-r--r--plugins/API/API.php2
-rw-r--r--plugins/Actions/API.php1
-rw-r--r--plugins/CoreHome/Controller.php2
-rw-r--r--plugins/CoreHome/templates/datatable.js48
-rw-r--r--plugins/CoreHome/templates/datatable.tpl14
-rw-r--r--plugins/CoreHome/templates/datatable_actions.tpl11
-rw-r--r--plugins/CoreHome/templates/datatable_actions_recursive.tpl16
-rw-r--r--plugins/CoreHome/templates/datatable_actions_subdatable.tpl3
-rw-r--r--plugins/CoreHome/templates/datatable_cell.tpl17
-rw-r--r--plugins/CoreHome/templates/datatable_js.tpl2
-rw-r--r--plugins/CoreHome/templates/header_message.tpl3
-rw-r--r--plugins/CoreHome/templates/js_global_variables.tpl4
-rw-r--r--plugins/CoreHome/templates/menu.tpl2
-rw-r--r--plugins/Dashboard/Controller.php13
-rw-r--r--plugins/ExampleAPI/tests/compareExpectedAndProcessedFiles.WinMerge12
-rw-r--r--plugins/ExampleAPI/tests/expected/test_allGetMethods__ExampleAPI.getMultiArray.xml2
-rw-r--r--plugins/ExamplePlugin/ExamplePlugin.php10
-rw-r--r--plugins/ExamplePlugin/lang/en.php1
-rw-r--r--plugins/Feedback/Controller.php2
-rw-r--r--plugins/Goals/API.php1
-rw-r--r--plugins/Goals/Controller.php14
-rw-r--r--plugins/Goals/Goals.php4
-rw-r--r--plugins/Installation/Controller.php5
-rw-r--r--plugins/Installation/templates/systemCheck.tpl2
-rw-r--r--plugins/LanguagesManager/tests/LanguagesManager.test.php23
-rw-r--r--plugins/Live/API.php3
-rw-r--r--plugins/Live/Controller.php7
-rw-r--r--plugins/Live/Live.php5
-rw-r--r--plugins/Live/templates/lastVisits.tpl6
-rw-r--r--plugins/Live/templates/totalVisits.tpl2
-rw-r--r--plugins/Live/templates/visitorLog.tpl18
-rw-r--r--plugins/Login/Auth.php16
-rw-r--r--plugins/Login/Controller.php4
-rw-r--r--plugins/Login/tests/Login.test.php30
-rw-r--r--plugins/MultiSites/templates/index.tpl6
-rw-r--r--plugins/SEO/Controller.php5
-rw-r--r--plugins/SEO/templates/index.tpl7
-rw-r--r--plugins/SitesManager/API.php6
-rw-r--r--plugins/SitesManager/Controller.php4
-rw-r--r--plugins/UsersManager/Controller.php3
-rw-r--r--plugins/Widgetize/Controller.php6
-rw-r--r--plugins/Widgetize/templates/widgetize.js8
-rw-r--r--tests/core/Common.test.php21
-rw-r--r--tests/integration/Main.test.php3
-rw-r--r--tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getAvailableLanguageNames.xml198
-rw-r--r--tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getTranslationsForLanguage.xml4907
79 files changed, 5498 insertions, 344 deletions
diff --git a/core/API/ResponseBuilder.php b/core/API/ResponseBuilder.php
index de8af21d02..669fd91327 100644
--- a/core/API/ResponseBuilder.php
+++ b/core/API/ResponseBuilder.php
@@ -383,7 +383,7 @@ class Piwik_API_ResponseBuilder
}
} else {
$xml.= $marginLeft .
- "<$key>".$value."</$key>\n";
+ "<$key>".Piwik_DataTable_Renderer::formatValueXml($value)."</$key>\n";
}
}
return $xml;
diff --git a/core/Archive/Array.php b/core/Archive/Array.php
index a31e1cffa6..5d5547f84b 100644
--- a/core/Archive/Array.php
+++ b/core/Archive/Array.php
@@ -171,18 +171,23 @@ abstract class Piwik_Archive_Array extends Piwik_Archive
}
/**
- * Takes a list of fields defining numeric values and returns a quoted string
- * of the field names fit to be used in the where clause of a SQL Query
+ * Takes a list of fields defining numeric values and returns the corresponding
+ * unnamed parameters to be bound to the field names in the where clause of a SQL query
*
- * @param array|string $fields array( fieldName1, fieldName2, ...) Names of the mysql table fields to load
- * @return String
+ * @param array|string $fields array( fieldName1, fieldName2, fieldName3) Names of the mysql table fields to load
+ * @return string "?, ?, ?"
*/
public static function getSqlStringFieldsArray( $fields )
{
- if(!is_array($fields))
+ if(is_string($fields))
{
- return "'$fields'";
+ $fields = array($fields);
}
- return "'" . implode("', '",$fields) . "'";
+ $count = count($fields);
+ if($count == 0)
+ {
+ return "''";
+ }
+ return '?'.str_repeat(',?', $count-1);
}
}
diff --git a/core/Archive/Array/IndexedByDate.php b/core/Archive/Array/IndexedByDate.php
index 173854b715..319e3382d5 100644
--- a/core/Archive/Array/IndexedByDate.php
+++ b/core/Archive/Array/IndexedByDate.php
@@ -109,7 +109,7 @@ class Piwik_Archive_Array_IndexedByDate extends Piwik_Archive_Array
FROM $table
WHERE idarchive IN ( $inIds )
AND name IN ( $inNames )";
- $values = $db->fetchAll($sql);
+ $values = $db->fetchAll($sql, $fields);
foreach($values as $value)
{
$timestamp = Piwik_Date::factory($value['startDate'])->getTimestamp();
diff --git a/core/Archive/Array/IndexedBySite.php b/core/Archive/Array/IndexedBySite.php
index a5ec51ad04..0b2e76e129 100644
--- a/core/Archive/Array/IndexedBySite.php
+++ b/core/Archive/Array/IndexedBySite.php
@@ -89,11 +89,12 @@ class Piwik_Archive_Array_IndexedBySite extends Piwik_Archive_Array
private function loadValuesFromDB($fields)
{
+ $inNames = $this->getSqlStringFieldsArray($fields);
$sql = "SELECT value, name, idarchive, idsite
FROM {$this->getNumericTableName()}
WHERE idarchive IN ( {$this->getArchiveIds()} )
- AND name IN ( {$this->getSqlStringFieldsArray($fields)} )";
- return Piwik_FetchAll($sql);
+ AND name IN ( $inNames )";
+ return Piwik_FetchAll($sql, $fields);
}
private function getFirstArchive()
diff --git a/core/Common.php b/core/Common.php
index c7d37a3bc9..246f861d9c 100644
--- a/core/Common.php
+++ b/core/Common.php
@@ -33,7 +33,7 @@ class Piwik_Common
* Flag used with htmlspecialchar
* See php.net/htmlspecialchars
*/
- const HTML_ENCODING_QUOTE_STYLE = ENT_COMPAT;
+ const HTML_ENCODING_QUOTE_STYLE = ENT_QUOTES;
/*
* Database
@@ -577,6 +577,7 @@ class Piwik_Common
{
// $_GET and $_REQUEST already urldecode()'d
$value = html_entity_decode($value, self::HTML_ENCODING_QUOTE_STYLE, 'UTF-8');
+ $value = str_replace(array("\n","\r","\0"), "", $value);
return htmlspecialchars( $value, self::HTML_ENCODING_QUOTE_STYLE, 'UTF-8' );
}
diff --git a/core/Controller.php b/core/Controller.php
index 2d07c7e4c5..940a51ea56 100644
--- a/core/Controller.php
+++ b/core/Controller.php
@@ -418,7 +418,7 @@ abstract class Piwik_Controller
if(Piwik::isUserIsSuperUser())
{
- Piwik_ExitWithMessage("Error: no website were found in this Piwik installation.
+ Piwik_ExitWithMessage("Error: no website was found in this Piwik installation.
<br />Check the table '". Piwik_Common::prefixTable('site') ."' that should contain your Piwik websites.", false, true);
}
diff --git a/core/DataTable/Renderer.php b/core/DataTable/Renderer.php
index 01f79c48b4..3f1f1758aa 100644
--- a/core/DataTable/Renderer.php
+++ b/core/DataTable/Renderer.php
@@ -50,7 +50,7 @@ abstract class Piwik_DataTable_Renderer
/**
* Output HTTP Content-Type header
*/
- protected function renderHeader()
+ protected static function renderHeader()
{
@header('Content-Type: text/html; charset=utf-8');
}
@@ -135,6 +135,7 @@ abstract class Piwik_DataTable_Renderer
return new $className;
} catch(Exception $e) {
$availableRenderers = implode(', ', self::getRenderers());
+ self::renderHeader();
throw new Exception(Piwik_TranslateException('General_ExceptionInvalidRendererFormat', array($name, $availableRenderers)));
}
}
@@ -147,6 +148,24 @@ abstract class Piwik_DataTable_Renderer
*/
static protected function renderHtmlEntities( $rawData )
{
- return htmlentities($rawData, ENT_COMPAT, "UTF-8");
+ return self::formatValueXml($rawData);
+ }
+
+ public static function formatValueXml($value)
+ {
+ if(is_string($value)
+ && !is_numeric($value))
+ {
+ $value = html_entity_decode($value, ENT_COMPAT, 'UTF-8');
+ $value = htmlspecialchars($value, ENT_COMPAT, 'UTF-8');
+ $htmlentities = array( "&nbsp;","&iexcl;","&cent;","&pound;","&curren;","&yen;","&brvbar;","&sect;","&uml;","&copy;","&ordf;","&laquo;","&not;","&shy;","&reg;","&macr;","&deg;","&plusmn;","&sup2;","&sup3;","&acute;","&micro;","&para;","&middot;","&cedil;","&sup1;","&ordm;","&raquo;","&frac14;","&frac12;","&frac34;","&iquest;","&Agrave;","&Aacute;","&Acirc;","&Atilde;","&Auml;","&Aring;","&AElig;","&Ccedil;","&Egrave;","&Eacute;","&Ecirc;","&Euml;","&Igrave;","&Iacute;","&Icirc;","&Iuml;","&ETH;","&Ntilde;","&Ograve;","&Oacute;","&Ocirc;","&Otilde;","&Ouml;","&times;","&Oslash;","&Ugrave;","&Uacute;","&Ucirc;","&Uuml;","&Yacute;","&THORN;","&szlig;","&agrave;","&aacute;","&acirc;","&atilde;","&auml;","&aring;","&aelig;","&ccedil;","&egrave;","&eacute;","&ecirc;","&euml;","&igrave;","&iacute;","&icirc;","&iuml;","&eth;","&ntilde;","&ograve;","&oacute;","&ocirc;","&otilde;","&ouml;","&divide;","&oslash;","&ugrave;","&uacute;","&ucirc;","&uuml;","&yacute;","&thorn;","&yuml;","&euro;");
+ $xmlentities = array( "&#162;","&#163;","&#164;","&#165;","&#166;","&#167;","&#168;","&#169;","&#170;","&#171;","&#172;","&#173;","&#174;","&#175;","&#176;","&#177;","&#178;","&#179;","&#180;","&#181;","&#182;","&#183;","&#184;","&#185;","&#186;","&#187;","&#188;","&#189;","&#190;","&#191;","&#192;","&#193;","&#194;","&#195;","&#196;","&#197;","&#198;","&#199;","&#200;","&#201;","&#202;","&#203;","&#204;","&#205;","&#206;","&#207;","&#208;","&#209;","&#210;","&#211;","&#212;","&#213;","&#214;","&#215;","&#216;","&#217;","&#218;","&#219;","&#220;","&#221;","&#222;","&#223;","&#224;","&#225;","&#226;","&#227;","&#228;","&#229;","&#230;","&#231;","&#232;","&#233;","&#234;","&#235;","&#236;","&#237;","&#238;","&#239;","&#240;","&#241;","&#242;","&#243;","&#244;","&#245;","&#246;","&#247;","&#248;","&#249;","&#250;","&#251;","&#252;","&#253;","&#254;","&#255;","&#8364;" );
+ $value = str_replace($htmlentities,$xmlentities,$value);
+ }
+ elseif($value===false)
+ {
+ $value = 0;
+ }
+ return $value;
}
}
diff --git a/core/DataTable/Renderer/Console.php b/core/DataTable/Renderer/Console.php
index b24c50e9bb..e42cfccc84 100644
--- a/core/DataTable/Renderer/Console.php
+++ b/core/DataTable/Renderer/Console.php
@@ -22,13 +22,13 @@ class Piwik_DataTable_Renderer_Console extends Piwik_DataTable_Renderer
function render()
{
- $this->renderHeader();
+ self::renderHeader();
return $this->renderTable($this->table);
}
function renderException()
{
- $this->renderHeader();
+ self::renderHeader();
$exceptionMessage = self::renderHtmlEntities($this->exception->getMessage());
return 'Error: '.$exceptionMessage;
}
diff --git a/core/DataTable/Renderer/Csv.php b/core/DataTable/Renderer/Csv.php
index 0fc544c59b..a84c22a986 100644
--- a/core/DataTable/Renderer/Csv.php
+++ b/core/DataTable/Renderer/Csv.php
@@ -69,7 +69,7 @@ class Piwik_DataTable_Renderer_Csv extends Piwik_DataTable_Renderer
return 'No data available';
}
- $this->renderHeader();
+ self::renderHeader();
if($this->convertToUnicode
&& function_exists('mb_convert_encoding'))
@@ -271,7 +271,7 @@ class Piwik_DataTable_Renderer_Csv extends Piwik_DataTable_Renderer
return $value;
}
- protected function renderHeader()
+ protected static function renderHeader()
{
// silent fail otherwise unit tests fail
@header('Content-Type: application/vnd.ms-excel');
diff --git a/core/DataTable/Renderer/Html.php b/core/DataTable/Renderer/Html.php
index d2bb0edd89..e58ace3dfb 100644
--- a/core/DataTable/Renderer/Html.php
+++ b/core/DataTable/Renderer/Html.php
@@ -31,7 +31,7 @@ class Piwik_DataTable_Renderer_Html extends Piwik_DataTable_Renderer
function render()
{
- $this->renderHeader();
+ self::renderHeader();
$this->tableStructure = array();
$this->allColumns = array();
$this->i = 0;
@@ -41,7 +41,7 @@ class Piwik_DataTable_Renderer_Html extends Piwik_DataTable_Renderer
function renderException()
{
- $this->renderHeader();
+ self::renderHeader();
$exceptionMessage = self::renderHtmlEntities($this->exception->getMessage());
return nl2br($exceptionMessage);
}
@@ -151,7 +151,7 @@ class Piwik_DataTable_Renderer_Html extends Piwik_DataTable_Renderer
$value = "-";
if(isset($row[$name]))
{
- $value = $this->formatValue($row[$name]);
+ $value = self::formatValueXml($row[$name]);
}
$html .= "\t\t<td>$value</td>\n";
@@ -164,19 +164,4 @@ class Piwik_DataTable_Renderer_Html extends Piwik_DataTable_Renderer
return $html;
}
-
- protected function formatValue($value)
- {
- if(is_string($value)
- && !is_numeric($value))
- {
- $value = html_entity_decode($value, ENT_COMPAT, 'UTF-8');
- $value = htmlspecialchars($value);
- }
- elseif($value===false)
- {
- $value = 0;
- }
- return $value;
- }
}
diff --git a/core/DataTable/Renderer/Json.php b/core/DataTable/Renderer/Json.php
index 695f57f4a9..6c411fcdd1 100644
--- a/core/DataTable/Renderer/Json.php
+++ b/core/DataTable/Renderer/Json.php
@@ -21,13 +21,13 @@ class Piwik_DataTable_Renderer_Json extends Piwik_DataTable_Renderer
{
public function render()
{
- $this->renderHeader();
+ self::renderHeader();
return $this->renderTable($this->table);
}
function renderException()
{
- $this->renderHeader();
+ self::renderHeader();
$exceptionMessage = self::renderHtmlEntities($this->exception->getMessage());
$exceptionMessage = str_replace("\n", "", $exceptionMessage);
@@ -72,7 +72,7 @@ class Piwik_DataTable_Renderer_Json extends Piwik_DataTable_Renderer
return $str;
}
- protected function renderHeader()
+ protected static function renderHeader()
{
@header('Content-Type: application/json; charset=utf-8');
Piwik::overrideCacheControlHeaders();
diff --git a/core/DataTable/Renderer/Php.php b/core/DataTable/Renderer/Php.php
index e75a0adf7e..eda662d795 100644
--- a/core/DataTable/Renderer/Php.php
+++ b/core/DataTable/Renderer/Php.php
@@ -48,7 +48,7 @@ class Piwik_DataTable_Renderer_Php extends Piwik_DataTable_Renderer
public function render( $dataTable = null )
{
- $this->renderHeader();
+ self::renderHeader();
if(is_null($dataTable))
{
@@ -69,7 +69,7 @@ class Piwik_DataTable_Renderer_Php extends Piwik_DataTable_Renderer
function renderException()
{
- $this->renderHeader();
+ self::renderHeader();
$exceptionMessage = self::renderHtmlEntities($this->exception->getMessage());
@@ -170,10 +170,14 @@ class Piwik_DataTable_Renderer_Php extends Piwik_DataTable_Renderer
{
$array = $this->renderSimpleTable($this->table);
}
- else
+ elseif($this->table instanceof Piwik_DataTable)
{
$array = $this->renderTable($this->table);
}
+ else
+ {
+ throw new Exception("Unexpected data type to render.");
+ }
if($this->serialize)
{
diff --git a/core/DataTable/Renderer/Rss.php b/core/DataTable/Renderer/Rss.php
index 95a58e80f9..18622260e1 100644
--- a/core/DataTable/Renderer/Rss.php
+++ b/core/DataTable/Renderer/Rss.php
@@ -22,13 +22,13 @@ class Piwik_DataTable_Renderer_Rss extends Piwik_DataTable_Renderer
{
function render()
{
- $this->renderHeader();
+ self::renderHeader();
return $this->renderTable($this->table);
}
function renderException()
{
- $this->renderHeader();
+ self::renderHeader();
$exceptionMessage = self::renderHtmlEntities($this->exception->getMessage());
return 'Error: '.$exceptionMessage;
}
@@ -41,12 +41,11 @@ class Piwik_DataTable_Renderer_Rss extends Piwik_DataTable_Renderer
throw new Exception("RSS Feed only used on Piwik_DataTable_Array with keyName = 'date'");
}
- $idSite = Piwik_Common::getRequestVar('idSite', 1);
+ $idSite = Piwik_Common::getRequestVar('idSite', 1, 'int');
$period = Piwik_Common::getRequestVar('period');
- $currentUrl = Piwik_Url::getCurrentUrlWithoutFileName();
-
- $piwikUrl = $currentUrl . "?module=CoreHome&action=index&idSite=" . $idSite . "&period=" . $period;
+ $piwikUrl = Piwik_Url::getCurrentUrlWithoutFileName()
+ . "?module=CoreHome&action=index&idSite=" . $idSite . "&period=" . $period;
$out = "";
$moreRecentFirst = array_reverse($table->getArray(), true);
foreach($moreRecentFirst as $date => $subtable )
@@ -55,9 +54,9 @@ class Piwik_DataTable_Renderer_Rss extends Piwik_DataTable_Renderer
$site = $table->metadata[$date]['site'];
$pudDate = date('r', $timestamp);
-
+
$dateInSiteTimezone = Piwik_Date::factory($timestamp)->setTimezone($site->getTimezone())->toString('Y-m-d');
- $thisPiwikUrl = htmlentities($piwikUrl . "&date=$dateInSiteTimezone");
+ $thisPiwikUrl = Piwik_Common::sanitizeInputValue($piwikUrl . "&date=$dateInSiteTimezone");
$siteName = $site->getName();
$title = $siteName . " on ". $date;
@@ -69,7 +68,7 @@ class Piwik_DataTable_Renderer_Rss extends Piwik_DataTable_Renderer
<author>http://piwik.org</author>
<description>";
- $out .= htmlspecialchars( $this->renderDataTable($subtable) );
+ $out .= Piwik_Common::sanitizeInputValue( $this->renderDataTable($subtable) );
$out .= "</description>\n\t</item>\n";
}
@@ -79,7 +78,7 @@ class Piwik_DataTable_Renderer_Rss extends Piwik_DataTable_Renderer
return $header . $out . $footer;
}
- protected function renderHeader()
+ protected static function renderHeader()
{
@header('Content-Type: text/xml; charset=utf-8');
}
diff --git a/core/DataTable/Renderer/Xml.php b/core/DataTable/Renderer/Xml.php
index d4bd89e8b4..4ad46de6f0 100644
--- a/core/DataTable/Renderer/Xml.php
+++ b/core/DataTable/Renderer/Xml.php
@@ -24,14 +24,13 @@ class Piwik_DataTable_Renderer_Xml extends Piwik_DataTable_Renderer
{
function render()
{
- $this->renderHeader();
-
+ self::renderHeader();
return '<?xml version="1.0" encoding="utf-8" ?>' . "\n" . $this->renderTable($this->table);
}
function renderException()
{
- $this->renderHeader();
+ self::renderHeader();
$exceptionMessage = self::renderHtmlEntities($this->exception->getMessage());
@@ -100,7 +99,7 @@ class Piwik_DataTable_Renderer_Xml extends Piwik_DataTable_Renderer
}
else
{
- $out = "<result>".$this->formatValue($out)."</result>";
+ $out = "<result>".self::formatValueXml($out)."</result>";
}
return $out;
}
@@ -142,7 +141,7 @@ class Piwik_DataTable_Renderer_Xml extends Piwik_DataTable_Renderer
}
else
{
- $xml .= $prefixLines . "\t<result $nameDescriptionAttribute=\"$valueAttribute\">".$this->formatValue($value)."</result>\n";
+ $xml .= $prefixLines . "\t<result $nameDescriptionAttribute=\"$valueAttribute\">".self::formatValueXml($value)."</result>\n";
}
}
return $xml;
@@ -252,7 +251,7 @@ class Piwik_DataTable_Renderer_Xml extends Piwik_DataTable_Renderer
{
if(!is_array($row))
{
- $value = $this->formatValue($row);
+ $value = self::formatValueXml($row);
$out .= $prefixLine."\t\t<$rowId>".$value."</$rowId>\n";
continue;
}
@@ -285,7 +284,7 @@ class Piwik_DataTable_Renderer_Xml extends Piwik_DataTable_Renderer
}
else
{
- $value = $this->formatValue($value);
+ $value = self::formatValueXml($value);
}
$out .= $prefixLine."\t\t<$name>".$value."</$name>\n";
}
@@ -301,27 +300,12 @@ class Piwik_DataTable_Renderer_Xml extends Piwik_DataTable_Renderer
$out = '';
foreach($array as $keyName => $value)
{
- $out .= $prefixLine."\t<$keyName>".$this->formatValue($value)."</$keyName>\n";
+ $out .= $prefixLine."\t<$keyName>".self::formatValueXml($value)."</$keyName>\n";
}
return $out;
}
- protected function formatValue($value)
- {
- if(is_string($value)
- && !is_numeric($value))
- {
- $value = html_entity_decode($value, ENT_COMPAT, 'UTF-8');
- $value = htmlspecialchars($value);
- }
- elseif($value===false)
- {
- $value = 0;
- }
- return $value;
- }
-
- protected function renderHeader()
+ protected static function renderHeader()
{
// silent fail because otherwise it throws an exception in the unit tests
@header('Content-Type: text/xml; charset=utf-8');
diff --git a/core/FrontController.php b/core/FrontController.php
index c5c26910fe..edb0c63f46 100644
--- a/core/FrontController.php
+++ b/core/FrontController.php
@@ -125,6 +125,8 @@ class Piwik_FrontController
return call_user_func_array( array($controller, $action ), $parameters);
} catch(Piwik_Access_NoAccessException $e) {
Piwik_PostEvent('FrontController.NoAccessException', $e);
+ } catch(Exception $e) {
+ Piwik_ExitWithMessage($e->getMessage(), false, true);
}
}
@@ -248,7 +250,7 @@ class Piwik_FrontController
Piwik_PostEvent('FrontController.checkForUpdates');
} catch(Exception $e) {
- Piwik_ExitWithMessage($e->getMessage(), $e->getTraceAsString(), true);
+ Piwik_ExitWithMessage($e->getMessage(), false, true);
}
}
diff --git a/core/Log.php b/core/Log.php
index da01c28f7c..6b4dfa1c6b 100644
--- a/core/Log.php
+++ b/core/Log.php
@@ -173,7 +173,7 @@ class Piwik_Log_Formatter_ScreenFormatter implements Zend_Log_Formatter_Interfac
function formatEvent($event)
{
// no injection in error messages, backtrace when displayed on screen
- return array_map('htmlspecialchars', $event);
+ return array_map('Piwik_Common::sanitizeInputValue', $event);
}
function format($string)
@@ -198,6 +198,10 @@ class Piwik_Log_Formatter_ScreenFormatter implements Zend_Log_Formatter_Interfac
$string = strip_tags($string);
}
}
+ else
+ {
+ @header('Content-Type: text/html; charset=utf-8');
+ }
return $string;
}
}
diff --git a/core/Log/Error.php b/core/Log/Error.php
index c29257fc9f..54262cb1aa 100644
--- a/core/Log/Error.php
+++ b/core/Log/Error.php
@@ -86,7 +86,9 @@ class Piwik_Log_Error_Formatter_ScreenFormatter extends Piwik_Log_Formatter_Scre
// it gives an errno 0, and in this case the objective is to NOT display anything on the screen!
// is there any other case where the errno is zero at this point?
if($errno == 0) return '';
- $strReturned .= "\n<div style='word-wrap: break-word; border: 3px solid red; padding:4px; width:70%; background-color:#FFFF96;'><b>";
+ $strReturned .= "\n<div style='word-wrap: break-word; border: 3px solid red; padding:4px; width:70%; background-color:#FFFF96;'>
+ <strong>There is an error. Please report the message and full backtrace in the <a href='?module=Proxy&action=redirect&url=http://forum.piwik.org' target='_blank'>Piwik forums</a>.<br /><br/>
+ ";
switch($errno)
{
case E_ERROR: $strReturned .= "Error"; break;
@@ -106,11 +108,11 @@ class Piwik_Log_Error_Formatter_ScreenFormatter extends Piwik_Log_Formatter_Scre
case E_USER_DEPRECATED: $strReturned .= "User Deprecated"; break;
default: $strReturned .= "Unknown error ($errno)"; break;
}
- $strReturned .= ":</b> <i>$errstr</i> in <b>$errfile</b> on line <b>$errline</b>\n";
+ $strReturned .= ":</strong> <i>$errstr</i> in <b>$errfile</b> on line <b>$errline</b>\n";
$strReturned .= "<br /><br />Backtrace --&gt;<div style=\"font-family:Courier;font-size:10pt\">";
$strReturned .= str_replace("\n", "<br />\n", $backtrace);
- $strReturned .= "</div><br /><br />";
- $strReturned .= "\n</pre></div><br />";
+ $strReturned .= "</div><br />";
+ $strReturned .= "\n </pre></div><br />";
return parent::format($strReturned);
}
diff --git a/core/Piwik.php b/core/Piwik.php
index 2c7c01438c..00b8379852 100644
--- a/core/Piwik.php
+++ b/core/Piwik.php
@@ -435,6 +435,7 @@ class Piwik
'/config',
'/core',
'/lang',
+ '/tmp',
);
foreach($directoriesToProtect as $directoryToProtect)
{
@@ -444,7 +445,7 @@ class Piwik
// more selective allow/deny filters
$allowAny = "<Files \"*\">\nAllow from all\nSatisfy any\n</Files>\n";
$allowStaticAssets = "<Files ~ \"\\.(test\.php|gif|ico|jpg|png|js|css|swf)$\">\nSatisfy any\nAllow from all\n</Files>\n";
- $denyDirectPhp = "<Files ~ \"\\.(php|php4|php5|inc|tpl)$\">\nDeny from all\n</Files>\n";
+ $denyDirectPhp = "<Files ~ \"\\.(php|php4|php5|inc|tpl|in)$\">\nDeny from all\n</Files>\n";
$directoriesToProtect = array(
'/js' => $allowAny,
'/libs' => $denyDirectPhp . $allowStaticAssets,
@@ -474,9 +475,14 @@ class Piwik
<add segment="config" />
<add segment="core" />
<add segment="lang" />
+ <add segment="tmp" />
</hiddenSegments>
<fileExtensions>
<add fileExtension=".tpl" allowed="false" />
+ <add fileExtension=".php4" allowed="false" />
+ <add fileExtension=".php5" allowed="false" />
+ <add fileExtension=".inc" allowed="false" />
+ <add fileExtension=".in" allowed="false" />
</fileExtensions>
</requestFiltering>
</security>
@@ -1306,9 +1312,9 @@ class Piwik
$jsTag = file_get_contents( PIWIK_INCLUDE_PATH . "/core/Tracker/javascriptTag.tpl");
$jsTag = nl2br(htmlentities($jsTag));
$piwikUrl = preg_match('~^(http|https)://(.*)$~', $piwikUrl, $matches);
- $piwikUrl = $matches[2];
+ $piwikUrl = @$matches[2];
$jsTag = str_replace('{$idSite}', $idSite, $jsTag);
- $jsTag = str_replace('{$piwikUrl}', $piwikUrl, $jsTag);
+ $jsTag = str_replace('{$piwikUrl}', Piwik_Common::sanitizeInputValue($piwikUrl), $jsTag);
$jsTag = str_replace('{$hrefTitle}', Piwik::getRandomTitle(), $jsTag);
return $jsTag;
}
@@ -1338,6 +1344,18 @@ class Piwik
$title = $titles[ $id % count($titles)];
return $title;
}
+
+ /**
+ * Number of websites to show in the Website selector
+ *
+ * @return int
+ */
+ static public function getWebsitesCountToDisplay()
+ {
+ $count = max(Zend_Registry::get('config')->General->site_selector_max_sites,
+ Zend_Registry::get('config')->General->autocomplete_min_sites);
+ return (int)$count;
+ }
/*
* Access
@@ -1423,10 +1441,15 @@ class Piwik
return false;
}
}
+
+ static public function isUserIsAnonymous()
+ {
+ return Piwik::getCurrentUserLogin() == 'anonymous';
+ }
static public function checkUserIsNotAnonymous()
{
- if(Piwik::getCurrentUserLogin() == 'anonymous')
+ if(self::isUserIsAnonymous())
{
throw new Exception(Piwik_Translate('General_YouMustBeLoggedIn'));
}
diff --git a/core/SmartyPlugins/function.url.php b/core/SmartyPlugins/function.url.php
index a30c2debc5..ce4f1947c0 100644
--- a/core/SmartyPlugins/function.url.php
+++ b/core/SmartyPlugins/function.url.php
@@ -26,5 +26,5 @@
*/
function smarty_function_url($params, &$smarty)
{
- return htmlspecialchars('index.php' . Piwik_Url::getCurrentQueryStringWithParametersModified( $params ));
+ return Piwik_Common::sanitizeInputValue('index.php' . Piwik_Url::getCurrentQueryStringWithParametersModified( $params ));
}
diff --git a/core/SmartyPlugins/modifier.escape.php b/core/SmartyPlugins/modifier.escape.php
index 31e6998453..4662476202 100644
--- a/core/SmartyPlugins/modifier.escape.php
+++ b/core/SmartyPlugins/modifier.escape.php
@@ -23,7 +23,7 @@
* @param html|htmlall|url|quotes|hex|hexentity|javascript
* @return string
*/
-function smarty_modifier_escape($string, $esc_type = 'html', $char_set = 'ISO-8859-1')
+function smarty_modifier_escape($string, $esc_type = 'html', $char_set = 'UTF-8')
{
switch ($esc_type) {
case 'html':
diff --git a/core/SmartyPlugins/modifier.urlRewriteBasicView.php b/core/SmartyPlugins/modifier.urlRewriteBasicView.php
index 9ec68fdafe..17c948f499 100644
--- a/core/SmartyPlugins/modifier.urlRewriteBasicView.php
+++ b/core/SmartyPlugins/modifier.urlRewriteBasicView.php
@@ -36,5 +36,5 @@ function smarty_modifier_urlRewriteBasicView($parameters)
// add module=CoreHome&action=showInContext
$url = $url . '&amp;module=CoreHome&amp;action=showInContext';
- return htmlspecialchars($url);
+ return Piwik_Common::sanitizeInputValue($url);
}
diff --git a/core/SmartyPlugins/modifier.urlRewriteWithParameters.php b/core/SmartyPlugins/modifier.urlRewriteWithParameters.php
index 6cec46aa5d..e6fc201bc6 100644
--- a/core/SmartyPlugins/modifier.urlRewriteWithParameters.php
+++ b/core/SmartyPlugins/modifier.urlRewriteWithParameters.php
@@ -20,5 +20,5 @@ function smarty_modifier_urlRewriteWithParameters($parameters)
{
$parameters['updated'] = null;
$url = Piwik_Url::getCurrentQueryStringWithParametersModified($parameters);
- return htmlspecialchars($url);
+ return Piwik_Common::sanitizeInputValue($url);
}
diff --git a/core/Tracker.php b/core/Tracker.php
index f85f5e21a5..f7eae6bf8c 100644
--- a/core/Tracker.php
+++ b/core/Tracker.php
@@ -23,7 +23,6 @@
class Piwik_Tracker
{
protected $stateValid = self::STATE_NOTHING_TO_NOTICE;
- protected $urlToRedirect;
/**
* @var Piwik_Tracker_Db
@@ -31,10 +30,8 @@ class Piwik_Tracker
protected static $db = null;
const STATE_NOTHING_TO_NOTICE = 1;
- const STATE_TO_REDIRECT_URL = 2;
const STATE_LOGGING_DISABLE = 10;
const STATE_EMPTY_REQUEST = 11;
- const STATE_TRACK_ONLY = 12;
const STATE_NOSCRIPT_REQUEST = 13;
const COOKIE_INDEX_IDVISITOR = 1;
@@ -113,15 +110,8 @@ class Piwik_Tracker
$this->loadTrackerPlugins();
$this->handleDisabledTracker();
$this->handleEmptyRequest();
- $this->handleDownloadRedirect();
- $this->handleOutlinkRedirect();
- $this->handleDataPush();
}
- // display the logo or pixel 1*1 GIF
- // or a marketing page if no parameters in the url
- // or redirect to a url
- // or load a URL (rss feed) (forward the cookie as well)
protected function end()
{
switch($this->getState())
@@ -136,14 +126,6 @@ class Piwik_Tracker
echo "<a href='/'>Piwik</a> is a free open source <a href='http://piwik.org'>web analytics</a> alternative to Google analytics.";
break;
- case self::STATE_TO_REDIRECT_URL:
- $this->sendHeader('Location: ' . $this->getUrlToRedirect());
- break;
-
- case self::STATE_TRACK_ONLY:
- printDebug("Data push, tracking only");
- break;
-
case self::STATE_NOSCRIPT_REQUEST:
case self::STATE_NOTHING_TO_NOTICE:
default:
@@ -284,16 +266,6 @@ class Piwik_Tracker
return $this->stateValid;
}
- protected function setUrlToRedirect( $url )
- {
- $this->urlToRedirect = $url;
- }
-
- protected function getUrlToRedirect()
- {
- return $this->urlToRedirect;
- }
-
protected function setState( $value )
{
$this->stateValid = $value;
@@ -316,42 +288,6 @@ class Piwik_Tracker
}
}
- protected function handleDataPush()
- {
- if( Piwik_Common::getRequestVar( 'data_push', 0, 'int', $this->request) == 1)
- {
- $this->setState( self::STATE_TRACK_ONLY );
- }
- }
-
- protected function handleDownloadRedirect()
- {
- $urlDownload = Piwik_Common::getRequestVar( 'download', '', 'string', $this->request);
-
- if( !empty($urlDownload) )
- {
- if( Piwik_Common::getRequestVar( 'redirect', 1, 'int', $this->request) == 1)
- {
- $this->setState( self::STATE_TO_REDIRECT_URL );
- $this->setUrlToRedirect ( $urlDownload );
- }
- }
- }
-
- protected function handleOutlinkRedirect()
- {
- $urlOutlink = Piwik_Common::getRequestVar( 'link', '', 'string', $this->request);
-
- if( !empty($urlOutlink) )
- {
- if( Piwik_Common::getRequestVar( 'redirect', 1, 'int', $this->request) == 1)
- {
- $this->setState( self::STATE_TO_REDIRECT_URL );
- $this->setUrlToRedirect ( $urlOutlink);
- }
- }
- }
-
protected function handleEmptyRequest()
{
$countParameters = count($this->request);
diff --git a/core/Tracker/Visit.php b/core/Tracker/Visit.php
index 5937f9d24d..c603c8a112 100644
--- a/core/Tracker/Visit.php
+++ b/core/Tracker/Visit.php
@@ -126,7 +126,7 @@ class Piwik_Tracker_Visit implements Piwik_Tracker_Visit_Interface
{
return;
}
-
+
$goalManager = new Piwik_Tracker_GoalManager();
$someGoalsConverted = false;
$actionUrlId = 0;
@@ -228,7 +228,12 @@ class Piwik_Tracker_Visit implements Piwik_Tracker_Visit_Interface
}
unset($goalManager);
unset($action);
+ $this->printCookie();
+ }
+
+ protected function printCookie()
+ {
printDebug("<pre>");
printDebug($this->cookie);
printDebug("</pre>");
@@ -278,7 +283,6 @@ class Piwik_Tracker_Visit implements Piwik_Tracker_Visit_Interface
*/
protected function handleKnownVisit($actionUrlId, $someGoalsConverted)
{
-
// gather information that needs to be updated
$valuesToUpdate = array();
if($someGoalsConverted)
@@ -337,15 +341,16 @@ class Piwik_Tracker_Visit implements Piwik_Tracker_Visit_Interface
$result = Piwik_Tracker::getDatabase()->query($sqlQuery, $sqlBind);
printDebug('Updating visitor with idvisit='.$this->visitorInfo['idvisit'].', setting visit_last_action_time='.$datetimeServer.' and visit_total_time='.$visitTotalTime);
+
+ $this->visitorInfo['visit_last_action_time'] = $serverTimestamp;
if(Piwik_Tracker::getDatabase()->rowCount($result) == 0)
{
+ printDebug("Visitor with this idcookie and idvisit wasn't found in the DB.");
throw new Piwik_Tracker_Visit_VisitorNotFoundInDatabase(
"The visitor with visitor_idcookie=".$this->visitorInfo['visitor_idcookie']." and idvisit=".$this->visitorInfo['idvisit']
." wasn't found in the DB, we fallback to a new visitor");
}
- $this->visitorInfo['visit_last_action_time'] = $serverTimestamp;
-
Piwik_PostEvent('Tracker.knownVisitorInformation', $this->visitorInfo);
}
@@ -708,6 +713,8 @@ class Piwik_Tracker_Visit implements Piwik_Tracker_Visit_Interface
$this->getCookiePath(),
$key = $this->idsite ) );
+ $this->printCookie();
+
/*
* Case the visitor has the piwik cookie.
* We make sure all the data that should saved in the cookie is available.
@@ -735,6 +742,14 @@ class Piwik_Tracker_Visit implements Piwik_Tracker_Visit_Interface
printDebug("The visitor is known because he has the piwik cookie (idcookie = {$this->visitorInfo['visitor_idcookie']}, idvisit = {$this->visitorInfo['idvisit']}, last action = ".date("r", $this->visitorInfo['visit_last_action_time']).") ");
}
+ else
+ {
+ printDebug("Visitor has the piwik cookie, but some values are invalid: ts first action = $timestampLastAction, ts last action = $timestampFirstAction, idvisit = $idVisit, id last action = $idLastAction.");
+ }
+ }
+ else
+ {
+ printDebug("Visitor doesn't have the piwik cookie (id=".$idVisitor);
}
/*
diff --git a/core/Url.php b/core/Url.php
index 4e12c7f8cc..7b64f3ca9e 100644
--- a/core/Url.php
+++ b/core/Url.php
@@ -175,6 +175,7 @@ class Piwik_Url
$default = Piwik_Common::sanitizeInputValue($_SERVER['HTTP_HOST']);
}
+ $default = Piwik_Common::sanitizeInputValue($default);
// @todo temporary workaround for #1331
if(!method_exists('Piwik_Common', 'getProxyFromHeader'))
{
@@ -294,7 +295,7 @@ class Piwik_Url
*/
static public function redirectToUrl( $url )
{
- header("Location: $url");
+ @header("Location: $url");
exit;
}
diff --git a/core/View.php b/core/View.php
index ed23227ed1..0d4292807c 100644
--- a/core/View.php
+++ b/core/View.php
@@ -84,8 +84,8 @@ class Piwik_View implements Piwik_iView
}
// global value accessible to all templates: the piwik base URL for the current request
- $this->piwikUrl = Piwik_Url::getCurrentUrlWithoutFileName();
-
+ $this->piwikUrl = Piwik_Common::sanitizeInputValue(Piwik_Url::getCurrentUrlWithoutFileName());
+ $this->currentUrlWithoutFilename = Piwik_Common::sanitizeInputValue(Piwik_Url::getCurrentUrlWithoutFileName());
$this->piwik_version = Piwik_Version::VERSION;
}
@@ -124,10 +124,10 @@ class Piwik_View implements Piwik_iView
$this->currentModule = Piwik::getModule();
$this->userLogin = Piwik::getCurrentUserLogin();
- $sites = Piwik_SitesManager_API::getInstance()->getSitesWithAtLeastViewAccess(Zend_Registry::get('config')->General->site_selector_max_sites);
+ $sites = Piwik_SitesManager_API::getInstance()->getSitesWithAtLeastViewAccess(Piwik::getWebsitesCountToDisplay());
usort($sites, create_function('$site1, $site2', 'return strcasecmp($site1["name"], $site2["name"]);'));
$this->sites = $sites;
- $this->url = Piwik_Url::getCurrentUrl();
+ $this->url = Piwik_Common::sanitizeInputValue(Piwik_Url::getCurrentUrl());
$this->token_auth = Piwik::getCurrentUserTokenAuth();
$this->userHasSomeAdminAccess = Piwik::isUserHasSomeAdminAccess();
$this->userIsSuperUser = Piwik::isUserIsSuperUser();
@@ -141,7 +141,7 @@ class Piwik_View implements Piwik_iView
$this->show_autocompleter = false;
}
- // @todo temporary workaround for #1331
+ // workaround for #1331
$this->loginModule = method_exists('Piwik', 'getLoginPluginName') ? Piwik::getLoginPluginName() : 'Login';
} catch(Exception $e) {
// can fail, for example at installation (no plugin loaded yet)
@@ -155,7 +155,7 @@ class Piwik_View implements Piwik_iView
$this->totalNumberOfQueries = 0;
}
- // @todo temporary workaround for #1331
+ // workaround for #1331
if(method_exists('Piwik', 'overrideCacheControlHeaders'))
{
Piwik::overrideCacheControlHeaders('no-store');
diff --git a/core/ViewDataTable.php b/core/ViewDataTable.php
index 40717b6a3c..00f963152a 100644
--- a/core/ViewDataTable.php
+++ b/core/ViewDataTable.php
@@ -184,7 +184,6 @@ abstract class Piwik_ViewDataTable
{
$type = Piwik_Common::getRequestVar('viewDataTable', $defaultType, 'string');
}
-
switch($type)
{
case 'cloud':
@@ -371,6 +370,19 @@ abstract class Piwik_ViewDataTable
}
/**
+ * Checks that the API returned a normal DataTable (as opposed to DataTable_Array)
+ * @throws Exception
+ * @return void
+ */
+ protected function checkStandardDataTable()
+ {
+ if(!($this->dataTable instanceof Piwik_DataTable))
+ {
+ throw new Exception("Unexpected data type to render.");
+ }
+ }
+
+ /**
* Hook called after the dataTable has been loaded from the API
* Can be used to add, delete or modify the data freshly loaded
*/
@@ -552,7 +564,7 @@ abstract class Piwik_ViewDataTable
foreach($_GET as $name => $value)
{
- try{
+ try {
$requestValue = Piwik_Common::getRequestVar($name);
}
catch(Exception $e) {
@@ -635,7 +647,7 @@ abstract class Piwik_ViewDataTable
{
if(isset($_GET[$nameVar]))
{
- return htmlspecialchars($_GET[$nameVar]);
+ return Piwik_Common::sanitizeInputValue($_GET[$nameVar]);
}
$default = $this->getDefault($nameVar);
return $default;
@@ -855,6 +867,11 @@ abstract class Piwik_ViewDataTable
*/
public function setColumnTranslation( $columnName, $columnTranslation, $columnDescription = false )
{
+ if(empty($columnTranslation))
+ {
+ throw new Exception('Unknown column: '.$columnName);
+ }
+
$this->columnsTranslations[$columnName] = $columnTranslation;
$this->columnsDescriptions[$columnName] = $columnDescription;
}
diff --git a/core/ViewDataTable/Cloud.php b/core/ViewDataTable/Cloud.php
index 17f8421e93..7efc1dec65 100644
--- a/core/ViewDataTable/Cloud.php
+++ b/core/ViewDataTable/Cloud.php
@@ -67,6 +67,7 @@ class Piwik_ViewDataTable_Cloud extends Piwik_ViewDataTable
} catch(Exception $e) {
$this->isDataAvailable = false;
}
+ $this->checkStandardDataTable();
$this->view = $this->buildView();
}
diff --git a/core/ViewDataTable/GenerateGraphData.php b/core/ViewDataTable/GenerateGraphData.php
index 02110803ba..beeebc475e 100644
--- a/core/ViewDataTable/GenerateGraphData.php
+++ b/core/ViewDataTable/GenerateGraphData.php
@@ -101,6 +101,7 @@ abstract class Piwik_ViewDataTable_GenerateGraphData extends Piwik_ViewDataTable
// throws exception if no view access
$this->loadDataTableFromAPI();
+ $this->checkStandardDataTable();
$graphLimit = $this->getGraphLimit();
if(!empty($graphLimit))
diff --git a/core/ViewDataTable/GenerateGraphData/ChartEvolution.php b/core/ViewDataTable/GenerateGraphData/ChartEvolution.php
index 848253ae64..9c7bb05722 100644
--- a/core/ViewDataTable/GenerateGraphData/ChartEvolution.php
+++ b/core/ViewDataTable/GenerateGraphData/ChartEvolution.php
@@ -18,6 +18,15 @@
*/
class Piwik_ViewDataTable_GenerateGraphData_ChartEvolution extends Piwik_ViewDataTable_GenerateGraphData
{
+ protected function checkStandardDataTable()
+ {
+ // DataTable_Array and DataTable allowed for the evolution chart
+ if(!($this->dataTable instanceof Piwik_DataTable_Array)
+ && !($this->dataTable instanceof Piwik_DataTable))
+ {
+ throw new Exception("Unexpected data type to render.");
+ }
+ }
protected function getViewDataTableId()
{
return 'generateDataChartEvolution';
@@ -119,7 +128,7 @@ class Piwik_ViewDataTable_GenerateGraphData_ChartEvolution extends Piwik_ViewDat
$yAxisLabelToValueCleaned[$yAxisLabel][] = $columnValue;
}
}
- $idSite = Piwik_Common::getRequestVar('idSite');
+ $idSite = Piwik_Common::getRequestVar('idSite', null, 'int');
$unit = $this->yAxisUnit;
if(empty($unit))
diff --git a/core/ViewDataTable/GenerateGraphHTML.php b/core/ViewDataTable/GenerateGraphHTML.php
index 7b39e528a1..4ecee4068e 100644
--- a/core/ViewDataTable/GenerateGraphHTML.php
+++ b/core/ViewDataTable/GenerateGraphHTML.php
@@ -103,10 +103,15 @@ abstract class Piwik_ViewDataTable_GenerateGraphHTML extends Piwik_ViewDataTable
$url = Piwik_Url::getCurrentQueryStringWithParametersModified($this->parametersToModify);
$this->includeData = !Zend_Registry::get('config')->Debug->disable_merged_requests;
- $idSite = Piwik_Common::getRequestVar('idSite', 1);
+ $idSite = Piwik_Common::getRequestVar('idSite', 1, 'int');
Piwik_API_Request::reloadAuthUsingTokenAuth();
- if(Piwik::isUserHasViewAccess($idSite) && $this->includeData)
+ if(!Piwik::isUserHasViewAccess($idSite))
+ {
+ throw new Exception(Piwik_TranslateException('General_ExceptionPrivilegeAccessWebsite', array("'view'", $idSite)));
+
+ }
+ if($this->includeData)
{
$this->chartData = $this->getFlashData();
}
diff --git a/core/testMinimumPhpVersion.php b/core/testMinimumPhpVersion.php
index f2e2105edb..ba931cc791 100644
--- a/core/testMinimumPhpVersion.php
+++ b/core/testMinimumPhpVersion.php
@@ -59,6 +59,7 @@ if(!function_exists('session_cache_limiter'))
*/
function Piwik_ExitWithMessage($message, $optionalTrace = false, $optionalLinks = false)
{
+ @header('Content-Type: text/html; charset=utf-8');
if($optionalTrace)
{
$optionalTrace = '<font color="#888888">Backtrace:<br /><pre>'.$optionalTrace.'</pre></font>';
diff --git a/libs/PiwikTracker/PiwikTracker.php b/libs/PiwikTracker/PiwikTracker.php
index 8b5b4578c7..80544c8e60 100644
--- a/libs/PiwikTracker/PiwikTracker.php
+++ b/libs/PiwikTracker/PiwikTracker.php
@@ -23,6 +23,10 @@ class PiwikTracker
*/
static public $URL = '';
+ /**
+ * API Version
+ * @var int
+ */
const VERSION = 1;
/**
diff --git a/plugins/API/API.php b/plugins/API/API.php
index 6013562358..b484999c2f 100644
--- a/plugins/API/API.php
+++ b/plugins/API/API.php
@@ -350,7 +350,7 @@ class Piwik_API_API
$dataTable->filter('AddColumnsProcessedMetrics');
}
- $dataTable->filter('SafeDecodeLabel', array($outputHTML = false));
+ $dataTable->filter('SafeDecodeLabel');
$renderer = new Piwik_DataTable_Renderer_Php();
$renderer->setTable($dataTable);
$renderer->setSerialize(false);
diff --git a/plugins/Actions/API.php b/plugins/Actions/API.php
index 4f3b0dda75..a626a9ac4c 100644
--- a/plugins/Actions/API.php
+++ b/plugins/Actions/API.php
@@ -71,7 +71,6 @@ class Piwik_Actions_API
// % Exit = Number of visits that finished on this page / visits on this page
$dataTable->filter('ColumnCallbackAddColumnPercentage', array('exit_rate', 'exit_nb_visits', 'nb_hits', 0));
-
return $dataTable;
}
diff --git a/plugins/CoreHome/Controller.php b/plugins/CoreHome/Controller.php
index 21e0f6af03..9674fb9507 100644
--- a/plugins/CoreHome/Controller.php
+++ b/plugins/CoreHome/Controller.php
@@ -66,7 +66,7 @@ class Piwik_CoreHome_Controller extends Piwik_Controller
{
return;
}
- $websiteId = Piwik_Common::getRequestVar('idSite', false);
+ $websiteId = Piwik_Common::getRequestVar('idSite', false, 'int');
if ($websiteId) {
$website = new Piwik_Site($websiteId);
$datetimeCreationDate = $this->site->getCreationDate()->getDatetime();
diff --git a/plugins/CoreHome/templates/datatable.js b/plugins/CoreHome/templates/datatable.js
index dc90f379f4..d1797fb488 100644
--- a/plugins/CoreHome/templates/datatable.js
+++ b/plugins/CoreHome/templates/datatable.js
@@ -217,52 +217,10 @@ dataTable.prototype =
self.handleLowPopulationLink(domElem);
self.handleOffsetInformation(domElem);
self.handleExportBox(domElem);
- self.handleLinkedRows(domElem);
self.applyCosmetics(domElem);
self.handleSubDataTable(domElem);
},
-
- handleLinkedRows: function(domElem)
- {
- var self = this;
- var urlLinkFoundDom = $("tr td:first-child:has('.urlLink')", domElem);
- if(urlLinkFoundDom.length == 0)
- {
- self.truncate( $("table tr td:first-child", domElem) );
- }
- else
- {
- urlLinkFoundDom.each( function(){
- // we add a link based on the <span id="urlLink"> present in the column label (the first column)
- // if this span is there, we add the link around the HTML in the TD
- // but we add this link only for the rows that are not clickable already (subDataTable)
- var imgToPrepend = '';
- if( $(this).find('img').length == 0 )
- {
- var imageLinkWidth = 10;
- var imageLinkHeight = 9;
- imgToPrepend = '<img class="link" width="'+imageLinkWidth+'" height="'+imageLinkHeight+'" src="themes/default/images/link.gif" /> ';
- }
- var urlLinkDom = $('.urlLink',this);
- var urlToLink = $(urlLinkDom).html();
- $(urlLinkDom).remove();
-
- var truncationOffsetBecauseImageIsPrepend = -2; //website subtable needs -9.
-
- self.truncate( $(this), truncationOffsetBecauseImageIsPrepend );
- if( urlToLink.match("javascript:") )
- {
- $(this).prepend(imgToPrepend).wrapInner('<a href="#" onclick="' + urlToLink.replace("javascript:","") + '"></a>');
- }
- else
- {
- $(this).prepend(imgToPrepend).wrapInner('<a target="_blank" href="' + urlToLink + '"></a>');
- }
- });
- }
- },
-
// if sorting the columns is enabled, when clicking on a column,
// - if this column was already the one used for sorting, we revert the order desc<->asc
// - we send the ajax request with the new sorting information
@@ -732,6 +690,8 @@ dataTable.prototype =
$("td:first-child:even", domElem).addClass('label labelodd');
$("tr:odd td", domElem).slice(1).addClass('columnodd');
$("tr:even td", domElem).slice(1).addClass('columneven');
+
+ $('td span.label', domElem).each(function(){ self.truncate($(this)); } );
},
@@ -824,7 +784,6 @@ actionDataTable.prototype =
handleExportBox: dataTable.prototype.handleExportBox,
handleSort: dataTable.prototype.handleSort,
onClickSort: dataTable.prototype.onClickSort,
- handleLinkedRows: dataTable.prototype.handleLinkedRows,
truncate: dataTable.prototype.truncate,
handleOffsetInformation: dataTable.prototype.handleOffsetInformation,
setActiveIcon: dataTable.prototype.setActiveIcon,
@@ -864,7 +823,6 @@ actionDataTable.prototype =
self.handleExportBox(domElem);
self.handleSort(domElem);
- self.handleLinkedRows(domElem);
self.handleOffsetInformation(domElem);
if( self.workingDivId != undefined)
{
@@ -882,7 +840,7 @@ actionDataTable.prototype =
.css('font-weight','bold');
$("th:first-child", domElem).addClass('label');
-
+ $('td span.label', domElem).each(function(){ self.truncate($(this)); } );
var imagePlusMinusWidth = 12;
var imagePlusMinusHeight = 12;
$('tr.subActionsDataTable.rowToProcess td:first-child')
diff --git a/plugins/CoreHome/templates/datatable.tpl b/plugins/CoreHome/templates/datatable.tpl
index 76654601c4..b9cc8a655a 100644
--- a/plugins/CoreHome/templates/datatable.tpl
+++ b/plugins/CoreHome/templates/datatable.tpl
@@ -11,7 +11,7 @@
<thead>
<tr>
{foreach from=$dataTableColumns item=column name=head}
- <th class="sortable {if $smarty.foreach.head.first}first{elseif $smarty.foreach.head.last}last{/if}" id="{$column}"><div id="thDIV">{$columnTranslations[$column]}</div></th>
+ <th class="sortable {if $smarty.foreach.head.first}first{elseif $smarty.foreach.head.last}last{/if}" id="{$column}"><div id="thDIV">{$columnTranslations[$column]|escape:'html'}</div></th>
{/foreach}
</tr>
</thead>
@@ -19,13 +19,11 @@
<tbody>
{foreach from=$arrayDataTable item=row}
<tr {if $row.idsubdatatable && $javascriptVariablesToSet.controllerActionCalledWhenRequestSubTable != null}class="subDataTable" id="{$row.idsubdatatable}"{/if}>
-{foreach from=$dataTableColumns item=column}
-<td>
-{if !$row.idsubdatatable && $column=='label' && !empty($row.metadata.url)}<span class="urlLink">{$row.metadata.url}</span>{/if}
-{if $column=='label'}{logoHtml metadata=$row.metadata alt=$row.columns.label}{/if}
-{if isset($row.columns[$column])}{$row.columns[$column]}{else}{$defaultWhenColumnValueNotDefined}{/if}
-</td>
-{/foreach}
+ {foreach from=$dataTableColumns item=column}
+ <td>
+ {include file="CoreHome/templates/datatable_cell.tpl"}
+ </td>
+ {/foreach}
</tr>
{/foreach}
</tbody>
diff --git a/plugins/CoreHome/templates/datatable_actions.tpl b/plugins/CoreHome/templates/datatable_actions.tpl
index 46ac6c711d..3c6b4a0832 100644
--- a/plugins/CoreHome/templates/datatable_actions.tpl
+++ b/plugins/CoreHome/templates/datatable_actions.tpl
@@ -18,12 +18,11 @@
<tbody>
{foreach from=$arrayDataTable item=row}
<tr {if $row.idsubdatatable}class="rowToProcess subActionsDataTable" id="{$row.idsubdatatable}"{else} class="actionsDataTable rowToProcess"{/if}>
- {foreach from=$dataTableColumns item=column}
- <td>
- {if !$row.idsubdatatable && $column=='label' && isset($row.metadata.url)}<span class="urlLink">{$row.metadata.url}</span>{/if}
- {if isset($row.columns[$column])}{$row.columns[$column]}{else}{$defaultWhenColumnValueNotDefined}{/if}
- </td>
- {/foreach}
+ {foreach from=$dataTableColumns item=column}
+ <td>
+ {include file="CoreHome/templates/datatable_cell.tpl"}
+ </td>
+ {/foreach}
</tr>
{/foreach}
</tbody>
diff --git a/plugins/CoreHome/templates/datatable_actions_recursive.tpl b/plugins/CoreHome/templates/datatable_actions_recursive.tpl
index 60d95e6683..f624e07d3b 100644
--- a/plugins/CoreHome/templates/datatable_actions_recursive.tpl
+++ b/plugins/CoreHome/templates/datatable_actions_recursive.tpl
@@ -10,7 +10,7 @@
<thead>
<tr>
{foreach from=$dataTableColumns item=column}
- <th class="sortable" id="{$column}">{$columnTranslations[$column]}</td>
+ <th class="sortable" id="{$column}">{$columnTranslations[$column]|escape:'html'}</td>
{/foreach}
</tr>
</thead>
@@ -18,18 +18,20 @@
<tbody>
{foreach from=$arrayDataTable item=row}
<tr {if $row.idsubdatatable}class="level{$row.level} rowToProcess subActionsDataTable" id="{$row.idsubdatatable}"{else}class="actionsDataTable rowToProcess level{$row.level}"{/if}>
- {foreach from=$dataTableColumns item=column}
- <td>
- {if isset($row.columns[$column])}{$row.columns[$column]}{else}{$defaultWhenColumnValueNotDefined}{/if}
- </td>
- {/foreach}
+ {foreach from=$dataTableColumns item=column}
+ <td>
+ {include file="CoreHome/templates/datatable_cell.tpl"}
+ </td>
+ {/foreach}
</tr>
{/foreach}
</tbody>
</table>
{/if}
- {include file="CoreHome/templates/datatable_footer.tpl"}
+ {if $properties.show_footer}
+ {include file="CoreHome/templates/datatable_footer.tpl"}
+ {/if}
{include file="CoreHome/templates/datatable_actions_js.tpl"}
{/if}
</div>
diff --git a/plugins/CoreHome/templates/datatable_actions_subdatable.tpl b/plugins/CoreHome/templates/datatable_actions_subdatable.tpl
index dbd7b903c7..10c0921b69 100644
--- a/plugins/CoreHome/templates/datatable_actions_subdatable.tpl
+++ b/plugins/CoreHome/templates/datatable_actions_subdatable.tpl
@@ -9,8 +9,7 @@
<tr {if $row.idsubdatatable}class="subActionsDataTable" id="{$row.idsubdatatable}"{else}class="actionsDataTable"{/if}>
{foreach from=$dataTableColumns item=column}
<td>
- {if !$row.idsubdatatable && $column=='label' && isset($row.metadata.url)}<span class="urlLink">{$row.metadata.url}</span>{/if}
- {if isset($row.columns[$column])}{$row.columns[$column]}{else}{$defaultWhenColumnValueNotDefined}{/if}
+ {include file="CoreHome/templates/datatable_cell.tpl"}
</td>
{/foreach}
</tr>
diff --git a/plugins/CoreHome/templates/datatable_cell.tpl b/plugins/CoreHome/templates/datatable_cell.tpl
new file mode 100644
index 0000000000..d26d45c9f0
--- /dev/null
+++ b/plugins/CoreHome/templates/datatable_cell.tpl
@@ -0,0 +1,17 @@
+{if !$row.idsubdatatable && $column=='label' && !empty($row.metadata.url)}
+<a target="_blank" href='{if !in_array(substr($row.metadata.url,0,4), array('http','ftp:'))}http://{/if}{$row.metadata.url|escape:'html'}'>
+ {if empty($row.metadata.logo)}
+ <img class="link" width="10" height="9" src="themes/default/images/link.gif" />
+ {/if}
+{/if}
+{if $column=='label'}
+ {logoHtml metadata=$row.metadata alt=$row.columns.label}
+ <span class='label'>
+{/if}
+{if isset($row.columns[$column])}{$row.columns[$column]}{else}{$defaultWhenColumnValueNotDefined}{/if}
+{if $column=='label'}
+</span>
+{/if}
+{if !$row.idsubdatatable && $column=='label' && !empty($row.metadata.url)}
+ </a>
+{/if} \ No newline at end of file
diff --git a/plugins/CoreHome/templates/datatable_js.tpl b/plugins/CoreHome/templates/datatable_js.tpl
index 3c0571e600..0888a90672 100644
--- a/plugins/CoreHome/templates/datatable_js.tpl
+++ b/plugins/CoreHome/templates/datatable_js.tpl
@@ -4,7 +4,7 @@ $(document).ready(function(){literal}{{/literal}
dataTables['{$properties.uniqueId}'] = new {$dataTableClassName}();
dataTables['{$properties.uniqueId}'].param = {literal}{{/literal}
{foreach from=$javascriptVariablesToSet key=name item=value name=loop}
- {$name}: {if is_array($value)}'{','|implode:$value}'{else}'{$value}'{/if} {if !$smarty.foreach.loop.last},{/if}
+ '{$name|escape:'javascript'}': {if is_array($value)}'{','|implode:$value}'{else}'{$value}'{/if} {if !$smarty.foreach.loop.last},{/if}
{/foreach}
{literal}};{/literal}
dataTables['{$properties.uniqueId}'].init('{$properties.uniqueId}');
diff --git a/plugins/CoreHome/templates/header_message.tpl b/plugins/CoreHome/templates/header_message.tpl
index 877aa7da85..e1f906ce68 100644
--- a/plugins/CoreHome/templates/header_message.tpl
+++ b/plugins/CoreHome/templates/header_message.tpl
@@ -1,6 +1,7 @@
-{* testing *}
+{* testing, remove test_ from var names *}
{assign var=test_latest_version_available value="1.0"}
{assign var=test_piwikUrl value='http://demo.piwik.org/'}
+
<span id="header_message" class="{if $piwikUrl == 'http://demo.piwik.org/' || !$latest_version_available}header_info{else}header_alert{/if}">
<span class="header_short">
{if $piwikUrl == 'http://demo.piwik.org/'}
diff --git a/plugins/CoreHome/templates/js_global_variables.tpl b/plugins/CoreHome/templates/js_global_variables.tpl
index 83d5735fe2..ee7dd1c842 100644
--- a/plugins/CoreHome/templates/js_global_variables.tpl
+++ b/plugins/CoreHome/templates/js_global_variables.tpl
@@ -3,8 +3,8 @@
piwik.token_auth = "{$token_auth}";
piwik.piwik_url = "{$piwikUrl}";
{if isset($idSite)}piwik.idSite = "{$idSite}";{/if}
- {if isset($siteName)}piwik.siteName = "{$siteName}";{/if}
- {if isset($siteMainUrl)}piwik.siteMainUrl = "{$siteMainUrl}";{/if}
+ {if isset($siteName)}piwik.siteName = "{$siteName|escape:'javascript'}";{/if}
+ {if isset($siteMainUrl)}piwik.siteMainUrl = "{$siteMainUrl|escape:'javascript'}";{/if}
{if isset($period)}piwik.period = "{$period}";{/if}
{if isset($date)}piwik.currentDateString = "{$date}";{/if}
{if isset($minDateYear)}piwik.minDateYear = {$minDateYear};{/if}
diff --git a/plugins/CoreHome/templates/menu.tpl b/plugins/CoreHome/templates/menu.tpl
index 4fb5e422d0..46a9408165 100644
--- a/plugins/CoreHome/templates/menu.tpl
+++ b/plugins/CoreHome/templates/menu.tpl
@@ -5,7 +5,7 @@
<ul>
{foreach from=$level2 key=name item=urlParameters name=level2}
{if strpos($name, '_') !== 0}
- <li><a name='{$urlParameters._url|@urlRewriteWithParameters}' href='index.php{$urlParameters._url|@urlRewriteBasicView}'>{$name|translate}</a></li>
+ <li><a name='{$urlParameters._url|@urlRewriteWithParameters}' href='index.php{$urlParameters._url|@urlRewriteBasicView}'>{$name|translate|escape:'html'}</a></li>
{/if}
{/foreach}
</ul>
diff --git a/plugins/Dashboard/Controller.php b/plugins/Dashboard/Controller.php
index ae7750bf65..b3164485fc 100644
--- a/plugins/Dashboard/Controller.php
+++ b/plugins/Dashboard/Controller.php
@@ -91,16 +91,15 @@ class Piwik_Dashboard_Controller extends Piwik_Controller
$this->checkTokenInUrl();
$layout = Piwik_Common::getRequestVar('layout');
$idDashboard = Piwik_Common::getRequestVar('idDashboard', 1, 'int' );
- $currentUser = Piwik::getCurrentUserLogin();
- if($currentUser == 'anonymous')
+ if(Piwik::isUserIsAnonymous())
{
$session = new Piwik_Session_Namespace("Piwik_Dashboard");
$session->dashboardLayout = $layout;
- $session->setExpirationSeconds(86400);
+ $session->setExpirationSeconds(7*86400);
}
else
{
- $this->saveLayoutForUser($currentUser,$idDashboard, $layout);
+ $this->saveLayoutForUser(Piwik::getCurrentUserLogin(),$idDashboard, $layout);
}
}
@@ -112,12 +111,10 @@ class Piwik_Dashboard_Controller extends Piwik_Controller
protected function getLayout()
{
$idDashboard = Piwik_Common::getRequestVar('idDashboard', 1, 'int' );
- $currentUser = Piwik::getCurrentUserLogin();
- if($currentUser == 'anonymous')
+ if(Piwik::isUserIsAnonymous())
{
$session = new Piwik_Session_Namespace("Piwik_Dashboard");
-
if(!isset($session->dashboardLayout))
{
return false;
@@ -126,7 +123,7 @@ class Piwik_Dashboard_Controller extends Piwik_Controller
}
else
{
- $layout = $this->getLayoutForUser($currentUser,$idDashboard);
+ $layout = $this->getLayoutForUser(Piwik::getCurrentUserLogin(),$idDashboard);
}
// layout was JSON.stringified
diff --git a/plugins/ExampleAPI/tests/compareExpectedAndProcessedFiles.WinMerge b/plugins/ExampleAPI/tests/compareExpectedAndProcessedFiles.WinMerge
new file mode 100644
index 0000000000..e45988ed3c
--- /dev/null
+++ b/plugins/ExampleAPI/tests/compareExpectedAndProcessedFiles.WinMerge
@@ -0,0 +1,12 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+
+<project>
+ <paths>
+ <left>expected\</left>
+ <right>processed\</right>
+ <filter>*</filter>
+ <subfolders>0</subfolders>
+ <left-readonly>0</left-readonly>
+ <right-readonly>0</right-readonly>
+ </paths>
+</project>
diff --git a/plugins/ExampleAPI/tests/expected/test_allGetMethods__ExampleAPI.getMultiArray.xml b/plugins/ExampleAPI/tests/expected/test_allGetMethods__ExampleAPI.getMultiArray.xml
index 963d90548f..c279e76ac2 100644
--- a/plugins/ExampleAPI/tests/expected/test_allGetMethods__ExampleAPI.getMultiArray.xml
+++ b/plugins/ExampleAPI/tests/expected/test_allGetMethods__ExampleAPI.getMultiArray.xml
@@ -7,7 +7,7 @@
</Limitation>
<Second_Dimension>
<row>1</row>
- <row></row>
+ <row>0</row>
<row>1</row>
<row>0</row>
<row>152</row>
diff --git a/plugins/ExamplePlugin/ExamplePlugin.php b/plugins/ExamplePlugin/ExamplePlugin.php
index 46bacb63ab..6f6ab997ed 100644
--- a/plugins/ExamplePlugin/ExamplePlugin.php
+++ b/plugins/ExamplePlugin/ExamplePlugin.php
@@ -63,7 +63,6 @@ class Piwik_ExamplePlugin extends Piwik_Plugin
Piwik_AddWidget('ExamplePlugin_exampleWidgets', 'ExamplePlugin_blogPiwikRss', 'ExamplePlugin', 'blogPiwik');
Piwik_AddWidget('ExamplePlugin_exampleWidgets', 'ExamplePlugin_photostreamMatt', 'ExamplePlugin', 'photostreamMatt');
Piwik_AddWidget('ExamplePlugin_exampleWidgets', 'ExamplePlugin_piwikDownloads', 'ExamplePlugin', 'piwikDownloads');
- Piwik_AddWidget('ExamplePlugin_exampleWidgets', 'ExamplePlugin_websitesAndUsers', 'ExamplePlugin', 'websitesAndUsers');
}
}
@@ -123,15 +122,6 @@ class Piwik_ExamplePlugin_Controller extends Piwik_Controller
echo $view->render();
}
- function websitesAndUsers()
- {
- $view = Piwik_View::factory('websitesAndUsers');
- $view->siteCount = Piwik_FetchOne("SELECT COUNT(*) FROM piwik_site");
- $view->users = Piwik_FetchOne("SELECT COUNT(*) FROM piwik_user")+1; // + 1 for default admin user
- $view->version = Piwik_Version::VERSION;
- echo $view->render();
- }
-
/**
* This method displays a text containing an help about "How to build plugins for Piwik".
* This help is then used on http://dev.piwik.org/trac/wiki/Plugins/GlobalFunctions
diff --git a/plugins/ExamplePlugin/lang/en.php b/plugins/ExamplePlugin/lang/en.php
index a4aa6c0ea0..ee04745181 100644
--- a/plugins/ExamplePlugin/lang/en.php
+++ b/plugins/ExamplePlugin/lang/en.php
@@ -16,7 +16,6 @@ $translations = array(
'ExamplePlugin_exampleWidget' => 'Example widget',
'ExamplePlugin_blogPiwikRss' => 'Blog Piwik RSS',
'ExamplePlugin_photostreamMatt' => 'Matt\'s Photos',
- 'ExamplePlugin_websitesAndUsers' => 'Website and Users',
'ExamplePlugin_piwikDownloads' => 'Piwik Downloads',
'ExamplePlugin_PiwikHasBeenDownloaded' => 'On %s, Piwik was downloaded %s times.'
diff --git a/plugins/Feedback/Controller.php b/plugins/Feedback/Controller.php
index 6ec54178b7..081df12970 100644
--- a/plugins/Feedback/Controller.php
+++ b/plugins/Feedback/Controller.php
@@ -46,7 +46,7 @@ class Piwik_Feedback_Controller extends Piwik_Controller
{
throw new Exception(Piwik_TranslateException('UsersManager_ExceptionInvalidEmail'));
}
- if(strpos($body, 'http://') !== false)
+ if(preg_match('/https?:/i', $body))
{
throw new Exception(Piwik_TranslateException('Feedback_ExceptionNoUrls'));
}
diff --git a/plugins/Goals/API.php b/plugins/Goals/API.php
index 56a66fcf93..2fe16bb02d 100644
--- a/plugins/Goals/API.php
+++ b/plugins/Goals/API.php
@@ -37,6 +37,7 @@ class Piwik_Goals_API
*/
public function getGoals( $idSite )
{
+ Piwik::checkUserHasViewAccess($idSite);
$goals = Piwik_FetchAll("SELECT *
FROM ".Piwik_Common::prefixTable('goal')."
WHERE idsite = ?
diff --git a/plugins/Goals/Controller.php b/plugins/Goals/Controller.php
index 9111d8e22a..2076507c5d 100644
--- a/plugins/Goals/Controller.php
+++ b/plugins/Goals/Controller.php
@@ -32,8 +32,16 @@ class Piwik_Goals_Controller extends Piwik_Controller
public function __construct()
{
parent::__construct();
- $this->idSite = Piwik_Common::getRequestVar('idSite');
+ $this->idSite = Piwik_Common::getRequestVar('idSite', null, 'int');
$this->goals = Piwik_Goals_API::getInstance()->getGoals($this->idSite);
+ foreach($this->goals as &$goal)
+ {
+ $goal['name'] = Piwik_Common::sanitizeInputValue($goal['name']);
+ if(isset($goal['pattern']))
+ {
+ $goal['pattern'] = Piwik_Common::sanitizeInputValue($goal['pattern']);
+ }
+ }
}
public function widgetGoalReport()
@@ -168,13 +176,15 @@ class Piwik_Goals_Controller extends Piwik_Controller
if(empty($idGoal))
{
- $idGoal = Piwik_Common::getRequestVar('idGoal', false);
+ $idGoal = Piwik_Common::getRequestVar('idGoal', false, 'int');
}
$view = $this->getLastUnitGraph($this->pluginName, __FUNCTION__, 'Goals.get');
$view->setParametersToModify(array('idGoal' => $idGoal));
foreach($columns as $columnName)
{
+ $columnTranslation = '';
+
// find the right translation for this column, eg. find 'revenue' if column is Goal_1_revenue
foreach($this->goalColumnNameToLabel as $metric => $metricTranslation)
{
diff --git a/plugins/Goals/Goals.php b/plugins/Goals/Goals.php
index b10ffae95d..56dec06334 100644
--- a/plugins/Goals/Goals.php
+++ b/plugins/Goals/Goals.php
@@ -163,7 +163,7 @@ class Piwik_Goals extends Piwik_Plugin
function addWidgets()
{
Piwik_AddWidget('Goals_Goals', 'Goals_GoalsOverview', 'Goals', 'widgetGoalsOverview');
- $goals = Piwik_Tracker_GoalManager::getGoalDefinitions(Piwik_Common::getRequestVar('idSite'));
+ $goals = Piwik_Tracker_GoalManager::getGoalDefinitions(Piwik_Common::getRequestVar('idSite', null, 'int'));
if(count($goals) > 0)
{
foreach($goals as $goal)
@@ -175,7 +175,7 @@ class Piwik_Goals extends Piwik_Plugin
function addMenus()
{
- $goals = Piwik_Tracker_GoalManager::getGoalDefinitions(Piwik_Common::getRequestVar('idSite'));
+ $goals = Piwik_Tracker_GoalManager::getGoalDefinitions(Piwik_Common::getRequestVar('idSite', null, 'int'));
if(count($goals)==0)
{
Piwik_AddMenu('Goals_Goals', '', array('module' => 'Goals', 'action' => 'addNewGoal'), true, 25);
diff --git a/plugins/Installation/Controller.php b/plugins/Installation/Controller.php
index 7272f9bae5..843b9dc3ff 100644
--- a/plugins/Installation/Controller.php
+++ b/plugins/Installation/Controller.php
@@ -70,7 +70,7 @@ class Piwik_Installation_Controller extends Piwik_Controller
/**
* Installation Step 1: Welcome
*/
- function welcome($message)
+ function welcome($message = false)
{
// Delete merged js/css files to force regenerations based on updated activated plugin list
Piwik_AssetManager::removeMergedAssets();
@@ -494,7 +494,6 @@ class Piwik_Installation_Controller extends Piwik_Controller
$viewTrackingHelp->displaySiteName = $siteName;
$viewTrackingHelp->jsTag = Piwik::getJavascriptCode($idSite, Piwik_Url::getCurrentUrlWithoutFileName());
$viewTrackingHelp->idSite = $idSite;
- $viewTrackingHelp->currentUrlWithoutFilename = Piwik_Url::getCurrentUrlWithoutFileName();
// Assign the html output to a smarty variable
$view->trackingHelp = $viewTrackingHelp->render();
@@ -637,7 +636,7 @@ class Piwik_Installation_Controller extends Piwik_Controller
$message = Piwik_Translate('Installation_ErrorInvalidState',
array( '<br /><b>',
'</b>',
- '<a href=\''.Piwik_Url::getCurrentUrlWithoutFileName().'\'>',
+ '<a href=\''.Piwik_Common::sanitizeInputValue(Piwik_Url::getCurrentUrlWithoutFileName()).'\'>',
'</a>')
);
Piwik::exitWithErrorMessage( $message );
diff --git a/plugins/Installation/templates/systemCheck.tpl b/plugins/Installation/templates/systemCheck.tpl
index d1757b24b7..5d0695f2fb 100644
--- a/plugins/Installation/templates/systemCheck.tpl
+++ b/plugins/Installation/templates/systemCheck.tpl
@@ -31,7 +31,7 @@
{if $infos.isWindows}
{'Installation_SystemCheckWinPdoAndMysqliHelp'|translate:"<br /><br /><code>extension=php_mysqli.dll</code><br /><code>extension=php_pdo.dll</code><br /><code>extension=php_pdo_mysql.dll</code><br />"|nl2br}
{else}
- {'Installation_SystemCheckPdoAndMysqliHelp'|translate:"<br /><br /><code>--with-mysqli</code><br /><code>--with-pdo-mysql</code><br />":"<br /><br /><code>extension=mysqli.so</code><br /><code>extension=pdo.so</code><br /><code>extension=pdo_mysql.so</code><br />"|nl2br}
+ {'Installation_SystemCheckPdoAndMysqliHelp'|translate:"<br /><br /><code>--with-mysqli</code><br /><code>--with-pdo-mysql</code><br /><br />":"<br /><br /><code>extension=mysqli.so</code><br /><code>extension=pdo.so</code><br /><code>extension=pdo_mysql.so</code><br />"}
{/if}
<br />
{'Installation_SystemCheckPhpPdoAndMysqliSite'|translate}
diff --git a/plugins/LanguagesManager/tests/LanguagesManager.test.php b/plugins/LanguagesManager/tests/LanguagesManager.test.php
index c65224756f..ccc0104846 100644
--- a/plugins/LanguagesManager/tests/LanguagesManager.test.php
+++ b/plugins/LanguagesManager/tests/LanguagesManager.test.php
@@ -37,9 +37,14 @@ class Test_Languages_Manager extends UnitTestCase
$writeCleanedFile = false;
$strings = Piwik_LanguagesManager_API::getInstance()->getTranslationsForLanguage($language);
$content = ob_get_flush();
- $this->assertTrue(strpos(serialize($strings), "<script") === false, " language file containing javascript");
+ $serializedStrings = serialize($strings);
+ $invalids = array("<script", 'document.', 'javascript:', 'src=', 'BACKGROUND=', 'onload=' );
+ foreach($invalids as $invalid)
+ {
+ $this->assertTrue(stripos($serializedStrings, $invalid) === false, "$language: language file containing javascript");
+ }
$this->assertTrue(count($strings) > 100); // at least 100 translations in the language file
- $this->assertTrue(strlen($content) == 0, "buffer was ".strlen($content)." long but should be zero. Translation file for '$language' must be buggy.");
+ $this->assertTrue(strlen($content) == 0, "$language: buffer was ".strlen($content)." long but should be zero. Translation file for '$language' must be buggy.");
$cleanedStrings = array();
foreach($strings as $string)
@@ -79,6 +84,18 @@ class Test_Languages_Manager extends UnitTestCase
$cleanedStrings[$stringLabel] = $stringValue;
}
}
+ // remove excessive line breaks from translations
+ if($stringLabel != 'Login_MailPasswordRecoveryBody'
+ && !empty($cleanedStrings[$stringLabel]))
+ {
+ $stringNoLineBreak = str_replace(array("\n", "\r"), " ", $cleanedStrings[$stringLabel]);
+ if($cleanedStrings[$stringLabel] !== $stringNoLineBreak)
+ {
+ echo "$language: found line breaks in some strings in $stringLabel <br/>\n";
+ $writeCleanedFile = true;
+ $cleanedStrings[$stringLabel] = $stringNoLineBreak;
+ }
+ }
}
if($writeCleanedFile)
{
@@ -153,7 +170,7 @@ class Test_Languages_Manager extends UnitTestCase
}
else
{
- $this->assertTrue($name == $names);
+ $this->assertTrue($name == $names, "$language: failed because $name == $names <br/>");
}
}
else
diff --git a/plugins/Live/API.php b/plugins/Live/API.php
index 0f042f1d0a..9ee7461887 100644
--- a/plugins/Live/API.php
+++ b/plugins/Live/API.php
@@ -345,8 +345,7 @@ class Piwik_Live_API
private function cleanVisitorDetails( &$visitorDetails, $idSite )
{
$toUnset = array('config_md5config');
- if(!Piwik::isUserIsSuperUser()
- && !Piwik::isUserHasAdminAccess($idSite))
+ if(Piwik::isUserIsAnonymous())
{
$toUnset[] = 'visitor_idcookie';
$toUnset[] = 'location_ip';
diff --git a/plugins/Live/Controller.php b/plugins/Live/Controller.php
index 3d166a8207..c84bdfe477 100644
--- a/plugins/Live/Controller.php
+++ b/plugins/Live/Controller.php
@@ -18,7 +18,6 @@ class Piwik_Live_Controller extends Piwik_Controller
function __construct()
{
parent::__construct();
- $this->idSite = Piwik_Common::getRequestVar('idSite');
$this->minIdVisit = Piwik_Common::getRequestVar('minIdVisit', 0, 'int');
}
@@ -30,7 +29,7 @@ class Piwik_Live_Controller extends Piwik_Controller
public function widget($fetch = false)
{
$view = Piwik_View::factory('index');
- $view->idSite = Piwik_Common::getRequestVar('idSite');
+ $view->idSite = $this->idSite;
$view->visitorsCountHalfHour = $this->getUsersInLastXMin(30);
$view->visitorsCountToday = $this->getUsersInLastXDays(1);
$view->pisHalfhour = $this->getPageImpressionsInLastXMin(30);
@@ -77,7 +76,7 @@ class Piwik_Live_Controller extends Piwik_Controller
public function getLastVisitsStart($fetch = false)
{
$view = Piwik_View::factory('lastVisits');
- $view->idSite = Piwik_Common::getRequestVar('idSite');
+ $view->idSite = $this->idSite;
$view->visitors = $this->getLastVisits(10);
@@ -129,7 +128,7 @@ class Piwik_Live_Controller extends Piwik_Controller
public function ajaxTotalVisitors($fetch = false)
{
$view = Piwik_View::factory('totalVisits');
- $view->idSite = Piwik_Common::getRequestVar('idSite');
+ $view->idSite = $this->idSite;
$view->visitorsCountHalfHour = $this->getUsersInLastXMin(30);
$view->visitorsCountToday = $this->getUsersInLastXDays(1);
$view->pisHalfhour = $this->getPageImpressionsInLastXMin(30);
diff --git a/plugins/Live/Live.php b/plugins/Live/Live.php
index 3a051e5aba..01dd23a9d6 100644
--- a/plugins/Live/Live.php
+++ b/plugins/Live/Live.php
@@ -56,8 +56,9 @@ class Piwik_Live extends Piwik_Plugin
Piwik_AddMenu('General_Visitors', 'Live_VisitorLog', array('module' => 'Live', 'action' => 'getVisitorLog'));
}
- public function addWidget() {
- Piwik_AddWidget('Live!', 'Live Visitors!', 'Live', 'widget');
+ public function addWidget()
+ {
+ Piwik_AddWidget('Live!', 'Live_VisitorsInRealTime', 'Live', 'widget');
}
}
diff --git a/plugins/Live/templates/lastVisits.tpl b/plugins/Live/templates/lastVisits.tpl
index 3fa1423cff..404bcedac0 100644
--- a/plugins/Live/templates/lastVisits.tpl
+++ b/plugins/Live/templates/lastVisits.tpl
@@ -12,8 +12,8 @@
</div>
<!--<div class="settings"></div>-->
<div class="referer">
- {if $visitor.refererType != 'directEntry'}from <a href="{$visitor.refererUrl}" target="_blank">{if !empty($visitor.searchEngineIcon)}<img src="{$visitor.searchEngineIcon}" /> {/if}{$visitor.refererName}</a>
- {if !empty($visitor.keywords)}"{$visitor.keywords}"{/if}
+ {if $visitor.refererType != 'directEntry'}from <a href="{$visitor.refererUrl|escape:'html'}" target="_blank">{if !empty($visitor.searchEngineIcon)}<img src="{$visitor.searchEngineIcon}" /> {/if}{$visitor.refererName|escape:'html'}</a>
+ {if !empty($visitor.keywords)}"{$visitor.keywords|escape:'html'}"{/if}
{/if}
{if $visitor.refererType == 'directEntry'}{'Referers_DirectEntry'|translate}{/if}
</div>
@@ -28,7 +28,7 @@
$col=0;
}
{/php}
- <a href="{$action.pageUrl}" target="_blank"><img align="middle" src="plugins/Live/templates/images/file{php} echo $col; {/php}.png" title="{$action.pageUrl}" /></a>
+ <a href="{$action.pageUrl|escape:'html'}" target="_blank"><img align="middle" src="plugins/Live/templates/images/file{php} echo $col; {/php}.png" title="{$action.pageUrl|escape:'html'}" /></a>
{/foreach}
</div>
</div>
diff --git a/plugins/Live/templates/totalVisits.tpl b/plugins/Live/templates/totalVisits.tpl
index 8131130d37..36d8558eb3 100644
--- a/plugins/Live/templates/totalVisits.tpl
+++ b/plugins/Live/templates/totalVisits.tpl
@@ -12,7 +12,7 @@
</thead>
<tbody>
<tr class="">
- <td class="columnodd">{'General_Today'|translate}</td>
+ <td class="columnodd">{'Live_LastHours'|translate:24}</td>
<td class="columnodd">{$visitorsCountToday}</td>
<td class="columnodd">{$pisToday}</td>
</tr>
diff --git a/plugins/Live/templates/visitorLog.tpl b/plugins/Live/templates/visitorLog.tpl
index bab4a45311..6ff08902a4 100644
--- a/plugins/Live/templates/visitorLog.tpl
+++ b/plugins/Live/templates/visitorLog.tpl
@@ -66,27 +66,27 @@
<div class="referer">
{if $visitor.columns.refererType == 'website'}
{'Referers_ColumnWebsite'|translate}:
- <a href="{$visitor.columns.refererUrl}" target="_blank" title="{$visitor.columns.refererUrl}" style="text-decoration:underline;">
- {$visitor.columns.refererName}
+ <a href="{$visitor.columns.refererUrl|escape:'html'}" target="_blank" title="{$visitor.columns.refererUrl|escape:'html'}" style="text-decoration:underline;">
+ {$visitor.columns.refererName|escape:'html'}
</a>
{/if}
{if $visitor.columns.refererType == 'campaign'}
{'Referers_Campaigns'|translate}
<br />
- <a href="{$visitor.columns.refererUrl}" target="_blank" title="{$visitor.columns.refererUrl}" style="text-decoration:underline;">
- {$visitor.columns.refererName}
+ <a href="{$visitor.columns.refererUrl|escape:'html'}" target="_blank" title="{$visitor.columns.refererUrl|escape:'html'}" style="text-decoration:underline;">
+ {$visitor.columns.refererName|escape:'html'}
</a>
{/if}
{if $visitor.columns.refererType == 'searchEngine'}
{if !empty($visitor.columns.searchEngineIcon)}
- <img src="{$visitor.columns.searchEngineIcon}" alt="{$visitor.columns.refererName}" />
+ <img src="{$visitor.columns.searchEngineIcon}" alt="{$visitor.columns.refererName|escape:'html'}" />
{/if}
- {$visitor.columns.refererName}
+ {$visitor.columns.refererName|escape:'html'}
<br />
{if !empty($visitor.columns.keywords)}{'Referers_Keywords'|translate}:{/if}
- <a href="{$visitor.columns.refererUrl}" target="_blank" style="text-decoration:underline;">
+ <a href="{$visitor.columns.refererUrl|escape:'html'}" target="_blank" style="text-decoration:underline;">
{if !empty($visitor.columns.keywords)}
- "{$visitor.columns.keywords}"
+ "{$visitor.columns.keywords|escape:'html'}"
{/if}
</a>
{/if}
@@ -107,7 +107,7 @@
<ol style="list-style:decimal inside none;">
{foreach from=$visitor.columns.actionDetails item=action}
<li>
- <a href="{$action.pageUrl}" target="_blank" style="text-decoration:underline;" title="{$action.pageUrl}">{$action.pageUrl|truncate:80:"...":true}</a>
+ <a href="{$action.pageUrl|escape:'html'}" target="_blank" style="text-decoration:underline;" title="{$action.pageUrl|escape:'html'}">{$action.pageUrl|escape:'html'|truncate:80:"...":true}</a>
{if $visitor.columns.goalUrl eq $action.pageIdAction}
<ul class="actionGoalDetails">
<li>
diff --git a/plugins/Login/Auth.php b/plugins/Login/Auth.php
index 57589e3d0a..bd52367c49 100644
--- a/plugins/Login/Auth.php
+++ b/plugins/Login/Auth.php
@@ -42,7 +42,7 @@ class Piwik_Login_Auth implements Piwik_Auth
if(is_null($this->login))
{
- if($this->token_auth == $rootToken)
+ if($this->token_auth === $rootToken)
{
return new Piwik_Auth_Result(Piwik_Auth_Result::SUCCESS_SUPERUSER_AUTH_CODE, $rootLogin, $this->token_auth );
}
@@ -53,16 +53,16 @@ class Piwik_Login_Auth implements Piwik_Auth
WHERE token_auth = ?',
array($this->token_auth)
);
- if($login !== false)
+ if(!empty($login))
{
return new Piwik_Auth_Result(Piwik_Auth_Result::SUCCESS, $login, $this->token_auth );
}
}
else if(!empty($this->login))
{
- if($this->login == $rootLogin
- && ($this->getHashTokenAuth($rootLogin, $rootToken) == $this->token_auth)
- || $rootToken == $this->token_auth)
+ if($this->login === $rootLogin
+ && ($this->getHashTokenAuth($rootLogin, $rootToken) === $this->token_auth)
+ || $rootToken === $this->token_auth)
{
$this->setTokenAuth($rootToken);
return new Piwik_Auth_Result(Piwik_Auth_Result::SUCCESS_SUPERUSER_AUTH_CODE, $rootLogin, $this->token_auth );
@@ -75,9 +75,9 @@ class Piwik_Login_Auth implements Piwik_Auth
WHERE login = ?',
array($login)
);
- if($userToken !== false
- && (($this->getHashTokenAuth($login, $userToken) == $this->token_auth)
- || $userToken == $this->token_auth))
+ if(!empty($userToken)
+ && (($this->getHashTokenAuth($login, $userToken) === $this->token_auth)
+ || $userToken === $this->token_auth))
{
$this->setTokenAuth($userToken);
return new Piwik_Auth_Result(Piwik_Auth_Result::SUCCESS, $login, $userToken );
diff --git a/plugins/Login/Controller.php b/plugins/Login/Controller.php
index e2c8ec95e5..2d5da5e98f 100644
--- a/plugins/Login/Controller.php
+++ b/plugins/Login/Controller.php
@@ -105,7 +105,7 @@ class Piwik_Login_Controller extends Piwik_Controller
$currentUrl = 'index.php';
$urlToRedirect = Piwik_Common::getRequestVar('url', $currentUrl, 'string');
- $urlToRedirect = htmlspecialchars_decode($urlToRedirect);
+ $urlToRedirect = Piwik_Common::unsanitizeInputValue($urlToRedirect);
$this->authenticateAndRedirect($login, $password, false, $urlToRedirect);
}
@@ -178,7 +178,7 @@ class Piwik_Login_Controller extends Piwik_Controller
$resetToken = self::generatePasswordResetToken($user);
$ip = Piwik_Common::getIpString();
- $url = Piwik_Url::getCurrentUrlWithoutQueryString() . "?module=Login&action=resetPassword&token=$resetToken";
+ $url = Piwik_Common::sanitizeInputValue(Piwik_Url::getCurrentUrlWithoutQueryString() . "?module=Login&action=resetPassword&token=$resetToken");
// send email with new password
try
diff --git a/plugins/Login/tests/Login.test.php b/plugins/Login/tests/Login.test.php
index 6eb875a31f..207bf4124e 100644
--- a/plugins/Login/tests/Login.test.php
+++ b/plugins/Login/tests/Login.test.php
@@ -88,6 +88,12 @@ class Test_Piwik_Login extends Test_Database
$rc = $auth->authenticate();
$this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+ // not equal
+ $auth->setLogin('anonymous');
+ $auth->setTokenAuth(0);
+ $rc = $auth->authenticate();
+ $this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+
// API authentication
$auth->setLogin(null);
$auth->setTokenAuth('anonymous');
@@ -132,6 +138,24 @@ class Test_Piwik_Login extends Test_Database
$rc = $auth->authenticate();
$this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+ // not equal
+ $auth->setLogin(0);
+ $auth->setTokenAuth(0);
+ $rc = $auth->authenticate();
+ $this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+
+ // not equal
+ $auth->setLogin(0);
+ $auth->setTokenAuth($tokenAuth);
+ $rc = $auth->authenticate();
+ $this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+
+ // not equal
+ $auth->setLogin($user['login']);
+ $auth->setTokenAuth(0);
+ $rc = $auth->authenticate();
+ $this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+
// API authentication
$auth->setLogin(null);
$auth->setTokenAuth($tokenAuth);
@@ -179,6 +203,12 @@ class Test_Piwik_Login extends Test_Database
$rc = $auth->authenticate();
$this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+ // not equal
+ $auth->setLogin($user['login']);
+ $auth->setTokenAuth(0);
+ $rc = $auth->authenticate();
+ $this->assertEqual( $rc->getCode(), Piwik_Auth_Result::FAILURE );
+
// API authentication
$auth->setLogin(null);
$auth->setTokenAuth($tokenAuth);
diff --git a/plugins/MultiSites/templates/index.tpl b/plugins/MultiSites/templates/index.tpl
index 017a06fac2..f729f1ca78 100644
--- a/plugins/MultiSites/templates/index.tpl
+++ b/plugins/MultiSites/templates/index.tpl
@@ -8,7 +8,7 @@
var allSites = new Array();
var params = new Array();
{foreach from=$mySites key=i item=site}
- allSites[{$i}] = new setRowData({$site.idsite}, {$site.visits}, {$site.actions}, {$site.unique}, '{$site.name|escape:"quotes"}', '{$site.main_url}', '{$site.visitsSummaryValue|replace:",":"."}', '{$site.actionsSummaryValue|replace:",":"."}', '{$site.uniqueSummaryValue|replace:",":"."}');
+ allSites[{$i}] = new setRowData({$site.idsite}, {$site.visits}, {$site.actions}, {$site.unique}, '{$site.name|escape:"javascript"}', '{$site.main_url|escape:"javascript"}', '{$site.visitsSummaryValue|replace:",":"."}', '{$site.actionsSummaryValue|replace:",":"."}', '{$site.uniqueSummaryValue|replace:",":"."}');
{/foreach}
params['period'] = '{$period}';
params['date'] = '{$date}';
@@ -19,8 +19,8 @@
params['site'] = '{$site}';
params['limit'] = '{$limit}';
params['page'] = 1;
- params['prev'] = "{'General_Previous'|translate}";
- params['next'] = "{'General_Next'|translate}";
+ params['prev'] = "{'General_Previous'|translate|escape:"javascript"}";
+ params['next'] = "{'General_Next'|translate|escape:"javascript"}";
params['row'] = '{$row|escape:"javascript"}';
</script>
diff --git a/plugins/SEO/Controller.php b/plugins/SEO/Controller.php
index ce92286a92..7f41522b21 100644
--- a/plugins/SEO/Controller.php
+++ b/plugins/SEO/Controller.php
@@ -21,12 +21,13 @@ class Piwik_SEO_Controller extends Piwik_Controller
$site = new Piwik_Site($idSite);
$url = urldecode(Piwik_Common::getRequestVar('url', '', 'string'));
- if(empty($url))
+
+ if(empty($url) || @parse_url($url) === false)
{
$url = $site->getMainUrl();
}
- $dataTable = Piwik_SEO_API::getInstance()->getRank($url);
+ $dataTable = Piwik_SEO_API::getInstance()->getRank($url);
$view = Piwik_View::factory('index');
$view->urlToRank = $url;
diff --git a/plugins/SEO/templates/index.tpl b/plugins/SEO/templates/index.tpl
index 76c16ba910..9484f14cc4 100644
--- a/plugins/SEO/templates/index.tpl
+++ b/plugins/SEO/templates/index.tpl
@@ -4,7 +4,7 @@
<form method="post" style="padding: 8px;" >
<div align="left" class="mediumtext">
{'Installation_SetupWebSiteURL'|translate|ucfirst}
- <input type="text" id="seoUrl" size="30" value="{$urlToRank}" class="textbox" />
+ <input type="text" id="seoUrl" size="30" value="{$urlToRank|escape:'html'}" class="textbox" />
<span style="padding-left:2px;">
<input type="submit" id="rankbutton" value="{'SEO_Rank'|translate}" />
</span>
@@ -16,7 +16,10 @@
{if empty($ranks)}
{'General_Error'|translate}
{else}
- {'SEO_SEORankingsFor'|translate:"<a href='$urlToRank' target='_blank'>$urlToRank</a>"}
+{capture name=cleanUrl}
+<a href='{$urlToRank|escape:'html'}' target='_blank'>{$urlToRank|escape:'html'}</a>
+{/capture}
+ {'SEO_SEORankingsFor'|translate:$smarty.capture.cleanUrl}
<table cellspacing='2' style='margin:auto;line-height:1.5em;padding-top:10px'>
{foreach from=$ranks item=rank}
<tr>
diff --git a/plugins/SitesManager/API.php b/plugins/SitesManager/API.php
index 1079ff5115..23ab2b8381 100644
--- a/plugins/SitesManager/API.php
+++ b/plugins/SitesManager/API.php
@@ -51,11 +51,11 @@ class Piwik_SitesManager_API
{
$piwikUrl = Piwik_Url::getCurrentUrlWithoutFileName();
}
- $piwikUrl = addslashes(Piwik_Common::sanitizeInputValues($piwikUrl));
+ $piwikUrl = Piwik_Common::sanitizeInputValues($piwikUrl);
$htmlEncoded = Piwik::getJavascriptCode($idSite, $piwikUrl);
$htmlEncoded = str_replace(array('<br>','<br />','<br/>'), '', $htmlEncoded);
- return html_entity_decode($htmlEncoded);
+ return $htmlEncoded;
}
/**
@@ -906,7 +906,7 @@ class Piwik_SitesManager_API
WHERE ( s.name like ?
OR s.main_url like ?)
AND idsite in ($ids_str)
- LIMIT ".Zend_Registry::get('config')->General->site_selector_max_sites,
+ LIMIT ".Piwik::getWebsitesCountToDisplay(),
$bind) ;
return $sites;
}
diff --git a/plugins/SitesManager/Controller.php b/plugins/SitesManager/Controller.php
index 86f3ad6f03..28aedf527e 100644
--- a/plugins/SitesManager/Controller.php
+++ b/plugins/SitesManager/Controller.php
@@ -91,7 +91,6 @@ class Piwik_SitesManager_Controller extends Piwik_Controller
$site = new Piwik_Site($idSite);
$view->displaySiteName = $site->getName();
$view->jsTag = $jsTag;
- $view->currentUrlWithoutFilename = Piwik_Url::getCurrentUrlWithoutFileName();
echo $view->render();
}
@@ -116,9 +115,6 @@ class Piwik_SitesManager_Controller extends Piwik_Controller
$view->idSite = Piwik_Common::getRequestVar('idSite');
$view->piwikUrl = Piwik_Common::getRequestVar('piwikUrl');
$view->calledExternally = true;
-
- // Links are prefixed, need to be absolute for this page as it is externally loaded
- $view->currentUrlWithoutFilename = Piwik_Url::getCurrentUrlWithoutFileName();
echo $view->render();
}
diff --git a/plugins/UsersManager/Controller.php b/plugins/UsersManager/Controller.php
index 3977253e47..305ad68612 100644
--- a/plugins/UsersManager/Controller.php
+++ b/plugins/UsersManager/Controller.php
@@ -30,7 +30,7 @@ class Piwik_UsersManager_Controller extends Piwik_Controller
if(count($IdSitesAdmin) > 0)
{
$defaultWebsiteId = $IdSitesAdmin[0];
- $idSiteSelected = Piwik_Common::getRequestVar('idsite', $defaultWebsiteId);
+ $idSiteSelected = Piwik_Common::getRequestVar('idsite', $defaultWebsiteId, 'int');
}
if($idSiteSelected==='all')
@@ -67,7 +67,6 @@ class Piwik_UsersManager_Controller extends Piwik_Controller
$view->idSiteSelected = $idSiteSelected;
$view->users = $users;
$view->usersAccessByWebsite = $usersAccessByWebsite;
- $view->formUrl = Piwik_Url::getCurrentUrl();
$view->websites = Piwik_SitesManager_API::getInstance()->getSitesWithAdminAccess();
$this->setBasicVariablesView($view);
$view->menu = Piwik_GetAdminMenu();
diff --git a/plugins/Widgetize/Controller.php b/plugins/Widgetize/Controller.php
index 809f6c5a5c..cb785bb8a9 100644
--- a/plugins/Widgetize/Controller.php
+++ b/plugins/Widgetize/Controller.php
@@ -41,7 +41,10 @@ class Piwik_Widgetize_Controller extends Piwik_Controller
echo $view->render();
}
- function js()
+ /**
+ * Disabled for now, not obvious that this is useful (iframe sounds like a better solution)
+ */
+ private function js()
{
Piwik_API_Request::reloadAuthUsingTokenAuth();
$controllerName = Piwik_Common::getRequestVar('moduleToWidgetize');
@@ -49,7 +52,6 @@ class Piwik_Widgetize_Controller extends Piwik_Controller
$parameters = array ( $fetch = true );
$content = Piwik_FrontController::getInstance()->fetchDispatch( $controllerName, $actionName, $parameters);
$view = Piwik_View::factory('js');
- $view->piwikUrl = Piwik_Url::getCurrentUrlWithoutFileName();
$content = str_replace(array("\t","\n","\r\n","\r"), "", $content);
$view->content = $content;
echo $view->render();
diff --git a/plugins/Widgetize/templates/widgetize.js b/plugins/Widgetize/templates/widgetize.js
index 48abb7e135..cd38dbb2c5 100644
--- a/plugins/Widgetize/templates/widgetize.js
+++ b/plugins/Widgetize/templates/widgetize.js
@@ -56,10 +56,11 @@ function widgetize()
self.deleteEmbedElements();
var exportButtonsElement = $('<span id="exportButtons">');
+ var urlIframe = self.getEmbedUrl(widgetParameters, "iframe");
// We first build the HTML code that will load the widget in an IFRAME
var widgetIframeHtml = '<div id="widgetIframe">'+
'<iframe width="100%" height="350" src="'+
- self.getEmbedUrl(widgetParameters, "iframe")+
+ urlIframe +
'" scrolling="no" frameborder="0" marginheight="0" marginwidth="0">'+
'</iframe>'+
'</div>';
@@ -71,7 +72,10 @@ function widgetize()
'<span id="embedThisWidgetIframeInput">'+
self.getInputFormWithHtml('iframeEmbed', widgetIframeHtml)+
'</span>'+
- '</div>'
+ '</div>' +
+ '<div> <label for="embedThisWidgetDirectLink">&rsaquo; Direct Link</label>'+
+ '<span id="embedThisWidgetDirectLink"> '+self.getInputFormWithHtml('directLinkEmbed', urlIframe)+' - <a href="'+urlIframe+'" target="_blank">'+_pk_translate('General_OpenInNewWindow_js')+'</a></span>'
+ +'</div>'
);
// Add the Flash Export if a flash <embed> is found in the widget
diff --git a/tests/core/Common.test.php b/tests/core/Common.test.php
index 86325a3507..bf1d106577 100644
--- a/tests/core/Common.test.php
+++ b/tests/core/Common.test.php
@@ -62,17 +62,17 @@ class Test_Piwik_Common extends UnitTestCase
// sanitize an array OK
function test_sanitizeInputValues_array1()
{
- $a1 = array('test1' => 't1', 't45', "teatae''", 4568, array('test'), 1.52);
+ $a1 = array('test1' => 't1', 't45', "teatae", 4568, array('test'), 1.52);
$this->assertEqual( $a1, Piwik_Common::sanitizeInputValues($a1));
}
// sanitize an array OK
function test_sanitizeInputValues_array2()
{
- $a1 = array('test1' => 't1', 't45', "teatae''", 4568, array('test'), 1.52,
- array('test1' => 't1', 't45', "teatae''", 4568, array('test'), 1.52),
- array('test1' => 't1', 't45', "teatae''", 4568, array('test'), 1.52),
- array( array(array(array('test1' => 't1', 't45', "teatae''", 4568, array('test'), 1.52)))
+ $a1 = array('test1' => 't1', 't45', "teatae", 4568, array('test'), 1.52,
+ array('test1' => 't1', 't45', "teatae", 4568, array('test'), 1.52),
+ array('test1' => 't1', 't45', "teatae", 4568, array('test'), 1.52),
+ array( array(array(array('test1' => 't1', 't45', "teatae", 4568, array('test'), 1.52)))
));
$this->assertEqual( $a1, Piwik_Common::sanitizeInputValues($a1));
}
@@ -108,7 +108,7 @@ class Test_Piwik_Common extends UnitTestCase
function test_sanitizeInputValues_badString()
{
$string = '& " < > 123abc\'';
- $stringOK = '&amp; &quot; &lt; &gt; 123abc\'';
+ $stringOK = '&amp; &quot; &lt; &gt; 123abc&#039;';
$this->assertEqual($stringOK, Piwik_Common::sanitizeInputValues($string));
}
@@ -130,7 +130,7 @@ class Test_Piwik_Common extends UnitTestCase
function test_sanitizeInputValues_HTML()
{
$html = "<test toto='mama' piwik=\"cool\">Piwik!!!!!</test>";
- $htmlOK = "&lt;test toto='mama' piwik=&quot;cool&quot;&gt;Piwik!!!!!&lt;/test&gt;";
+ $htmlOK = "&lt;test toto=&#039;mama&#039; piwik=&quot;cool&quot;&gt;Piwik!!!!!&lt;/test&gt;";
$this->assertEqual($htmlOK, Piwik_Common::sanitizeInputValues($html));
}
@@ -138,7 +138,7 @@ class Test_Piwik_Common extends UnitTestCase
function test_sanitizeInputValues_SQLQuery()
{
$sql = "SELECT piwik FROM piwik_tests where test= 'super\"value' AND cool=toto #comment here";
- $sqlOK = "SELECT piwik FROM piwik_tests where test= 'super&quot;value' AND cool=toto #comment here";
+ $sqlOK = "SELECT piwik FROM piwik_tests where test= &#039;super&quot;value&#039; AND cool=toto #comment here";
$this->assertEqual($sqlOK, Piwik_Common::sanitizeInputValues($sql));
}
@@ -175,15 +175,12 @@ class Test_Piwik_Common extends UnitTestCase
// sanitize with magic quotes off
function test_sanitizeInputValues_magicquotesOFF()
{
-
$this->assertTrue(@set_magic_quotes_runtime(0));
$this->assertEqual(@get_magic_quotes_runtime(), 0);
$this->test_sanitizeInputValues_array1();
$this->test_sanitizeInputValues_array2();
$this->test_sanitizeInputValues_badString();
$this->test_sanitizeInputValues_HTML();
-
-
}
/**
@@ -317,7 +314,7 @@ class Test_Piwik_Common extends UnitTestCase
$_GET['test'] = '';
$this->assertEqual( Piwik_Common::getRequestVar('test', 45, 'string'), '45');
$this->assertEqual( Piwik_Common::getRequestVar('test', "geaga", 'string'), "geaga");
- $this->assertEqual( Piwik_Common::getRequestVar('test', "'}{}}{}{}'", 'string'), "'}{}}{}{}'");
+ $this->assertEqual( Piwik_Common::getRequestVar('test', "&#039;}{}}{}{}&#039;", 'string'), "&#039;}{}}{}{}&#039;");
}
diff --git a/tests/integration/Main.test.php b/tests/integration/Main.test.php
index 05a9fb9618..bd703574de 100644
--- a/tests/integration/Main.test.php
+++ b/tests/integration/Main.test.php
@@ -62,7 +62,7 @@ class Test_Piwik_Integration_Main extends Test_Integration
function test_apiGetReportMetadata_year()
{
$this->setApiNotToCall(array());
- $this->setApiToCall( 'API.getProcessedReport' );
+ $this->setApiToCall( array('API.getProcessedReport', 'LanguagesManager.getTranslationsForLanguage', 'LanguagesManager.getAvailableLanguageNames') );
$dateTime = '2009-01-04 00:11:42';
$idSite = $this->createWebsite($dateTime);
$language = 'fr';
@@ -216,6 +216,7 @@ class Test_Piwik_Integration_Main extends Test_Integration
// End of second visit
}
+
/*
* Tests Tracker several websites, different days.
* Tests API for period=day/week/month/year, requesting data for both websites,
diff --git a/tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getAvailableLanguageNames.xml b/tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getAvailableLanguageNames.xml
new file mode 100644
index 0000000000..03c94e4a52
--- /dev/null
+++ b/tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getAvailableLanguageNames.xml
@@ -0,0 +1,198 @@
+<?xml version="1.0" encoding="utf-8" ?>
+<result>
+ <row>
+ <code>am</code>
+ <name>አማርኛ</name>
+ <english_name>Amharic</english_name>
+ </row>
+ <row>
+ <code>ar</code>
+ <name>العربية</name>
+ <english_name>Arabic</english_name>
+ </row>
+ <row>
+ <code>be</code>
+ <name>Беларуская</name>
+ <english_name>Belarusian</english_name>
+ </row>
+ <row>
+ <code>bg</code>
+ <name>Български</name>
+ <english_name>Bulgarian</english_name>
+ </row>
+ <row>
+ <code>ca</code>
+ <name>Català</name>
+ <english_name>Catalan</english_name>
+ </row>
+ <row>
+ <code>cs</code>
+ <name>Česky</name>
+ <english_name>Czech</english_name>
+ </row>
+ <row>
+ <code>da</code>
+ <name>Dansk</name>
+ <english_name>Danish</english_name>
+ </row>
+ <row>
+ <code>de</code>
+ <name>Deutsch</name>
+ <english_name>German</english_name>
+ </row>
+ <row>
+ <code>el</code>
+ <name>Ελληνικά</name>
+ <english_name>Greek</english_name>
+ </row>
+ <row>
+ <code>en</code>
+ <name>English</name>
+ <english_name>English</english_name>
+ </row>
+ <row>
+ <code>es</code>
+ <name>Español</name>
+ <english_name>Spanish</english_name>
+ </row>
+ <row>
+ <code>et</code>
+ <name>Eesti keel</name>
+ <english_name>Estonian</english_name>
+ </row>
+ <row>
+ <code>eu</code>
+ <name>Euskara</name>
+ <english_name>Basque</english_name>
+ </row>
+ <row>
+ <code>fi</code>
+ <name>Suomi</name>
+ <english_name>Finnish</english_name>
+ </row>
+ <row>
+ <code>fr</code>
+ <name>Français</name>
+ <english_name>French</english_name>
+ </row>
+ <row>
+ <code>gl</code>
+ <name>Galego</name>
+ <english_name>Galician</english_name>
+ </row>
+ <row>
+ <code>hu</code>
+ <name>Magyar</name>
+ <english_name>Hungarian</english_name>
+ </row>
+ <row>
+ <code>it</code>
+ <name>Italiano</name>
+ <english_name>Italian</english_name>
+ </row>
+ <row>
+ <code>ja</code>
+ <name>日本語</name>
+ <english_name>Japanese</english_name>
+ </row>
+ <row>
+ <code>ko</code>
+ <name>한국어</name>
+ <english_name>Korean</english_name>
+ </row>
+ <row>
+ <code>lt</code>
+ <name>Lietuvių</name>
+ <english_name>Lithuanian</english_name>
+ </row>
+ <row>
+ <code>nb</code>
+ <name>Norsk (bokmål)</name>
+ <english_name>Norwegian Bokmål</english_name>
+ </row>
+ <row>
+ <code>nl</code>
+ <name>Nederlands</name>
+ <english_name>Dutch</english_name>
+ </row>
+ <row>
+ <code>nn</code>
+ <name>Nynorsk</name>
+ <english_name>Norwegian Nynorsk</english_name>
+ </row>
+ <row>
+ <code>pl</code>
+ <name>Polski</name>
+ <english_name>Polish</english_name>
+ </row>
+ <row>
+ <code>pt-br</code>
+ <name>Português brasileiro</name>
+ <english_name>Brazilian Portuguese</english_name>
+ </row>
+ <row>
+ <code>pt</code>
+ <name>Português</name>
+ <english_name>Portuguese</english_name>
+ </row>
+ <row>
+ <code>ro</code>
+ <name>Română</name>
+ <english_name>Romanian</english_name>
+ </row>
+ <row>
+ <code>ru</code>
+ <name>Русский</name>
+ <english_name>Russian</english_name>
+ </row>
+ <row>
+ <code>sk</code>
+ <name>Slovensky</name>
+ <english_name>Slovak</english_name>
+ </row>
+ <row>
+ <code>sq</code>
+ <name>Shqip</name>
+ <english_name>Albanian</english_name>
+ </row>
+ <row>
+ <code>sr</code>
+ <name>Srpski</name>
+ <english_name>Serbian</english_name>
+ </row>
+ <row>
+ <code>sv</code>
+ <name>Svenska</name>
+ <english_name>Swedish</english_name>
+ </row>
+ <row>
+ <code>te</code>
+ <name>తెలుగు</name>
+ <english_name>Telugu</english_name>
+ </row>
+ <row>
+ <code>th</code>
+ <name>ภาษาไทย</name>
+ <english_name>Thai</english_name>
+ </row>
+ <row>
+ <code>tr</code>
+ <name>Türkçe</name>
+ <english_name>Turkish</english_name>
+ </row>
+ <row>
+ <code>uk</code>
+ <name>Українська</name>
+ <english_name>Ukrainian</english_name>
+ </row>
+ <row>
+ <code>zh-cn</code>
+ <name>简体中文</name>
+ <english_name>Simplified Chinese</english_name>
+ </row>
+ <row>
+ <code>zh-tw</code>
+ <name>台灣語</name>
+ <english_name>Traditional Chinese (Taiwan)</english_name>
+ </row>
+</result> \ No newline at end of file
diff --git a/tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getTranslationsForLanguage.xml b/tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getTranslationsForLanguage.xml
new file mode 100644
index 0000000000..7068f75a2d
--- /dev/null
+++ b/tests/integration/expected/test_apiGetReportMetadata_year__LanguagesManager.getTranslationsForLanguage.xml
@@ -0,0 +1,4907 @@
+<?xml version="1.0" encoding="utf-8" ?>
+<result>
+ <row>
+ <label>General_Locale</label>
+ <value>fr_FR.UTF-8</value>
+ </row>
+ <row>
+ <label>General_TranslatorName</label>
+ <value>Vincent BIRET</value>
+ </row>
+ <row>
+ <label>General_TranslatorEmail</label>
+ <value>admin@get-surf.com</value>
+ </row>
+ <row>
+ <label>General_EnglishLanguageName</label>
+ <value>French</value>
+ </row>
+ <row>
+ <label>General_OriginalLanguageName</label>
+ <value>Français</value>
+ </row>
+ <row>
+ <label>General_HelloUser</label>
+ <value>Bonjour, %s</value>
+ </row>
+ <row>
+ <label>General_OpenSourceWebAnalytics</label>
+ <value>Analyse web libre</value>
+ </row>
+ <row>
+ <label>General_Dashboard</label>
+ <value>Tableau de bord</value>
+ </row>
+ <row>
+ <label>General_DashboardForASpecificWebsite</label>
+ <value>Tableau de bord pour un site particulier</value>
+ </row>
+ <row>
+ <label>General_MultiSitesSummary</label>
+ <value>Tous les sites web</value>
+ </row>
+ <row>
+ <label>General_AllWebsitesDashboard</label>
+ <value>Tableau de bord de tous les sites</value>
+ </row>
+ <row>
+ <label>General_API</label>
+ <value>API</value>
+ </row>
+ <row>
+ <label>General_Widgets</label>
+ <value>Widgets</value>
+ </row>
+ <row>
+ <label>General_Settings</label>
+ <value>Paramètres</value>
+ </row>
+ <row>
+ <label>General_GiveUsYourFeedback</label>
+ <value>Envoyez-nous vos commentaires !</value>
+ </row>
+ <row>
+ <label>General_Unknown</label>
+ <value>Inconnu</value>
+ </row>
+ <row>
+ <label>General_Required</label>
+ <value>%s requis</value>
+ </row>
+ <row>
+ <label>General_NotValid</label>
+ <value>%s n'est pas valide</value>
+ </row>
+ <row>
+ <label>General_Error</label>
+ <value>Erreur</value>
+ </row>
+ <row>
+ <label>General_Warning</label>
+ <value>Attention</value>
+ </row>
+ <row>
+ <label>General_BackToHomepage</label>
+ <value>Retour à la page d'accueil Piwik</value>
+ </row>
+ <row>
+ <label>General_Yes</label>
+ <value>Oui</value>
+ </row>
+ <row>
+ <label>General_No</label>
+ <value>Non</value>
+ </row>
+ <row>
+ <label>General_Delete</label>
+ <value>Supprimer</value>
+ </row>
+ <row>
+ <label>General_Edit</label>
+ <value>Éditer</value>
+ </row>
+ <row>
+ <label>General_Ok</label>
+ <value>Ok</value>
+ </row>
+ <row>
+ <label>General_Close</label>
+ <value>Fermer</value>
+ </row>
+ <row>
+ <label>General_Logout</label>
+ <value>Déconnexion</value>
+ </row>
+ <row>
+ <label>General_Username</label>
+ <value>Nom d'utilisateur</value>
+ </row>
+ <row>
+ <label>General_Done</label>
+ <value>Fait</value>
+ </row>
+ <row>
+ <label>General_Details</label>
+ <value>Détails</value>
+ </row>
+ <row>
+ <label>General_Default</label>
+ <value>Par défaut</value>
+ </row>
+ <row>
+ <label>General_LoadingData</label>
+ <value>Chargement des données...</value>
+ </row>
+ <row>
+ <label>General_Loading_js</label>
+ <value>Chargement...</value>
+ </row>
+ <row>
+ <label>General_YourChangesHaveBeenSaved</label>
+ <value>Vos modifications ont été enregistrées.</value>
+ </row>
+ <row>
+ <label>General_ErrorRequest</label>
+ <value>Oups ! Problème rencontré durant la requête, veuillez réessayer.</value>
+ </row>
+ <row>
+ <label>General_Next</label>
+ <value>Suivant</value>
+ </row>
+ <row>
+ <label>General_Previous</label>
+ <value>Précédent</value>
+ </row>
+ <row>
+ <label>General_Search</label>
+ <value>Rechercher</value>
+ </row>
+ <row>
+ <label>General_Others</label>
+ <value>Autres</value>
+ </row>
+ <row>
+ <label>General_Table</label>
+ <value>Tableau</value>
+ </row>
+ <row>
+ <label>General_Piechart</label>
+ <value>Pointe de tarte</value>
+ </row>
+ <row>
+ <label>General_TagCloud</label>
+ <value>Nuage de tags</value>
+ </row>
+ <row>
+ <label>General_VBarGraph</label>
+ <value>Histogramme vertical</value>
+ </row>
+ <row>
+ <label>General_Export</label>
+ <value>Exporter</value>
+ </row>
+ <row>
+ <label>General_ExportAsImage_js</label>
+ <value>Exporter au format Image</value>
+ </row>
+ <row>
+ <label>General_SaveImageOnYourComputer</label>
+ <value>Pour enregistrer l'image sur votre ordinateur, faites un clic droit sur l'image et sélectionnez &quot;Enregistrer l'image sous...&quot;</value>
+ </row>
+ <row>
+ <label>General_Refresh</label>
+ <value>Rafraîchir la page</value>
+ </row>
+ <row>
+ <label>General_Today</label>
+ <value>Aujourd'hui</value>
+ </row>
+ <row>
+ <label>General_Yesterday</label>
+ <value>Hier</value>
+ </row>
+ <row>
+ <label>General_CurrentWeek</label>
+ <value>Semaine courante</value>
+ </row>
+ <row>
+ <label>General_CurrentMonth</label>
+ <value>Mois courant</value>
+ </row>
+ <row>
+ <label>General_CurrentYear</label>
+ <value>Année courante</value>
+ </row>
+ <row>
+ <label>General_Visitors</label>
+ <value>Visiteurs</value>
+ </row>
+ <row>
+ <label>General_ColumnNbUniqVisitors</label>
+ <value>Visiteurs uniques</value>
+ </row>
+ <row>
+ <label>General_ColumnNbVisits</label>
+ <value>Visites</value>
+ </row>
+ <row>
+ <label>General_ColumnNbActions</label>
+ <value>Actions</value>
+ </row>
+ <row>
+ <label>General_ColumnMaxActions</label>
+ <value>Nombre maximum d'actions en une visite</value>
+ </row>
+ <row>
+ <label>General_ColumnSumVisitLength</label>
+ <value>Temps total passé par les visiteurs (en secondes)</value>
+ </row>
+ <row>
+ <label>General_ColumnLabel</label>
+ <value>Nom</value>
+ </row>
+ <row>
+ <label>General_ColumnActionsPerVisit</label>
+ <value>Actions par visite</value>
+ </row>
+ <row>
+ <label>General_ColumnAvgTimeOnSite</label>
+ <value>Temps moyen sur le site</value>
+ </row>
+ <row>
+ <label>General_ColumnBounceRate</label>
+ <value>Taux de rebond</value>
+ </row>
+ <row>
+ <label>General_ColumnPageviews</label>
+ <value>Vues</value>
+ </row>
+ <row>
+ <label>General_ColumnUniquePageviews</label>
+ <value>Vues uniques</value>
+ </row>
+ <row>
+ <label>General_ColumnValuePerVisit</label>
+ <value>Valeur par Visite</value>
+ </row>
+ <row>
+ <label>General_ColumnVisitsWithConversions</label>
+ <value>Visites avec Conversions</value>
+ </row>
+ <row>
+ <label>General_Save</label>
+ <value>Enregistrer</value>
+ </row>
+ <row>
+ <label>General_ForExampleShort</label>
+ <value>ex.</value>
+ </row>
+ <row>
+ <label>General_Website</label>
+ <value>Site</value>
+ </row>
+ <row>
+ <label>General_GeneralSettings</label>
+ <value>Paramètres généraux</value>
+ </row>
+ <row>
+ <label>General_AllowPiwikArchivingToTriggerBrowser</label>
+ <value>Autoriser l'archivage de Piwik à se déclencher lorsque les rapports sont visionnés depuis le navigateur</value>
+ </row>
+ <row>
+ <label>General_ArchivingInlineHelp</label>
+ <value>Pour les sites à trafic moyen et fort il est recommandé de désactiver l'archivage de Piwik depuis le navigateur. Nous vous recommandons de mettre en place une tâche planifiée (cron) qui génère les rapports toutes les heures.</value>
+ </row>
+ <row>
+ <label>General_ArchivingTriggerDescription</label>
+ <value>Recommandé pour les installations importantes de Piwik, vous devriez %s mettre en place une tâche planifiée (cron) %s pour générer les rapports automatiquement.</value>
+ </row>
+ <row>
+ <label>General_SeeTheOfficialDocumentationForMoreInformation</label>
+ <value>Consultez la %s documentation officielle %s pour plus d'information.</value>
+ </row>
+ <row>
+ <label>General_ReportsForTodayWillBeProcessedAtMostEvery</label>
+ <value>Les rapports d'aujourd'hui seront traités au plus tous (toutes) les</value>
+ </row>
+ <row>
+ <label>General_NSeconds</label>
+ <value>%s secondes</value>
+ </row>
+ <row>
+ <label>General_SmallTrafficYouCanLeaveDefault</label>
+ <value>Pour les sites à faible trafic, vous pouvez laisser le délais %s secondes par défaut, et ainsi accéder aux rapports en temps réel.</value>
+ </row>
+ <row>
+ <label>General_RequiresFlash</label>
+ <value>L'affichage des graphs dans Piwik requiert Flash</value>
+ </row>
+ <row>
+ <label>General_GraphHelp</label>
+ <value>Plus d'informations à propos de l'affichage des graphs dans Piwik.</value>
+ </row>
+ <row>
+ <label>General_NoDataForGraph</label>
+ <value>Aucune donnée pour ce graphique</value>
+ </row>
+ <row>
+ <label>General_NoDataForTagCloud</label>
+ <value>Aucune donnée pour ce nuage de tags.</value>
+ </row>
+ <row>
+ <label>General_DisplayNormalTable</label>
+ <value>Voir tableau normal</value>
+ </row>
+ <row>
+ <label>General_DisplayMoreData</label>
+ <value>Voir plus de données</value>
+ </row>
+ <row>
+ <label>General_PiwikIsACollaborativeProjectYouCanContribute</label>
+ <value>%1$s Piwik %2$s est un projet collaboratif. %3$s Si vous aimez Piwik, vous pouvez nous aider! Allez voir %4$s Comment contribuer à Piwik ?%5$s </value>
+ </row>
+ <row>
+ <label>General_YouAreCurrentlyViewingDemoOfPiwik</label>
+ <value>Vous êtes dans la démo de %s; %stéléchargez%s la version complète ! Visitez %s.</value>
+ </row>
+ <row>
+ <label>General_PiwikXIsAvailablePleaseUpdateNow</label>
+ <value>Piwik %1$s est maintenant disponible. %2$s Merci de mettre à jour!%3$s (voir %4$s les modifications%5$s).</value>
+ </row>
+ <row>
+ <label>General_PiwikXIsAvailablePleaseNotifyPiwikAdmin</label>
+ <value>%s est disponible. Merci de prévenir l'administrateur du site.</value>
+ </row>
+ <row>
+ <label>General_BackToPiwik</label>
+ <value>Retourner à Piwik</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_1</label>
+ <value>Jan</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_2</label>
+ <value>Fév</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_3</label>
+ <value>Mar</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_4</label>
+ <value>Avr</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_5</label>
+ <value>Mai</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_6</label>
+ <value>Jun</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_7</label>
+ <value>Jul</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_8</label>
+ <value>Aoû</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_9</label>
+ <value>Sep</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_10</label>
+ <value>Oct</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_11</label>
+ <value>Nov</value>
+ </row>
+ <row>
+ <label>General_ShortMonth_12</label>
+ <value>Dec</value>
+ </row>
+ <row>
+ <label>General_LongMonth_1</label>
+ <value>Janvier</value>
+ </row>
+ <row>
+ <label>General_LongMonth_2</label>
+ <value>Février</value>
+ </row>
+ <row>
+ <label>General_LongMonth_3</label>
+ <value>Mars</value>
+ </row>
+ <row>
+ <label>General_LongMonth_4</label>
+ <value>Avril</value>
+ </row>
+ <row>
+ <label>General_LongMonth_5</label>
+ <value>Mai</value>
+ </row>
+ <row>
+ <label>General_LongMonth_6</label>
+ <value>Juin</value>
+ </row>
+ <row>
+ <label>General_LongMonth_7</label>
+ <value>Juillet</value>
+ </row>
+ <row>
+ <label>General_LongMonth_8</label>
+ <value>Août</value>
+ </row>
+ <row>
+ <label>General_LongMonth_9</label>
+ <value>Septembre</value>
+ </row>
+ <row>
+ <label>General_LongMonth_10</label>
+ <value>Octobre</value>
+ </row>
+ <row>
+ <label>General_LongMonth_11</label>
+ <value>Novembre</value>
+ </row>
+ <row>
+ <label>General_LongMonth_12</label>
+ <value>Décembre</value>
+ </row>
+ <row>
+ <label>General_ShortDay_1</label>
+ <value>Lun</value>
+ </row>
+ <row>
+ <label>General_ShortDay_2</label>
+ <value>Mar</value>
+ </row>
+ <row>
+ <label>General_ShortDay_3</label>
+ <value>Mer</value>
+ </row>
+ <row>
+ <label>General_ShortDay_4</label>
+ <value>Jeu</value>
+ </row>
+ <row>
+ <label>General_ShortDay_5</label>
+ <value>Ven</value>
+ </row>
+ <row>
+ <label>General_ShortDay_6</label>
+ <value>Sam</value>
+ </row>
+ <row>
+ <label>General_ShortDay_7</label>
+ <value>Dim</value>
+ </row>
+ <row>
+ <label>General_LongDay_1</label>
+ <value>Lundi</value>
+ </row>
+ <row>
+ <label>General_LongDay_2</label>
+ <value>Mardi</value>
+ </row>
+ <row>
+ <label>General_LongDay_3</label>
+ <value>Mercredi</value>
+ </row>
+ <row>
+ <label>General_LongDay_4</label>
+ <value>Jeudi</value>
+ </row>
+ <row>
+ <label>General_LongDay_5</label>
+ <value>Vendredi</value>
+ </row>
+ <row>
+ <label>General_LongDay_6</label>
+ <value>Samedi</value>
+ </row>
+ <row>
+ <label>General_LongDay_7</label>
+ <value>Dimanche</value>
+ </row>
+ <row>
+ <label>General_ExceptionDatabaseVersion</label>
+ <value>Votre version de %1$s est %2$s mais Piwik a besoin au minimum de la version %3$s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionIncompatibleClientServerVersions</label>
+ <value>La version de votre client %1$s est %2$s ce qui est incompatible avec le serveur de version %3$s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionMissingFile</label>
+ <value>Fichier manquant : %s</value>
+ </row>
+ <row>
+ <label>General_ExceptionFilesizeMismatch</label>
+ <value>Différence de taille de fichier : %1$s (longueur attendue: %2$s, rencontrée : %3$s)</value>
+ </row>
+ <row>
+ <label>General_ExceptionFileIntegrity</label>
+ <value>Échec du contrôle d'intégrité : %s</value>
+ </row>
+ <row>
+ <label>General_ExceptionNonceMismatch</label>
+ <value>Impossible de vérifier le token de sécurité pour ce formulaire.</value>
+ </row>
+ <row>
+ <label>General_WarningFileIntegritySkipped</label>
+ <value>Environnement de développement détecté. Contrôle d'intégrité ignoré.</value>
+ </row>
+ <row>
+ <label>General_WarningFileIntegrityNoManifest</label>
+ <value>Le contrôle d'intégrité n'a pu être effectué car le fichier manifest.inc.php est manquant.</value>
+ </row>
+ <row>
+ <label>General_WarningFileIntegrityNoMd5file</label>
+ <value>Le contrôle d'intégrité n'a pu être effectué car la fonction md5_file() est manquante.</value>
+ </row>
+ <row>
+ <label>General_FileIntegrityWarningExplanation</label>
+ <value>Le contrôle d'intégrité a échoué et a rapporté des erreurs. Cela est probablement du à un envoi de fichier partiel ou en échec des fichiers de Piwik. Vous devriez envoyer de nouveau les fichiers de Piwik et rafraichir cette page jusqu'à ce qu'elle n'affiche plus aucune erreur.</value>
+ </row>
+ <row>
+ <label>Actions_PluginDescription</label>
+ <value>Effectue des rapports sur les affichages de pages, les liens sortants et les téléchargements. Le suivi des liens sortants et des téléchargements est automatique!</value>
+ </row>
+ <row>
+ <label>Actions_Actions</label>
+ <value>Actions</value>
+ </row>
+ <row>
+ <label>Actions_SubmenuPages</label>
+ <value>Pages</value>
+ </row>
+ <row>
+ <label>Actions_SubmenuPageTitles</label>
+ <value>Titres des pages</value>
+ </row>
+ <row>
+ <label>Actions_SubmenuOutlinks</label>
+ <value>Liens sortants</value>
+ </row>
+ <row>
+ <label>Actions_SubmenuDownloads</label>
+ <value>Téléchargements</value>
+ </row>
+ <row>
+ <label>Actions_ColumnClicks</label>
+ <value>Clics</value>
+ </row>
+ <row>
+ <label>Actions_ColumnUniqueClicks</label>
+ <value>Clics uniques</value>
+ </row>
+ <row>
+ <label>Actions_ColumnDownloads</label>
+ <value>Téléchargements</value>
+ </row>
+ <row>
+ <label>Actions_ColumnUniqueDownloads</label>
+ <value>Téléchargements uniques</value>
+ </row>
+ <row>
+ <label>Actions_ColumnPageName</label>
+ <value>Nom de la page</value>
+ </row>
+ <row>
+ <label>Actions_ColumnPageURL</label>
+ <value>Url de la page</value>
+ </row>
+ <row>
+ <label>Actions_ColumnClickedURL</label>
+ <value>Url cliquées</value>
+ </row>
+ <row>
+ <label>Actions_ColumnDownloadURL</label>
+ <value>Url de téléchargement</value>
+ </row>
+ <row>
+ <label>AnonymizeIP_PluginDescription</label>
+ <value>Masque les adresses IP des visiteurs pour remplir les conditions légales et politiques locales.</value>
+ </row>
+ <row>
+ <label>API_PluginDescription</label>
+ <value>Toutes les données de Piwik sont disponibles au travers de simples APIs. Ce plugin est le point d'entrée du web service, ainsi vous pouvez obtenir vos données Statistiques Web en xml, json, php, csv, etc.</value>
+ </row>
+ <row>
+ <label>API_QuickDocumentation</label>
+ <value>&lt;h2&gt;Documentation rapide de l'API&lt;/h2&gt;&lt;p&gt;Si vous n'avez pas de données pour ajourd'hui, vous pouvez d'abord &lt;a href='misc/generateVisits.php' target=_blank&gt;générer des données&lt;/a&gt; en utilisant le Générateur de Visites.&lt;/p&gt;&lt;p&gt;Vous pouvez essayer les différents formats disponibles pour chaque méthode. Il est très facile d'extraire n'importe quelle donnée que vous voulez de Piwik!&lt;/p&gt;&lt;p&gt;&lt;b&gt;Pour plus d'informations visitez la &lt;a href='http://dev.piwik.org/trac/wiki/API'&gt;Documentation officielle de l'API&lt;/a&gt; or the &lt;a href='http://dev.piwik.org/trac/wiki/API/Reference'&gt;Référence API&lt;/a&gt;.&lt;/b&gt;&lt;/P&gt;&lt;h2&gt;Identification&lt;/h2&gt;&lt;p&gt;Si vous voulez &lt;b&gt;utiliser les données dans vos scripts, dans une crontab, etc. &lt;/b&gt; vous devez ajouter le paramètre &lt;code&gt;&lt;u&gt;&amp;token_auth=%s&lt;/u&gt;&lt;/code&gt; to the API calls URLs that require authentication.&lt;/p&gt;&lt;p&gt;Cette token_auth est aussi secrètes que votre nom d'utilisateur ou votre mot de passe, &lt;b&gt;ne la partagez pas!&lt;/p&gt;</value>
+ </row>
+ <row>
+ <label>API_LoadedAPIs</label>
+ <value>%s API chargées avec succès</value>
+ </row>
+ <row>
+ <label>CoreAdminHome_PluginDescription</label>
+ <value>Zone d'administration de Piwik.</value>
+ </row>
+ <row>
+ <label>CoreAdminHome_MenuGeneralSettings</label>
+ <value>Paramètres généraux</value>
+ </row>
+ <row>
+ <label>CoreHome_PluginDescription</label>
+ <value>Structure des rapports statistiques web.</value>
+ </row>
+ <row>
+ <label>CoreHome_NoPrivileges</label>
+ <value>Vous êtes connecté en tant que '%s' mais vous n'avez apparemment aucune permission de définie dans Piwik.&lt;br /&gt;Demandez à votre administrateur Piwik de vous donner l'accès 'voir' à un site web.</value>
+ </row>
+ <row>
+ <label>CoreHome_JavascriptDisabled</label>
+ <value>JavaScript doit être activé pour que vous puissiez utiliser Piwik de manière basique.&lt;br /&gt;Cependant, il semble que JasvaScript ne soit pas supporté ou soit désactivé sur votre navigateur.&lt;br /&gt;Pour utiliser l'interface basique, activez JavaScript en modifiant les options de votre navigateur, ensuite %1$sessayez encore%2$s.&lt;br /&gt;</value>
+ </row>
+ <row>
+ <label>CoreHome_TableNoData</label>
+ <value>Aucune donnée pour cette table.</value>
+ </row>
+ <row>
+ <label>CoreHome_CategoryNoData</label>
+ <value>Aucune donnée pour cette catégorie. Essayez &quot;d'inclure toute la population&quot;.</value>
+ </row>
+ <row>
+ <label>CoreHome_ShowJSCode</label>
+ <value>Afficher le code JavaScript à insérer</value>
+ </row>
+ <row>
+ <label>CoreHome_IncludeAllPopulation_js</label>
+ <value>Inclure toute la population</value>
+ </row>
+ <row>
+ <label>CoreHome_ExcludeLowPopulation_js</label>
+ <value>Exclure les populations mineures</value>
+ </row>
+ <row>
+ <label>CoreHome_PageOf_js</label>
+ <value>%1$s de %2$s</value>
+ </row>
+ <row>
+ <label>CoreHome_Loading_js</label>
+ <value>Chargement en cours...</value>
+ </row>
+ <row>
+ <label>CoreHome_DayFormat</label>
+ <value>%longDay% %day% %longMonth% %longYear%</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodDay</label>
+ <value>Jour</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodWeek</label>
+ <value>Semaine</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodMonth</label>
+ <value>Mois</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodYear</label>
+ <value>Année</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodDays</label>
+ <value>jours</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodWeeks</label>
+ <value>semaines</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodMonths</label>
+ <value>moirs</value>
+ </row>
+ <row>
+ <label>CoreHome_PeriodYears</label>
+ <value>années</value>
+ </row>
+ <row>
+ <label>CoreHome_DaySu_js</label>
+ <value>Di</value>
+ </row>
+ <row>
+ <label>CoreHome_DayMo_js</label>
+ <value>Lu</value>
+ </row>
+ <row>
+ <label>CoreHome_DayTu_js</label>
+ <value>Ma</value>
+ </row>
+ <row>
+ <label>CoreHome_DayWe_js</label>
+ <value>Me</value>
+ </row>
+ <row>
+ <label>CoreHome_DayTh_js</label>
+ <value>Je</value>
+ </row>
+ <row>
+ <label>CoreHome_DayFr_js</label>
+ <value>Ve</value>
+ </row>
+ <row>
+ <label>CoreHome_DaySa_js</label>
+ <value>Sa</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_1_js</label>
+ <value>Dim</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_2_js</label>
+ <value>Lun</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_3_js</label>
+ <value>Mar</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_4_js</label>
+ <value>Mer</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_5_js</label>
+ <value>Jeu</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_6_js</label>
+ <value>Ven</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortDay_7_js</label>
+ <value>Sam</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_1_js</label>
+ <value>Dimanche</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_2_js</label>
+ <value>Lundi</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_3_js</label>
+ <value>Mardi</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_4_js</label>
+ <value>Mercredi</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_5_js</label>
+ <value>Jeudi</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_6_js</label>
+ <value>Vendredi</value>
+ </row>
+ <row>
+ <label>CoreHome_LongDay_7_js</label>
+ <value>Samedi</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_1_js</label>
+ <value>Jan</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_2_js</label>
+ <value>Fév</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_3_js</label>
+ <value>Mar</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_4_js</label>
+ <value>Avr</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_5_js</label>
+ <value>Mai</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_6_js</label>
+ <value>Jun</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_7_js</label>
+ <value>Jul</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_8_js</label>
+ <value>Aoû</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_9_js</label>
+ <value>Sep</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_10_js</label>
+ <value>Oct</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_11_js</label>
+ <value>Nov</value>
+ </row>
+ <row>
+ <label>CoreHome_ShortMonth_12_js</label>
+ <value>Déc</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthJanuary_js</label>
+ <value>Janvier</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthFebruary_js</label>
+ <value>Février</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthMarch_js</label>
+ <value>Mars</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthApril_js</label>
+ <value>Avril</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthMay_js</label>
+ <value>Mai</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthJune_js</label>
+ <value>Juin</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthJuly_js</label>
+ <value>Juillet</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthAugust_js</label>
+ <value>Août</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthSeptember_js</label>
+ <value>Septembre</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthOctober_js</label>
+ <value>Octobre</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthNovember_js</label>
+ <value>Novembre</value>
+ </row>
+ <row>
+ <label>CoreHome_MonthDecember_js</label>
+ <value>Décembre</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_PluginDescription</label>
+ <value>Interface d'administration des plugins.</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Plugins</label>
+ <value>Plugins</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_PluginsManagement</label>
+ <value>Gestionnaire de plugins</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_MainDescription</label>
+ <value>Les plugins étendent et ajoutent des fonctionnalités à Piwik. Une fois un plugin installé, vous pouvez l'activer ou le désactiver ici.</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Plugin</label>
+ <value>Plugin</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Version</label>
+ <value>Version</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Description</label>
+ <value>Description</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Status</label>
+ <value>État</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Action</label>
+ <value>Action</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_PluginHomepage</label>
+ <value>Page d'accueil du plugin</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Activated</label>
+ <value>Activé</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Active</label>
+ <value>Actif</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Inactive</label>
+ <value>Inactif</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_ActivatedHelp</label>
+ <value>Ce plugin ne peut être désactivé</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Deactivate</label>
+ <value>Désactiver</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_Activate</label>
+ <value>Activer</value>
+ </row>
+ <row>
+ <label>CorePluginsAdmin_MenuPlugins</label>
+ <value>Plugins</value>
+ </row>
+ <row>
+ <label>CoreUpdater_PluginDescription</label>
+ <value>Mécanisme de mise à jour Piwik</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UpdateTitle</label>
+ <value>Mise à jour</value>
+ </row>
+ <row>
+ <label>CoreUpdater_DatabaseUpgradeRequired</label>
+ <value>Mise à jour de la base de données requise</value>
+ </row>
+ <row>
+ <label>CoreUpdater_YourDatabaseIsOutOfDate</label>
+ <value>Votre base de données est expirée et doit être mise à jour avant de pouvoir continuer.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_PiwikWillBeUpgradedFromVersionXToVersionY</label>
+ <value>La base de données de Piwik sera mise à jour depuis la version %1$s vers la version %2$s.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_TheFollowingPluginsWillBeUpgradedX</label>
+ <value>Les plugins suivants seront mis à jour : %s.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_NoteForLargePiwikInstances</label>
+ <value>Note importante pour les installations Piwik de taille importante</value>
+ </row>
+ <row>
+ <label>CoreUpdater_TheUpgradeProcessMayFailExecuteCommand</label>
+ <value>Si votre base de données Piwik est trop volumineuse, la mise à jour pourra être trop longue pour l'effectuer depuis le navigateur. dans ce cas exécutez depuis la ligne de commande : %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_YouCouldManuallyExecuteSqlQueries</label>
+ <value>Si vous n'aviez pas la possibilité d'utiliser la console (CLI) et si Piwik échouait à se mettre à jour (à cause du délais d'expiration de la base de données, du navigateur ou n'importe quel autre problème), vous pourriez exécuter manuellement les requêtes SQL pour mettre à jour Piwik.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ClickHereToViewSqlQueries</label>
+ <value>Cliquez ici pour visualiser la liste des commandes SQL qui vont être exécutées</value>
+ </row>
+ <row>
+ <label>CoreUpdater_NoteItIsExpectedThatQueriesFail</label>
+ <value>Note: si vous exécutez manuellement ces requêtes, il se peut que certaines d'entre elles échouent. Dans ce cas, ignorez simplement les erreurs, et exécutez les suivantes dans la liste.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ReadyToGo</label>
+ <value>Prêt à démarrer?</value>
+ </row>
+ <row>
+ <label>CoreUpdater_TheUpgradeProcessMayTakeAWhilePleaseBePatient</label>
+ <value>Le procédé de mise à jour peut être long, veuillez patienter.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UpgradePiwik</label>
+ <value>Mettez Piwik à jour</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDIYHelp</label>
+ <value>Si vous êtes un utilisateur avancé et que vous rencontrez une erreur lors de la mise à jour de la base de données :</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDIYHelp_1</label>
+ <value>identifiez la source exacte du problème (ex, memory_limit ou max_execution_time)</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDIYHelp_2</label>
+ <value>exécutez les requêtes restantes qui ont échoué</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDIYHelp_3</label>
+ <value>mettez à jour manuellement la table `option` de votre base de données Piwik, en spécifiant la valeur de version_core à la version de celle de l'échec de la mise à jour</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDIYHelp_4</label>
+ <value>ré-exécutez le gestionnaire de mise à jour (en commande ou via le navigateur) pour continuer l'installation des mises à jour restantes</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDIYHelp_5</label>
+ <value>rapportez le problème et la solution à Piwik, de cette manière il pourra être vérifié et distribué</value>
+ </row>
+ <row>
+ <label>CoreUpdater_CriticalErrorDuringTheUpgradeProcess</label>
+ <value>Erreur Critique pendant le procédé de mise à jour :</value>
+ </row>
+ <row>
+ <label>CoreUpdater_HelpMessageIntroductionWhenError</label>
+ <value>Ci-dessus est le message d'erreur du noyau. Cela devrait expliquer la cause, mais si vous nécessitez d'avantage d'aide merci de :</value>
+ </row>
+ <row>
+ <label>CoreUpdater_HelpMessageIntroductionWhenWarning</label>
+ <value>La mise à jour a été complétée avec succès. Cependant, des problèmes sont survenus. Lisez la description ci-dessus pour plus de détails. Pour d'avantage d'aide :</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UpgradeComplete</label>
+ <value>Mise à jour complète !</value>
+ </row>
+ <row>
+ <label>CoreUpdater_WarningMessages</label>
+ <value>Messages d'avertissement :</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ErrorDuringPluginsUpdates</label>
+ <value>Erreurs pendant les mises à jour de plugins :</value>
+ </row>
+ <row>
+ <label>CoreUpdater_WeAutomaticallyDeactivatedTheFollowingPlugins</label>
+ <value>Nous avons automatiquement désactivé les plugins suivants : %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_PiwikHasBeenSuccessfullyUpgraded</label>
+ <value>Piwik a été mis à jour avec succès !</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ContinueToPiwik</label>
+ <value>Continuer vers Piwik</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UpdateAutomatically</label>
+ <value>Mettre à jour automatiquement</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ThereIsNewVersionAvailableForUpdate</label>
+ <value>Il y a une nouvelle mise à jour de Piwik disponible</value>
+ </row>
+ <row>
+ <label>CoreUpdater_YouCanUpgradeAutomaticallyOrDownloadPackage</label>
+ <value>Vous pouvez mettre à jour vers la version %s automatiquement ou télécharger l'archive et l'installer manuellement:</value>
+ </row>
+ <row>
+ <label>CoreUpdater_DownloadX</label>
+ <value>Télécharger %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UpdateHasBeenCancelled</label>
+ <value>La mise à jour a été annulée.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_DownloadingUpdateFromX</label>
+ <value>Téléchargement de la mise à jour depuis %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UnpackingTheUpdate</label>
+ <value>Décompression de la mise à jour</value>
+ </row>
+ <row>
+ <label>CoreUpdater_VerifyingUnpackedFiles</label>
+ <value>Vérification des fichiers décompressés</value>
+ </row>
+ <row>
+ <label>CoreUpdater_CreatingBackupOfConfigurationFile</label>
+ <value>Création d'une sauvegarde du fichier de configuration dans le répertoire %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_InstallingTheLatestVersion</label>
+ <value>Installation de la dernière version</value>
+ </row>
+ <row>
+ <label>CoreUpdater_PiwikUpdatedSuccessfully</label>
+ <value>Piwik a été mis à jour avec succès!</value>
+ </row>
+ <row>
+ <label>CoreUpdater_EmptyDatabaseError</label>
+ <value>La base de données %s est vide. Vous devez éditer ou supprimer votre fichier de configuration Piwik.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ExceptionAlreadyLatestVersion</label>
+ <value>Votre version de Piwik %s est à jour.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ExceptionArchiveIncompatible</label>
+ <value>Archive incompatible: %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ExceptionArchiveEmpty</label>
+ <value>Archive vide.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_ExceptionArchiveIncomplete</label>
+ <value>L'archive est incomplète: des fichiers sont manquants (ex. %s).</value>
+ </row>
+ <row>
+ <label>Dashboard_PluginDescription</label>
+ <value>Votre tableau de bord de statistiques web. Vous pouvez personnaliser votre tableau de bord: ajoutez de nouveau widgets, changez l'ordre de vos widgets. Chaque utilisateur peut accéder à son propre tableau de bord.</value>
+ </row>
+ <row>
+ <label>Dashboard_Dashboard</label>
+ <value>Tableau de bord</value>
+ </row>
+ <row>
+ <label>Dashboard_AddWidget</label>
+ <value>Ajouter un widget...</value>
+ </row>
+ <row>
+ <label>Dashboard_DeleteWidgetConfirm</label>
+ <value>Êtes-vous sûr de vouloir supprimer ce widget du tableau de bord?</value>
+ </row>
+ <row>
+ <label>Dashboard_SelectWidget</label>
+ <value>Sélectionnez le widget à ajouter au tableau de bord</value>
+ </row>
+ <row>
+ <label>Dashboard_AddPreviewedWidget_js</label>
+ <value>Ajouter le widget visualisé au tableau de bord</value>
+ </row>
+ <row>
+ <label>Dashboard_WidgetPreview_js</label>
+ <value>Prévisualisation du Widget</value>
+ </row>
+ <row>
+ <label>Dashboard_Close_js</label>
+ <value>Fermer</value>
+ </row>
+ <row>
+ <label>Dashboard_TitleWidgetInDashboard_js</label>
+ <value>Widget déjà présent sur le tableau de bord</value>
+ </row>
+ <row>
+ <label>Dashboard_TitleClickToAdd_js</label>
+ <value>Cliquez pour ajouter au tableau de bord</value>
+ </row>
+ <row>
+ <label>Dashboard_LoadingWidget_js</label>
+ <value>Chargement du widget, patientez svp...</value>
+ </row>
+ <row>
+ <label>Dashboard_WidgetNotFound_js</label>
+ <value>Widget introuvable</value>
+ </row>
+ <row>
+ <label>DBStats_PluginDescription</label>
+ <value>Ce plugin effectue des rapports sur l'utilisation de la base de données MySQL par les tables de Piwik.</value>
+ </row>
+ <row>
+ <label>DBStats_DatabaseUsage</label>
+ <value>Utilisation de la base de données</value>
+ </row>
+ <row>
+ <label>DBStats_MainDescription</label>
+ <value>Piwik stocke toutes vos donnés de statistiques web dans la base de données MySQL. En ce moment les tables de Piwik utilisent %s.</value>
+ </row>
+ <row>
+ <label>DBStats_LearnMore</label>
+ <value>Pour en apprendre plus à propos de la manière dont Piwik traite les données et sur comment faire fonctionner Piwik correctement pour les sites à moyen et fort trafic, consultez la documentation %s.</value>
+ </row>
+ <row>
+ <label>DBStats_Table</label>
+ <value>Table</value>
+ </row>
+ <row>
+ <label>DBStats_RowCount</label>
+ <value>Nombre de lignes</value>
+ </row>
+ <row>
+ <label>DBStats_DataSize</label>
+ <value>Taille des données</value>
+ </row>
+ <row>
+ <label>DBStats_IndexSize</label>
+ <value>Taille de l'index</value>
+ </row>
+ <row>
+ <label>DBStats_TotalSize</label>
+ <value>Taille totale</value>
+ </row>
+ <row>
+ <label>ExampleAPI_PluginDescription</label>
+ <value>Plugin d'exemple: Comment créer une API pour votre plugin, exporter vos données dans de multiples formats sans aucun développement spécial?</value>
+ </row>
+ <row>
+ <label>ExampleFeedburner_PluginDescription</label>
+ <value>Plugin d'exemple: Comment afficher votre abonnement Feedburner dans un Widget dans le tableau de bord?</value>
+ </row>
+ <row>
+ <label>ExampleRssWidget_PluginDescription</label>
+ <value>Plugin d'exemple: Comment créer un nouveau widget qui lit un flux RSS?</value>
+ </row>
+ <row>
+ <label>ExampleUI_PluginDescription</label>
+ <value>Plugin d'exemple: Ce plugin montre comment fonctionne l'interface utilisateur de Piwik: création de tables, graphs, etc.</value>
+ </row>
+ <row>
+ <label>Feedback_PluginDescription</label>
+ <value>Envoie vos retours à l'Equipe Piwik. Partagez vos idées et suggestions avec nous!</value>
+ </row>
+ <row>
+ <label>Feedback_DoYouHaveBugReportOrFeatureRequest</label>
+ <value>Avez vous un bug à rapporter ou une fonctionnalité à demander?</value>
+ </row>
+ <row>
+ <label>Feedback_ViewAnswersToFAQ</label>
+ <value>Voir les réponses de %s la FAQ %s</value>
+ </row>
+ <row>
+ <label>Feedback_WhyAreMyVisitsNoTracked</label>
+ <value>Pourquoi les visites de mes sites web ne sont pas enregistrées?</value>
+ </row>
+ <row>
+ <label>Feedback_HowToExclude</label>
+ <value>Comment puis-je exclure le suivi de mes visites?</value>
+ </row>
+ <row>
+ <label>Feedback_WhyWrongCountry</label>
+ <value>Pourquoi Piwik affiche un mauvais pays pour ma visite?</value>
+ </row>
+ <row>
+ <label>Feedback_HowToAnonymizeIP</label>
+ <value>Comment puis-je masquer les adresse IP de mes visiteurs de ma base de données?</value>
+ </row>
+ <row>
+ <label>Feedback_VisitTheForums</label>
+ <value>Visitez les %s Forums%s</value>
+ </row>
+ <row>
+ <label>Feedback_LearnWaysToParticipate</label>
+ <value>Renseignez vous sur les manières dont vous pouvez %s participer%s</value>
+ </row>
+ <row>
+ <label>Feedback_SpecialRequest</label>
+ <value>Avez vous une demande spéciale pour l'Equipe Piwik? </value>
+ </row>
+ <row>
+ <label>Feedback_ContactThePiwikTeam</label>
+ <value>Contactez l'Equipe Piwik!</value>
+ </row>
+ <row>
+ <label>Feedback_IWantTo</label>
+ <value>Je veux:</value>
+ </row>
+ <row>
+ <label>Feedback_CategoryShareStory</label>
+ <value>Partager une réussite avec Piwik</value>
+ </row>
+ <row>
+ <label>Feedback_CategorySponsor</label>
+ <value>Sponsoriser Piwik</value>
+ </row>
+ <row>
+ <label>Feedback_CategoryHire</label>
+ <value>Employer un consultant Piwik</value>
+ </row>
+ <row>
+ <label>Feedback_CategorySecurity</label>
+ <value>Rapporter un problème de sécurité</value>
+ </row>
+ <row>
+ <label>Feedback_MyEmailAddress</label>
+ <value>Mon adresse e-mail:</value>
+ </row>
+ <row>
+ <label>Feedback_MyMessage</label>
+ <value>Mon message:</value>
+ </row>
+ <row>
+ <label>Feedback_DetailsPlease</label>
+ <value>(merci d'inclure les détails)</value>
+ </row>
+ <row>
+ <label>Feedback_SendFeedback</label>
+ <value>Envoyer le retour</value>
+ </row>
+ <row>
+ <label>Feedback_ManuallySendEmailTo</label>
+ <value>Merci d'envoyer manuellement votre message à</value>
+ </row>
+ <row>
+ <label>Feedback_MessageSent</label>
+ <value>Votre message a été envoyé à l'Equipe Piwik.</value>
+ </row>
+ <row>
+ <label>Feedback_ThankYou</label>
+ <value>Merci d'avoir aidé à améliorer Piwik!</value>
+ </row>
+ <row>
+ <label>Feedback_ThePiwikTeam</label>
+ <value>L'Equipe Piwik</value>
+ </row>
+ <row>
+ <label>Feedback_ExceptionBodyLength</label>
+ <value>Le message doit faire au moins %s caractères de longueur.</value>
+ </row>
+ <row>
+ <label>Feedback_ExceptionNoUrls</label>
+ <value>Le message ne peut contenir d'URL pour éviter les problèmes de spam.</value>
+ </row>
+ <row>
+ <label>Goals_PluginDescription</label>
+ <value>Créer des objectifs et consulter les rapports sur vos conversions d'objectifs: évolution au cours du temps, revenu par visite, conversion par référant, par mot clef, etc.</value>
+ </row>
+ <row>
+ <label>Goals_ColumnConversions</label>
+ <value>Conversions</value>
+ </row>
+ <row>
+ <label>Goals_ColumnConversionRate</label>
+ <value>Taux de Conversion</value>
+ </row>
+ <row>
+ <label>Goals_ColumnRevenue</label>
+ <value>Revenu</value>
+ </row>
+ <row>
+ <label>Goals_OverallRevenue</label>
+ <value>%s revenu global</value>
+ </row>
+ <row>
+ <label>Goals_OverallConversionRate</label>
+ <value>%s taux de conversion global (visites avec un objectif rempli)</value>
+ </row>
+ <row>
+ <label>Goals_Conversions</label>
+ <value>%s conversions</value>
+ </row>
+ <row>
+ <label>Goals_ConversionRate</label>
+ <value>%s taux de conversion</value>
+ </row>
+ <row>
+ <label>Goals_NoGoalsNeedAccess</label>
+ <value>Uniquement un administrateur ou le super utilisateur peut ajouter un objectif à un site web donné. Veuillez demander à votre administrateur Piwik de mettre en place un objectif pour votre site web. &lt;br /&gt; Les objectifs sont un bon moyen pour comprendre et optimiser les performances de vos sites web! </value>
+ </row>
+ <row>
+ <label>Goals_AddNewGoal</label>
+ <value>Ajoutez un nouvel objectif</value>
+ </row>
+ <row>
+ <label>Goals_AddNewGoalOrEditExistingGoal</label>
+ <value>%sAjouter un nouvel objectif%s or %sEditer%s des objectifs existants</value>
+ </row>
+ <row>
+ <label>Goals_AddGoal_js</label>
+ <value>Ajouter un objectif</value>
+ </row>
+ <row>
+ <label>Goals_UpdateGoal_js</label>
+ <value>Mettre à jour un objectif</value>
+ </row>
+ <row>
+ <label>Goals_DeleteGoalConfirm_js</label>
+ <value>Etes vous sûr de vouloir supprimer l'objectif %s?</value>
+ </row>
+ <row>
+ <label>Goals_GoalName</label>
+ <value>Nom de l'objectif</value>
+ </row>
+ <row>
+ <label>Goals_GoalIsTriggered</label>
+ <value>L'objectif est déclenché</value>
+ </row>
+ <row>
+ <label>Goals_GoalIsTriggeredWhen</label>
+ <value>L'objectif est déclenché quand</value>
+ </row>
+ <row>
+ <label>Goals_WhenVisitors</label>
+ <value>quand les visiteurs</value>
+ </row>
+ <row>
+ <label>Goals_Manually</label>
+ <value>manuellement</value>
+ </row>
+ <row>
+ <label>Goals_ManuallyTriggeredUsingJavascriptFunction</label>
+ <value>Les objectifs sont déclenchés manuellement en utilisant l'API Javascript trackGoal()</value>
+ </row>
+ <row>
+ <label>Goals_VisitUrl</label>
+ <value>Visiter une URL donnée (page ou groupe de pages)</value>
+ </row>
+ <row>
+ <label>Goals_Download</label>
+ <value>Télécharger un fichier</value>
+ </row>
+ <row>
+ <label>Goals_ClickOutlink</label>
+ <value>Cliquez sur un Lien vers un site externe</value>
+ </row>
+ <row>
+ <label>Goals_Optional</label>
+ <value>(optionnel)</value>
+ </row>
+ <row>
+ <label>Goals_WhereVisitedPageManuallyCallsJavascriptTrackerLearnMore</label>
+ <value>où la page visitée contient un appel à la méthode JavaScript piwikTracker.trackGoal() (%sapprenez-en plus%s)</value>
+ </row>
+ <row>
+ <label>Goals_DefaultRevenue</label>
+ <value>Le revenue par défaut de l'objectif est </value>
+ </row>
+ <row>
+ <label>Goals_DefaultRevenueHelp</label>
+ <value>Par exemple, un formulaire de contact soumis par un visiteur peut avoir une valeur de 10 € en moyenne. Piwik vous aidera à comprendre comment se comportent vos visiteurs.</value>
+ </row>
+ <row>
+ <label>Goals_ConversionsOverview</label>
+ <value>Vue globale des conversions</value>
+ </row>
+ <row>
+ <label>Goals_BestCountries</label>
+ <value>Vos meilleurs pays de conversion sont: </value>
+ </row>
+ <row>
+ <label>Goals_BestKeywords</label>
+ <value>Vos meilleurs mots clefs sont: </value>
+ </row>
+ <row>
+ <label>Goals_BestReferers</label>
+ <value>Vos meilleurs sites web de conversion sont: </value>
+ </row>
+ <row>
+ <label>Goals_ReturningVisitorsConversionRateIs</label>
+ <value>Le taux de conversion des visiteurs déjà venus est %s</value>
+ </row>
+ <row>
+ <label>Goals_NewVisitorsConversionRateIs</label>
+ <value>Le taux de conversion des nouveaux visiteurs est %s</value>
+ </row>
+ <row>
+ <label>Goals_Contains</label>
+ <value>contient %s</value>
+ </row>
+ <row>
+ <label>Goals_IsExactly</label>
+ <value>est exactement %s</value>
+ </row>
+ <row>
+ <label>Goals_MatchesExpression</label>
+ <value>correspond à l'expression %s</value>
+ </row>
+ <row>
+ <label>Goals_CaseSensitive</label>
+ <value>Correspondance sensible à la case</value>
+ </row>
+ <row>
+ <label>Goals_Pattern</label>
+ <value>Modèle</value>
+ </row>
+ <row>
+ <label>Installation_PluginDescription</label>
+ <value>Procédé d'installation de Piwik. L'installation est effectuée une unique fois. Si le fichier de configuration config/config.inc.php est supprimé, l'installation recommencera.</value>
+ </row>
+ <row>
+ <label>Installation_Installation</label>
+ <value>Installation</value>
+ </row>
+ <row>
+ <label>Installation_InstallationStatus</label>
+ <value>Statut de l'installation</value>
+ </row>
+ <row>
+ <label>Installation_PercentDone</label>
+ <value>%s %% Fait</value>
+ </row>
+ <row>
+ <label>Installation_NoConfigFound</label>
+ <value>Le fichier de configuration de Piwik ne peut être trouvé et vous essayez d'accéder à une page de Piwik.&lt;br&gt; &lt;b&gt;  » Vous pouvez &lt;a href='index.php'&gt;installer Piwik maintenant&lt;/a&gt;&lt;/b&gt;&lt;br&gt;&lt;small&gt;Si vous avez déjà installé Piwik ne vous inquiétez pas Piwik réutilisera ces tables et leurs données.&lt;/small&gt;</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetup</label>
+ <value>Installation de la base de données</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetupServer</label>
+ <value>serveur de la base de données</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetupLogin</label>
+ <value>compte</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetupPassword</label>
+ <value>mot de passe</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetupDatabaseName</label>
+ <value>nom de la base</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetupTablePrefix</label>
+ <value>préfixe des tables</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseSetupAdapter</label>
+ <value>adaptateur</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseErrorConnect</label>
+ <value>Erreur lors de la tentative de connexion au serveur de base de données</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseCheck</label>
+ <value>Vérification de la base de données</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseServerVersion</label>
+ <value>Version du serveur de base de données</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseClientVersion</label>
+ <value>Version du client de base de données</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseCreation</label>
+ <value>Création de la base de données</value>
+ </row>
+ <row>
+ <label>Installation_PleaseFixTheFollowingErrors</label>
+ <value>Merci de corriger les erreurs suivantes</value>
+ </row>
+ <row>
+ <label>Installation_JsTag</label>
+ <value>Tag JavaScript</value>
+ </row>
+ <row>
+ <label>Installation_JsTagHelp</label>
+ <value>&lt;p&gt;Pour comptabiliser tous les visiteurs vous devez copier le tag sur toutes vos pages.&lt;/p&gt;&lt;p&gt;Vos pages n'ont pas besoin d'être en PHP, Piwik fonctionne avec tout type de pages (HTML, ASP, Perl ou n'importe quel autre langage).&lt;/p&gt;&lt;p&gt;Ici se trouve le code à insérer : (copiez/collez dans toutes vos pages) &lt;/p&gt;</value>
+ </row>
+ <row>
+ <label>Installation_JsTagHelpTitle</label>
+ <value>Comment insérer le tag dans vos sites web?</value>
+ </row>
+ <row>
+ <label>Installation_LargePiwikInstances</label>
+ <value>Aide pour les instances de Piwik volumineuses</value>
+ </row>
+ <row>
+ <label>Installation_JsTagArchivingHelp</label>
+ <value>Pour les sites à moyen et fort trafic, lisez &lt;a target=&quot;_blank&quot; href=&quot;http://piwik.org/docs/setup-auto-archiving/&quot;&gt;la page d'explication sur comment mettre en place une page d'auto archivage&lt;/a&gt; pour que Piwik devienne réellement rapide!</value>
+ </row>
+ <row>
+ <label>Installation_Congratulations</label>
+ <value>Félicitations</value>
+ </row>
+ <row>
+ <label>Installation_CongratulationsHelp</label>
+ <value>&lt;p&gt;Félicitations! Votre installation de Piwik est terminée.&lt;/p&gt;&lt;p&gt;Assurez vous que le code JavaScript est présent sur toutes vos pages et attendez vos premiers visiteurs!&lt;/p&gt;</value>
+ </row>
+ <row>
+ <label>Installation_ContinueToPiwik</label>
+ <value>Continuer vers Piwik</value>
+ </row>
+ <row>
+ <label>Installation_SetupWebsite</label>
+ <value>Paramétrer un site</value>
+ </row>
+ <row>
+ <label>Installation_SetupWebSiteName</label>
+ <value>nom du site web</value>
+ </row>
+ <row>
+ <label>Installation_SetupWebSiteURL</label>
+ <value>Url du site web</value>
+ </row>
+ <row>
+ <label>Installation_Timezone</label>
+ <value>fuseau horaire du site web</value>
+ </row>
+ <row>
+ <label>Installation_SetupWebsiteError</label>
+ <value>Une erreur a été rencontrée pendant l'ajout du site</value>
+ </row>
+ <row>
+ <label>Installation_SetupWebsiteSetupSuccess</label>
+ <value>Site %s créé avec succès!</value>
+ </row>
+ <row>
+ <label>Installation_GeneralSetup</label>
+ <value>Paramètres généraux</value>
+ </row>
+ <row>
+ <label>Installation_GeneralSetupSuccess</label>
+ <value>Paramètres généraux configurés avec succès</value>
+ </row>
+ <row>
+ <label>Installation_SuperUserLogin</label>
+ <value>login du super user</value>
+ </row>
+ <row>
+ <label>Installation_Password</label>
+ <value>mot de passe</value>
+ </row>
+ <row>
+ <label>Installation_PasswordRepeat</label>
+ <value>mot de passe (à nouveau)</value>
+ </row>
+ <row>
+ <label>Installation_Email</label>
+ <value>courriel</value>
+ </row>
+ <row>
+ <label>Installation_SecurityNewsletter</label>
+ <value>Envoyez moi un courriel pour les mises à jour de versions majeures de piwik ou pour les alertes de sécurité</value>
+ </row>
+ <row>
+ <label>Installation_CommunityNewsletter</label>
+ <value>Envoyez moi un courriel pour les nouveautés de la communauté (nouveaux plugins, nouvelles fonctionnalités, etc.)</value>
+ </row>
+ <row>
+ <label>Installation_PasswordDoNotMatch</label>
+ <value>Le mot de passe ne concorde pas</value>
+ </row>
+ <row>
+ <label>Installation_SubmitGo</label>
+ <value>Go!</value>
+ </row>
+ <row>
+ <label>Installation_Requirements</label>
+ <value>Pré-requis Piwik</value>
+ </row>
+ <row>
+ <label>Installation_Optional</label>
+ <value>Optionnel</value>
+ </row>
+ <row>
+ <label>Installation_Legend</label>
+ <value>Légendes</value>
+ </row>
+ <row>
+ <label>Installation_Extension</label>
+ <value>extension</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheck</label>
+ <value>Vérification du système</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckPhp</label>
+ <value>Version PHP</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckExtensions</label>
+ <value>Extensions requises</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckDatabaseHelp</label>
+ <value>Piwik requiert ou l'extension mysqli ou les extensions pdo et pdo_mysql.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckPdoAndMysqliHelp</label>
+ <value>Sur un serveur linux vous pouvez compiler PHP avec les options suivantes : %1$s
+
+
+
+
+
+
+
+ Dans votre php.ini, ajoutez les lignes suivantes: %2$s</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckPhpPdoAndMysqliSite</label>
+ <value>Plus d'informations sur: &lt;a style=&quot;color:red&quot; href=&quot;http://php.net/pdo&quot;&gt;PHP PDO&lt;/a&gt; et &lt;a style=&quot;color:red&quot; href=&quot;http://php.net/mysqli&quot;&gt;MYSQLI&lt;/a&gt;.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckWinPdoAndMysqliHelp</label>
+ <value>Sur un serveur windows vous pouvez ajouter les lignes suivantes à votre php.ini: %s</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckSplHelp</label>
+ <value>Vous devez configurer et recompiler PHP avec la librairie standard (par défaut).</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckZlibHelp</label>
+ <value>Vous devez reconfigurer et recompiler PHP avec le support zlib, --with-zlib.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckIconvHelp</label>
+ <value>Vous devez configurer PHP et le recompiler avec le support &quot;iconv&quot; activé, --with-iconv.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckDomHelp</label>
+ <value>DOM est une partie du coeur de PHP. Vous avez probablement besoin d'installer le module dom ex, php-5-dom.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckJson</label>
+ <value>JSON</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckJsonHelp</label>
+ <value>Vous devez recompiler PHP avec l'extension &quot;json&quot; ou &quot;xml&quot; activée.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckJsonSite</label>
+ <value>Plus d'informations sur : &lt;a style=&quot;color:red&quot; href=&quot;http://php.net/json&quot;&gt;PHP JSON&lt;/a&gt;.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckXml</label>
+ <value>XML</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckXmlHelp</label>
+ <value>Des plugins et librairies tierces pourront avoir besoin de l'extension XML.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckXmlSite</label>
+ <value>Plus d'informations sur: &lt;a style=&quot;color:red&quot; href=&quot;http://php.net/xml&quot;&gt;PHP XML&lt;/a&gt;.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckWriteDirs</label>
+ <value>Répertoires avec les droits d'accès en écriture</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckWriteDirsHelp</label>
+ <value>Pour corriger les erreurs sur votre système Linux essayez de taper les commandes suivantes</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMemoryLimit</label>
+ <value>Limite mémoire</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMemoryLimitHelp</label>
+ <value>Sur un site à trafic important le processus d'archivage peut prendre plus de mémoire que la limite actuelle autorisée.&lt;br /&gt;Référez vous à la configuration memory_limit de votre php.ini si nécessaire.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckOpenURL</label>
+ <value>Ouvrez l'URL</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckOpenURLHelp</label>
+ <value>Abonnements à la newsletter, notifications des mises à jour, et mise à jour en un click requièrent l'extension curl, allow_url_fopen=On, ou fsockopen() activé.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckGD</label>
+ <value>GD &gt; 2.x (graphiques)</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckGDHelp</label>
+ <value>Les sparklines (petits graphs) ne fonctionneront pas.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckFunctions</label>
+ <value>Fonctions requises</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckTimeLimitHelp</label>
+ <value>Sur un site à trafic important le processus d'archivage peut prendre plus de temps qu'il n'est déjà autorisé.&lt;br /&gt; Référez vous à la configuration max_execution_time de votre php.ini si nécessaire.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMailHelp</label>
+ <value>Les Feedback (commentaires) et mots de passe perdus ne pourront être envoyés sans la fonciton mail().</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckParseIniFileHelp</label>
+ <value>Cette fonction incluse a été désactivée sur votre serveur. Piwik va essayer d'émuler cette fonction mais il est possible que vous rencontriez des restrictions de sécurité par la suite. Les performances seront aussi impactées.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckDebugBacktraceHelp</label>
+ <value>View::factory ne pourra pas créer des vues pour le module appelé.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckCreateFunctionHelp</label>
+ <value>Piwik utilise des fonctions anonymes pour les callbacks.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMbstring</label>
+ <value>mbstring</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMbstringHelp</label>
+ <value>Vous devriez paramètrer mbstring.func_overload à &quot;0&quot;.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckFileIntegrity</label>
+ <value>Intégrité du fichier</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckError</label>
+ <value>Une erreur s'est produite — elle doit être corrigée avant de pouvoir continuer</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckWarning</label>
+ <value>Piwik fonctionnera normalement mais certaines fonctionnalités seront manquantes</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckProtocol</label>
+ <value>Protocole</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckProtocolHelp</label>
+ <value>Si Piwik se situe derrière un proxy inversé ajoutez ces lignes dans config/config.ini.php sous la section [General]:</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckIpv4</label>
+ <value>IPv4</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckIpv4Help</label>
+ <value>Vous devriez désactiver IPv6 dans la configuration de votre server.</value>
+ </row>
+ <row>
+ <label>Installation_Tables</label>
+ <value>Création des tables</value>
+ </row>
+ <row>
+ <label>Installation_TablesWithSameNamesFound</label>
+ <value>Environ %1$s tables dans votre base de données %2$s ont le même nom que celles que Piwik essaie de créer.</value>
+ </row>
+ <row>
+ <label>Installation_TablesFound</label>
+ <value>Les tables suivantes ont été trouvées dans la base de données</value>
+ </row>
+ <row>
+ <label>Installation_TablesWarningHelp</label>
+ <value>Vous pouvez choisir de réutiliser les tables de la base de données existante ou sélectionner une nouvelle installation pour effacer toutes les données existantes dans la base de données.</value>
+ </row>
+ <row>
+ <label>Installation_TablesReuse</label>
+ <value>Réutiliser les tables existantes</value>
+ </row>
+ <row>
+ <label>Installation_TablesDelete</label>
+ <value>Supprimer les tables détectées</value>
+ </row>
+ <row>
+ <label>Installation_TablesDeletedSuccess</label>
+ <value>Tables Piwik existantes supprimées avec succès</value>
+ </row>
+ <row>
+ <label>Installation_TablesCreatedSuccess</label>
+ <value>Tables crées avec succès!</value>
+ </row>
+ <row>
+ <label>Installation_DatabaseCreatedSuccess</label>
+ <value>Base de données %s crée avec succès !</value>
+ </row>
+ <row>
+ <label>Installation_GoBackAndDefinePrefix</label>
+ <value>Retournez à la page précédente et définissez le préfixe pour les tables Piwik</value>
+ </row>
+ <row>
+ <label>Installation_ConfirmDeleteExistingTables</label>
+ <value>Etes vous sûr de vouloir supprimer les tables : %s de votre base de données? ATTENTION: LES DONNEES SERONT DEFINITIVEMENT PERDUES!</value>
+ </row>
+ <row>
+ <label>Installation_Welcome</label>
+ <value>Bienvenue!</value>
+ </row>
+ <row>
+ <label>Installation_WelcomeHelp</label>
+ <value>&lt;p&gt;Piwik est une application d'analyse du web Open Source qui vous permet d'obtenir facilement les informations que vous désirez sur vos visiteurs.&lt;/p&gt; &lt;p&gt;Ce procédé est divisé en %s étapes faciles et vous prendra 5 minutes environ.&lt;/p&gt;</value>
+ </row>
+ <row>
+ <label>Installation_ConfigurationHelp</label>
+ <value>Votre configuration de Piwik semble être erronée. Vous pouvez ou bien supprimer config/config.inc.php et reprendre l'installation ou corriger les paramètres de connexion.</value>
+ </row>
+ <row>
+ <label>Installation_ErrorInvalidState</label>
+ <value>Erreur: il semble que vous essayez de sauter une étape du processus d'installation, ou vous avez désactivé les cookies, ou le fichier de configuration de Piwik est déjà créé. %1$sAssurez vous que les cookies sont bien activés%2$s et retournez %3$s à la première page d'installation %4$s.</value>
+ </row>
+ <row>
+ <label>LanguagesManager_PluginDescription</label>
+ <value>Ce plugin affichera la liste des langues disponibles pour l'interface de Piwik. Le langage sélectionné sera sauvegardé dans les préférences de chaque utilisateur.</value>
+ </row>
+ <row>
+ <label>LanguagesManager_AboutPiwikTranslations</label>
+ <value>A propos des traductions de Piwik</value>
+ </row>
+ <row>
+ <label>Live_PluginDescription</label>
+ <value>Espionnez vos visiteurs, en temps réel!</value>
+ </row>
+ <row>
+ <label>Live_VisitorLog</label>
+ <value>Log visiteur</value>
+ </row>
+ <row>
+ <label>Live_Date</label>
+ <value>Date</value>
+ </row>
+ <row>
+ <label>Live_Time</label>
+ <value>Temps</value>
+ </row>
+ <row>
+ <label>Live_Referrer_URL</label>
+ <value>URL du référant</value>
+ </row>
+ <row>
+ <label>Login_PluginDescription</label>
+ <value>Plugin de login, lisant les identifiants du fichier config/config.inc.php pour le the Super Utilisateur, et depuis la base de données pour les autres utilisateurs. Peut être facilement remplacé pour introduire un nouveau système d'authentification (OpenID, htaccess, custom Auth, etc.).</value>
+ </row>
+ <row>
+ <label>Login_LoginPasswordNotCorrect</label>
+ <value>Mot de passe et nom d'utilisateur incorrects.</value>
+ </row>
+ <row>
+ <label>Login_Password</label>
+ <value>Mot de passe</value>
+ </row>
+ <row>
+ <label>Login_PasswordRepeat</label>
+ <value>Mot de passe (répétez)</value>
+ </row>
+ <row>
+ <label>Login_ChangePassword</label>
+ <value>Modifier le mot de passe</value>
+ </row>
+ <row>
+ <label>Login_LoginOrEmail</label>
+ <value>Nom d'utilisateur ou courriel</value>
+ </row>
+ <row>
+ <label>Login_LogIn</label>
+ <value>Connexion</value>
+ </row>
+ <row>
+ <label>Login_Logout</label>
+ <value>Déconnexion</value>
+ </row>
+ <row>
+ <label>Login_LostYourPassword</label>
+ <value>Mot de passe perdu ?</value>
+ </row>
+ <row>
+ <label>Login_RemindPassword</label>
+ <value>Rappeler le mot de passe</value>
+ </row>
+ <row>
+ <label>Login_PasswordResetToken</label>
+ <value>Clef de remise à zéro du mot de passe</value>
+ </row>
+ <row>
+ <label>Login_PasswordReminder</label>
+ <value>Entrez un nom d'utilisateur ou un courriel valide, vous recevrez votre nouveau mot de passe par courriel.</value>
+ </row>
+ <row>
+ <label>Login_PasswordsDoNotMatch</label>
+ <value>Les mots de passe ne correspondent pas.</value>
+ </row>
+ <row>
+ <label>Login_PasswordSuccessfullyChanged</label>
+ <value>Mot de passe modifié avec succès!</value>
+ </row>
+ <row>
+ <label>Login_InvalidUsernameEmail</label>
+ <value>Nom d'utilisateur et/ou courriel invalide.</value>
+ </row>
+ <row>
+ <label>Login_InvalidNonceOrReferer</label>
+ <value>La clef de sécurité du formulaire est invalide ou a expiré. Merci de recharger le formulaire et de vérifier que vous avez activé les cookies.</value>
+ </row>
+ <row>
+ <label>Login_InvalidOrExpiredToken</label>
+ <value>La Clef est invalide ou a expiré</value>
+ </row>
+ <row>
+ <label>Login_MailTopicPasswordRecovery</label>
+ <value>Récupération du mot de passe</value>
+ </row>
+ <row>
+ <label>Login_PasswordSent</label>
+ <value>Le mot de passe vient juste d'être envoyé. Veuillez vérifier vos courriels.</value>
+ </row>
+ <row>
+ <label>Login_ContactAdmin</label>
+ <value>Raison possible : Votre hébergeur peut avoir désactivé la fonction mail(). &lt;br /&gt; Veuillez contacter votre administrateur Piwik.</value>
+ </row>
+ <row>
+ <label>MultiSites_PluginDescription</label>
+ <value>Affiche le sommaire/les statistiques multi-site. Actuellement maintenu comme un plugin Piwik cœur.</value>
+ </row>
+ <row>
+ <label>Provider_PluginDescription</label>
+ <value>Effectue des rapports sur les FAI des visiteurs.</value>
+ </row>
+ <row>
+ <label>Provider_WidgetProviders</label>
+ <value>Fournisseurs d'accès à Internet</value>
+ </row>
+ <row>
+ <label>Provider_ColumnProvider</label>
+ <value>FAI</value>
+ </row>
+ <row>
+ <label>Provider_SubmenuLocationsProvider</label>
+ <value>Situation géographique et FAI</value>
+ </row>
+ <row>
+ <label>Referers_PluginDescription</label>
+ <value>Effectue des rapports sur les données des référents: moteurs de recherche, mots clefs, sites web, suivi de campagne, entrée directe. </value>
+ </row>
+ <row>
+ <label>Referers_Referers</label>
+ <value>Référents</value>
+ </row>
+ <row>
+ <label>Referers_SearchEngines</label>
+ <value>Moteurs de recherche</value>
+ </row>
+ <row>
+ <label>Referers_Keywords</label>
+ <value>Mots-clés</value>
+ </row>
+ <row>
+ <label>Referers_DirectEntry</label>
+ <value>Entrées directes</value>
+ </row>
+ <row>
+ <label>Referers_Websites</label>
+ <value>Sites Internet</value>
+ </row>
+ <row>
+ <label>Referers_Campaigns</label>
+ <value>Campagnes</value>
+ </row>
+ <row>
+ <label>Referers_Evolution</label>
+ <value>Évolution sur la période</value>
+ </row>
+ <row>
+ <label>Referers_Type</label>
+ <value>Types d'affluents</value>
+ </row>
+ <row>
+ <label>Referers_ColumnRefererType</label>
+ <value>Type de Provenance</value>
+ </row>
+ <row>
+ <label>Referers_ColumnSearchEngine</label>
+ <value>Moteur de recherche</value>
+ </row>
+ <row>
+ <label>Referers_ColumnWebsite</label>
+ <value>Site Web</value>
+ </row>
+ <row>
+ <label>Referers_ColumnWebsitePage</label>
+ <value>Page du site</value>
+ </row>
+ <row>
+ <label>Referers_ColumnKeyword</label>
+ <value>Mot clef</value>
+ </row>
+ <row>
+ <label>Referers_ColumnCampaign</label>
+ <value>Campagne</value>
+ </row>
+ <row>
+ <label>Referers_DetailsByRefererType</label>
+ <value>Détails de types d'affluents</value>
+ </row>
+ <row>
+ <label>Referers_TypeDirectEntries</label>
+ <value>%s entrées directes</value>
+ </row>
+ <row>
+ <label>Referers_TypeSearchEngines</label>
+ <value>%s depuis des moteurs de recherche</value>
+ </row>
+ <row>
+ <label>Referers_TypeWebsites</label>
+ <value>%s depuis d'autres sites Internet</value>
+ </row>
+ <row>
+ <label>Referers_TypeCampaigns</label>
+ <value>%s depuis des campagnes</value>
+ </row>
+ <row>
+ <label>Referers_Distinct</label>
+ <value>Provenances distinctes par type de Provenance</value>
+ </row>
+ <row>
+ <label>Referers_DistinctSearchEngines</label>
+ <value>Moteurs de recherche distincts</value>
+ </row>
+ <row>
+ <label>Referers_DistinctKeywords</label>
+ <value>mots clef distincts</value>
+ </row>
+ <row>
+ <label>Referers_DistinctCampaigns</label>
+ <value>campagnes distinctes</value>
+ </row>
+ <row>
+ <label>Referers_DistinctWebsites</label>
+ <value>sites web distincts</value>
+ </row>
+ <row>
+ <label>Referers_SubmenuEvolution</label>
+ <value>Évolution</value>
+ </row>
+ <row>
+ <label>Referers_SubmenuSearchEngines</label>
+ <value>Moteurs de recherche et mots-clés</value>
+ </row>
+ <row>
+ <label>Referers_SubmenuWebsites</label>
+ <value>Sites Internet</value>
+ </row>
+ <row>
+ <label>Referers_SubmenuCampaigns</label>
+ <value>Campagnes</value>
+ </row>
+ <row>
+ <label>Referers_WidgetKeywords</label>
+ <value>Liste des mots-clés</value>
+ </row>
+ <row>
+ <label>Referers_WidgetCampaigns</label>
+ <value>Liste des campagnes</value>
+ </row>
+ <row>
+ <label>Referers_WidgetExternalWebsites</label>
+ <value>Liste des sites Internet externes</value>
+ </row>
+ <row>
+ <label>Referers_WidgetSearchEngines</label>
+ <value>Meilleurs moteurs de recherche</value>
+ </row>
+ <row>
+ <label>Referers_WidgetOverview</label>
+ <value>Récapitulatif</value>
+ </row>
+ <row>
+ <label>SecurityInfo_PluginDescription</label>
+ <value>Basé sur PhpSecInfo du Consortium de Sécurité de PHP, ce plugin fournit des information de sécurité à propos de votre environnement PHP et donne des suggestions pour son amélioration. C'est un outil d'approche sécurité multi-couches. Cela ne remplace ni les pratiques de développement sécurisé ni les audit du code.</value>
+ </row>
+ <row>
+ <label>SecurityInfo_Security</label>
+ <value>Sécurité</value>
+ </row>
+ <row>
+ <label>SecurityInfo_SecurityInformation</label>
+ <value>Information de sécurité de PHP</value>
+ </row>
+ <row>
+ <label>SecurityInfo_Test</label>
+ <value>Test</value>
+ </row>
+ <row>
+ <label>SecurityInfo_Result</label>
+ <value>Résultat</value>
+ </row>
+ <row>
+ <label>SitesManager_PluginDescription</label>
+ <value>Gestion des sites web dans Piwik: Ajoute un nouveau site web, modifie un existant, affiche le code JavaScript à inclure dans vos pages. Toutes les actions sont disponibles au travers de l'API.</value>
+ </row>
+ <row>
+ <label>SitesManager_Sites</label>
+ <value>Sites</value>
+ </row>
+ <row>
+ <label>SitesManager_WebsitesManagement</label>
+ <value>Gestion des sites</value>
+ </row>
+ <row>
+ <label>SitesManager_MainDescription</label>
+ <value>Piwik a besoin de sites pour générer des rapports ! Ajoutez, éditez et supprimez des sites, et voyez le code JavaScript à inclure dans vos pages.</value>
+ </row>
+ <row>
+ <label>SitesManager_JsTrackingTag</label>
+ <value>Code JavaScript de suivit</value>
+ </row>
+ <row>
+ <label>SitesManager_JsTrackingTagHelp</label>
+ <value>Ci-dessous le code JavaScript à inclure dans toutes vos pages </value>
+ </row>
+ <row>
+ <label>SitesManager_ShowTrackingTag</label>
+ <value>Afficher le code</value>
+ </row>
+ <row>
+ <label>SitesManager_NoWebsites</label>
+ <value>Vous n'avez aucun site Internet à administrer.</value>
+ </row>
+ <row>
+ <label>SitesManager_AddSite</label>
+ <value>Ajouter un site</value>
+ </row>
+ <row>
+ <label>SitesManager_AliasUrlHelp</label>
+ <value>Il est recommandé, mais pas requis, de spécifier les URL différentes que vos utilisateurs utilisent pour accéder au site web. Les URL d'alias pour un site n'apparaitront pas dans Référents &gt; Sites Internet. Il n'est pas nécessaire d'entrer les URL avec et sans les www, Piwik les traite automatiquement.</value>
+ </row>
+ <row>
+ <label>SitesManager_Id</label>
+ <value>Id</value>
+ </row>
+ <row>
+ <label>SitesManager_Name</label>
+ <value>Nom</value>
+ </row>
+ <row>
+ <label>SitesManager_Urls</label>
+ <value>URLs</value>
+ </row>
+ <row>
+ <label>SitesManager_MenuSites</label>
+ <value>Sites</value>
+ </row>
+ <row>
+ <label>SitesManager_DeleteConfirm_js</label>
+ <value>Êtes-vous sûr de vouloir supprimer le site %s?</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionDeleteSite</label>
+ <value>Impossible de supprimer le site car c'est le seul site enregistré dans Piwik. Vous pouvez d'abord en ajouter un nouveau, puis supprimez celui-ci.</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionNoUrl</label>
+ <value>Vous devez spécifier au moins une url pour le site.</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionEmptyName</label>
+ <value>Le nom du site ne peut être vide.</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionInvalidUrl</label>
+ <value>L'url '%s' est invalide.</value>
+ </row>
+ <row>
+ <label>SitesManager_SuperUserCan</label>
+ <value>Le super utilisateur peut aussi %s spécifier les paramètres généraux%s pour les nouveaux sites web.</value>
+ </row>
+ <row>
+ <label>SitesManager_ExcludedIps</label>
+ <value>IPs Exclues</value>
+ </row>
+ <row>
+ <label>SitesManager_GlobalListExcludedIps</label>
+ <value>Liste globale des IPs Exclues</value>
+ </row>
+ <row>
+ <label>SitesManager_ListOfIpsToBeExcludedOnAllWebsites</label>
+ <value>Les adresses IP ci-dessous seront exclues des statistiques sur tous les sites web.</value>
+ </row>
+ <row>
+ <label>SitesManager_ExcludedParameters</label>
+ <value>Paramètres Exclus</value>
+ </row>
+ <row>
+ <label>SitesManager_GlobalListExcludedQueryParameters</label>
+ <value>Liste globale des paramètres Url des requêtes à exclure</value>
+ </row>
+ <row>
+ <label>SitesManager_ListOfQueryParametersToBeExcludedOnAllWebsites</label>
+ <value>Les paramètres ci-dessous seront exclus des statistiques de tous les sites web.</value>
+ </row>
+ <row>
+ <label>SitesManager_ListOfQueryParametersToExclude</label>
+ <value>Entrez la liste des paramètres Url, un par ligne, à exclure des rapports des Url de pages.</value>
+ </row>
+ <row>
+ <label>SitesManager_PiwikWillAutomaticallyExcludeCommonSessionParameters</label>
+ <value>Piwik exclura automatiquement les paramètres de session communs (%s).</value>
+ </row>
+ <row>
+ <label>SitesManager_HelpExcludedIps</label>
+ <value>Entrez une liste d'adresses IP, une par ligne, que vous souhaitez exclure des statistiques Piwik. Vous pouvez utiliser des caractères jokers ex %1$s ou %2$s</value>
+ </row>
+ <row>
+ <label>SitesManager_YourCurrentIpAddressIs</label>
+ <value>Votre adresse IP actuelle est %s</value>
+ </row>
+ <row>
+ <label>SitesManager_SelectACity</label>
+ <value>Sélectionnez une ville</value>
+ </row>
+ <row>
+ <label>SitesManager_ChooseCityInSameTimezoneAsYou</label>
+ <value>Choisissez une ville qui se trouve dans le même fuseau horaire que vous.</value>
+ </row>
+ <row>
+ <label>SitesManager_ChangingYourTimezoneWillOnlyAffectDataForward</label>
+ <value>Le fait de modifier votre fuseau horaire affectera uniquement les nouvelles données, ce n'est pas rétroactif.</value>
+ </row>
+ <row>
+ <label>SitesManager_AdvancedTimezoneSupportNotFound</label>
+ <value>Le support avancé des fuseaux horaires n'a pu être trouvé dans votre configuration de PHP (supporté dans PHP&gt;=5.2). Vous pouvez toujours choisir manuellement un décalage UTC.</value>
+ </row>
+ <row>
+ <label>SitesManager_UTCTimeIs</label>
+ <value>l'heure UTC est %s.</value>
+ </row>
+ <row>
+ <label>SitesManager_Timezone</label>
+ <value>Fuseau horaire</value>
+ </row>
+ <row>
+ <label>SitesManager_GlobalWebsitesSettings</label>
+ <value>Paramètres généraux des sites web</value>
+ </row>
+ <row>
+ <label>SitesManager_DefaultTimezoneForNewWebsites</label>
+ <value>Fuseau horaire par défaut pour les nouveaux sites web</value>
+ </row>
+ <row>
+ <label>SitesManager_SelectDefaultTimezone</label>
+ <value>Vous pouvez sélectionner le fuseau horaire par défaut pour les nouveaux sites web.</value>
+ </row>
+ <row>
+ <label>SitesManager_Currency</label>
+ <value>Devise</value>
+ </row>
+ <row>
+ <label>SitesManager_CurrencySymbolWillBeUsedForGoals</label>
+ <value>Le symbole de la devise sera affiché à côté des revenus des Objectifs</value>
+ </row>
+ <row>
+ <label>SitesManager_DefaultCurrencyForNewWebsites</label>
+ <value>Devise par défaut pour les nouveaux sites web</value>
+ </row>
+ <row>
+ <label>SitesManager_SelectDefaultCurrency</label>
+ <value>Vous pouvez sélectionner la devise par défaut pour les nouveaux sites web.</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_PluginDescription</label>
+ <value>Aidez à traduire Piwik dans votre langue.</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_MenuTranslations</label>
+ <value>Traductions</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_MenuLanguages</label>
+ <value>Langues</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_Plugin</label>
+ <value>Plugin</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_Definition</label>
+ <value>Définition</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_DefaultString</label>
+ <value>Chaine par défaut (English)</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_TranslationString</label>
+ <value>Traduction (Langue actuelle : %s)</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_Translations</label>
+ <value>Traductions</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_FixPermissions</label>
+ <value>Veuillez définir les propriétés des fichiers systèmes</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_AvailableLanguages</label>
+ <value>Langues disponibles</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_AddLanguage</label>
+ <value>Ajouter langue</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_LanguageCode</label>
+ <value>Code langue</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_Export</label>
+ <value>Exporter langue</value>
+ </row>
+ <row>
+ <label>TranslationsAdmin_Import</label>
+ <value>Importer langue</value>
+ </row>
+ <row>
+ <label>UserCountry_PluginDescription</label>
+ <value>Effectue des rapports sur les pays des visiteurs.</value>
+ </row>
+ <row>
+ <label>UserCountry_Country</label>
+ <value>Pays</value>
+ </row>
+ <row>
+ <label>UserCountry_Continent</label>
+ <value>Continent</value>
+ </row>
+ <row>
+ <label>UserCountry_DistinctCountries</label>
+ <value>%s pays différents</value>
+ </row>
+ <row>
+ <label>UserCountry_SubmenuLocations</label>
+ <value>Provenances géographiques</value>
+ </row>
+ <row>
+ <label>UserCountry_WidgetContinents</label>
+ <value>Continents des visiteurs</value>
+ </row>
+ <row>
+ <label>UserCountry_WidgetCountries</label>
+ <value>Pays des visiteurs</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ac</label>
+ <value>Ascension (île)</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ad</label>
+ <value>Andorre</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ae</label>
+ <value>Émirats arabes unis</value>
+ </row>
+ <row>
+ <label>UserCountry_country_af</label>
+ <value>Afghanistan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ag</label>
+ <value>Antigua-et-Barbuda</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ai</label>
+ <value>Anguilla</value>
+ </row>
+ <row>
+ <label>UserCountry_country_al</label>
+ <value>Albanie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_am</label>
+ <value>Arménie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_an</label>
+ <value>Antilles Néerlandaises</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ao</label>
+ <value>Angola</value>
+ </row>
+ <row>
+ <label>UserCountry_country_aq</label>
+ <value>Antarctique</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ar</label>
+ <value>Argentine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_as</label>
+ <value>Samoa Américaines</value>
+ </row>
+ <row>
+ <label>UserCountry_country_at</label>
+ <value>Autriche</value>
+ </row>
+ <row>
+ <label>UserCountry_country_au</label>
+ <value>Australie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_aw</label>
+ <value>Aruba</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ax</label>
+ <value>État libre associé d'Åland</value>
+ </row>
+ <row>
+ <label>UserCountry_country_az</label>
+ <value>Azerbaïdjan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ba</label>
+ <value>Bosnie-Herzégovine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bb</label>
+ <value>La Barbade</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bd</label>
+ <value>Bangladesh</value>
+ </row>
+ <row>
+ <label>UserCountry_country_be</label>
+ <value>Belgique</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bf</label>
+ <value>Burkina Faso</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bg</label>
+ <value>Bulgarie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bh</label>
+ <value>Bahreïn</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bi</label>
+ <value>Burundi</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bj</label>
+ <value>Bénin</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bl</label>
+ <value>Saint Barthélemy</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bm</label>
+ <value>Bermudes</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bn</label>
+ <value>Brunei</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bo</label>
+ <value>Bolivie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_br</label>
+ <value>Brésil</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bs</label>
+ <value>Bahamas</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bt</label>
+ <value>Bhutan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bu</label>
+ <value>Union du Myanmar</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bv</label>
+ <value>Ile Bouvet</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bw</label>
+ <value>Botswana</value>
+ </row>
+ <row>
+ <label>UserCountry_country_by</label>
+ <value>Belarus</value>
+ </row>
+ <row>
+ <label>UserCountry_country_bz</label>
+ <value>Belize</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ca</label>
+ <value>Canada</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cc</label>
+ <value>Iles des Cocos (Keeling)</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cd</label>
+ <value>Congo, République démocratique du</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cf</label>
+ <value>République d'Afrique Centrale</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cg</label>
+ <value>Congo</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ch</label>
+ <value>Suisse</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ci</label>
+ <value>Cote D'Ivoire</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ck</label>
+ <value>Iles Cook</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cl</label>
+ <value>Chili</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cm</label>
+ <value>Cameroun</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cn</label>
+ <value>Chine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_co</label>
+ <value>Colombie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cp</label>
+ <value>Ile de La Passion</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cr</label>
+ <value>Costa Rica</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cs</label>
+ <value>Serbie Monténégro</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cu</label>
+ <value>Cuba</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cv</label>
+ <value>Cap Vert</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cx</label>
+ <value>Ile Christmas</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cy</label>
+ <value>Chypre</value>
+ </row>
+ <row>
+ <label>UserCountry_country_cz</label>
+ <value>République Tchèque</value>
+ </row>
+ <row>
+ <label>UserCountry_country_de</label>
+ <value>Allemagne</value>
+ </row>
+ <row>
+ <label>UserCountry_country_dg</label>
+ <value>Diego Garcia</value>
+ </row>
+ <row>
+ <label>UserCountry_country_dj</label>
+ <value>Djibouti</value>
+ </row>
+ <row>
+ <label>UserCountry_country_dk</label>
+ <value>Danemark</value>
+ </row>
+ <row>
+ <label>UserCountry_country_dm</label>
+ <value>Dominique</value>
+ </row>
+ <row>
+ <label>UserCountry_country_do</label>
+ <value>République Dominicaine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_dz</label>
+ <value>Algérie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ea</label>
+ <value>Ceuta, Melilla</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ec</label>
+ <value>Équateur</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ee</label>
+ <value>Estonie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_eg</label>
+ <value>Égypte</value>
+ </row>
+ <row>
+ <label>UserCountry_country_eh</label>
+ <value>Sahara occidental</value>
+ </row>
+ <row>
+ <label>UserCountry_country_er</label>
+ <value>Erythrée</value>
+ </row>
+ <row>
+ <label>UserCountry_country_es</label>
+ <value>Espagne</value>
+ </row>
+ <row>
+ <label>UserCountry_country_et</label>
+ <value>Ethiopie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_eu</label>
+ <value>Union Européenne</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fi</label>
+ <value>Finlande</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fj</label>
+ <value>Fidji</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fk</label>
+ <value>Iles Falkland</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fm</label>
+ <value>Micronesia, Federated States of</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fo</label>
+ <value>Iles Faroe</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fr</label>
+ <value>France</value>
+ </row>
+ <row>
+ <label>UserCountry_country_fx</label>
+ <value>France métropolitaine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ga</label>
+ <value>Gabon</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gb</label>
+ <value>Grande Bretagne</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gd</label>
+ <value>Grenade</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ge</label>
+ <value>Géorgie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gf</label>
+ <value>Guyane Française</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gg</label>
+ <value>Ile de Guernesey</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gh</label>
+ <value>Ghana</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gi</label>
+ <value>Gibraltar</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gl</label>
+ <value>Groenland</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gm</label>
+ <value>Gambie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gn</label>
+ <value>Guinée</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gp</label>
+ <value>Guadeloupe</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gq</label>
+ <value>Guinée Équatoriale</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gr</label>
+ <value>Grèce</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gs</label>
+ <value>Géorgie du Sud-et-les Îles Sandwich du Sud</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gt</label>
+ <value>Guatemala</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gu</label>
+ <value>Guam</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gw</label>
+ <value>Guinée-Bissau</value>
+ </row>
+ <row>
+ <label>UserCountry_country_gy</label>
+ <value>Guyane</value>
+ </row>
+ <row>
+ <label>UserCountry_country_hk</label>
+ <value>Hong Kong</value>
+ </row>
+ <row>
+ <label>UserCountry_country_hm</label>
+ <value>Iles heard et Mac Donald</value>
+ </row>
+ <row>
+ <label>UserCountry_country_hn</label>
+ <value>Honduras</value>
+ </row>
+ <row>
+ <label>UserCountry_country_hr</label>
+ <value>Croatie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ht</label>
+ <value>Haïti</value>
+ </row>
+ <row>
+ <label>UserCountry_country_hu</label>
+ <value>Hongrie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ic</label>
+ <value>Iles Canaries</value>
+ </row>
+ <row>
+ <label>UserCountry_country_id</label>
+ <value>Indonésie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ie</label>
+ <value>Irlande</value>
+ </row>
+ <row>
+ <label>UserCountry_country_il</label>
+ <value>Israël</value>
+ </row>
+ <row>
+ <label>UserCountry_country_im</label>
+ <value>Iles de Man</value>
+ </row>
+ <row>
+ <label>UserCountry_country_in</label>
+ <value>Inde</value>
+ </row>
+ <row>
+ <label>UserCountry_country_io</label>
+ <value>Océan indien (Territoire Britannique)</value>
+ </row>
+ <row>
+ <label>UserCountry_country_iq</label>
+ <value>Irak</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ir</label>
+ <value>Iran, République Islamique de</value>
+ </row>
+ <row>
+ <label>UserCountry_country_is</label>
+ <value>Islande</value>
+ </row>
+ <row>
+ <label>UserCountry_country_it</label>
+ <value>Italie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_je</label>
+ <value>Jersey</value>
+ </row>
+ <row>
+ <label>UserCountry_country_jm</label>
+ <value>Jamaïque</value>
+ </row>
+ <row>
+ <label>UserCountry_country_jo</label>
+ <value>Jordanie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_jp</label>
+ <value>Japon</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ke</label>
+ <value>Kenya</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kg</label>
+ <value>Kirghizstan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kh</label>
+ <value>Kampuchea (ex Cambodge)</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ki</label>
+ <value>Kiribati</value>
+ </row>
+ <row>
+ <label>UserCountry_country_km</label>
+ <value>Comores</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kn</label>
+ <value>Saint Christophe Nieves Ang.</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kp</label>
+ <value>Corée du Nord</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kr</label>
+ <value>Corée du Sud</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kw</label>
+ <value>Koweït</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ky</label>
+ <value>Iles Caïmans</value>
+ </row>
+ <row>
+ <label>UserCountry_country_kz</label>
+ <value>Kazakhstan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_la</label>
+ <value>Laos</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lb</label>
+ <value>Liban</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lc</label>
+ <value>Sainte Lucie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_li</label>
+ <value>Liechtenstein</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lk</label>
+ <value>Sri Lanka</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lr</label>
+ <value>Liberia</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ls</label>
+ <value>Lesotho</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lt</label>
+ <value>Lituanie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lu</label>
+ <value>Luxembourg</value>
+ </row>
+ <row>
+ <label>UserCountry_country_lv</label>
+ <value>Lettonie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ly</label>
+ <value>Lybie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ma</label>
+ <value>Maroc</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mc</label>
+ <value>Monaco</value>
+ </row>
+ <row>
+ <label>UserCountry_country_md</label>
+ <value>Moldavie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_me</label>
+ <value>Monténégro</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mf</label>
+ <value>Saint Martin</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mg</label>
+ <value>Madagascar</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mh</label>
+ <value>Iles Marshall</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mk</label>
+ <value>Macédoine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ml</label>
+ <value>Mali</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mm</label>
+ <value>Myanmar</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mn</label>
+ <value>Mongolie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mo</label>
+ <value>Macao</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mp</label>
+ <value>Iles Mariannes du Nord</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mq</label>
+ <value>Martinique</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mr</label>
+ <value>Mauritanie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ms</label>
+ <value>Montserrat</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mt</label>
+ <value>Malte</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mu</label>
+ <value>Ile Maurice</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mv</label>
+ <value>Maldives</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mw</label>
+ <value>Malawi</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mx</label>
+ <value>Mexique</value>
+ </row>
+ <row>
+ <label>UserCountry_country_my</label>
+ <value>Malaisie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_mz</label>
+ <value>Mozambique</value>
+ </row>
+ <row>
+ <label>UserCountry_country_na</label>
+ <value>Namibie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nc</label>
+ <value>Nouvelle Calédonie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ne</label>
+ <value>Niger</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nf</label>
+ <value>Ile Norfolk</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ng</label>
+ <value>Nigeria</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ni</label>
+ <value>Nicaragua</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nl</label>
+ <value>Pays-Bas</value>
+ </row>
+ <row>
+ <label>UserCountry_country_no</label>
+ <value>Norvège</value>
+ </row>
+ <row>
+ <label>UserCountry_country_np</label>
+ <value>Népal</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nr</label>
+ <value>Nauru</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nt</label>
+ <value>Zone Neutre</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nu</label>
+ <value>Nioue</value>
+ </row>
+ <row>
+ <label>UserCountry_country_nz</label>
+ <value>Nouvelle Zélande</value>
+ </row>
+ <row>
+ <label>UserCountry_country_om</label>
+ <value>Oman</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pa</label>
+ <value>Panama</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pe</label>
+ <value>Pérou</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pf</label>
+ <value>Polynésie Française</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pg</label>
+ <value>Papouasie Nouvelle Guinée</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ph</label>
+ <value>Philippines</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pk</label>
+ <value>Pakistan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pl</label>
+ <value>Pologne</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pm</label>
+ <value>Saint Pierre et Miquelon</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pn</label>
+ <value>Iles Pitcairn</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pr</label>
+ <value>Puerto Rico</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ps</label>
+ <value>Palestine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pt</label>
+ <value>Portugal</value>
+ </row>
+ <row>
+ <label>UserCountry_country_pw</label>
+ <value>Palau</value>
+ </row>
+ <row>
+ <label>UserCountry_country_py</label>
+ <value>Paraguay</value>
+ </row>
+ <row>
+ <label>UserCountry_country_qa</label>
+ <value>Qatar</value>
+ </row>
+ <row>
+ <label>UserCountry_country_re</label>
+ <value>La Réunion</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ro</label>
+ <value>Roumanie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ru</label>
+ <value>Russie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_rs</label>
+ <value>Serbie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_rw</label>
+ <value>Rwanda</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sa</label>
+ <value>Arabie Saoudite</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sb</label>
+ <value>Iles Salomon</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sc</label>
+ <value>Seychelles</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sd</label>
+ <value>Soudan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_se</label>
+ <value>Suède</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sf</label>
+ <value>Finlande</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sg</label>
+ <value>Singapour</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sh</label>
+ <value>Sainte Hélène</value>
+ </row>
+ <row>
+ <label>UserCountry_country_si</label>
+ <value>Slovénie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sj</label>
+ <value>Svalbard et Ile Jan Mayen</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sk</label>
+ <value>Slovaquie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sl</label>
+ <value>Sierra Leone</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sm</label>
+ <value>Saint-Marin</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sn</label>
+ <value>Sénégal</value>
+ </row>
+ <row>
+ <label>UserCountry_country_so</label>
+ <value>Somalie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sr</label>
+ <value>Surinam</value>
+ </row>
+ <row>
+ <label>UserCountry_country_st</label>
+ <value>Sao Tome et Principe</value>
+ </row>
+ <row>
+ <label>UserCountry_country_su</label>
+ <value>Ex U.R.S.S</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sv</label>
+ <value>El Salvador</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sy</label>
+ <value>Syrie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_sz</label>
+ <value>Swaziland</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ta</label>
+ <value>Île Tristan da Cunha</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tc</label>
+ <value>Iles Turks et Caicos</value>
+ </row>
+ <row>
+ <label>UserCountry_country_td</label>
+ <value>Tchad</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tf</label>
+ <value>Terres australes et antarctiques françaises</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tg</label>
+ <value>Togo</value>
+ </row>
+ <row>
+ <label>UserCountry_country_th</label>
+ <value>Thaïlande</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tj</label>
+ <value>Tadjikistan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tk</label>
+ <value>Tokelaou</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tl</label>
+ <value>Timor Oriental</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tm</label>
+ <value>Turkménistan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tn</label>
+ <value>Tunisie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_to</label>
+ <value>Tonga</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tp</label>
+ <value>Timor Oriental</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tr</label>
+ <value>Turquie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tt</label>
+ <value>Trinité et Tobago </value>
+ </row>
+ <row>
+ <label>UserCountry_country_tv</label>
+ <value>Tuvalu</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tw</label>
+ <value>Taïwan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_tz</label>
+ <value>Tanzanie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ua</label>
+ <value>Ukraine</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ug</label>
+ <value>Ouganda</value>
+ </row>
+ <row>
+ <label>UserCountry_country_uk</label>
+ <value>Royaume-Uni</value>
+ </row>
+ <row>
+ <label>UserCountry_country_um</label>
+ <value>Îles mineures éloignées des États-Unis</value>
+ </row>
+ <row>
+ <label>UserCountry_country_us</label>
+ <value>Etats Unis</value>
+ </row>
+ <row>
+ <label>UserCountry_country_uy</label>
+ <value>Uruguay</value>
+ </row>
+ <row>
+ <label>UserCountry_country_uz</label>
+ <value>Ouzbékistan</value>
+ </row>
+ <row>
+ <label>UserCountry_country_va</label>
+ <value>Vatican</value>
+ </row>
+ <row>
+ <label>UserCountry_country_vc</label>
+ <value>Saint Vincent et Grenadines</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ve</label>
+ <value>Venezuela</value>
+ </row>
+ <row>
+ <label>UserCountry_country_vg</label>
+ <value>Iles Vierges Britanniques</value>
+ </row>
+ <row>
+ <label>UserCountry_country_vi</label>
+ <value>Iles Vierges U.S.</value>
+ </row>
+ <row>
+ <label>UserCountry_country_vn</label>
+ <value>Vietnam</value>
+ </row>
+ <row>
+ <label>UserCountry_country_vu</label>
+ <value>Vanuatu</value>
+ </row>
+ <row>
+ <label>UserCountry_country_wf</label>
+ <value>Wallis et Futuna</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ws</label>
+ <value>Samoa Occidentales</value>
+ </row>
+ <row>
+ <label>UserCountry_country_ye</label>
+ <value>Yémen</value>
+ </row>
+ <row>
+ <label>UserCountry_country_yt</label>
+ <value>Mayotte</value>
+ </row>
+ <row>
+ <label>UserCountry_country_yu</label>
+ <value>Yougoslavie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_za</label>
+ <value>Afrique du Sud</value>
+ </row>
+ <row>
+ <label>UserCountry_country_zm</label>
+ <value>Zambie</value>
+ </row>
+ <row>
+ <label>UserCountry_country_zr</label>
+ <value>Zaïre</value>
+ </row>
+ <row>
+ <label>UserCountry_country_zw</label>
+ <value>Zimbabwe</value>
+ </row>
+ <row>
+ <label>UserCountry_continent_eur</label>
+ <value>Europe</value>
+ </row>
+ <row>
+ <label>UserCountry_continent_afr</label>
+ <value>Afrique</value>
+ </row>
+ <row>
+ <label>UserCountry_continent_asi</label>
+ <value>Asie</value>
+ </row>
+ <row>
+ <label>UserCountry_continent_ams</label>
+ <value>Amérique du sud et centrale</value>
+ </row>
+ <row>
+ <label>UserCountry_continent_amn</label>
+ <value>Amérique du nord</value>
+ </row>
+ <row>
+ <label>UserCountry_continent_oce</label>
+ <value>Océanie</value>
+ </row>
+ <row>
+ <label>UserCountryMap_map</label>
+ <value>carte</value>
+ </row>
+ <row>
+ <label>UserCountryMap_worldMap</label>
+ <value>mappemonde</value>
+ </row>
+ <row>
+ <label>UserSettings_PluginDescription</label>
+ <value>Effectue des rapports variés sur les paramètres utilisateurs: navigateur, famille du navigateur, système d'exploitation, plugins, résolution, paramètres généraux.</value>
+ </row>
+ <row>
+ <label>UserSettings_VisitorSettings</label>
+ <value>Paramètres visiteur</value>
+ </row>
+ <row>
+ <label>UserSettings_BrowserFamilies</label>
+ <value>Familles de navigateurs</value>
+ </row>
+ <row>
+ <label>UserSettings_Browsers</label>
+ <value>Navigateurs</value>
+ </row>
+ <row>
+ <label>UserSettings_Plugins</label>
+ <value>Plugins</value>
+ </row>
+ <row>
+ <label>UserSettings_Configurations</label>
+ <value>Configurations</value>
+ </row>
+ <row>
+ <label>UserSettings_OperatingSystems</label>
+ <value>Système d'exploitation</value>
+ </row>
+ <row>
+ <label>UserSettings_Resolutions</label>
+ <value>Résolutions</value>
+ </row>
+ <row>
+ <label>UserSettings_WideScreen</label>
+ <value>Largeur d'écran</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnBrowserFamily</label>
+ <value>Famille de navigateur</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnBrowser</label>
+ <value>Navigateur</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnPlugin</label>
+ <value>Plugin</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnConfiguration</label>
+ <value>Configuration</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnOperatingSystem</label>
+ <value>Système d'exploitation</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnResolution</label>
+ <value>Résolution</value>
+ </row>
+ <row>
+ <label>UserSettings_ColumnTypeOfScreen</label>
+ <value>Type d'écran</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetResolutions</label>
+ <value>Résolutions d'écran</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetBrowsers</label>
+ <value>Navigateurs du visiteur</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetPlugins</label>
+ <value>Liste de Plugins</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetWidescreen</label>
+ <value>Normal / Écran large</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetBrowserFamilies</label>
+ <value>Navigateurs par famille</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetOperatingSystems</label>
+ <value>Systèmes d'exploitation</value>
+ </row>
+ <row>
+ <label>UserSettings_WidgetGlobalVisitors</label>
+ <value>Configuration globale des visiteurs</value>
+ </row>
+ <row>
+ <label>UserSettings_SubmenuSettings</label>
+ <value>Paramètres</value>
+ </row>
+ <row>
+ <label>UsersManager_PluginDescription</label>
+ <value>Gestion des utilisateurs dans Piwik: ajouter un nouvel utilisateur, en éditer, mettre à jour les permissions. Toutes les actions sont aussi disponibles au travers de l'API.</value>
+ </row>
+ <row>
+ <label>UsersManager_UsersManagement</label>
+ <value>Gestion des utilisateurs</value>
+ </row>
+ <row>
+ <label>UsersManager_UsersManagementMainDescription</label>
+ <value>Créez de nouveaux utilisateurs ou modifiez-les. Vous pourrez ensuite changez leurs permissions ci-dessus.</value>
+ </row>
+ <row>
+ <label>UsersManager_ManageAccess</label>
+ <value>Gestion des accès utilisateurs</value>
+ </row>
+ <row>
+ <label>UsersManager_MainDescription</label>
+ <value>Décidez quels utilisateurs ont accès à quels sites. Vous pouvez aussi changer les permissions de tous les sites d'un seul coup.</value>
+ </row>
+ <row>
+ <label>UsersManager_Sites</label>
+ <value>Sites</value>
+ </row>
+ <row>
+ <label>UsersManager_AllWebsites</label>
+ <value>Tous les sites Internet</value>
+ </row>
+ <row>
+ <label>UsersManager_ApplyToAllWebsites</label>
+ <value>Appliquer à tous les sites</value>
+ </row>
+ <row>
+ <label>UsersManager_User</label>
+ <value>Utilisateur</value>
+ </row>
+ <row>
+ <label>UsersManager_PrivNone</label>
+ <value>Pas d'accès</value>
+ </row>
+ <row>
+ <label>UsersManager_PrivView</label>
+ <value>Consultation</value>
+ </row>
+ <row>
+ <label>UsersManager_PrivAdmin</label>
+ <value>Administration</value>
+ </row>
+ <row>
+ <label>UsersManager_ChangeAllConfirm</label>
+ <value>Êtes-vous sûr de vouloir changer les permissions de '%s' sur tous les sites Internet?</value>
+ </row>
+ <row>
+ <label>UsersManager_Password</label>
+ <value>Mot de passe</value>
+ </row>
+ <row>
+ <label>UsersManager_Email</label>
+ <value>Courriel</value>
+ </row>
+ <row>
+ <label>UsersManager_Alias</label>
+ <value>Alias</value>
+ </row>
+ <row>
+ <label>UsersManager_TheSuperUserAliasCannotBeChanged</label>
+ <value>L'alias du super utilisateur ne peut $etre changé.</value>
+ </row>
+ <row>
+ <label>UsersManager_ReportToLoadByDefault</label>
+ <value>Rapport à charger par défaut</value>
+ </row>
+ <row>
+ <label>UsersManager_ReportDateToLoadByDefault</label>
+ <value>Date du rapport à charger par défaut</value>
+ </row>
+ <row>
+ <label>UsersManager_ForAnonymousUsersReportDateToLoadByDefault</label>
+ <value>Pour les utilisateurs anonymes, date du rapport à charger par défaut</value>
+ </row>
+ <row>
+ <label>UsersManager_ExcludeVisitsViaCookie</label>
+ <value>Excluez vos visites en utilisant un cookie</value>
+ </row>
+ <row>
+ <label>UsersManager_YourVisitsAreIgnored</label>
+ <value>%sVos visites sont ignorées par Piwik%s (le cookie d'exclusion de Piwik a été trouvé sur votre navigateur).</value>
+ </row>
+ <row>
+ <label>UsersManager_YourVisitsAreNotIgnored</label>
+ <value>%sVos visites sont prises en compte par Piwik%s (le cookie d'exclusion de Piwik n'a pas été trouvé sur votre navigateur).</value>
+ </row>
+ <row>
+ <label>UsersManager_ClickHereToDeleteTheCookie</label>
+ <value>Cliquez ici pour supprimer le cookie et pour que Piwik prenne en compte vos visites</value>
+ </row>
+ <row>
+ <label>UsersManager_ClickHereToSetTheCookie</label>
+ <value>Cliquez ici pour mettre en place un cookie qui permettra à Piwik d'ignorer vos visites sur vos sites</value>
+ </row>
+ <row>
+ <label>UsersManager_Edit</label>
+ <value>Modifier</value>
+ </row>
+ <row>
+ <label>UsersManager_AddUser</label>
+ <value>Ajouter un nouvel utilisateur</value>
+ </row>
+ <row>
+ <label>UsersManager_MenuUsers</label>
+ <value>Utilisateurs</value>
+ </row>
+ <row>
+ <label>UsersManager_MenuUserSettings</label>
+ <value>Paramètres utilisateurs</value>
+ </row>
+ <row>
+ <label>UsersManager_MenuAnonymousUserSettings</label>
+ <value>Paramètres utilisateurs anonymes</value>
+ </row>
+ <row>
+ <label>UsersManager_NoteNoAnonymousUserAccessSettingsWontBeUsed</label>
+ <value>Note: Vous n'avez aucun site web dont l'accès est accordé à l'utilisateur anonyme, les paramètres suivants resteront inutilisés.</value>
+ </row>
+ <row>
+ <label>UsersManager_WhenUsersAreNotLoggedInAndVisitPiwikTheyShouldAccess</label>
+ <value>Quand les utilisateurs ne sont pas connectés et accèdent à Piwik, il verront</value>
+ </row>
+ <row>
+ <label>UsersManager_ChangePassword</label>
+ <value>Modifier le mot de passe</value>
+ </row>
+ <row>
+ <label>UsersManager_IfYouWouldLikeToChangeThePasswordTypeANewOne</label>
+ <value>Si vous souhaitez modifier votre mot de passe tapez en un nouveau. Sinon laissez le champ vide.</value>
+ </row>
+ <row>
+ <label>UsersManager_TypeYourPasswordAgain</label>
+ <value>Tapez à nouveau votre nouveau mot de passe.</value>
+ </row>
+ <row>
+ <label>UsersManager_TheLoginScreen</label>
+ <value>L'interface de connexion</value>
+ </row>
+ <row>
+ <label>UsersManager_DeleteConfirm_js</label>
+ <value>Etes vous sûr de vouloir supprimer l'utilisateur %s?</value>
+ </row>
+ <row>
+ <label>UsersManager_YourUsernameCannotBeChanged</label>
+ <value>Votre nom d'utilisateur a été modifié.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionLoginExists</label>
+ <value>Le login '%s' existe déjà.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionEmailExists</label>
+ <value>L'utilisateur avec l'e-mail '%s' existe déjà.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionInvalidPassword</label>
+ <value>Le mot de passe doit faire entre 6 et 26 caractères.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionInvalidEmail</label>
+ <value>L'adresse courriel est invalide.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionDeleteDoesNotExist</label>
+ <value>L'utilisateur '%s' est inexistant, il n'a pu être supprimé.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionAdminAnonymous</label>
+ <value>Vous ne pouvez pas autoriser l'accès administrateur à l'utilisateur Anonyme.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionEditAnonymous</label>
+ <value>L'utilisateur Anonyme ne peut être édité ou supprimé. Il est utilisé pour identifier un utilisateur qui ne s'est pas encore connecté. Par exemple vous pouvez rendre vos statistiques publiques en accordant l'accès 'vue' à l'utilisateur 'anonyme'.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionSuperUser</label>
+ <value>L'utilisateur demandé est le Super Utilisateur qui ne peut être sélectionné, édité ou supprimé depuis l'API. Vous pouvez l'éditer manuellement depuis le fichier de configuration.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionUserDoesNotExist</label>
+ <value>L'utilisateur '%s' est inexistant.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionAccessValues</label>
+ <value>Le paramètre access doit contenir une des valeurs suivantes : [ %s ]</value>
+ </row>
+ <row>
+ <label>VisitFrequency_PluginDescription</label>
+ <value>Effectue des rapports sur les visiteurs déjà venus vis à vis des nouveaux visiteurs.</value>
+ </row>
+ <row>
+ <label>VisitFrequency_Evolution</label>
+ <value>Évolution sur la période</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnReturningVisits</label>
+ <value>Visites retour</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnActionsByReturningVisits</label>
+ <value>Actions des visites retour</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnMaximumActionsByAReturningVisit</label>
+ <value>Nombre maximum d'actions par une visite retour</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnTotalTimeSpentByReturningVisits</label>
+ <value>Temps total passé par les visites retour (en secondes)</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnBounceRateForReturningVisits</label>
+ <value>Pourcentage de rebond par les visites retour</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnVisits</label>
+ <value>%s visites de visiteurs connus</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnActions</label>
+ <value>%s actions de visites de visiteurs connus</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnMaxActions</label>
+ <value>%s actions maximums par visite de visiteur connus</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnTotalTime</label>
+ <value>%s temps total passé par des visiteurs connus</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnBounceRate</label>
+ <value>%s visiteurs connus ont survolé (quitté le site après une page)</value>
+ </row>
+ <row>
+ <label>VisitFrequency_WidgetOverview</label>
+ <value>Récapitulatif de la Fréquence</value>
+ </row>
+ <row>
+ <label>VisitFrequency_WidgetGraphReturning</label>
+ <value>Graphique de visites de visiteurs connus</value>
+ </row>
+ <row>
+ <label>VisitFrequency_SubmenuFrequency</label>
+ <value>Fréquence</value>
+ </row>
+ <row>
+ <label>VisitorInterest_PluginDescription</label>
+ <value>Effectue des rapports à propos des intérêts des visiteurs: nombre de pages vues, temps passé sur le site.</value>
+ </row>
+ <row>
+ <label>VisitorInterest_VisitsPerDuration</label>
+ <value>Visites par durée de la visite</value>
+ </row>
+ <row>
+ <label>VisitorInterest_VisitsPerNbOfPages</label>
+ <value>Visites par nombre de pages</value>
+ </row>
+ <row>
+ <label>VisitorInterest_ColumnVisitDuration</label>
+ <value>Durée de la visite</value>
+ </row>
+ <row>
+ <label>VisitorInterest_ColumnPagesPerVisit</label>
+ <value>Pages par visite</value>
+ </row>
+ <row>
+ <label>VisitorInterest_WidgetLengths</label>
+ <value>Durée des visites</value>
+ </row>
+ <row>
+ <label>VisitorInterest_WidgetPages</label>
+ <value>Pages par visite</value>
+ </row>
+ <row>
+ <label>VisitorInterest_SubmenuFrequencyLoyalty</label>
+ <value>Fréquence et Fidélité</value>
+ </row>
+ <row>
+ <label>VisitorInterest_PlusXMin</label>
+ <value>%s min</value>
+ </row>
+ <row>
+ <label>VisitorInterest_OnePage</label>
+ <value>1 page</value>
+ </row>
+ <row>
+ <label>VisitorInterest_NPages</label>
+ <value>%s pages</value>
+ </row>
+ <row>
+ <label>VisitsSummary_PluginDescription</label>
+ <value>Effectue des rapports sur les valeurs générales des statistiques: visites, visiteurs uniques, nombre d'actions, taux de rebond, etc.</value>
+ </row>
+ <row>
+ <label>VisitsSummary_VisitsSummary</label>
+ <value>Récapitulatif des visites</value>
+ </row>
+ <row>
+ <label>VisitsSummary_NbVisits</label>
+ <value>%s visites</value>
+ </row>
+ <row>
+ <label>VisitsSummary_NbUniqueVisitors</label>
+ <value>%s visiteurs uniques</value>
+ </row>
+ <row>
+ <label>VisitsSummary_NbActionsDescription</label>
+ <value>%s actions (pages vues, téléchargements et liens de sortie)</value>
+ </row>
+ <row>
+ <label>VisitsSummary_TotalTime</label>
+ <value>%s temps total passé par les visiteurs</value>
+ </row>
+ <row>
+ <label>VisitsSummary_MaxNbActions</label>
+ <value>%s actions maximums en une visite</value>
+ </row>
+ <row>
+ <label>VisitsSummary_NbVisitsBounced</label>
+ <value>%s visiteurs ont survolé (quitté le site après une page)</value>
+ </row>
+ <row>
+ <label>VisitsSummary_EvolutionOverLastPeriods</label>
+ <value>Évolution sur les 30 derniers %s</value>
+ </row>
+ <row>
+ <label>VisitsSummary_Report</label>
+ <value>Rapport</value>
+ </row>
+ <row>
+ <label>VisitsSummary_GenerateTime</label>
+ <value>%s secondes pour générer la page</value>
+ </row>
+ <row>
+ <label>VisitsSummary_GenerateQueries</label>
+ <value>%s requêtes exécutées</value>
+ </row>
+ <row>
+ <label>VisitsSummary_WidgetLastVisits</label>
+ <value>Graphique des dernières visites</value>
+ </row>
+ <row>
+ <label>VisitsSummary_WidgetVisits</label>
+ <value>Récapitulatif des visites</value>
+ </row>
+ <row>
+ <label>VisitsSummary_WidgetLastVisitors</label>
+ <value>Graphique des derniers visiteurs uniques</value>
+ </row>
+ <row>
+ <label>VisitsSummary_WidgetOverviewGraph</label>
+ <value>Graphique récapitulatif</value>
+ </row>
+ <row>
+ <label>VisitsSummary_SubmenuOverview</label>
+ <value>Récapitulatif</value>
+ </row>
+ <row>
+ <label>VisitTime_PluginDescription</label>
+ <value>Effectue des rapports sur la date locale et serveur. Les informations serveur peuvent être utiles pour planifier une maintenance sur un site web.</value>
+ </row>
+ <row>
+ <label>VisitTime_LocalTime</label>
+ <value>Visites par heure locale</value>
+ </row>
+ <row>
+ <label>VisitTime_ServerTime</label>
+ <value>Visites par heure du serveur</value>
+ </row>
+ <row>
+ <label>VisitTime_ColumnServerTime</label>
+ <value>Heure serveur</value>
+ </row>
+ <row>
+ <label>VisitTime_ColumnLocalTime</label>
+ <value>Heure locale</value>
+ </row>
+ <row>
+ <label>VisitTime_WidgetLocalTime</label>
+ <value>Visites par fuseau horaire local</value>
+ </row>
+ <row>
+ <label>VisitTime_WidgetServerTime</label>
+ <value>Visites par fuseau horaire du serveur</value>
+ </row>
+ <row>
+ <label>VisitTime_SubmenuTimes</label>
+ <value>Horaires</value>
+ </row>
+ <row>
+ <label>VisitTime_NHour</label>
+ <value>%sh</value>
+ </row>
+ <row>
+ <label>Widgetize_PluginDescription</label>
+ <value>Le plugin rend l'export de n'importe quel Widget Piwik dans votre blog, site web ou sur Igoogle et Netvibes!</value>
+ </row>
+ <row>
+ <label>General_SaveImageOnYourComputer_js</label>
+ <value>Pour sauvegarder l'image sur votre ordinateur faites un clic droit dessus et sélectionnez &quot;Enregistrer l'image sous...&quot;</value>
+ </row>
+ <row>
+ <label>CoreUpdater_UpdateHasBeenCancelledExplanation</label>
+ <value>La mise à jour de Piwik en un clic a été désactivée. Si vous ne pouvez pas corriger la cause du message d'erreur ci-dessous, il est recommandé que vous fassiez manuellement la mise à jour de Piwik. %1$sConsultez la documentation%2$s de la mise à jour%3$s pour commencer!</value>
+ </row>
+ <row>
+ <label>ExamplePlugin_PluginDescription</label>
+ <value>Plugin d'exemple: ce plugin décrit comment créer un plugin très simple qui exporte 2 widgets du tableau de bord</value>
+ </row>
+ <row>
+ <label>ExamplePlugin_exampleWidgets</label>
+ <value>Widgets d'exemple</value>
+ </row>
+ <row>
+ <label>ExamplePlugin_exampleWidget</label>
+ <value>Widget d'exemple</value>
+ </row>
+ <row>
+ <label>ExamplePlugin_blogPiwikRss</label>
+ <value>Flux RSS du blog Piwik</value>
+ </row>
+ <row>
+ <label>ExamplePlugin_photostreamMatt</label>
+ <value>Photos de Matt</value>
+ </row>
+ <row>
+ <label>General_GoTo</label>
+ <value>Rendez vous à %s</value>
+ </row>
+ <row>
+ <label>General_PageBounceRateDefinition</label>
+ <value>Pourcentage de visites qui ont commencé sur cette page et se sont terminées juste après.</value>
+ </row>
+ <row>
+ <label>General_ColumnExitRate</label>
+ <value>Taux de sortie</value>
+ </row>
+ <row>
+ <label>General_PageExitRateDefinition</label>
+ <value>Pourcentage de visites sur cette page qui ont quitté le site juste après.</value>
+ </row>
+ <row>
+ <label>General_ColumnBounces</label>
+ <value>Rebonds</value>
+ </row>
+ <row>
+ <label>General_BouncesDefinition</label>
+ <value>Nombre de visites qui ont commencé sur cette page et se sont terminées juste après.</value>
+ </row>
+ <row>
+ <label>General_ColumnEntrances</label>
+ <value>Entrées</value>
+ </row>
+ <row>
+ <label>General_EntrancesDefinition</label>
+ <value>Nombre de visites qui ont commencé sur cette page</value>
+ </row>
+ <row>
+ <label>General_ColumnExits</label>
+ <value>Sorties</value>
+ </row>
+ <row>
+ <label>General_ExitsDefinition</label>
+ <value>Nombre de visites qui ont terminé sur cette page</value>
+ </row>
+ <row>
+ <label>General_ColumnAverageTimeOnPage</label>
+ <value>Temps moyen sur la page</value>
+ </row>
+ <row>
+ <label>General_AverageTimeOnPageDefinition</label>
+ <value>Le temps moyen passé par les visiteurs sur cette page</value>
+ </row>
+ <row>
+ <label>General_DaysHours</label>
+ <value>%1$s jours %2$s heures</value>
+ </row>
+ <row>
+ <label>General_HoursMinutes</label>
+ <value>%1$s heures %2$s min</value>
+ </row>
+ <row>
+ <label>General_MinutesSeconds</label>
+ <value>%1$s min %2$ss</value>
+ </row>
+ <row>
+ <label>General_Seconds</label>
+ <value>%ss</value>
+ </row>
+ <row>
+ <label>General_DisplayGoals</label>
+ <value>Afficher les objectifs</value>
+ </row>
+ <row>
+ <label>General_ConfigFileIsNotWritable</label>
+ <value>Le fichier de configuration de Piwik %s n'a pas la permission d'écriture, vos modifications ne seront pas sauvegardées. %s Merci de modifier les permissions du fichier de configuration de manière à le rendre accessible en écriture.</value>
+ </row>
+ <row>
+ <label>Actions_SubmenuPagesEntry</label>
+ <value>Pages d'entrée</value>
+ </row>
+ <row>
+ <label>Actions_SubmenuPagesExit</label>
+ <value>Pages de sortie</value>
+ </row>
+ <row>
+ <label>CoreAdminHome_Administration</label>
+ <value>Administration</value>
+ </row>
+ <row>
+ <label>CoreHome_WebAnalyticsReports</label>
+ <value>Rapports des statistiques web.</value>
+ </row>
+ <row>
+ <label>Goals_Goals</label>
+ <value>Objectifs</value>
+ </row>
+ <row>
+ <label>Goals_Overview</label>
+ <value>Vue d'ensemble</value>
+ </row>
+ <row>
+ <label>Goals_WhereThe</label>
+ <value>où le</value>
+ </row>
+ <row>
+ <label>Live_Last30Minutes</label>
+ <value>Les dernières 30 minutes</value>
+ </row>
+ <row>
+ <label>MultiSites_Evolution</label>
+ <value>Évolution</value>
+ </row>
+ <row>
+ <label>UsersManager_YourVisitsAreIgnoredOnDomain</label>
+ <value>%sVos visites sont ignorées par Piwik sur %s %s(Le cookie d'exclusion de Piwik est présent sur votre navigateur)</value>
+ </row>
+ <row>
+ <label>UsersManager_ClickHereToSetTheCookieOnDomain</label>
+ <value>Cliquez ici pour mettre en place un cookie qui exclura vos visites sur ceux de vos sites web qui sont analysés par Piwik sur %s</value>
+ </row>
+ <row>
+ <label>VisitorInterest_Engagement</label>
+ <value>Engagement</value>
+ </row>
+ <row>
+ <label>General_Report</label>
+ <value>Rapport</value>
+ </row>
+ <row>
+ <label>General_Download</label>
+ <value>Télécharger</value>
+ </row>
+ <row>
+ <label>General_OrCancel</label>
+ <value>ou %s Annuler %s</value>
+ </row>
+ <row>
+ <label>General_Description</label>
+ <value>Description</value>
+ </row>
+ <row>
+ <label>General_Name</label>
+ <value>Nom</value>
+ </row>
+ <row>
+ <label>General_Value</label>
+ <value>Valeur</value>
+ </row>
+ <row>
+ <label>General_Date</label>
+ <value>Date</value>
+ </row>
+ <row>
+ <label>General_Period</label>
+ <value>Période</value>
+ </row>
+ <row>
+ <label>General_DateRange</label>
+ <value>Période :</value>
+ </row>
+ <row>
+ <label>General_ExportThisReport</label>
+ <value>Exporter ce jeu de données dans d'autres formats</value>
+ </row>
+ <row>
+ <label>General_ColumnPercentageVisits</label>
+ <value>%s Visites</value>
+ </row>
+ <row>
+ <label>General_ColumnConversionRate</label>
+ <value>Taux de conversion</value>
+ </row>
+ <row>
+ <label>General_VisitDuration</label>
+ <value>Durée moy. des visites (en secondes)</value>
+ </row>
+ <row>
+ <label>General_YearsDays</label>
+ <value>%1$s années %2$s jours</value>
+ </row>
+ <row>
+ <label>General_YouMustBeLoggedIn</label>
+ <value>Vous devez être connecté(e) pour accéder à cette fonctionnalité.</value>
+ </row>
+ <row>
+ <label>General_MediumToHighTrafficItIsRecommendedTo</label>
+ <value>Pour les sites à moyen et fort trafic, nous recommandons d'effectuer les rapports du jours au plus toutes les demies heures (%s secondes) ou toutes les heures (%secondes).</value>
+ </row>
+ <row>
+ <label>General_DisplaySimpleTable</label>
+ <value>Afficher un tableau simple</value>
+ </row>
+ <row>
+ <label>General_DisplayTableWithMoreMetrics</label>
+ <value>Afficher un tableau avec plus d'unités</value>
+ </row>
+ <row>
+ <label>General_DisplayTableWithGoalMetrics</label>
+ <value>Afficher un tableau avec des Objectifs en tant qu'unités</value>
+ </row>
+ <row>
+ <label>General_YouAreViewingDemoShortMessage</label>
+ <value>Vous êtes en train de visionner la démonstration de Piwik</value>
+ </row>
+ <row>
+ <label>General_DownloadFullVersion</label>
+ <value>%1$sTéléchargez%2$s la version complète! Rendez vous sur %3$s</value>
+ </row>
+ <row>
+ <label>General_AboutPiwikX</label>
+ <value>À propos de Piwik %s</value>
+ </row>
+ <row>
+ <label>General_NewReportsWillBeProcessedByCron</label>
+ <value>Quand l'archivage de Piwik n'est pas déclenché par le navigateur, les nouveaux rapports seront générés par la crontab.</value>
+ </row>
+ <row>
+ <label>General_ReportsWillBeProcessedAtMostEveryHour</label>
+ <value>Les rapports seront donc traités tout au plus à chaque heure.</value>
+ </row>
+ <row>
+ <label>General_IfArchivingIsFastYouCanSetupCronRunMoreOften</label>
+ <value>En supposant que l'archivage soit rapide pour votre installation, vous pouvez paramétrer la crontab pour s'exécuter plus fréquemment.</value>
+ </row>
+ <row>
+ <label>General_Daily</label>
+ <value>Quotidiennement</value>
+ </row>
+ <row>
+ <label>General_Weekly</label>
+ <value>Hebdomadaire</value>
+ </row>
+ <row>
+ <label>General_Monthly</label>
+ <value>Mensuellement</value>
+ </row>
+ <row>
+ <label>General_ExceptionVariableNotFound</label>
+ <value>La variable '%s' requise est incorrecte ou n'a pas été trouvée lors de l'appel à l'API</value>
+ </row>
+ <row>
+ <label>General_ExceptionMethodNotFound</label>
+ <value>La méthode '%s' n'existe pas ou n'est pas disponible dans le module '%s'</value>
+ </row>
+ <row>
+ <label>General_ExceptionSubtableNotFoundInArchive</label>
+ <value>Vous demandez une sous-table précise, mais il n'y a pas de telles données dans les archives. </value>
+ </row>
+ <row>
+ <label>General_ExceptionInvalidRendererFormat</label>
+ <value>Le format de rendu '%s' n'est pas valide. Veuillez essayer un de ceux-ci à la place: %s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionInvalidPeriod</label>
+ <value>La période '%s' n'est pas supportée. Veuillez essayer parmi celles-ci à la place: %s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionInvalidDateRange</label>
+ <value>La date '%s' ne correspond pas au format suivant : %s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionGoalNotFound</label>
+ <value>L'objectif id = %s n'a put être trouvé.</value>
+ </row>
+ <row>
+ <label>General_ExceptionUndeletableFile</label>
+ <value>Impossible de supprimer %s</value>
+ </row>
+ <row>
+ <label>General_ExceptionPrivilege</label>
+ <value>Vous ne pouvez accéder à cette ressource, ceci requiert un accès de type %s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionPrivilegeAtLeastOneWebsite</label>
+ <value>Vous ne pouvez accéder à cette ressource, ceci requiert au moins un accès de type %s à un site web.</value>
+ </row>
+ <row>
+ <label>General_ExceptionPrivilegeAccessWebsite</label>
+ <value>Vous ne pouvez pas accéder à cette ressource, ceci requiert un accès de type %s pour le site id = %d.</value>
+ </row>
+ <row>
+ <label>General_ExceptionInvalidArchiveTimeToLive</label>
+ <value>La durée de l'archivage doit être un nombre de secondes supérieur à zéro.</value>
+ </row>
+ <row>
+ <label>General_ExceptionUnreadableFileDisabledMethod</label>
+ <value>Le fichier de configuration {%s} n'a pas pu être lu. votre hébergeur a probablement désactivé %s.</value>
+ </row>
+ <row>
+ <label>General_ExceptionInvalidToken</label>
+ <value>La clef partagée (token) n'est pas valide.</value>
+ </row>
+ <row>
+ <label>General_ExceptionInvalidDateFormat</label>
+ <value>Le format de date doit être: %s ou n'importe quel mot clef supporté par la fonction %s (visitez %s pour plus d'informations)</value>
+ </row>
+ <row>
+ <label>General_ExceptionLanguageFileNotFound</label>
+ <value>Le fichier de langage '%s' n'a pas été trouvé.</value>
+ </row>
+ <row>
+ <label>General_UseSMTPServerForEmail</label>
+ <value>Utiliser le serveur SMTP pour les mails</value>
+ </row>
+ <row>
+ <label>General_SmtpServerAddress</label>
+ <value>Adresse du serveur SMTP</value>
+ </row>
+ <row>
+ <label>General_SmtpPort</label>
+ <value>Port du serveur SMTP</value>
+ </row>
+ <row>
+ <label>General_AuthenticationMethodSmtp</label>
+ <value>Méthode d'authentification au serveur SMTP</value>
+ </row>
+ <row>
+ <label>General_SmtpUsername</label>
+ <value>Nom d'utilisateur SMTP</value>
+ </row>
+ <row>
+ <label>General_SmtpPassword</label>
+ <value>Mot de passe SMTP</value>
+ </row>
+ <row>
+ <label>General_SelectYesIfYouWantToSendEmailsViaServer</label>
+ <value>Sélectionnez &quot;Oui&quot; si vous voulez ou devez envoyer un e-mail via un serveur nommé à la place de la fonction de courrier local.</value>
+ </row>
+ <row>
+ <label>General_OnlyUsedIfUserPwdIsSet</label>
+ <value>Seulement utilisé si un nom d'utilisateur / mot de passe est activée, demandez à votre fournisseur si vous n'êtes pas la méthode à utiliser.</value>
+ </row>
+ <row>
+ <label>General_OnlyEnterIfRequired</label>
+ <value>Entrez un nom d'utilisateur seulement si le serveur SMTP le requiert</value>
+ </row>
+ <row>
+ <label>General_OnlyEnterIfRequiredPassword</label>
+ <value>Entrez un mot de passe seulement si le serveur SMTP le requiert</value>
+ </row>
+ <row>
+ <label>General_WarningPasswordStored</label>
+ <value>%sAttention:%s Ce mot de passe sera stocké dans le fichier de configuration et sera visible pour n'importe qui y ayant accès.</value>
+ </row>
+ <row>
+ <label>General_InvalidResponse</label>
+ <value>Les données reçues sont invalides</value>
+ </row>
+ <row>
+ <label>General_ChooseLanguage</label>
+ <value>Sélectionnez la langue</value>
+ </row>
+ <row>
+ <label>General_ChoosePeriod</label>
+ <value>Sélectionnez la période</value>
+ </row>
+ <row>
+ <label>General_ChooseWebsite</label>
+ <value>Sélectionnez le site web</value>
+ </row>
+ <row>
+ <label>General_Language</label>
+ <value>Langue</value>
+ </row>
+ <row>
+ <label>General_PleaseUpdatePiwik</label>
+ <value>Merci de mettre à jour Piwik</value>
+ </row>
+ <row>
+ <label>General_RequestTimedOut</label>
+ <value>Une requête vers %s a expiré. Veuillez réessayer.</value>
+ </row>
+ <row>
+ <label>API_QuickDocumentationTitle</label>
+ <value>Documentation rapide de l'API.</value>
+ </row>
+ <row>
+ <label>API_GenerateVisits</label>
+ <value>Si vous n'avez pas de données pour aujourd'hui vous pouvez en générer en utilisant le plugin %s. Vous pouvez activer le plugin %s, ensuite cliquez sur le menu 'Générateur de visites' dans la zone d'administration de Piwik.</value>
+ </row>
+ <row>
+ <label>API_MoreInformation</label>
+ <value>Pour plus d'informations à propos de l'API de Piwik, merci de visiter %s l'introduction à Piwik %s et %s la référence de l'API Piwik %s.</value>
+ </row>
+ <row>
+ <label>API_UserAuthentication</label>
+ <value>Authentification de l'utilisateur</value>
+ </row>
+ <row>
+ <label>API_UsingTokenAuth</label>
+ <value>Si vous souhaitez %s requêter des données depuis un script, une crontab, etc %s vous devez ajouter le paramètre %s aux appels d'URLs de l'API qui requièrent une authentification.</value>
+ </row>
+ <row>
+ <label>API_KeepTokenSecret</label>
+ <value>Cette clef partagée (tocken_auth) est aussi secrète que votre login et mot de passe, %s ne la partagez pas%s!</value>
+ </row>
+ <row>
+ <label>CoreHome_ThereIsNoDataForThisReport</label>
+ <value>Il n'y a pas de données pour ce rapport.</value>
+ </row>
+ <row>
+ <label>CoreUpdater_YouMustDownloadPackageOrFixPermissions</label>
+ <value>Piwik ne peut pas écraser votre installation courante.
+
+
+
+
+
+
+
+Vous pouvez soit corriger les permissions du répertoire/fichier, soit télécharger le package et installer la version %s manuellement:</value>
+ </row>
+ <row>
+ <label>Goals_GoalsOverview</label>
+ <value>Vue d'ensemble des Objectifs</value>
+ </row>
+ <row>
+ <label>Goals_GoalsManagement</label>
+ <value>Gestion des Objectifs</value>
+ </row>
+ <row>
+ <label>Goals_ConversionsOverviewBySegment</label>
+ <value>Vue d'ensemble des conversions par segments</value>
+ </row>
+ <row>
+ <label>Goals_GoalConversionsBySegment</label>
+ <value>Conversions de l'objectif %s par segment</value>
+ </row>
+ <row>
+ <label>Goals_ViewGoalsBySegment</label>
+ <value>Visualiser les Objectifs par %s</value>
+ </row>
+ <row>
+ <label>Goals_GoalX</label>
+ <value>Objectif %s</value>
+ </row>
+ <row>
+ <label>Goals_CreateNewGOal</label>
+ <value>Créer un nouvel Objectif</value>
+ </row>
+ <row>
+ <label>Goals_ViewAndEditGoals</label>
+ <value>Afficher et modifier un Objectif</value>
+ </row>
+ <row>
+ <label>Goals_URL</label>
+ <value>URL</value>
+ </row>
+ <row>
+ <label>Goals_Filename</label>
+ <value>nom de fichier</value>
+ </row>
+ <row>
+ <label>Goals_ExternalWebsiteUrl</label>
+ <value>URL externe du site web</value>
+ </row>
+ <row>
+ <label>Goals_ExceptionInvalidMatchingString</label>
+ <value>Si vous choisissez 'correspondance exacte', la chaine de caractères doit être une URL commençant par %s. Par exemple,'%s'.</value>
+ </row>
+ <row>
+ <label>Goals_LearnMoreAboutGoalTrackingDocumentation</label>
+ <value>Apprenez en plus à propos de %s Comment traquer les Objectifs dans Piwik %s dans la documentation utilisateur</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckEvalHelp</label>
+ <value>Requis part le système de modèle HTML QuickForm et Smarty.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMbstringExtensionHelp</label>
+ <value>L'extension mbstring est requise pour les caractères multi-bytes lors des réponses de l'API utilisant des valeurs séparées par des virgules (CSV) ou par des tabulations (TSV).</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckMbstringFuncOverloadHelp</label>
+ <value>Vous devriez régler mbstring.func_overload à &quot;0&quot;.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckAutoUpdateHelp</label>
+ <value>Note: La mise à jour de Piwik en un clic requiert une permission en écriture sur le dossier de Piwik et son contenu.</value>
+ </row>
+ <row>
+ <label>Login_MailPasswordRecoveryBody</label>
+ <value>Bonjour %1$s, Une requête de remise à zéro du mot de passe a été reçue depuis %2$s. Pour remettre à zéro le mot de passe: 1) Rendez vous au formulaire de remise à zéro du mot de passe à l'adresse : %3$s
+
+
+
+2) Entrez la clef suivante: %4$s
+
+
+
+3) Remplissez le formulaire (en entrant deux fois votre nouveaux mot de passe) et soumettez le.
+
+
+
+Note: cette clef expirera dans 24h.</value>
+ </row>
+ <row>
+ <label>Login_ExceptionPasswordMD5HashExpected</label>
+ <value>Le paramètre mot de passe doit être le hash MD5 du mot de passe.</value>
+ </row>
+ <row>
+ <label>Login_ExceptionInvalidSuperUserAuthenticationMethod</label>
+ <value>Le Super Utilisateur ne peut pas être authentifié en utilisant le mécanisme '%s'.</value>
+ </row>
+ <row>
+ <label>Referers_MetricsFromRefererTypeGraphLegend</label>
+ <value>%1$s (depuis %2$s)</value>
+ </row>
+ <row>
+ <label>Referers_UsingNDistinctUrls</label>
+ <value>(utilisant %s urls distinctes)</value>
+ </row>
+ <row>
+ <label>SEO_SeoRankings</label>
+ <value>Notations des SEO</value>
+ </row>
+ <row>
+ <label>SEO_AlexaRank</label>
+ <value>Notation Alexa</value>
+ </row>
+ <row>
+ <label>SEO_YahooIndexedPages</label>
+ <value>Pages indexées Yahoo</value>
+ </row>
+ <row>
+ <label>SEO_DomainAge</label>
+ <value>Age du domaine</value>
+ </row>
+ <row>
+ <label>SEO_YahooBacklinks</label>
+ <value>Liens de retour Yahoo</value>
+ </row>
+ <row>
+ <label>SEO_Rank</label>
+ <value>Notation</value>
+ </row>
+ <row>
+ <label>SEO_Backlinks</label>
+ <value>Liens de retour</value>
+ </row>
+ <row>
+ <label>SEO_Pages</label>
+ <value>Pages</value>
+ </row>
+ <row>
+ <label>SEO_SEORankingsFor</label>
+ <value>Notations SEO pour %s</value>
+ </row>
+ <row>
+ <label>SitesManager_TrackingTags</label>
+ <value>Tags de suivit pour %s</value>
+ </row>
+ <row>
+ <label>SitesManager_NotFound</label>
+ <value>Aucun site trouvé pour</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionInvalidTimezone</label>
+ <value>Le fuseau horaire '%s' n'est pas valide. Veuillez entrer un fuseau horaire valide.</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionInvalidCurrency</label>
+ <value>La monnaie '%s' n'est pas valide. Veuillez entrer un symbole monétaire valide (ex. %s)</value>
+ </row>
+ <row>
+ <label>SitesManager_ExceptionInvalidIPFormat</label>
+ <value>L'IP à exclure '%s' n'a pas un format valide (ex. %s).</value>
+ </row>
+ <row>
+ <label>SitesManager_Save_js</label>
+ <value>Enregistrer</value>
+ </row>
+ <row>
+ <label>SitesManager_Cancel_js</label>
+ <value>Annuler</value>
+ </row>
+ <row>
+ <label>UserCountry_Location</label>
+ <value>Localisation</value>
+ </row>
+ <row>
+ <label>UserSettings_PluginDetectionDoesNotWorkInIE</label>
+ <value>Note : La détection des plugins ne fonctionne pas avec Internet Explorer. Ce rapport est basé sur les navigateurs non-IE.</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionInvalidLoginFormat</label>
+ <value>Le login doit contenir entre %1$s et %2$s caractères et être composé uniquement de lettres, chiffres, ou les caractères '_' ou '-' ou '.'</value>
+ </row>
+ <row>
+ <label>UsersManager_ExceptionPasswordMD5HashExpected</label>
+ <value>UsersManager.getTokenAuth attend un mot de passe hashé en MD5 (chaine de 32 caractères). Veuillez appeler la fonction md5() sur le mot de passe avant d'appeler cette méthode.</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnAverageVisitDurationForReturningVisitors</label>
+ <value>Durée moyenne des visites pour les visiteurs connus (en secondes)</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ColumnAvgActionsPerReturningVisit</label>
+ <value>Nombre d'actions moyen par visiteur connu.</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnAvgActions</label>
+ <value>%s actions par visiteur connu</value>
+ </row>
+ <row>
+ <label>VisitFrequency_ReturnAverageVisitDuration</label>
+ <value>%s durée moyenne de la visite des visiteurs connus</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_PluginDescription</label>
+ <value>Plugin visant à créer de fausses visites. Il peut être utilisé par les utilisateurs Piwik ou par les développeurs comme un moyen aisé de générer de fausses données de manière à peupler les rapports Piwik.</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_VisitorGenerator</label>
+ <value>Générateur de visites</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_Warning</label>
+ <value>Vous êtes sur le point de générer de fausses visites qui seront enregistrées dans votre base de donnés Piwik</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_NotReversible</label>
+ <value>Il sera %s impossible%s de supprimer facilement ces données des logs Piwik.</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_AreYouSure</label>
+ <value>Etes vous sûrs de vouloir générer de fausses visites?</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_ChoiceYes</label>
+ <value>Oui, je suis sûr!</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_Submit</label>
+ <value>Soumettre</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_SelectWebsite</label>
+ <value>Sélectionner le site Web</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_Visitors</label>
+ <value>Visiteurs</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_MinVisitors</label>
+ <value>Visiteurs Minimum</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_MaxVisitors</label>
+ <value>Visiteurs Maximum</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_NbActions</label>
+ <value>Nombre d'actions</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_ActionsPerVisit</label>
+ <value>Actions par visite</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_NbRequestsPerSec</label>
+ <value>Requêtes par seconde</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_DaysToCompute</label>
+ <value>Jours à calculer</value>
+ </row>
+ <row>
+ <label>VisitorGenerator_Date</label>
+ <value>Date</value>
+ </row>
+ <row>
+ <label>VisitorInterest_BetweenXYMinutes</label>
+ <value>%1$s-%2$s min</value>
+ </row>
+ <row>
+ <label>VisitorInterest_BetweenXYSeconds</label>
+ <value>%1$s-%2$ss</value>
+ </row>
+ <row>
+ <label>VisitsSummary_AverageVisitDuration</label>
+ <value>%s durée moyenne de la visite</value>
+ </row>
+ <row>
+ <label>VisitsSummary_NbActionsPerVisit</label>
+ <value>%s actions par visite</value>
+ </row>
+ <row>
+ <label>General_PleaseSpecifyValue</label>
+ <value>Merci de spécifier une valeur pour %s</value>
+ </row>
+ <row>
+ <label>General_ExceptionConfigurationFileNotFound</label>
+ <value>Le fichier de configuration {%s} n'a pas été trouvé</value>
+ </row>
+ <row>
+ <label>Live_LinkVisitorLog</label>
+ <value>Voir les logs visiteurs détaillés</value>
+ </row>
+ <row>
+ <label>Live_Actions</label>
+ <value>Actions</value>
+ </row>
+ <row>
+ <label>Live_Action</label>
+ <value>Action</value>
+ </row>
+ <row>
+ <label>Live_GoalType</label>
+ <value>Type</value>
+ </row>
+ <row>
+ <label>Mobile_AnonymousAccess</label>
+ <value>Accès anonyme</value>
+ </row>
+ <row>
+ <label>Mobile_EnableGraphsLabel</label>
+ <value>Afficher les graphs</value>
+ </row>
+ <row>
+ <label>Mobile_SaveSuccessError</label>
+ <value>Merci de vérifier vos paramètres</value>
+ </row>
+ <row>
+ <label>Mobile_YouAreOffline</label>
+ <value>Désolé, vous êtes actuellement déconnecté</value>
+ </row>
+ <row>
+ <label>UserCountryMap_toggleFullscreen</label>
+ <value>Plein écran</value>
+ </row>
+ <row>
+ <label>PDFReports_PDF</label>
+ <value>PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_EmailSchedule</label>
+ <value>Planification courriel</value>
+ </row>
+ <row>
+ <label>PDFReports_SendReportTo</label>
+ <value>Envoyer le(s) rapport(s) à </value>
+ </row>
+ <row>
+ <label>PDFReports_SentToMe</label>
+ <value>Envoyer à moi</value>
+ </row>
+ <row>
+ <label>PDFReports_CreateAndSchedulePDFReport</label>
+ <value>Créer et planifier un rapport PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_CreatePDFReport</label>
+ <value>Créer un rapport PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_UpdatePDFReport</label>
+ <value>Mettre à jour un rapport PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_EmailHello</label>
+ <value>Bonjour,</value>
+ </row>
+ <row>
+ <label>General_Id</label>
+ <value>Id</value>
+ </row>
+ <row>
+ <label>General_NewUpdatePiwikX</label>
+ <value>Nouvelle mise à jour : Piwik %s</value>
+ </row>
+ <row>
+ <label>CoreUpdater_HelpMessageContent</label>
+ <value>Allez voir la %1$s FAQ Piwik %2$s qui explique les erreurs courantes lors de la mise à jour. %3$s Demandez à votre administrateur système - il pourra être à même avec cette erreur qui est très probablement liée à la configuration de votre serveur MySQL.</value>
+ </row>
+ <row>
+ <label>Installation_SystemCheckGlobHelp</label>
+ <value>Cette fonction native a été désactivée sur votre hôte. Piwik va tenter de l'émuler mais il pourra rencontrer des restrictions de sécurité. Les fonctionnalités pourront en être impactées.</value>
+ </row>
+ <row>
+ <label>Live_GoalTime</label>
+ <value>Temps de première conversion</value>
+ </row>
+ <row>
+ <label>Live_GoalRevenue</label>
+ <value>Revenu</value>
+ </row>
+ <row>
+ <label>Live_GoalDetails</label>
+ <value>Détails</value>
+ </row>
+ <row>
+ <label>PDFReports_PluginDescription</label>
+ <value>Créez et téléchargez vos rapports PDF personnalisés et recevez les par e-mail quotidiennement, hebdomadairement ou mensuellement.</value>
+ </row>
+ <row>
+ <label>PDFReports_ManagePdfReports</label>
+ <value>Gérer les rapports PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_EmailReports</label>
+ <value>Rapports e-mail</value>
+ </row>
+ <row>
+ <label>PDFReports_SendReportNow</label>
+ <value>Envoyer le rapport maintenant</value>
+ </row>
+ <row>
+ <label>PDFReports_CancelAndReturnToPDF</label>
+ <value>Annuler et %sretourner à la liste des rapports PDF%s</value>
+ </row>
+ <row>
+ <label>PDFReports_DescriptionWillBeFirstPage</label>
+ <value>La description du rapport sera affichée sur la première page du rapport PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_WeeklyScheduleHelp</label>
+ <value>Planification hebdomadaire : le rapport sera envoyé le Lundi de chaque semaine.</value>
+ </row>
+ <row>
+ <label>PDFReports_MonthlyScheduleHelp</label>
+ <value>Planification mensuelle : le rapport sera envoyé le premier jour de chaque mois.</value>
+ </row>
+ <row>
+ <label>PDFReports_AlsoSendReportToTheseEmails</label>
+ <value>Envoyer le rapport aussi à ces adresses e-mail (une par ligne) :</value>
+ </row>
+ <row>
+ <label>PDFReports_ReportsIncludedInPDF</label>
+ <value>Rapports inclus en PDF</value>
+ </row>
+ <row>
+ <label>PDFReports_PiwikReports</label>
+ <value>Rapports Piwik</value>
+ </row>
+ <row>
+ <label>PDFReports_DefaultPDFContainingAllReports</label>
+ <value>Rapport PDF par défaut contenant tous les rapports disponibles</value>
+ </row>
+ <row>
+ <label>PDFReports_PleaseFindAttachedFile</label>
+ <value>Veuillez trouver en pièce jointe votre rapport %1$s pour %2$s.</value>
+ </row>
+ <row>
+ <label>PDFReports_AreYouSureYouWantToDeleteReport</label>
+ <value>Etes vous sûr de vouloir supprimer ce rapport PDF ainsi que sa planification?</value>
+ </row>
+ <row>
+ <label>PDFReports_ThereIsNoPDFReportToManage</label>
+ <value>Il n'y a aucun rapport PDF à gérer pour le site %s</value>
+ </row>
+ <row>
+ <label>PDFReports_YouMustBeLoggedIn</label>
+ <value>Vous devez être connecté afin de pouvoir créer et planifier des rapports PDF personnalisés.</value>
+ </row>
+</result> \ No newline at end of file