field basic

This commit is contained in:
xiaomlove
2021-03-02 21:03:02 +08:00
parent 2cb04a1a4f
commit 16bd7ac76d
8 changed files with 273 additions and 5 deletions
+7 -4
View File
@@ -1253,11 +1253,14 @@ function allowedemails()
function redirect($url)
{
if (substr($url, 0, 4) != 'http') {
$url = getSchemeAndHttpHost() . '/' . trim($url, '/');
}
if(!headers_sent()){
header("Location : $url");
}
else
echo "<script type=\"text/javascript\">window.location.href = '$url';</script>";
header("Location: $url", true, 302);
} else {
echo "<script type=\"text/javascript\">window.location.href = '$url';</script>";
}
exit;
}
+21
View File
@@ -0,0 +1,21 @@
<?php
$lang_fields = [
'field_management' => '字段管理',
'text_manage' => '管理',
'text_add' => '添加',
'text_field' => '字段',
'text_delete' => '删除',
'text_edit' => '编辑',
'col_id' => 'ID',
'col_name' => 'Name',
'col_label' => '显示标签',
'col_type' => '类型',
'col_required' => '不能为空',
'col_help' => '辅助说明',
'col_options' => '选项',
'col_action' => '操作',
'js_sure_to_delete_this' => '你确信要删除此项目吗?',
'submit_submit' => '提交'
];
+14
View File
@@ -150,4 +150,18 @@ class DB
return mysql_insert_id();
}
public static function update($table, $data, $whereStr)
{
if (empty($table) || empty($data) || !is_array($data) || empty($whereStr)) {
throw new DatabaseException("require table and data(array) and whereStr.");
}
$updateArr = [];
foreach ($data as $field => $value) {
$updateArr[] = "`$field` = " . sqlesc($value);
}
$sql = sprintf("update `%s` set %s where %s", $table, implode(', ', $updateArr), $whereStr);
sql_query($sql);
return mysql_affected_rows();
}
}
+160
View File
@@ -0,0 +1,160 @@
<?php
namespace Nexus\Field;
use Nexus\Database\DB;
class Field
{
const TYPE_TEXT = 'text';
const TYPE_TEXTAREA = 'textarea';
const TYPE_RADIO = 'radio';
const TYPE_CHECKBOX = 'checkbox';
const TYPE_SELECT = 'select';
const TYPE_FILE = 'file';
public static $types = [
self::TYPE_TEXT => '短文本',
self::TYPE_TEXTAREA => '长文本',
self::TYPE_RADIO => '横向单选',
self::TYPE_CHECKBOX => '横向多选',
self::TYPE_SELECT => '下拉单选',
self::TYPE_FILE => '文件',
];
public function radio($name, $options, $current = null)
{
$arr = [];
foreach ($options as $value => $label) {
$arr[] = sprintf(
'<label><input type="radio" name="%s" value="%s"%s />%s</label>',
$name, $value, (string)$current === (string)$value ? ' checked' : '', $label
);
}
return implode('', $arr);
}
function buildFieldForm(array $row = [])
{
global $lang_fields;
$trName = tr($lang_fields['col_name'] . '<font color="red">*</font>', '<input type="text" name="name" value="' . ($row['name'] ?? '') . '" style="width: 300px" />&nbsp;&nbsp;仅允许数字、字母、下划线', 1, '', true);
$trLabel = tr($lang_fields['col_label'] . '<font color="red">*</font>', '<input type="text" name="label" value="' . ($row['label'] ?? '') . '" style="width: 300px" />', 1, '', true);
$trType = tr($lang_fields['col_type'] . '<font color="red">*</font>', $this->radio('type', self::$types, $row['type'] ?? null), 1, '', true);
$trRequired = tr($lang_fields['col_required'] . '<font color="red">*</font>', $this->radio('required', ['0' => '否', '1' => '是'], $row['required'] ?? null), 1, '', true);
$trHelp = tr($lang_fields['col_help'], '<textarea name="help" rows="4" cols="80">' . ($row['help'] ?? '') . '</textarea>', 1, '', true);
$trOptions = tr($lang_fields['col_options'], '<textarea name="options" rows="6" cols="80">' . ($row['options'] ?? '') . '</textarea><br/>类型为单选、多选、下拉时必填,一行一个,格式:选项值|选项描述文本', 1, '', true);
$id = $row['id'] ?? 0;
$form = <<<HTML
<div style="width: 940px">
<h1 align="center"><a class="faqlink" href="?action=view&type=">{$lang_fields['text_field']}</a></h1>
<form method="post" action="fields.php?action=submit&type=">
<div>
<table border="1" cellspacing="0" cellpadding="10" width="100%">
<input type="hidden" name="id" value="{$id}"/>
{$trName}
{$trLabel}
{$trType}
{$trRequired}
{$trHelp}
{$trOptions}
</table>
</div>
<div style="text-align: center; margin-top: 10px;">
<input type="submit" value="{$lang_fields['submit_submit']}" />
</div>
</form>
</div>
HTML;
return $form;
}
function buildFieldTable()
{
global $lang_fields;
$sql = 'select * from torrents_custom_fields';
$res = sql_query($sql);
$header = [
'id' => $lang_fields['col_id'],
'name' => $lang_fields['col_name'],
'label' => $lang_fields['col_label'],
'type' => $lang_fields['col_type'],
'required_text' => $lang_fields['col_required'],
'action' => $lang_fields['col_action'],
];
$rows = [];
while ($row = mysql_fetch_assoc($res)) {
$row['required_text'] = $row['required'] ? '是' : '否';
$row['action'] = sprintf(
"<a href=\"javascript:confirm_delete('%s', '%s', '');\">%s</a> | <a href=\"?action=edit&type=&id=%s\">%s</a>",
$row['id'], $lang_fields['js_sure_to_delete_this'], $lang_fields['text_delete'], $row['id'], $lang_fields['text_edit']
);
$rows[] = $row;
}
$table = $this->buildTable($header, $rows);
return $table;
}
public function save($data)
{
$attributes = [];
if (empty($data['name'])) {
throw new \InvalidArgumentException("Name 必须");
}
if (!preg_match('/^\w+$/', $data['name'])) {
throw new \InvalidArgumentException("Name 非法");
}
$attributes['name'] = $data['name'];
if (empty($data['label'])) {
throw new \InvalidArgumentException("显示标签 必须");
}
$attributes['label'] = $data['label'];
if (empty($data['type'])) {
throw new \InvalidArgumentException("类型 必须");
}
if (!isset(self::$types[$data['type']])) {
throw new \InvalidArgumentException("类型 非法");
}
$attributes['type'] = $data['type'];
if (!isset($data['required'])) {
throw new \InvalidArgumentException("不能为空 必须");
}
if (!in_array($data['required'], ["0", "1"], true)) {
throw new \InvalidArgumentException("不能为空 非法");
}
$attributes['required'] = $data['required'];
$attributes['help'] = $data['help'] ?? '';
$attributes['options'] = trim($data['options'] ?? '');
$now = date('Y-m-d H:i:s');
$attributes['updated_at'] = $now;
$table = 'torrents_custom_fields';
if (!empty($data['id'])) {
$result = DB::update($table, $attributes, "id = " . sqlesc($data['id']));
} else {
$attributes['created_at'] = $now;
$result = DB::insert($table, $attributes);
}
return $result;
}
public function buildTable(array $header, array $rows)
{
$table = '<table border="1" cellspacing="0" cellpadding="5" width="100%"><thead><tr>';
foreach ($header as $key => $value) {
$table .= sprintf('<td class="colhead">%s</td>', $value);
}
$table .= '</tr></thead><tbody>';
foreach ($rows as $row) {
$table .= '<tr>';
foreach ($header as $headerKey => $headerValue) {
$table .= sprintf('<td class="colfollow">%s</td>', $row[$headerKey] ?? '');
}
$table .= '</tr>';
}
$table .= '</tbody>';
return $table;
}
}
+69
View File
@@ -0,0 +1,69 @@
<?php
require "../include/bittorrent.php";
dbconn();
require_once(get_langfile_path());
loggedinorreturn();
if (get_user_class() < UC_ADMINISTRATOR) {
permissiondenied();
}
$field = new \Nexus\Field\Field();
function buildTableHead()
{
global $lang_fields;
$head = <<<HEAD
<h1 align="center">{$lang_fields['field_management']} - </h1>
<div>
<span id="item" onclick="dropmenu(this);">
<span style="cursor: pointer;" class="big"><b>{$lang_fields['text_manage']}</b></span>
<div id="itemlist" class="dropmenu" style="display: none">
<ul>
<li><a href="?action=view&type=field">{$lang_fields['text_field']}</a></li>
</ul>
</div>
</span>
<span id="add">
<a href="?action=add&type=" class="big"><b>{$lang_fields['text_add']}</b></a>
</span>
</div>
HEAD;
return $head;
}
$action = $_GET['action'] ?? 'view';
if ($action == 'view') {
stdhead($lang_fields['field_management']." - ".$lang_fields['text_field']);
begin_main_frame();
echo buildTableHead();
echo $field->buildFieldTable();
} elseif ($action == 'add') {
stdhead($lang_fields['field_management']." - ".$lang_fields['text_add']);
begin_main_frame();
echo $field->buildFieldForm();
} elseif ($action == 'submit') {
try {
$result = $field->save($_REQUEST);
redirect('fields.php?action=view&type=');
} catch (\Exception $e) {
stderr($lang_fields['field_management']." - ".$lang_fields['text_field'], $e->getMessage());
}
} elseif ($action == 'edit') {
$id = intval($_GET['id'] ?? 0);
if ($id == 0) {
stderr($lang_fields['field_management'], "invalid id");
}
$sql = "select * from torrents_custom_fields where id = $id";
$res = sql_query($sql);
$row = mysql_fetch_assoc($res);
if (empty($row)) {
stderr('', 'invlaid id');
}
stdhead($lang_fields['field_management']." - ".$lang_fields['text_edit']);
begin_main_frame();
echo $field->buildFieldForm($row);
}
File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 5.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.9 KiB

+1 -1
View File
@@ -343,7 +343,7 @@ if (empty($url) && !empty($ptGenImdbLink)) {
}
$ret = sql_query("INSERT INTO torrents (filename, owner, visible, anonymous, name, size, numfiles, type, url, small_descr, descr, ori_descr, category, source, medium, codec, audiocodec, standard, processing, team, save_as, sp_state, added, last_action, nfo, info_hash, pt_gen, tags) VALUES (".sqlesc($fname).", ".sqlesc($CURUSER["id"]).", 'yes', ".sqlesc($anonymous).", ".sqlesc($torrent).", ".sqlesc($totallen).", ".count($filelist).", ".sqlesc($type).", ".sqlesc($url).", ".sqlesc($small_descr).", ".sqlesc($descr).", ".sqlesc($descr).", ".sqlesc($catid).", ".sqlesc($sourceid).", ".sqlesc($mediumid).", ".sqlesc($codecid).", ".sqlesc($audiocodecid).", ".sqlesc($standardid).", ".sqlesc($processingid).", ".sqlesc($teamid).", ".sqlesc($dname).", ".sqlesc($sp_state) .
", " . sqlesc(date("Y-m-d H:i:s")) . ", " . sqlesc(date("Y-m-d H:i:s")) . ", ".sqlesc($nfo).", " . sqlesc($infohash). ", " . sqlesc(json_encode($postPtGen)) . ", " . array_sum($_POST['tags']) . ")");
", " . sqlesc(date("Y-m-d H:i:s")) . ", " . sqlesc(date("Y-m-d H:i:s")) . ", ".sqlesc($nfo).", " . sqlesc($infohash). ", " . sqlesc(json_encode($postPtGen)) . ", " . array_sum($_POST['tags'] ?? []) . ")");
if (!$ret) {
if (mysql_errno() == 1062)
bark($lang_takeupload['std_torrent_existed']);