X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=WEB-INF%2Flib%2FttGroupExportHelper.class.php;h=8a7b7e7706632a4fe39e2f199d77c6836f012ea5;hb=ed41335d63e71a11d30e92f4367106e9398adf9d;hp=f2290fbad1b158402c120c98ae7ea5f5a596f892;hpb=a99eed64c692add1b423ea89d0972f6698e4e6fa;p=timetracker.git diff --git a/WEB-INF/lib/ttGroupExportHelper.class.php b/WEB-INF/lib/ttGroupExportHelper.class.php index f2290fba..8a7b7e77 100644 --- a/WEB-INF/lib/ttGroupExportHelper.class.php +++ b/WEB-INF/lib/ttGroupExportHelper.class.php @@ -123,7 +123,8 @@ class ttGroupExportHelper { // Write group info. $group = $this->getGroupAttrs(); - $group_part = "taskMap[$record['task_id']]."\""; $log_part .= " timesheet_id=\"".$this->timesheetMap[$record['timesheet_id']]."\""; $log_part .= " invoice_id=\"".$this->invoiceMap[$record['invoice_id']]."\""; - $log_part .= " comment=\"".htmlspecialchars($record['comment'])."\""; + $log_part .= " comment=\"".$this->encodeLineBreaks($record['comment'])."\""; $log_part .= " billable=\"".$record['billable']."\""; $log_part .= " approved=\"".$record['approved']."\""; $log_part .= " paid=\"".$record['paid']."\""; @@ -459,7 +460,7 @@ class ttGroupExportHelper { $expense_item_part .= " user_id=\"".$this->userMap[$expense_item['user_id']]."\""; $expense_item_part .= " client_id=\"".$this->clientMap[$expense_item['client_id']]."\""; $expense_item_part .= " project_id=\"".$this->projectMap[$expense_item['project_id']]."\""; - $expense_item_part .= " name=\"".htmlspecialchars($expense_item['name'])."\""; + $expense_item_part .= " name=\"".$this->encodeLineBreaks($expense_item['name'])."\""; $expense_item_part .= " cost=\"".$expense_item['cost']."\""; $expense_item_part .= " invoice_id=\"".$this->invoiceMap[$expense_item['invoice_id']]."\""; $expense_item_part .= " approved=\"".$expense_item['approved']."\""; @@ -495,7 +496,7 @@ class ttGroupExportHelper { foreach ($templates as $template) { $template_part = $this->indentation.' '."\n"; fwrite($this->file, $template_part); @@ -634,4 +635,18 @@ class ttGroupExportHelper { fwrite($this->file, $this->indentation."\n"); } + + // encodeLineBreaks encodes line breaks with an escape sequence. + // We do this, because our strings are attribute values inside XML tags. + // + // If we don't, we lose line breaks after importing data because + // XML parser converts line breaks into a single white character. + // + // TODO: investigate whether we need to encode \t, etc. + private function encodeLineBreaks($source) { + $result = htmlspecialchars($source); + $result = str_replace ("\n", ' ', $result); + $result = str_replace ("\r", ' ', $result); + return $result; + } }