Files
adminer/plugins/file-upload.php

54 lines
2.0 KiB
PHP
Raw Normal View History

2011-02-09 17:57:10 +01:00
<?php
2011-10-09 23:28:18 -07:00
//! delete
2011-02-09 17:57:10 +01:00
/** Edit fields ending with "_path" by <input type="file"> and link to the uploaded files from select
2015-09-08 09:23:25 -07:00
* @link https://www.adminer.org/plugins/#use
2017-02-27 13:43:33 +01:00
* @author Jakub Vrana, https://www.vrana.cz/
2018-01-14 11:03:54 +01:00
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
* @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
2011-02-09 17:57:10 +01:00
*/
class AdminerFileUpload {
2011-08-11 17:06:42 +02:00
/** @access protected */
2011-10-09 23:28:18 -07:00
var $uploadPath, $displayPath, $extensions;
2011-02-09 17:57:10 +01:00
/**
* @param string prefix for uploading data (create writable subdirectory for each table containing uploadable fields)
* @param string prefix for displaying data, null stands for $uploadPath
2011-10-09 23:28:18 -07:00
* @param string regular expression with allowed file extensions
2011-02-09 17:57:10 +01:00
*/
2015-08-15 17:04:21 +02:00
function __construct($uploadPath = "../static/data/", $displayPath = null, $extensions = "[a-zA-Z0-9]+") {
2011-02-09 17:57:10 +01:00
$this->uploadPath = $uploadPath;
2012-05-13 23:54:07 -07:00
$this->displayPath = ($displayPath !== null ? $displayPath : $uploadPath);
2011-10-09 23:28:18 -07:00
$this->extensions = $extensions;
2011-02-09 17:57:10 +01:00
}
2011-02-09 17:57:10 +01:00
function editInput($table, $field, $attrs, $value) {
if (preg_match('~(.*)_path$~', $field["field"])) {
2018-02-06 11:57:02 +01:00
return "<input type='file'$attrs>";
2011-02-09 17:57:10 +01:00
}
}
2011-02-09 17:57:10 +01:00
function processInput($field, $value, $function = "") {
if (preg_match('~(.*)_path$~', $field["field"], $regs)) {
2011-02-09 17:57:10 +01:00
$table = ($_GET["edit"] != "" ? $_GET["edit"] : $_GET["select"]);
$name = "fields-$field[field]";
if ($_FILES[$name]["error"] || !preg_match("~(\\.($this->extensions))?\$~", $_FILES[$name]["name"], $regs2)) {
2011-02-09 17:57:10 +01:00
return false;
}
//! unlink old
2025-02-18 08:26:07 +01:00
$filename = (function_exists('random_bytes') ? bin2hex(random_bytes(8)) : uniqid("", true)) . $regs2[0];
2011-02-09 17:57:10 +01:00
if (!move_uploaded_file($_FILES[$name]["tmp_name"], "$this->uploadPath$table/$regs[1]-$filename")) {
return false;
}
return q($filename);
}
}
2014-01-10 21:32:07 -08:00
function selectVal($val, &$link, $field, $original) {
if ($val != "" && preg_match('~(.*)_path$~', $field["field"], $regs)) {
2011-02-09 17:57:10 +01:00
$link = "$this->displayPath$_GET[select]/$regs[1]-$val";
}
}
2011-02-09 17:57:10 +01:00
}