- URL 하드코딩 → .env APP_URL 기반 동적 URL로 변경 - DB 연결 하드코딩 → .env 기반으로 변경 - MySQL strict mode DATE 오류 수정
105 lines
4.5 KiB
PHP
105 lines
4.5 KiB
PHP
<?php
|
|
require_once($_SERVER['DOCUMENT_ROOT'] . "/session.php");
|
|
$tablename = isset($_REQUEST['tablename']) ? $_REQUEST['tablename'] : 'account_plan';
|
|
$mode = isset($_REQUEST['mode']) ? $_REQUEST['mode'] : '';
|
|
|
|
header("Content-Type: application/json"); // Use JSON content type
|
|
|
|
require_once($_SERVER['DOCUMENT_ROOT'] . "/lib/mydb.php");
|
|
$pdo = db_connect();
|
|
|
|
include "_request.php";
|
|
|
|
// Construct the searchtag value
|
|
$searchtag = $registDate . ' ' . $inoutsep . ' ' . $content . ' ' . $amount . $content_detail ;
|
|
|
|
try {
|
|
if ($mode == "update") {
|
|
$update_log = date("Y-m-d H:i:s") . " - " . $_SESSION["name"] . " " . $update_log . "
";
|
|
$pdo->beginTransaction();
|
|
// Prepare the SQL query for updating the account information
|
|
$sql = "UPDATE {$DB}.{$tablename} SET ";
|
|
$sql .= "registDate = ?, inoutsep = ?, content = ?, content_detail = ?, amount = ?, memo = ?, searchtag = ?, update_log = ?, first_writer = ?, bankbook = ?, secondordnum = ?, ForeDate = ?, approvalRequest = ?, eworksNum = ?, workDone = ? ";
|
|
$sql .= "WHERE num = ? LIMIT 1"; // Update only one record matching the 'num'
|
|
|
|
$stmh = $pdo->prepare($sql);
|
|
|
|
// Bind the variables to the prepared statement as parameters
|
|
$stmh->bindValue(1, $registDate, PDO::PARAM_STR);
|
|
$stmh->bindValue(2, $inoutsep, PDO::PARAM_STR);
|
|
$stmh->bindValue(3, $content, PDO::PARAM_STR);
|
|
$stmh->bindValue(4, $content_detail, PDO::PARAM_STR);
|
|
$stmh->bindValue(5, str_replace(',', '', $amount), PDO::PARAM_STR); // 숫자안에 콤마제거후 저장
|
|
$stmh->bindValue(6, $memo, PDO::PARAM_STR);
|
|
$stmh->bindValue(7, $searchtag, PDO::PARAM_STR);
|
|
$stmh->bindValue(8, $update_log, PDO::PARAM_STR);
|
|
$stmh->bindValue(9, $first_writer, PDO::PARAM_STR);
|
|
$stmh->bindValue(10, $bankbook, PDO::PARAM_STR);
|
|
$stmh->bindValue(11, $secondordnum, PDO::PARAM_STR);
|
|
$stmh->bindValue(12, $ForeDate, PDO::PARAM_STR);
|
|
$stmh->bindValue(13, $approvalRequest, PDO::PARAM_STR);
|
|
$stmh->bindValue(14, $eworksNum, PDO::PARAM_STR);
|
|
$stmh->bindValue(15, $workDone, PDO::PARAM_STR);
|
|
$stmh->bindValue(16, $num, PDO::PARAM_INT);
|
|
|
|
// Execute the statement
|
|
$stmh->execute();
|
|
$pdo->commit();
|
|
}
|
|
|
|
if ($mode == "insert" || $mode == '' || $mode == null) {
|
|
$first_writer = date("Y-m-d H:i:s") . " - " . $_SESSION["name"] ;
|
|
$update_log = date("Y-m-d H:i:s") . " - " . $_SESSION["name"] . " " . $update_log . "
";
|
|
// Data insertion
|
|
$pdo->beginTransaction();
|
|
|
|
// Updated columns and values to be inserted
|
|
$sql = "INSERT INTO {$DB}.{$tablename} (";
|
|
$sql .= "registDate, inoutsep, content, content_detail, amount, memo, searchtag, update_log, first_writer, bankbook, secondordnum, ForeDate, approvalRequest, eworksNum, workDone ";
|
|
$sql .= ") VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
|
|
|
|
$stmh = $pdo->prepare($sql);
|
|
|
|
$stmh->bindValue(1, $registDate, PDO::PARAM_STR);
|
|
$stmh->bindValue(2, $inoutsep, PDO::PARAM_STR);
|
|
$stmh->bindValue(3, $content, PDO::PARAM_STR);
|
|
$stmh->bindValue(4, $content_detail, PDO::PARAM_STR);
|
|
$stmh->bindValue(5, str_replace(',', '', $amount), PDO::PARAM_STR);
|
|
$stmh->bindValue(6, $memo, PDO::PARAM_STR);
|
|
$stmh->bindValue(7, $searchtag, PDO::PARAM_STR);
|
|
$stmh->bindValue(8, $update_log, PDO::PARAM_STR);
|
|
$stmh->bindValue(9, $first_writer, PDO::PARAM_STR);
|
|
$stmh->bindValue(10, $bankbook, PDO::PARAM_STR);
|
|
$stmh->bindValue(11, $secondordnum, PDO::PARAM_STR);
|
|
$stmh->bindValue(12, $ForeDate, PDO::PARAM_STR);
|
|
$stmh->bindValue(13, $approvalRequest, PDO::PARAM_STR);
|
|
$stmh->bindValue(14, $eworksNum, PDO::PARAM_STR);
|
|
$stmh->bindValue(15, $workDone, PDO::PARAM_STR);
|
|
|
|
// Execute the statement
|
|
$stmh->execute();
|
|
$pdo->commit();
|
|
}
|
|
|
|
if ($mode == "delete") { // Data deletion
|
|
$pdo->beginTransaction();
|
|
$sql = "UPDATE " . $tablename . " SET is_deleted=1 WHERE num = ?";
|
|
$stmh = $pdo->prepare($sql);
|
|
$stmh->bindValue(1, $num, PDO::PARAM_INT);
|
|
$stmh->execute();
|
|
$pdo->commit();
|
|
}
|
|
|
|
$data = [
|
|
'num' => $num,
|
|
'mode' => $mode
|
|
];
|
|
|
|
echo json_encode($data, JSON_UNESCAPED_UNICODE);
|
|
|
|
} catch (PDOException $Exception) {
|
|
$pdo->rollBack();
|
|
echo json_encode(['error' => $Exception->getMessage()], JSON_UNESCAPED_UNICODE);
|
|
}
|
|
|
|
?>
|