FileUploader.php 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819
  1. <?php
  2. class FileUploader {
  3. private $_column = '';
  4. private $_glob = '';
  5. private $_cnf = array();
  6. private $_foundFolders = array();
  7. private $_record = null;
  8. private $BAD_FILE_SIGNS = array();
  9. private $OK_FILE_SIGNS = array();
  10. private $_lastUploadedFile = null;
  11. public function __construct($column, $record) {
  12. $this->_column = $column;
  13. $this->_record = $record;
  14. $this->BAD_FILE_SIGNS = array('.', ' ', ',', '/', 'ą', 'ć', 'ę', 'ł', 'ń', 'ó', 'ś', 'ź', 'ż', 'Ą', 'Ć', 'Ę', 'Ł', 'Ń', 'Ó', 'Ś', 'Ź', 'Ż');
  15. $this->OK_FILE_SIGNS = array('-', '_', '--', '---', 'a', 'c', 'e', 'l', 'n', 'o', 's', 'z', 'z', 'A', 'C', 'E', 'L', 'N', 'O', 'S', 'Z', 'Z');
  16. }
  17. public function hasRecordOwnFolder() {
  18. $fldLookAt = V::get('LOOK_GLOB', '', $this->_cnf['LOOKAT_FOLDER']);
  19. if ($fldLookAt) {
  20. if (false !== strpos($fldLookAt, '<VARNAME')) {
  21. return true;
  22. }
  23. }
  24. return false;
  25. }
  26. public function setConfig($conf, &$errMsg = '') {
  27. $DBG = (V::get('DBG_F', 0, $_GET, 'int') > 0);
  28. $this->_cnf['LOCAL_PATH'] = V::get('mount_point', null, $conf);
  29. $this->_cnf['PATH'] = V::get('share_point', null, $conf);
  30. $this->_cnf['WWW'] = V::get('www_share_point', null, $conf);
  31. $this->_cnf['LOOKAT_FOLDER'] = array();
  32. $this->_cnf['LOOKAT_FILES'] = array();// LOOKAT_FILES_LOOK_GLOB
  33. $this->_cnf['DEST_FOLDER'] = array();
  34. foreach ($conf as $key => $val) {
  35. if (substr($key, 0, 14) == 'LOOKAT_FOLDER_') {
  36. $key = substr($key, 14);
  37. $this->_cnf['LOOKAT_FOLDER'][$key] = $val;
  38. }
  39. else if (substr($key, 0, 12) == 'DEST_FOLDER_') {
  40. $key = substr($key, 12);
  41. $this->_cnf['DEST_FOLDER'][$key] = $val;
  42. }
  43. else if (substr($key, 0, 13) == 'LOOKAT_FILES_') {
  44. $key = substr($key, 13);
  45. $this->_cnf['LOOKAT_FILES'][$key] = $val;
  46. }
  47. }
  48. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">this->_conf (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($this->_cnf);echo'</pre>'."\n"; }
  49. foreach ($this->_cnf as $key => $val) {
  50. if ($key == 'LOOKAT_FILES') {
  51. continue;
  52. }
  53. if ($val == null) {
  54. $errMsg = "Brak wartości dla {$key}.";
  55. return false;
  56. }
  57. }
  58. if (!is_writable($this->_cnf['LOCAL_PATH'])) {
  59. $errMsg = "Error: brak uprawnień do zapisu w głównym katalogu!";
  60. return false;
  61. }
  62. return true;
  63. }
  64. private function setLastUploadedFile($lastUploadedFile) {
  65. $this->_lastUploadedFile = $lastUploadedFile;
  66. }
  67. public function getLastUploadedFile() {
  68. return $this->_lastUploadedFile;
  69. }
  70. public function getFolderWeb() {
  71. return $this->_cnf['WWW'];
  72. }
  73. public function getLocalPath() {
  74. return $this->_cnf['LOCAL_PATH'];
  75. }
  76. function findFolder() {
  77. $DBG = (V::get('DBG_F', 0, $_GET, 'int') > 0);
  78. if (!empty($this->_foundFolders)) {
  79. return $this->_foundFolders;
  80. }
  81. $this->_foundFolders = array();
  82. if (empty($this->_cnf['LOOKAT_FOLDER'])) {
  83. return $this->_foundFolders;
  84. }
  85. $look = new stdClass();
  86. //$look->regex = V::get('LOOK_REGEX', '', $this->_cnf['LOOKAT_FOLDER']);
  87. $look->glob = V::get('LOOK_GLOB', '', $this->_cnf['LOOKAT_FOLDER']);
  88. $look->varname = array();
  89. $look->varname['VARNAME'] = V::get('VARNAME', '', $this->_cnf['LOOKAT_FOLDER']);
  90. $look->varname['VARNAME1'] = V::get('VARNAME1', '', $this->_cnf['LOOKAT_FOLDER']);
  91. $look->varname['VARNAME2'] = V::get('VARNAME2', '', $this->_cnf['LOOKAT_FOLDER']);
  92. $look->varname['VARNAME3'] = V::get('VARNAME3', '', $this->_cnf['LOOKAT_FOLDER']);
  93. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$look (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($look);echo'</pre>'; }
  94. foreach ($look->varname as $kName => $vVar) {
  95. if ($vVar) {
  96. if (isset($this->_record->{$vVar})) {
  97. $vVar = $this->_record->{$vVar};
  98. }
  99. $look->glob = str_replace("<{$kName}>", $vVar, $look->glob);
  100. }
  101. }
  102. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">look->glob (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($look->glob);echo'</pre>'."\n"; }
  103. $foundFolders = glob("{$this->_cnf['LOCAL_PATH']}/{$look->glob}", GLOB_ONLYDIR & GLOB_NOSORT);
  104. if (false == $foundFolders) {
  105. return false;
  106. } else {
  107. foreach ($foundFolders as $vFolder) {
  108. $vFolderParts = explode('/', $vFolder);
  109. $this->_foundFolders[] = end($vFolderParts);
  110. }
  111. }
  112. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">this->_foundFolders (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($this->_foundFolders);echo'</pre>'."\n"; }
  113. return $this->_foundFolders;
  114. }
  115. function cleanFilenamePart($part) {
  116. if ($part == '') return '_';
  117. $part = str_replace($this->BAD_FILE_SIGNS, $this->OK_FILE_SIGNS, trim($part));
  118. if (strlen($part) > 20) $part = substr($part, 0, 20) . '_';
  119. $part = preg_replace('/[^0-9a-zA-Z\-_]/', '_', $part);
  120. return $part;
  121. }
  122. /**
  123. * TODO:
  124. */
  125. function generateFolderName() {
  126. $DBG = false;
  127. $folderParts = array();
  128. $look = new stdClass();
  129. $look->format = V::get('FORMAT', '', $this->_cnf['DEST_FOLDER']);
  130. $look->varname = array();
  131. $look->varname['VARNAME'] = V::get('VARNAME', '', $this->_cnf['DEST_FOLDER']);
  132. $look->varname['VARNAME1'] = V::get('VARNAME1', '', $this->_cnf['DEST_FOLDER']);
  133. $look->varname['VARNAME2'] = V::get('VARNAME2', '', $this->_cnf['DEST_FOLDER']);
  134. $look->varname['VARNAME3'] = V::get('VARNAME3', '', $this->_cnf['DEST_FOLDER']);
  135. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$look (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($look);echo'</pre>'; }
  136. foreach ($look->varname as $kName => $vVar) {
  137. if (!empty($vVar)) {
  138. if (isset($this->_record->{$vVar})) {
  139. if ($vVar == 'M_DIST_DESC') {
  140. $badPrefixes = array();
  141. $badPrefixes[] = 'Sprawy związane z ';
  142. $badPrefixes[] = 'Sprawy związane ze ';
  143. $badPrefixes[] = 'Sprawy zwiazane z ';
  144. $badPrefixes[] = 'Sprawy zwiazane ze ';
  145. $badPrefixes[] = 'Sprawy prowadzone przez ';
  146. $badPrefixes[] = 'Sprawy ';
  147. foreach ($badPrefixes as $vBadPrefix) {
  148. $prefixLen = strlen($vBadPrefix);
  149. if (substr($this->_record->{$vVar}, 0, $prefixLen) == $vBadPrefix) {
  150. $this->_record->{$vVar} = substr($this->_record->{$vVar}, $prefixLen);
  151. break;
  152. }
  153. }
  154. }
  155. $part = $this->cleanFilenamePart($this->_record->{$vVar});
  156. }
  157. if (empty($part)) {
  158. $part = '_';
  159. }
  160. $look->format = str_replace("<{$kName}>", $part, $look->format);
  161. }
  162. }
  163. if (false !== strpos('<', $look->format) || false !== strpos('>', $look->format)) {
  164. return false;// TODO: blad konfiguracji - brakuje definicji zmiennych
  165. }
  166. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$look (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($look);echo'</pre>'; }
  167. return $look->format;
  168. }
  169. function generateFolderName__OLD() {
  170. $dir_tree = array();
  171. foreach ($this->_cnf['DEST_FOLDER'] as $k => $v_fldr) {
  172. $look = new stdClass();
  173. $look->regex = V::get('LOOK_REGEX', '', $v_fldr);
  174. $look->varname = array();
  175. foreach ($v_fldr['VARNAME'] as $k_var_ind => $v_look) {
  176. if (false !== strpos($v_look, '$_SESSION[$thiss->DETECT_TABLE_COLUMN][EDITRECORD][')) {
  177. $v_look = substr($v_look, strlen('$_SESSION[$thiss->DETECT_TABLE_COLUMN][EDITRECORD]['), -1);
  178. $v_look = V::get($v_look, '', $_SESSION[$this->_column]['EDITRECORD']);
  179. }
  180. $v_look = (empty($v_look))? '_' : $this->cleanFilenamePart($v_look);
  181. $look->regex = str_replace('<VARNAME' . $k_var_ind.'>', $v_look, $look->regex);
  182. }
  183. if (false !== strpos('<', $look->regex) || false !== strpos('>', $look->regex)) {
  184. die('<p>' . "Error: Blad konfiguracji \$FOLDERS[{$this->_column}_DEST_FOLDER]" . '</p>');
  185. } else {
  186. $dir_tree []= $look->regex;
  187. }
  188. }
  189. return implode('/', $dir_tree);
  190. }
  191. function getDestFolder($show_if_not_found = false) {
  192. if (empty($this->_foundFolders)) {
  193. if ($show_if_not_found) {
  194. return $this->generateFolderName();
  195. }
  196. } else {
  197. return reset($this->_foundFolders);
  198. }
  199. return null;
  200. }
  201. function getDestPathShare($show_if_not_found = false) {
  202. $dest_dir = $this->getDestFolder($show_if_not_found);
  203. if (!$dest_dir) {
  204. return null;
  205. }
  206. return $this->_cnf['PATH'] . '/' . $dest_dir;
  207. }
  208. function getDestLocalPath($show_if_not_found = false) {
  209. $dest_dir = $this->getDestFolder($show_if_not_found);
  210. if (!$dest_dir) {
  211. return null;
  212. }
  213. return "{$this->_cnf['LOCAL_PATH']}/{$dest_dir}";
  214. }
  215. function getFoundFolders() {
  216. return $this->_foundFolders;
  217. }
  218. function getFilesFromFolder($folder, $fileNamesOnly = false, $recursive = false) {
  219. $DBG = (V::get('DBG_F', 0, $_GET, 'int') > 0);
  220. if (empty($folder)) {
  221. return false;
  222. }
  223. $lookGlob = $this->getFileSearchRegex();
  224. $ret = glob("{$this->_cnf['LOCAL_PATH']}/{$folder}/{$lookGlob}", GLOB_NOSORT);
  225. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">glob('."{$this->_cnf['LOCAL_PATH']}/{$folder}/*.*".') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($ret);echo'</pre>'; }
  226. if ($recursive) {
  227. $retSubFolderFiles = glob("{$this->_cnf['LOCAL_PATH']}/{$folder}/*/*.*", GLOB_NOSORT);
  228. if ($retSubFolderFiles !== false) {
  229. foreach ($retSubFolderFiles as $vFile) {
  230. if ($fileNamesOnly == true) {
  231. $ret[] = str_replace("{$this->_cnf['LOCAL_PATH']}/{$folder}/", '', $vFile);
  232. } else {
  233. $ret[] = $vFile;
  234. }
  235. }
  236. }
  237. }
  238. if (false === $ret) {
  239. return false;
  240. } else {
  241. foreach ($ret as $k => $vFile) {
  242. if ($fileNamesOnly == true) {
  243. $ret[$k] = str_replace("{$this->_cnf['LOCAL_PATH']}/{$folder}/", '', $vFile);
  244. } else {
  245. $ret[$k] = $vFile;
  246. }
  247. }
  248. }
  249. return $ret;
  250. }
  251. public function getFileSearchRegex() {
  252. $DBG = false;
  253. $look = new stdClass();
  254. if ($this->_cnf['LOOKAT_FILES']) {
  255. //$look->regex = V::get('LOOK_REGEX', '', $this->_cnf['LOOKAT_FOLDER']);
  256. $look->glob = V::get('LOOK_GLOB', '', $this->_cnf['LOOKAT_FILES']);
  257. $look->varname = array();
  258. $look->varname['VARNAME'] = V::get('VARNAME', '', $this->_cnf['LOOKAT_FILES']);
  259. $look->varname['VARNAME1'] = V::get('VARNAME1', '', $this->_cnf['LOOKAT_FILES']);
  260. $look->varname['VARNAME2'] = V::get('VARNAME2', '', $this->_cnf['LOOKAT_FILES']);
  261. $look->varname['VARNAME3'] = V::get('VARNAME3', '', $this->_cnf['LOOKAT_FILES']);
  262. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$look (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($look);echo'</pre>'; }
  263. foreach ($look->varname as $kName => $vVar) {
  264. if ($vVar) {
  265. if (isset($this->_record->{$vVar})) {
  266. $vVar = $this->_record->{$vVar};
  267. }
  268. $look->glob = str_replace("<{$kName}>", $vVar, $look->glob);
  269. }
  270. }
  271. } else {
  272. $look->glob = "*.*";
  273. }
  274. return $look->glob;
  275. }
  276. function getFilesFromSkany($skanyConf, $fileNamesOnly = false) {
  277. $DBG = (V::get('DBG_F', 0, $_GET, 'int') > 0);
  278. if (empty($skanyConf)) {
  279. return false;
  280. }
  281. $skanyLocalPath = V::get('mount_point', '', $skanyConf);
  282. if (empty($skanyLocalPath)) {
  283. return false;
  284. }
  285. $ret = glob("{$skanyLocalPath}/*.*", GLOB_NOSORT);
  286. if($DBG){ echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">glob('."{$this->_cnf['LOCAL_PATH']}/{$folder}/*.*".') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($ret);echo'</pre>'; }
  287. if (false === $ret) {
  288. return false;
  289. } else {
  290. foreach ($ret as $k => $vFile) {
  291. if ($fileNamesOnly == true) {
  292. $ret[$k] = end(explode('/', $vFile));
  293. } else {
  294. $ret[$k] = $vFile;
  295. }
  296. }
  297. }
  298. return $ret;
  299. }
  300. function showFoundFolders() {// TODO: RMME not used
  301. $cnt_dirs = count($this->_foundFolders);
  302. if ($cnt_dirs > 1) {
  303. echo '<p style="color:red">' . "Odnaleziono {$cnt_dirs} folderów, przenieś pliki do jednego folderu i usuń błędnie nazwane." . '</p>';
  304. } else if ($cnt_dirs == 0) {
  305. echo '<p>' . "Nie odnaleziono folderu - zostanie utworzony automatycznie podczas dodawania pliku." . '</p>';
  306. } else {
  307. echo '<p style="color:green">' . "Odnaleziono odpowiedni folder: " . '<code><b>' . $this->getDestFolder() . '</b></code>' . '</p>';
  308. }
  309. foreach ($this->_foundFolders as $v_dir) {
  310. $v_files = $this->getFilesFromFolder($v_dir);
  311. $path_samba = $this->_cnf['PATH'] . '/' . $v_dir;
  312. $path_www = $this->_cnf['WWW'] . '/' . $v_dir;
  313. echo '<table cellspacing="0" cellpadding="0" border="0" style="margin:20px 0;border:1px solid #777;">';
  314. echo '<tr><td colspan="3" bgcolor="#ccf" style="font-size:small;"><img src="icon/ms_directory.gif" border="0">' . "Adres:" . '<a href="' . "file://{$path_samba}" . '">' . $path_samba . '</a>' . " WWW: " . '<a href="' . $path_www . '" target="_blank">' . "(Web)" . '</font></a> </td></tr>';
  315. echo '<tr>';
  316. echo '<th style="border-right:1px solid #777;text-align:left;">' . "Nazwa" . '</th>';
  317. echo '<th style="border-right:1px solid #777;text-align:left;">' . "Rozmiar" . '</th>';
  318. echo '<th style="text-align:left;">' . "Typ" . '</th>';
  319. echo '</tr>';
  320. if (empty($v_files)) {
  321. echo '<tr><td colspan="3">' . '<i style="color:#777;">' . "Folder jest pusty" . '</i>' . '</td></tr>';
  322. } else {
  323. foreach ($v_files as $v_file) {
  324. $v_file_name = end(explode('/', $v_file));
  325. $v_file_www = $path_www . '/' . $v_file_name;
  326. echo '<tr>';
  327. echo '<td style="border-right:1px solid #777;">' . $v_file_name . '</td>';
  328. echo '<td style="border-right:1px solid #777;text-align:right">' . filesize($v_file) . " B" . '</td>';
  329. echo '<td>' . (is_dir($v_file)? "Folder" : "Plik") . " " . '<a href="' . $v_file_www . '" target="_blank">' . "(Web)" . '</a>' . '</td>';
  330. echo '</tr>';
  331. }
  332. }
  333. echo '</table>';
  334. }
  335. }
  336. /**
  337. * TODO: obecnie działa tylko werjs tryUploadAjax
  338. */
  339. function tryUpload() {
  340. return false;
  341. if ($_FILES['M_DIST_FILES_NAME']['error'] > 0) {
  342. echo '<p style="color:red">Error: Wystąpił błąd podczas wgrywania pliku: ' . $_FILES['M_DIST_FILES_NAME']['error'] . '</p>';
  343. return;
  344. }
  345. echo '<div style="border:1px solid #777">';
  346. echo 'Informacje o wgrywanym pliku:<br />';
  347. echo 'Nazwa: ' . $_FILES['M_DIST_FILES_NAME']['name'] . '<br>';
  348. echo 'Typ: ' . $_FILES['M_DIST_FILES_NAME']['type'] . '<br>';
  349. echo 'Rozmiar: ' . $_FILES['M_DIST_FILES_NAME']['size'] . ' B<br>';
  350. if ($_SESSION['DEBUG']) echo 'Stored in: ' . $_FILES['M_DIST_FILES_NAME']['tmp_name'];
  351. echo '</div>';
  352. //if (false === strpos($_SESSION[$this->_column]['PERMEDIT']['M_DIST_FILES'], "W")) {
  353. // echo '<p>' . "Error: Brak uprawnień do zapisu (W) dla pola M_DIST_FILES." . '</p>';
  354. // return;
  355. //}
  356. if (!is_uploaded_file($_FILES['M_DIST_FILES_NAME']['tmp_name'])) {
  357. echo '<p>' . "Error: Wystąpił błąd podczas wgrywania pliku." . '</p>';
  358. return;
  359. }
  360. $IN7_FILERENAME = $this->renameFile($_POST, $_FILES['M_DIST_FILES_NAME']['name'], $this->getDestLocalPath(true));
  361. if ($IN7_FILERENAME == false) {
  362. return false;
  363. }
  364. if (!empty($IN7_FILERENAME['ERROR'])) {
  365. echo "<br> <font color=red> Wystapil error (".$IN7_FILERENAME['ERROR'].")<br>EOL.";
  366. }
  367. else if (!empty($IN7_FILERENAME['DST_FILE_NAME']) && !empty($IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER'])) {
  368. if (!move_uploaded_file($_FILES['M_DIST_FILES_NAME']['tmp_name'], $IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER'] . "/" . $IN7_FILERENAME['DST_FILE_NAME'])) {
  369. echo '<hr /><h1 style="color:red">' . "Error: plik nie został przeniesiony do odpowiedniego katalogu, " . '<a href="JavaScript:window.close()">zamknij to okno i wroc do wczesniejszego</a></h1>';
  370. }
  371. else {
  372. echo "<br>wykonalem funkcje move dla parametrow ".$_FILES['M_DIST_FILES_NAME']['tmp_name']." oraz ".$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']."/".$IN7_FILERENAME['DST_FILE_NAME'] ." <br>Informacje dodatkowe :".$IN7_FILERENAME['INFO']." <br> EOL <br> ";
  373. if (file_exists($IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']."/".$IN7_FILERENAME['DST_FILE_NAME'])) {
  374. echo '<hr /><h1 style="color:green">' . "Plik został poprawnie wgrany do odpowiedniego katalogu, " . '<a href="JavaScript:window.close()">zamknij to okno i wroc do wczesniejszego</a></h1>';
  375. IN7_POST_HISTORY($TABLE, array('M_DIST_FILES'), array(" Wgrano plik z przegladarki WWW ".$_SERVER['REMOTE_ADDR']." ".$_FILES['M_DIST_FILES_NAME']['name']." do ".$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']."/".$IN7_FILERENAME['DST_FILE_NAME']." "), $thiss, $SESSION);
  376. }
  377. else {
  378. echo '<hr /><h1 style="color:red">' . "PLIK NIE ZOSTAL WGRANY BLAD/ERROR, " . '<a href="JavaScript:window.close()">zamknij to okno i wroc do wczesniejszego</a></h1>';
  379. }
  380. }
  381. }
  382. }
  383. function tryUploadAjax(&$errorMsg) {
  384. if ($_FILES['M_DIST_FILES_NAME']['error'] > 0) {
  385. $errorMsg = 'Wystąpił błąd podczas wgrywania pliku: ' . $_FILES['M_DIST_FILES_NAME']['error'] . '';
  386. return false;
  387. }
  388. /*
  389. echo '<div style="border:1px solid #777">';
  390. echo 'Informacje o wgrywanym pliku:<br />';
  391. echo 'Nazwa: ' . $_FILES['M_DIST_FILES_NAME']['name'] . '<br>';
  392. echo 'Typ: ' . $_FILES['M_DIST_FILES_NAME']['type'] . '<br>';
  393. echo 'Rozmiar: ' . $_FILES['M_DIST_FILES_NAME']['size'] . ' B<br>';
  394. if ($_SESSION['DEBUG']) echo 'Stored in: ' . $_FILES['M_DIST_FILES_NAME']['tmp_name'];
  395. echo '</div>';
  396. */
  397. //if (false === strpos($_SESSION[$this->_column]['PERMEDIT']['M_DIST_FILES'], "W")) {
  398. // echo '<p>' . "Error: Brak uprawnień do zapisu (W) dla pola M_DIST_FILES." . '</p>';
  399. // return;
  400. //}
  401. if (!is_uploaded_file($_FILES['M_DIST_FILES_NAME']['tmp_name'])) {
  402. $errorMsg = ' Wystąpił błąd podczas wgrywania pliku';
  403. return;
  404. }
  405. $renameErrorMsg = '';
  406. $IN7_FILERENAME = $this->renameFile($_POST, $_FILES['M_DIST_FILES_NAME']['name'], $this->getDestLocalPath(true), $renameErrorMsg);
  407. if ($IN7_FILERENAME == false) {
  408. $errorMsg = "Wystąpił błąd podczas zmiany nazwy wgrywanego pliku: {$renameErrorMsg}.";
  409. return false;
  410. }
  411. if (!empty($IN7_FILERENAME['ERROR'])) {
  412. $errorMsg = "Wystąpiły błądy podczas zmiany nazwy wgrywanego pliku: '{$IN7_FILERENAME['ERROR']}'";
  413. }
  414. else if (!empty($IN7_FILERENAME['DST_FILE_NAME']) && !empty($IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER'])) {
  415. $newFilePath = "{$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']}/{$IN7_FILERENAME['DST_FILE_NAME']}";
  416. if (!move_uploaded_file($_FILES['M_DIST_FILES_NAME']['tmp_name'], $newFilePath)) {
  417. $errorMsg = "plik nie został przeniesiony do odpowiedniego katalogu";
  418. }
  419. else {
  420. if (file_exists($newFilePath)) {
  421. $this->setLastUploadedFile($newFilePath);
  422. return true;
  423. }
  424. else {
  425. $errorMsg = "PLIK NIE ZOSTAL WGRANY BLAD/ERROR";
  426. }
  427. }
  428. }
  429. return false;
  430. }
  431. function tryMoveFromScanAjax(&$errorMsg) {
  432. $destFolderPath = $this->getDestLocalPath(true);
  433. $skanFileName = V::get('SCANS_COLUMN_ADD', '', $_POST);
  434. if (empty($skanFileName)) {
  435. $errorMsg = 'Nie wybrano pliku ze skanów';
  436. return false;
  437. }
  438. Lib::loadClass('FoldersConfig');
  439. $skanyConf = FoldersConfig::getAll('SCANS_COLUMN');
  440. $skanyLocalPath = V::get('mount_point', '', $skanyConf);
  441. $skanyFiles = $this->getFilesFromSkany($skanyConf, true);
  442. if (!in_array($skanFileName, $skanyFiles)) {
  443. $errorMsg = 'Wybrany plik nie istnieje w skanach';
  444. return false;
  445. }
  446. $renameErrorMsg = '';
  447. $IN7_FILERENAME = $this->renameFile($_POST, $skanFileName, $destFolderPath, $renameErrorMsg);
  448. if ($IN7_FILERENAME == false) {
  449. $errorMsg = "Wystąpił błąd podczas zmiany nazwy wgrywanego pliku: {$renameErrorMsg}.";
  450. return false;
  451. }
  452. if (!empty($IN7_FILERENAME['ERROR'])) {
  453. $errorMsg = "Wystąpiły błądy podczas zmiany nazwy wgrywanego pliku: '{$IN7_FILERENAME['ERROR']}'";
  454. }
  455. else if (!empty($IN7_FILERENAME['DST_FILE_NAME']) && !empty($IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER'])) {
  456. $newFilePath = "{$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']}/{$IN7_FILERENAME['DST_FILE_NAME']}";
  457. if (!copy("{$skanyLocalPath}/{$skanFileName}", "{$newFilePath}")) {
  458. $errorMsg = "Plik nie został przeniesiony do odpowiedniego katalogu";
  459. }
  460. else {
  461. unlink("{$skanyLocalPath}/{$skanFileName}");
  462. if (file_exists("{$newFilePath}")) {
  463. $this->setLastUploadedFile($newFilePath);
  464. return true;
  465. }
  466. else {
  467. $errorMsg = "Plik nie został przenisiony ze skanów";
  468. }
  469. }
  470. }
  471. return false;
  472. }
  473. /**
  474. * TODO: obecnie działa tylko wersja tryMoveFromScanAjax
  475. */
  476. function tryMoveFromScan() {
  477. return false;
  478. $dest_folder = $this->getDestLocalPath(true);
  479. foreach ($_POST as $POST_I => $POST_V) {
  480. if (false === strpos($POST_I, 'SCANS_COLUMN_ADD__')) continue;
  481. echo "<br> Proba przeniesienia pliku ze SCANS_COLUMN \n";
  482. $SCAN_PLIK = end(explode('__',$POST_I));
  483. echo "DLa ID {$SCAN_PLIK} ";
  484. echo $_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FOLDER'];
  485. $IN7_FILERENAME = $this->renameFile($_POST, $_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FILE'], $dest_folder);
  486. if (($IN7_FILERENAME['DST_FILE_NAME'])&&($IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER'])&&(!$IN7_FILERENAME['ERROR'])) {
  487. if(file_exists($_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FOLDER']."/".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FILE'])) {
  488. if(copy($_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FOLDER']."/".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK][FILE],$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']."/".$IN7_FILERENAME['DST_FILE_NAME'])) {
  489. chmod("$IN7_FILERENAME[M_DIST_FILES_DEST_FOLDER]."/".$IN7_FILERENAME[DST_FILE_NAME]", 0777);
  490. unlink($_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FOLDER']."/".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FILE']);
  491. } else $IN7_FILERENAME['ERROR'].="COPY_ERROR Problem z kopiowaniem pliku w docelowe miejsce , ";
  492. } else $IN7_FILERENAME['ERROR'].="COPY_ERROR Problem z kopiowaniem brak pliku zrodlowego , ";
  493. echo "<br>wykonalem funkcje move dla parametrow ".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FOLDER']."/".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FILE']." oraz ".$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']."/".$IN7_FILERENAME['DST_FILE_NAME'] ." <br>
  494. Informacje dodatkowe :".$IN7_FILERENAME['INFO']." <br> EOL <br> <hr><h1>PRAWDOPODOBNIE WGRALES PLIK, zamknij to okno i wroc do wczesniejszego</h1>";
  495. } else if($IN7_FILERENAME['ERROR']) {
  496. echo "<br> <font color=red> Wystapil error (".$IN7_FILERENAME['ERROR'].")<br>EOL.";
  497. }
  498. if ($IN7_FILERENAME['ERROR']) {
  499. echo "<br> <font color=red> Wystapil error (".$IN7_FILERENAME['ERROR'].")<br>EOL.";
  500. }
  501. else {
  502. SEF('IN7_POST_HISTORY');
  503. IN7_POST_HISTORY($TABLE,array('M_DIST_FILES'),array("Przeniesiono plik z folderu ".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FOLDER']."/".$_SESSION["SCANS_COLUMN"]["ADD_FILE"][$SCAN_PLIK]['FILE']." do ".$IN7_FILERENAME['M_DIST_FILES_DEST_FOLDER']."/".$IN7_FILERENAME['DST_FILE_NAME']." "),$thiss,$SESSION);
  504. }
  505. }
  506. }
  507. function _isDate($str) {
  508. $str_arr = explode("-", $str);
  509. if (count($str_arr) == 3 &&
  510. strlen($str_arr[2]) == 2 &&
  511. strlen($str_arr[1]) == 2 &&
  512. strlen($str_arr[0]) == 4 &&
  513. $str_arr[0] > 1980 &&
  514. $str_arr[0] < 9999 &&
  515. $str_arr[1] <= 12 &&
  516. $str_arr[2] <= 33
  517. ) {
  518. return true;
  519. }
  520. return false;
  521. }
  522. /**
  523. * Rename file by params.
  524. *
  525. * @param array $params
  526. * @param string $FILENAME_POST
  527. * @param string $dest_folder
  528. *
  529. * @returns array (
  530. * 'M_DIST_FILES_DEST_FOLDER',
  531. * 'DST_FILE_NAME',
  532. * 'ERROR',
  533. * 'INFO'
  534. * )
  535. */
  536. function renameFile($params, $FILENAME_POST, $dest_folder, &$errorMsg = '') {
  537. $genLog = array();// return array
  538. $genLog_INDEX = array();
  539. $postFileNameByDot = explode('.', $FILENAME_POST);
  540. $postFileNameBy_ = explode('_', $FILENAME_POST);
  541. if (empty($params['M_DIST_FILES_TYPE'])) {
  542. $errorMsg = "nie wybrano typu pliku";
  543. return false;
  544. }
  545. $genLog['INDEXNAME'] = $this->_record->ID;
  546. $genLog['EXT'] = end($postFileNameByDot);
  547. $genLog['TYPE'] = $params['M_DIST_FILES_TYPE'];
  548. if (!empty($params['M_DIST_FILES_TEMP'])) {
  549. $genLog['TYPE'] .= "_TEMP";
  550. }
  551. // set $genLog['DATE'], $genLog_INDEX['DATE']
  552. // use $params M_DIST_FILES_DATE
  553. $postFileNameBy_Cnt = count($postFileNameBy_);
  554. if ($postFileNameBy_Cnt >= 2 && $postFileNameBy_Cnt <= 7) {
  555. foreach ($postFileNameBy_ as $ind => $file_part) {
  556. if ($this->_isDate($file_part)) {
  557. if (empty($params['M_DIST_FILES_DATE'])) {
  558. $genLog['DATE'] = $file_part;
  559. }
  560. $genLog_INDEX['DATE'] []= array('PREFIX'=>"_", 'INDEKS'=>"$ind", 'VALUE'=>$file_part);
  561. }
  562. }
  563. }
  564. // set $genLog['DATE'], $genLog_INDEX['DATE']
  565. // use $params M_DIST_FILES_DATE
  566. $FILE_P_COUNT = count($postFileNameByDot);
  567. if ($FILE_P_COUNT >= 2 && $FILE_P_COUNT <= 7) {
  568. foreach ($postFileNameByDot as $ind => $file_part) {
  569. if ($this->_isDate($file_part)) {
  570. if (empty($params['M_DIST_FILES_DATE'])) {
  571. if (!$genLog_INDEX['DATE'][1]) {
  572. $genLog['DATE'] = $file_part;
  573. }
  574. }
  575. $genLog_INDEX['DATE'] []= array('PREFIX'=>".", 'INDEKS'=>"$ind", 'VALUE'=>$file_part);
  576. }
  577. }
  578. }
  579. // set $genLog['VERSION']
  580. // TODO: szuka wersji w miejscu drugiej daty?
  581. if (!empty($params['M_DIST_FILES_VERSION'])) {
  582. $genLog['VERSION'] = $params['M_DIST_FILES_VERSION'];
  583. }
  584. else if (!empty($params['M_DIST_FILES_VERSION_AUTO'])) {
  585. if (isset($genLog_INDEX['DATE'][1])) {// sa 2 poprawne daty w pliku
  586. $SPLITER = $genLog_INDEX['DATE'][1]['PREFIX'];
  587. $GIS = explode($SPLITER, $FILENAME_POST);
  588. echo $genLog_INDEX['DATE'][1]['INDEKS'];
  589. $pattern = '/[[:alpha:]]/';
  590. $subject = $GIS[$genLog_INDEX['DATE'][1]['INDEKS']];
  591. $PO = preg_match($pattern, $subject, $PO2, PREG_OFFSET_CAPTURE);
  592. if ($PO == 0 && $GIS[$genLog_INDEX['DATE'][1]['INDEKS']] >= 0 && $GIS[$genLog_INDEX['DATE'][1]['INDEKS']] <= 999) {
  593. $genLog['VERSION'] = $GIS[$genLog_INDEX['DATE'][1]['INDEKS']];
  594. }
  595. }
  596. }
  597. // set $genLog['DESCRIPTION']
  598. $genLog['DESCRIPTION'] = '';
  599. if (!empty($params['M_DIST_FILES_DESCRIPTION'])) {
  600. $genLog['DESCRIPTION'] = $params['M_DIST_FILES_DESCRIPTION'];
  601. }
  602. else {// !empty($params['M_DIST_FILES_DESCRIPTION_AUTO'])
  603. //echo "M_DIST_FILES_DESCRIPTION_AUTO <br> dla parametru $FILENAME_POST (FILENAME_POST) <br>\n";
  604. $genLog['DESCRIPTION'] = $params['M_DIST_FILES_DESCRIPTION'] . "_" . $FILENAME_POST;
  605. if (isset($genLog_INDEX['DATE'][0])) {
  606. $SPL = explode('_', $genLog['DESCRIPTION']);
  607. $genLog['DESCRIPTION'] = '';// clear $genLog['DESCRIPTION']
  608. foreach ($SPL as $SPLL) {
  609. //echo "<br> if $SPLL == ".$genLog_INDEX['DATE'][0]['VALUE']." EOL";
  610. if (false === strpos($SPLL, $genLog_INDEX['DATE'][0]['VALUE'])) {
  611. $genLog['DESCRIPTION'] .= "_" . $SPLL;
  612. //echo "<br> Added Line 177a | $SPLL |";
  613. }
  614. }
  615. //echo "<br> GUESS[DESCRIPTION] line 177: ".$genLog['DESCRIPTION']." should be added ".$params['M_DIST_FILES_DESCRIPTION']." EOL.";
  616. if (isset($genLog_INDEX['DATE'][1])) {
  617. $SPL = explode('.', $genLog['DESCRIPTION']);
  618. $genLog['DESCRIPTION'] = '';// clear $genLog['DESCRIPTION']
  619. foreach ($SPL as $SPLL) {
  620. if (false === strpos($SPLL, $genLog_INDEX['DATE'][1]['VALUE'])) {
  621. $genLog['DESCRIPTION'] .= "." . $SPLL;
  622. }
  623. }
  624. }
  625. //echo "<br> DESCRIPT TO $genLog[DESCRIPTION] - line 203";
  626. }
  627. $genLog['DESCRIPTION'] = str_replace('.' . $genLog['EXT'], '', $genLog['DESCRIPTION']);
  628. $SPL = explode('.', $genLog['DESCRIPTION']);
  629. $genLog['DESCRIPTION'] = '';// clear $genLog['DESCRIPTION'] po raz kolejny
  630. $I = 0;
  631. foreach ($SPL as $SPLL) {
  632. if (!strstr($genLog['VERSION'], $SPLL)) {
  633. $genLog['DESCRIPTION'] .= $SPLL;
  634. //if ($_SESSION['DEBUG']) echo "<br>Sciagam z desc wersje $SPLL == ".$genLog['VERSION']." |";
  635. }
  636. //if ($_SESSION['DEBUG']) echo "<br>line 203: teraz GUESS[DESCRIPTION]= ".$genLog['DESCRIPTION']." | a w oryginale z parametru: ".$FILENAME_POST." |";
  637. }
  638. }
  639. if (!empty($params['M_DIST_FILES_DATE'])) {
  640. $genLog['DATE'] = $params['M_DIST_FILES_DATE'];
  641. }
  642. if (empty($genLog['DATE'])) {
  643. //$errorMsg = "Error: Pusta data {$genLog['DATE']} - ustawiam na dzisiaj";
  644. $genLog['DATE'] = date('Y-m-d');
  645. }
  646. else {
  647. if ($this->_isDate($genLog['DATE'])) {
  648. $genLog['INFO'] .= "3.1.1 WALIDACJA DATY OK , ";
  649. }
  650. else {
  651. $genLog['ERROR'] .= "ERROR_BAD_M_DIST_FILES_DATE (zly format daty {$genLog['DATE']}) , ";
  652. $errorMsg = "zły format daty {$genLog['DATE']}";
  653. return false;
  654. }
  655. }
  656. if (!$genLog['VERSION'] && $params['M_DIST_FILES_VERSION']) {
  657. $genLog['VERSION'] = $params['M_DIST_FILES_VERSION'];
  658. }
  659. else if (!$genLog['VERSION'] && !$params['M_DIST_FILES_VERSION']) {
  660. $genLog['VERSION'] = "1";
  661. }
  662. $genLog['VERSION'] = str_replace(' ', '_', $genLog['VERSION']);
  663. $genLog['DESCRIPTION'] = str_replace(' ', '_', $genLog['DESCRIPTION']);
  664. if($_SESSION['DEBUG']) print_r($genLog);
  665. // try to create folder if not exists
  666. if (!file_exists($dest_folder)) {
  667. mkdir($dest_folder, 0777, true);
  668. @chmod($dest_folder, 0777);
  669. $genLog['INFO'] .= "TWORZE_NOWY_FOLDER , ";
  670. if (!file_exists($dest_folder)) {
  671. //$genLog['ERROR'] .= "ERROR_DEST_FOLDER_NOT_EXISTS";
  672. $errorMsg = "folder nie istnieje - nie udało się go utworzyć";
  673. return false;
  674. }
  675. }
  676. $dest_folder_name = end(explode('/', $dest_folder));
  677. $genLog['M_DIST_FILES_DEST_FOLDER'] = $dest_folder;
  678. $genLog['DST_FILE_NAME'] = $this->generateFileName( array($genLog['INDEXNAME'], $genLog['TYPE'], $genLog['DESCRIPTION'], $genLog['DATE'], $genLog['VERSION'], $genLog['EXT']) );
  679. $v_files = $this->getFilesFromFolder($dest_folder_name, true);
  680. if (!empty($v_files)) {
  681. $genLog['VERSION'] = $this->getFileNextVersion($v_files, $genLog['TYPE'], $genLog['DATE'], $genLog['VERSION']);
  682. $genLog['DST_FILE_NAME'] = $this->generateFileName( array($genLog['INDEXNAME'], $genLog['TYPE'], $genLog['DESCRIPTION'], $genLog['DATE'], $genLog['VERSION'], $genLog['EXT']) );
  683. }
  684. return $genLog;
  685. }
  686. function generateFileName($dirname_parts) {
  687. foreach ($dirname_parts as $k_ind => $v_part) {
  688. $dirname_parts[$k_ind] = $this->cleanFilenamePart($v_part);
  689. }
  690. return implode('.', $dirname_parts);
  691. }
  692. /**
  693. * Generate next file version if exists with the same type and date.
  694. */
  695. function getFileNextVersion($files, $type, $date, $version) {
  696. $max_version = $version;
  697. if (empty($files)) {
  698. return $max_version;
  699. }
  700. foreach ($files as $v_file) {
  701. $v_file_parts = explode('.', $v_file);
  702. if (count($v_file_parts) == 6) {// nowe nazewnictwo 5 kropek
  703. $v_file_type = $v_file_parts[1];
  704. $v_file_date = $v_file_parts[3];
  705. $v_file_version = $v_file_parts[4];
  706. if ($v_file_type == $type && $v_file_date == $date) {
  707. // TODO: echo "<br>WARNING Plik typu $v_file_type dodany w dniu $v_file_date juz istnieje z numerem wersji = $v_file_version ($v_file)";
  708. if (is_numeric($v_file_version)) {
  709. $v_file_version++;
  710. $max_version = max($max_version, $v_file_version);
  711. }
  712. }
  713. } else {
  714. // pomin plik - bledna nazwa
  715. }
  716. }
  717. return $max_version;
  718. }
  719. function tryRemoveFromAjax($fileName) {
  720. $localPath = $this->getDestLocalPath();
  721. if (!$localPath) {
  722. return false;
  723. }
  724. $pathParts = explode('/', $fileName);
  725. $realFileName = array_pop($pathParts);
  726. if (!empty($pathParts)) {
  727. array_unshift($pathParts, $localPath);
  728. $localPath = implode('/', $pathParts);
  729. }
  730. if (file_exists("{$localPath}/{$realFileName}")) {
  731. //return unlink("{$localPath}/{$realFileName}");
  732. $deletedFileName = ".deleted-" . date("Y-m-d-H-i") . ".{$realFileName}";
  733. rename("{$localPath}/{$realFileName}", "{$localPath}/{$deletedFileName}");
  734. return true;
  735. }
  736. return false;
  737. }
  738. }