-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathExportToCsvUtf16le.php
executable file
·125 lines (103 loc) · 4.61 KB
/
ExportToCsvUtf16le.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
<?php
/*
"Contact Form to Database" Copyright (C) 2011-2012 Michael Simpson (email : [email protected])
This file is part of Contact Form to Database.
Contact Form to Database is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Contact Form to Database is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Contact Form to Database.
If not, see <http://www.gnu.org/licenses/>.
*/
require_once('ExportBase.php');
require_once('CFDBExport.php');
class ExportToCsvUtf16le extends ExportBase implements CFDBExport {
public function export($formName, $options = null) {
$this->setOptions($options);
$this->setCommonOptions();
// Security Check
if (!$this->isAuthorized()) {
$this->assertSecurityErrorMessage();
return;
}
// Headers
$this->echoHeaders(
array('Content-Type: text/csv; charset=UTF-16LE',
"Content-Disposition: attachment; filename=\"$formName.csv\""));
// todo: make this work
// $fileName = $formName . '.csv';
// $fileName = $this->encodeWordRfc2231($formName) . '.csv';
// header("Content-Disposition: attachment; filename*=UTF-8''$fileName");
//Bytes FF FE (UTF-16LE BOM)
echo chr(255) . chr(254);
$eol = $this->encode(utf8_encode("\n"));
$delimiter = $this->encode(utf8_encode("\t"));
// Query DB for the data for that form
$submitTimeKeyName = 'Submit_Time_Key';
$this->setDataIterator($formName, $submitTimeKeyName);
// Column Headers
if (isset($this->options['header']) && $this->options['header'] != 'true') {
// do not output column headers
}
else {
foreach ($this->dataIterator->getDisplayColumns() as $aCol) {
$colDisplayValue = $aCol;
if ($this->headers && isset($this->headers[$aCol])) {
$colDisplayValue = $this->headers[$aCol];
}
echo $this->prepareCsvValue($colDisplayValue);
echo $delimiter;
}
echo $eol;
}
// Rows
$showFileUrlsInExport = $this->plugin->getOption('ShowFileUrlsInExport') == 'true';
while ($this->dataIterator->nextRow()) {
$fields_with_file = null;
if ($showFileUrlsInExport &&
isset($this->dataIterator->row['fields_with_file']) &&
$this->dataIterator->row['fields_with_file'] != null) {
$fields_with_file = explode(',', $this->dataIterator->row['fields_with_file']);
}
foreach ($this->dataIterator->getDisplayColumns() as $aCol) {
$cell = isset($this->dataIterator->row[$aCol]) ? $this->dataIterator->row[$aCol] : '';
if ($showFileUrlsInExport &&
$fields_with_file &&
$cell &&
in_array($aCol, $fields_with_file)) {
$cell = $this->plugin->getFileUrl($this->dataIterator->row[$submitTimeKeyName], $formName, $aCol);
}
echo $this->prepareCsvValue($cell);
echo $delimiter;
}
echo $eol;
}
}
protected function &prepareCsvValue($text) {
// Excel does not like \n characters in UTF-16LE, so we replace with a space
$text = str_replace("\n", ' ', $text);
// In CSV, escape double-quotes by putting two double quotes together
$text = str_replace('"', '""', $text);
// Quote it to escape delimiters
$text = '"' . $text . '"';
// Encode UTF-16LE
$text = $this->encode($text);
return $text;
}
protected function encode($text) {
return mb_convert_encoding($text, 'UTF-16LE', 'UTF-8');
}
protected function &encodeWordRfc2231($word) {
$binArray = unpack("C*", $word);
$hex = '';
foreach ($binArray as $chr) {
$hex .= '%' . sprintf("%02X", base_convert($chr, 2, 16));
}
return $hex;
}
}