"use strict"; /* * ATTENTION: An "eval-source-map" devtool has been used. * This devtool is neither made for production nor for readable output files. * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) * or disable the default devtool with "devtool: false". * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). */ (() => { var exports = {}; exports.id = "app/api/contracts/[id]/route"; exports.ids = ["app/api/contracts/[id]/route"]; exports.modules = { /***/ "next/dist/compiled/next-server/app-page.runtime.dev.js": /*!*************************************************************************!*\ !*** external "next/dist/compiled/next-server/app-page.runtime.dev.js" ***! \*************************************************************************/ /***/ ((module) => { module.exports = require("next/dist/compiled/next-server/app-page.runtime.dev.js"); /***/ }), /***/ "next/dist/compiled/next-server/app-route.runtime.dev.js": /*!**************************************************************************!*\ !*** external "next/dist/compiled/next-server/app-route.runtime.dev.js" ***! \**************************************************************************/ /***/ ((module) => { module.exports = require("next/dist/compiled/next-server/app-route.runtime.dev.js"); /***/ }), /***/ "buffer": /*!*************************!*\ !*** external "buffer" ***! \*************************/ /***/ ((module) => { module.exports = require("buffer"); /***/ }), /***/ "crypto": /*!*************************!*\ !*** external "crypto" ***! \*************************/ /***/ ((module) => { module.exports = require("crypto"); /***/ }), /***/ "fs": /*!*********************!*\ !*** external "fs" ***! \*********************/ /***/ ((module) => { module.exports = require("fs"); /***/ }), /***/ "path": /*!***********************!*\ !*** external "path" ***! \***********************/ /***/ ((module) => { module.exports = require("path"); /***/ }), /***/ "sql.js": /*!*************************!*\ !*** external "sql.js" ***! \*************************/ /***/ ((module) => { module.exports = require("sql.js"); /***/ }), /***/ "stream": /*!*************************!*\ !*** external "stream" ***! \*************************/ /***/ ((module) => { module.exports = require("stream"); /***/ }), /***/ "util": /*!***********************!*\ !*** external "util" ***! \***********************/ /***/ ((module) => { module.exports = require("util"); /***/ }), /***/ "(rsc)/./node_modules/next/dist/build/webpack/loaders/next-app-loader.js?name=app%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&page=%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute.js&appDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F%2Fsrc%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D!": /*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\ !*** ./node_modules/next/dist/build/webpack/loaders/next-app-loader.js?name=app%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&page=%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute.js&appDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F%2Fsrc%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D! ***! \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ originalPathname: () => (/* binding */ originalPathname),\n/* harmony export */ patchFetch: () => (/* binding */ patchFetch),\n/* harmony export */ requestAsyncStorage: () => (/* binding */ requestAsyncStorage),\n/* harmony export */ routeModule: () => (/* binding */ routeModule),\n/* harmony export */ serverHooks: () => (/* binding */ serverHooks),\n/* harmony export */ staticGenerationAsyncStorage: () => (/* binding */ staticGenerationAsyncStorage)\n/* harmony export */ });\n/* harmony import */ var next_dist_server_future_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! next/dist/server/future/route-modules/app-route/module.compiled */ \"(rsc)/./node_modules/next/dist/server/future/route-modules/app-route/module.compiled.js\");\n/* harmony import */ var next_dist_server_future_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(next_dist_server_future_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var next_dist_server_future_route_kind__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! next/dist/server/future/route-kind */ \"(rsc)/./node_modules/next/dist/server/future/route-kind.js\");\n/* harmony import */ var next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! next/dist/server/lib/patch-fetch */ \"(rsc)/./node_modules/next/dist/server/lib/patch-fetch.js\");\n/* harmony import */ var next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _Users_gandanxiangzhao_Desktop_src_app_api_contracts_id_route_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./src/app/api/contracts/[id]/route.js */ \"(rsc)/./src/app/api/contracts/[id]/route.js\");\n\n\n\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new next_dist_server_future_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0__.AppRouteRouteModule({\n definition: {\n kind: next_dist_server_future_route_kind__WEBPACK_IMPORTED_MODULE_1__.RouteKind.APP_ROUTE,\n page: \"/api/contracts/[id]/route\",\n pathname: \"/api/contracts/[id]\",\n filename: \"route\",\n bundlePath: \"app/api/contracts/[id]/route\"\n },\n resolvedPagePath: \"/Users/gandanxiangzhao/Desktop/合同流转审批系统/src/app/api/contracts/[id]/route.js\",\n nextConfigOutput,\n userland: _Users_gandanxiangzhao_Desktop_src_app_api_contracts_id_route_js__WEBPACK_IMPORTED_MODULE_3__\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { requestAsyncStorage, staticGenerationAsyncStorage, serverHooks } = routeModule;\nconst originalPathname = \"/api/contracts/[id]/route\";\nfunction patchFetch() {\n return (0,next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2__.patchFetch)({\n serverHooks,\n staticGenerationAsyncStorage\n });\n}\n\n\n//# sourceMappingURL=app-route.js.map//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvbmV4dC9kaXN0L2J1aWxkL3dlYnBhY2svbG9hZGVycy9uZXh0LWFwcC1sb2FkZXIuanM/bmFtZT1hcHAlMkZhcGklMkZjb250cmFjdHMlMkYlNUJpZCU1RCUyRnJvdXRlJnBhZ2U9JTJGYXBpJTJGY29udHJhY3RzJTJGJTVCaWQlNUQlMkZyb3V0ZSZhcHBQYXRocz0mcGFnZVBhdGg9cHJpdmF0ZS1uZXh0LWFwcC1kaXIlMkZhcGklMkZjb250cmFjdHMlMkYlNUJpZCU1RCUyRnJvdXRlLmpzJmFwcERpcj0lMkZVc2VycyUyRmdhbmRhbnhpYW5nemhhbyUyRkRlc2t0b3AlMkYlRTUlOTAlODglRTUlOTAlOEMlRTYlQjUlODElRTglQkQlQUMlRTUlQUUlQTElRTYlODklQjklRTclQjMlQkIlRTclQkIlOUYlMkZzcmMlMkZhcHAmcGFnZUV4dGVuc2lvbnM9dHN4JnBhZ2VFeHRlbnNpb25zPXRzJnBhZ2VFeHRlbnNpb25zPWpzeCZwYWdlRXh0ZW5zaW9ucz1qcyZyb290RGlyPSUyRlVzZXJzJTJGZ2FuZGFueGlhbmd6aGFvJTJGRGVza3RvcCUyRiVFNSU5MCU4OCVFNSU5MCU4QyVFNiVCNSU4MSVFOCVCRCVBQyVFNSVBRSVBMSVFNiU4OSVCOSVFNyVCMyVCQiVFNyVCQiU5RiZpc0Rldj10cnVlJnRzY29uZmlnUGF0aD10c2NvbmZpZy5qc29uJmJhc2VQYXRoPSZhc3NldFByZWZpeD0mbmV4dENvbmZpZ091dHB1dD0mcHJlZmVycmVkUmVnaW9uPSZtaWRkbGV3YXJlQ29uZmlnPWUzMCUzRCEiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQXNHO0FBQ3ZDO0FBQ2M7QUFDMkI7QUFDeEc7QUFDQTtBQUNBO0FBQ0Esd0JBQXdCLGdIQUFtQjtBQUMzQztBQUNBLGNBQWMseUVBQVM7QUFDdkI7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLFlBQVk7QUFDWixDQUFDO0FBQ0Q7QUFDQTtBQUNBO0FBQ0EsUUFBUSxpRUFBaUU7QUFDekU7QUFDQTtBQUNBLFdBQVcsNEVBQVc7QUFDdEI7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUN1SDs7QUFFdkgiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9jb250cmFjdC1hcHByb3ZhbC1zeXN0ZW0vP2Y5ZTQiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXBwUm91dGVSb3V0ZU1vZHVsZSB9IGZyb20gXCJuZXh0L2Rpc3Qvc2VydmVyL2Z1dHVyZS9yb3V0ZS1tb2R1bGVzL2FwcC1yb3V0ZS9tb2R1bGUuY29tcGlsZWRcIjtcbmltcG9ydCB7IFJvdXRlS2luZCB9IGZyb20gXCJuZXh0L2Rpc3Qvc2VydmVyL2Z1dHVyZS9yb3V0ZS1raW5kXCI7XG5pbXBvcnQgeyBwYXRjaEZldGNoIGFzIF9wYXRjaEZldGNoIH0gZnJvbSBcIm5leHQvZGlzdC9zZXJ2ZXIvbGliL3BhdGNoLWZldGNoXCI7XG5pbXBvcnQgKiBhcyB1c2VybGFuZCBmcm9tIFwiL1VzZXJzL2dhbmRhbnhpYW5nemhhby9EZXNrdG9wL+WQiOWQjOa1gei9rOWuoeaJueezu+e7ny9zcmMvYXBwL2FwaS9jb250cmFjdHMvW2lkXS9yb3V0ZS5qc1wiO1xuLy8gV2UgaW5qZWN0IHRoZSBuZXh0Q29uZmlnT3V0cHV0IGhlcmUgc28gdGhhdCB3ZSBjYW4gdXNlIHRoZW0gaW4gdGhlIHJvdXRlXG4vLyBtb2R1bGUuXG5jb25zdCBuZXh0Q29uZmlnT3V0cHV0ID0gXCJcIlxuY29uc3Qgcm91dGVNb2R1bGUgPSBuZXcgQXBwUm91dGVSb3V0ZU1vZHVsZSh7XG4gICAgZGVmaW5pdGlvbjoge1xuICAgICAgICBraW5kOiBSb3V0ZUtpbmQuQVBQX1JPVVRFLFxuICAgICAgICBwYWdlOiBcIi9hcGkvY29udHJhY3RzL1tpZF0vcm91dGVcIixcbiAgICAgICAgcGF0aG5hbWU6IFwiL2FwaS9jb250cmFjdHMvW2lkXVwiLFxuICAgICAgICBmaWxlbmFtZTogXCJyb3V0ZVwiLFxuICAgICAgICBidW5kbGVQYXRoOiBcImFwcC9hcGkvY29udHJhY3RzL1tpZF0vcm91dGVcIlxuICAgIH0sXG4gICAgcmVzb2x2ZWRQYWdlUGF0aDogXCIvVXNlcnMvZ2FuZGFueGlhbmd6aGFvL0Rlc2t0b3Av5ZCI5ZCM5rWB6L2s5a6h5om557O757ufL3NyYy9hcHAvYXBpL2NvbnRyYWN0cy9baWRdL3JvdXRlLmpzXCIsXG4gICAgbmV4dENvbmZpZ091dHB1dCxcbiAgICB1c2VybGFuZFxufSk7XG4vLyBQdWxsIG91dCB0aGUgZXhwb3J0cyB0aGF0IHdlIG5lZWQgdG8gZXhwb3NlIGZyb20gdGhlIG1vZHVsZS4gVGhpcyBzaG91bGRcbi8vIGJlIGVsaW1pbmF0ZWQgd2hlbiB3ZSd2ZSBtb3ZlZCB0aGUgb3RoZXIgcm91dGVzIHRvIHRoZSBuZXcgZm9ybWF0LiBUaGVzZVxuLy8gYXJlIHVzZWQgdG8gaG9vayBpbnRvIHRoZSByb3V0ZS5cbmNvbnN0IHsgcmVxdWVzdEFzeW5jU3RvcmFnZSwgc3RhdGljR2VuZXJhdGlvbkFzeW5jU3RvcmFnZSwgc2VydmVySG9va3MgfSA9IHJvdXRlTW9kdWxlO1xuY29uc3Qgb3JpZ2luYWxQYXRobmFtZSA9IFwiL2FwaS9jb250cmFjdHMvW2lkXS9yb3V0ZVwiO1xuZnVuY3Rpb24gcGF0Y2hGZXRjaCgpIHtcbiAgICByZXR1cm4gX3BhdGNoRmV0Y2goe1xuICAgICAgICBzZXJ2ZXJIb29rcyxcbiAgICAgICAgc3RhdGljR2VuZXJhdGlvbkFzeW5jU3RvcmFnZVxuICAgIH0pO1xufVxuZXhwb3J0IHsgcm91dGVNb2R1bGUsIHJlcXVlc3RBc3luY1N0b3JhZ2UsIHN0YXRpY0dlbmVyYXRpb25Bc3luY1N0b3JhZ2UsIHNlcnZlckhvb2tzLCBvcmlnaW5hbFBhdGhuYW1lLCBwYXRjaEZldGNoLCAgfTtcblxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YXBwLXJvdXRlLmpzLm1hcCJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/next/dist/build/webpack/loaders/next-app-loader.js?name=app%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&page=%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute.js&appDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F%2Fsrc%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D!\n"); /***/ }), /***/ "(rsc)/./src/app/api/contracts/[id]/route.js": /*!*********************************************!*\ !*** ./src/app/api/contracts/[id]/route.js ***! \*********************************************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ GET: () => (/* binding */ GET),\n/* harmony export */ PUT: () => (/* binding */ PUT),\n/* harmony export */ dynamic: () => (/* binding */ dynamic)\n/* harmony export */ });\n/* harmony import */ var _lib_db__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @/lib/db */ \"(rsc)/./src/lib/db.js\");\n/* harmony import */ var _lib_auth__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @/lib/auth */ \"(rsc)/./src/lib/auth.js\");\nconst dynamic = \"force-dynamic\";\n\n\nfunction buildOpinions(contract) {\n const opinions = [];\n if (contract.supervisor_approved === 1 || contract.supervisor_approved === 0) {\n opinions.push({\n approver_name: contract.supervisor_name || \"主管\",\n role: \"supervisor\",\n created_at: contract.supervisor_time,\n approved: contract.supervisor_approved === 1,\n opinion: contract.supervisor_opinion\n });\n }\n if (contract.finance_approved === 1 || contract.finance_approved === 0) {\n opinions.push({\n approver_name: contract.finance_name || \"财务\",\n role: \"finance\",\n created_at: contract.finance_time,\n approved: contract.finance_approved === 1,\n opinion: contract.finance_opinion\n });\n }\n if (contract.secretary_approved === 1 || contract.secretary_approved === 0) {\n opinions.push({\n approver_name: contract.secretary_name || \"秘书长\",\n role: \"secretary\",\n created_at: contract.secretary_time,\n approved: contract.secretary_approved === 1,\n opinion: contract.secretary_opinion\n });\n }\n return opinions;\n}\n// GET /api/contracts/[id] - 获取单个合同详情(含附件)\nasync function GET(request, { params }) {\n try {\n const user = (0,_lib_auth__WEBPACK_IMPORTED_MODULE_1__.getUserFromRequest)(request);\n if (!user) return (0,_lib_auth__WEBPACK_IMPORTED_MODULE_1__.unauthorizedResponse)();\n const { id } = await params;\n const db = await (0,_lib_db__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\n const contract = db.prepare(\"SELECT * FROM contracts WHERE id = ?\").get(id);\n if (!contract) {\n return Response.json({\n error: \"合同不存在\"\n }, {\n status: 404\n });\n }\n // 获取附件\n const attachments = db.prepare(\"SELECT * FROM contract_attachments WHERE contract_id = ? ORDER BY created_at DESC\").all(id);\n return Response.json({\n ...contract,\n attachments,\n opinions: buildOpinions(contract)\n });\n } catch (error) {\n console.error(\"获取合同详情失败:\", error);\n return Response.json({\n error: \"服务器内部错误\"\n }, {\n status: 500\n });\n }\n}\n// PUT /api/contracts/[id] - 更新合同(仅创建者可更新,且合同状态为 rejected 时才能更新)\nasync function PUT(request, { params }) {\n try {\n const user = (0,_lib_auth__WEBPACK_IMPORTED_MODULE_1__.getUserFromRequest)(request);\n if (!user) return (0,_lib_auth__WEBPACK_IMPORTED_MODULE_1__.unauthorizedResponse)();\n const { id } = await params;\n const db = await (0,_lib_db__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\n const contract = db.prepare(\"SELECT * FROM contracts WHERE id = ?\").get(id);\n if (!contract) {\n return Response.json({\n error: \"合同不存在\"\n }, {\n status: 404\n });\n }\n // 只有创建者可以更新\n if (contract.creator_id !== user.id) {\n return Response.json({\n error: \"只有合同创建者可以修改\"\n }, {\n status: 403\n });\n }\n // 只有被驳回的合同才能修改\n if (contract.status !== \"rejected\") {\n return Response.json({\n error: \"只有被驳回的合同才能修改\"\n }, {\n status: 400\n });\n }\n const body = await request.json();\n const { project_name, partner_id, contract_content, contract_years, contract_amount, estimated_profit, payment_type, sign_date, project_leader } = body;\n // 查找合作单位名称\n let partner_name = contract.partner_name;\n if (partner_id && partner_id !== contract.partner_id) {\n const partner = db.prepare(\"SELECT name FROM partners WHERE id = ? AND is_deleted = 0\").get(partner_id);\n if (!partner) {\n return Response.json({\n error: \"合作单位不存在\"\n }, {\n status: 400\n });\n }\n partner_name = partner.name;\n }\n // 更新合同并重置状态和审批字段\n db.prepare(`\n UPDATE contracts SET\n project_name = ?,\n partner_id = ?,\n partner_name = ?,\n contract_content = ?,\n contract_years = ?,\n contract_amount = ?,\n estimated_profit = ?,\n payment_type = ?,\n sign_date = ?,\n project_leader = ?,\n status = 'pending_supervisor',\n supervisor_opinion = NULL,\n supervisor_approved = NULL,\n supervisor_id = NULL,\n supervisor_name = NULL,\n supervisor_time = NULL,\n finance_opinion = NULL,\n finance_approved = NULL,\n finance_id = NULL,\n finance_name = NULL,\n finance_time = NULL,\n secretary_opinion = NULL,\n secretary_approved = NULL,\n secretary_id = NULL,\n secretary_name = NULL,\n secretary_time = NULL,\n reject_reason = NULL,\n updated_at = CURRENT_TIMESTAMP\n WHERE id = ?\n `).run(project_name || contract.project_name, partner_id || contract.partner_id, partner_name, contract_content !== undefined ? contract_content : contract.contract_content, contract_years !== undefined ? contract_years : contract.contract_years, contract_amount !== undefined ? contract_amount : contract.contract_amount, estimated_profit !== undefined ? estimated_profit : contract.estimated_profit, payment_type || contract.payment_type, sign_date !== undefined ? sign_date : contract.sign_date, project_leader !== undefined ? project_leader : contract.project_leader, id);\n const updated = db.prepare(\"SELECT * FROM contracts WHERE id = ?\").get(id);\n // 获取附件\n const attachments = db.prepare(\"SELECT * FROM contract_attachments WHERE contract_id = ? ORDER BY created_at DESC\").all(id);\n return Response.json({\n ...updated,\n attachments,\n opinions: buildOpinions(updated)\n });\n } catch (error) {\n console.error(\"更新合同失败:\", error);\n return Response.json({\n error: \"服务器内部错误\"\n }, {\n status: 500\n });\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9zcmMvYXBwL2FwaS9jb250cmFjdHMvW2lkXS9yb3V0ZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFPLE1BQU1BLFVBQVUsZ0JBQWdCO0FBQ1Y7QUFDeUM7QUFFdEUsU0FBU0ksY0FBY0MsUUFBUTtJQUM3QixNQUFNQyxXQUFXLEVBQUU7SUFDbkIsSUFBSUQsU0FBU0UsbUJBQW1CLEtBQUssS0FBS0YsU0FBU0UsbUJBQW1CLEtBQUssR0FBRztRQUM1RUQsU0FBU0UsSUFBSSxDQUFDO1lBQ1pDLGVBQWVKLFNBQVNLLGVBQWUsSUFBSTtZQUMzQ0MsTUFBTTtZQUNOQyxZQUFZUCxTQUFTUSxlQUFlO1lBQ3BDQyxVQUFVVCxTQUFTRSxtQkFBbUIsS0FBSztZQUMzQ1EsU0FBU1YsU0FBU1csa0JBQWtCO1FBQ3RDO0lBQ0Y7SUFDQSxJQUFJWCxTQUFTWSxnQkFBZ0IsS0FBSyxLQUFLWixTQUFTWSxnQkFBZ0IsS0FBSyxHQUFHO1FBQ3RFWCxTQUFTRSxJQUFJLENBQUM7WUFDWkMsZUFBZUosU0FBU2EsWUFBWSxJQUFJO1lBQ3hDUCxNQUFNO1lBQ05DLFlBQVlQLFNBQVNjLFlBQVk7WUFDakNMLFVBQVVULFNBQVNZLGdCQUFnQixLQUFLO1lBQ3hDRixTQUFTVixTQUFTZSxlQUFlO1FBQ25DO0lBQ0Y7SUFDQSxJQUFJZixTQUFTZ0Isa0JBQWtCLEtBQUssS0FBS2hCLFNBQVNnQixrQkFBa0IsS0FBSyxHQUFHO1FBQzFFZixTQUFTRSxJQUFJLENBQUM7WUFDWkMsZUFBZUosU0FBU2lCLGNBQWMsSUFBSTtZQUMxQ1gsTUFBTTtZQUNOQyxZQUFZUCxTQUFTa0IsY0FBYztZQUNuQ1QsVUFBVVQsU0FBU2dCLGtCQUFrQixLQUFLO1lBQzFDTixTQUFTVixTQUFTbUIsaUJBQWlCO1FBQ3JDO0lBQ0Y7SUFDQSxPQUFPbEI7QUFDVDtBQUVBLDBDQUEwQztBQUNuQyxlQUFlbUIsSUFBSUMsT0FBTyxFQUFFLEVBQUVDLE1BQU0sRUFBRTtJQUMzQyxJQUFJO1FBQ0YsTUFB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QUFZVixpQkFBaUJ6QyxTQUFTeUMsY0FBYyxFQUN2RUMsb0JBQW9CUyxZQUFZVCxrQkFBa0IxQyxTQUFTMEMsZUFBZSxFQUMxRUMscUJBQXFCUSxZQUFZUixtQkFBbUIzQyxTQUFTMkMsZ0JBQWdCLEVBQzdFQyxnQkFBZ0I1QyxTQUFTNEMsWUFBWSxFQUNyQ0MsY0FBY00sWUFBWU4sWUFBWTdDLFNBQVM2QyxTQUFTLEVBQ3hEQyxtQkFBbUJLLFlBQVlMLGlCQUFpQjlDLFNBQVM4QyxjQUFjLEVBQ3ZFdEI7UUFHRixNQUFNNEIsVUFBVTNCLEdBQUdDLE9BQU8sQ0FBQyx3Q0FBd0NDLEdBQUcsQ0FBQ0g7UUFFdkUsT0FBTztRQUNQLE1BQU1RLGNBQWNQLEdBQUdDLE9BQU8sQ0FDNUIscUZBQ0FPLEdBQUcsQ0FBQ1Q7UUFFTixPQUFPSSxTQUFTQyxJQUFJLENBQUM7WUFDbkIsR0FBR3VCLE9BQU87WUFDVnBCO1lBQ0EvQixVQUFVRixjQUFjcUQ7UUFDMUI7SUFDRixFQUFFLE9BQU90QixPQUFPO1FBQ2RJLFFBQVFKLEtBQUssQ0FBQyxXQUFXQTtRQUN6QixPQUFPRixTQUFTQyxJQUFJLENBQ2xCO1lBQUVDLE9BQU87UUFBVSxHQUNuQjtZQUFFQyxRQUFRO1FBQUk7SUFFbEI7QUFDRiIsInNvdXJjZXMiOlsid2VicGFjazovL2NvbnRyYWN0LWFwcHJvdmFsLXN5c3RlbS8uL3NyYy9hcHAvYXBpL2NvbnRyYWN0cy9baWRdL3JvdXRlLmpzPzdiNjYiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGR5bmFtaWMgPSBcImZvcmNlLWR5bmFtaWNcIjtcbmltcG9ydCBnZXREYiBmcm9tICdAL2xpYi9kYic7XG5pbXBvcnQgeyBnZXRVc2VyRnJvbVJlcXVlc3QsIHVuYXV0aG9yaXplZFJlc3BvbnNlIH0gZnJvbSAnQC9saWIvYXV0aCc7XG5cbmZ1bmN0aW9uIGJ1aWxkT3BpbmlvbnMoY29udHJhY3QpIHtcbiAgY29uc3Qgb3BpbmlvbnMgPSBbXTtcbiAgaWYgKGNvbnRyYWN0LnN1cGVydmlzb3JfYXBwcm92ZWQgPT09IDEgfHwgY29udHJhY3Quc3VwZXJ2aXNvcl9hcHByb3ZlZCA9PT0gMCkge1xuICAgIG9waW5pb25zLnB1c2goe1xuICAgICAgYXBwcm92ZXJfbmFtZTogY29udHJhY3Quc3VwZXJ2aXNvcl9uYW1lIHx8ICfkuLvnrqEnLFxuICAgICAgcm9sZTogJ3N1cGVydmlzb3InLFxuICAgICAgY3JlYXRlZF9hdDogY29udHJhY3Quc3VwZXJ2aXNvcl90aW1lLFxuICAgICAgYXBwcm92ZWQ6IGNvbnRyYWN0LnN1cGVydmlzb3JfYXBwcm92ZWQgPT09IDEsXG4gICAgICBvcGluaW9uOiBjb250cmFjdC5zdXBlcnZpc29yX29waW5pb25cbiAgICB9KTtcbiAgfVxuICBpZiAoY29udHJhY3QuZmluYW5jZV9hcHByb3ZlZCA9PT0gMSB8fCBjb250cmFjdC5maW5hbmNlX2FwcHJvdmVkID09PSAwKSB7XG4gICAgb3BpbmlvbnMucHVzaCh7XG4gICAgICBhcHByb3Zlcl9uYW1lOiBjb250cmFjdC5maW5hbmNlX25hbWUgfHwgJ+i0ouWKoScsXG4gICAgICByb2xlOiAnZmluYW5jZScsXG4gICAgICBjcmVhdGVkX2F0OiBjb250cmFjdC5maW5hbmNlX3RpbWUsXG4gICAgICBhcHByb3ZlZDogY29udHJhY3QuZmluYW5jZV9hcHByb3ZlZCA9PT0gMSxcbiAgICAgIG9waW5pb246IGNvbnRyYWN0LmZpbmFuY2Vfb3BpbmlvblxuICAgIH0pO1xuICB9XG4gIGlmIChjb250cmFjdC5zZWNyZXRhcnlfYXBwcm92ZWQgPT09IDEgfHwgY29udHJhY3Quc2VjcmV0YXJ5X2FwcHJvdmVkID09PSAwKSB7XG4gICAgb3BpbmlvbnMucHVzaCh7XG4gICAgICBhcHByb3Zlcl9uYW1lOiBjb250cmFjdC5zZWNyZXRhcnlfbmFtZSB8fCAn56eY5Lmm6ZW/JyxcbiAgICAgIHJvbGU6ICdzZWNyZXRhcnknLFxuICAgICAgY3JlYXRlZF9hdDogY29udHJhY3Quc2VjcmV0YXJ5X3RpbWUsXG4gICAgICBhcHByb3ZlZDogY29udHJhY3Quc2VjcmV0YXJ5X2FwcHJvdmVkID09PSAxLFxuICAgICAgb3BpbmlvbjogY29udHJhY3Quc2VjcmV0YXJ5X29waW5pb25cbiAgICB9KTtcbiAgfVxuICByZXR1cm4gb3BpbmlvbnM7XG59XG5cbi8vIEdFVCAvYXBpL2NvbnRyYWN0cy9baWRdIC0g6I635Y+W5Y2V5Liq5ZCI5ZCM6K+m5oOF77yI5ZCr6ZmE5Lu277yJXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gR0VUKHJlcXVlc3QsIHsgcGFyYW1zIH0pIHtcbiAgdHJ5IHtcbiAgICBjb25zdCB1c2VyID0gZ2V0VXNlckZyb21SZXF1ZXN0KHJlcXVlc3QpO1xuICAgIGlmICghdXNlcikgcmV0dXJuIHVuYXV0aG9yaXplZFJlc3BvbnNlKCk7XG5cbiAgICBjb25zdCB7IGlkIH0gPSBhd2FpdCBwYXJhbXM7XG4gICAgY29uc3QgZGIgPSBhd2FpdCBnZXREYigpO1xuXG4gICAgY29uc3QgY29udHJhY3QgPSBkYi5wcmVwYXJlKCdTRUxFQ1QgKiBGUk9NIGNvbnRyYWN0cyBXSEVSRSBpZCA9ID8nKS5nZXQoaWQpO1xuICAgIGlmICghY29udHJhY3QpIHtcbiAgICAgIHJldHVybiBSZXNwb25zZS5qc29uKFxuICAgICAgICB7IGVycm9yOiAn5ZCI5ZCM5LiN5a2Y5ZyoJyB9LFxuICAgICAgICB7IHN0YXR1czogNDA0IH1cbiAgICAgICk7XG4gICAgfVxuXG4gICAgLy8g6I635Y+W6ZmE5Lu2XG4gICAgY29uc3QgYXR0YWNobWVudHMgPSBkYi5wcmVwYXJlKFxuICAgICAgJ1NFTEVDVCAqIEZST00gY29udHJhY3RfYXR0YWNobWVudHMgV0hFUkUgY29udHJhY3RfaWQgPSA/IE9SREVSIEJZIGNyZWF0ZWRfYXQgREVTQydcbiAgICApLmFsbChpZCk7XG5cbiAgICByZXR1cm4gUmVzcG9uc2UuanNvbih7XG4gICAgICAuLi5jb250cmFjdCxcbiAgICAgIGF0dGFjaG1lbnRzLFxuICAgICAgb3BpbmlvbnM6IGJ1aWxkT3BpbmlvbnMoY29udHJhY3QpLFxuICAgIH0pO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoJ+iOt+WPluWQiOWQjOivpuaDheWksei0pTonLCBlcnJvcik7XG4gICAgcmV0dXJuIFJlc3BvbnNlLmpzb24oXG4gICAgICB7IGVycm9yOiAn5pyN5Yqh5Zmo5YaF6YOo6ZSZ6K+vJyB9LFxuICAgICAgeyBzdGF0dXM6IDUwMCB9XG4gICAgKTtcbiAgfVxufVxuXG4vLyBQVVQgL2FwaS9jb250cmFjdHMvW2lkXSAtIOabtOaWsOWQiOWQjO+8iOS7heWIm+W7uuiAheWPr+abtOaWsO+8jOS4lOWQiOWQjOeKtuaAgeS4uiByZWplY3RlZCDml7bmiY3og73mm7TmlrDvvIlcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBQVVQocmVxdWVzdCwgeyBwYXJhbXMgfSkge1xuICB0cnkge1xuICAgIGNvbnN0IHVzZXIgPSBnZXRVc2VyRnJvbVJlcXVlc3QocmVxdWVzdCk7XG4gICAgaWYgKCF1c2VyKSByZXR1cm4gdW5hdXRob3JpemVkUmVzcG9uc2UoKTtcblxuICAgIGNvbnN0IHsgaWQgfSA9IGF3YWl0IHBhcmFtcztcbiAgICBjb25zdCBkYiA9IGF3YWl0IGdldERiKCk7XG5cbiAgICBjb25zdCBjb250cmFjdCA9IGRiLnByZXBhcmUoJ1NFTEVDVCAqIEZST00gY29udHJhY3RzIFdIRVJFIGlkID0gPycpLmdldChpZCk7XG4gICAgaWYgKCFjb250cmFjdCkge1xuICAgICAgcmV0dXJuIFJlc3BvbnNlLmpzb24oXG4gICAgICAgIHsgZXJyb3I6ICflkIjlkIzkuI3lrZjlnKgnIH0sXG4gICAgICAgIHsgc3RhdHVzOiA0MDQgfVxuICAgICAgKTtcbiAgICB9XG5cbiAgICAvLyDlj6rmnInliJvlu7rogIXlj6/ku6Xmm7TmlrBcbiAgICBpZiAoY29udHJhY3QuY3JlYXRvcl9pZCAhPT0gdXNlci5pZCkge1xuICAgICAgcmV0dXJuIFJlc3BvbnNlLmpzb24oXG4gICAgICAgIHsgZXJyb3I6ICflj6rmnInlkIjlkIzliJvlu7rogIXlj6/ku6Xkv67mlLknIH0sXG4gICAgICAgIHsgc3RhdHVzOiA0MDMgfVxuICAgICAgKTtcbiAgICB9XG5cbiAgICAvLyDlj6rmnInooqvpqbPlm57nmoTlkIjlkIzmiY3og73kv67mlLlcbiAgICBpZiAoY29udHJhY3Quc3RhdHVzICE9PSAncmVqZWN0ZWQnKSB7XG4gICAgICByZXR1cm4gUmVzcG9uc2UuanNvbihcbiAgICAgICAgeyBlcnJvcjogJ+WPquacieiiq+mps+WbnueahOWQiOWQjOaJjeiDveS/ruaUuScgfSxcbiAgICAgICAgeyBzdGF0dXM6IDQwMCB9XG4gICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IGJvZHkgPSBhd2FpdCByZXF1ZXN0Lmpzb24oKTtcbiAgICBjb25zdCB7XG4gICAgICBwcm9qZWN0X25hbWUsIHBhcnRuZXJfaWQsIGNvbnRyYWN0X2NvbnRlbnQsIGNvbnRyYWN0X3llYXJzLFxuICAgICAgY29udHJhY3RfYW1vdW50LCBlc3RpbWF0ZWRfcHJvZml0LCBwYXltZW50X3R5cGUsIHNpZ25fZGF0ZSwgcHJvamVjdF9sZWFkZXIsXG4gICAgfSA9IGJvZHk7XG5cbiAgICAvLyDmn6Xmib7lkIjkvZzljZXkvY3lkI3np7BcbiAgICBsZXQgcGFydG5lcl9uYW1lID0gY29udHJhY3QucGFydG5lcl9uYW1lO1xuICAgIGlmIChwYXJ0bmVyX2lkICYmIHBhcnRuZXJfaWQgIT09IGNvbnRyYWN0LnBhcnRuZXJfaWQpIHtcbiAgICAgIGNvbnN0IHBhcnRuZXIgPSBkYi5wcmVwYXJlKCdTRUxFQ1QgbmFtZSBGUk9NIHBhcnRuZXJzIFdIRVJFIGlkID0gPyBBTkQgaXNfZGVsZXRlZCA9IDAnKS5nZXQocGFydG5lcl9pZCk7XG4gICAgICBpZiAoIXBhcnRuZXIpIHtcbiAgICAgICAgcmV0dXJuIFJlc3BvbnNlLmpzb24oXG4gICAgICAgICAgeyBlcnJvcjogJ+WQiOS9nOWNleS9jeS4jeWtmOWcqCcgfSxcbiAgICAgICAgICB7IHN0YXR1czogNDAwIH1cbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICAgIHBhcnRuZXJfbmFtZSA9IHBhcnRuZXIubmFtZTtcbiAgICB9XG5cbiAgICAvLyDmm7TmlrDlkIjlkIzlubbph43nva7nirbmgIHlkozlrqHmibnlrZfmrrVcbiAgICBkYi5wcmVwYXJlKGBcbiAgICAgIFVQREFURSBjb250cmFjdHMgU0VUXG4gICAgICAgIHByb2plY3RfbmFtZSA9ID8sXG4gICAgICAgIHBhcnRuZXJfaWQgPSA/LFxuICAgICAgICBwYXJ0bmVyX25hbWUgPSA/LFxuICAgICAgICBjb250cmFjdF9jb250ZW50ID0gPyxcbiAgICAgICAgY29udHJhY3RfeWVhcnMgPSA/LFxuICAgICAgICBjb250cmFjdF9hbW91bnQgPSA/LFxuICAgICAgICBlc3RpbWF0ZWRfcHJvZml0ID0gPyxcbiAgICAgICAgcGF5bWVudF90eXBlID0gPyxcbiAgICAgICAgc2lnbl9kYXRlID0gPyxcbiAgICAgICAgcHJvamVjdF9sZWFkZXIgPSA/LFxuICAgICAgICBzdGF0dXMgPSAncGVuZGluZ19zdXBlcnZpc29yJyxcbiAgICAgICAgc3VwZXJ2aXNvcl9vcGluaW9uID0gTlVMTCxcbiAgICAgICAgc3VwZXJ2aXNvcl9hcHByb3ZlZCA9IE5VTEwsXG4gICAgICAgIHN1cGVydmlzb3JfaWQgPSBOVUxMLFxuICAgICAgICBzdXBlcnZpc29yX25hbWUgPSBOVUxMLFxuICAgICAgICBzdXBlcnZpc29yX3RpbWUgPSBOVUxMLFxuICAgICAgICBmaW5hbmNlX29waW5pb24gPSBOVUxMLFxuICAgICAgICBmaW5hbmNlX2FwcHJvdmVkID0gTlVMTCxcbiAgICAgICAgZmluYW5jZV9pZCA9IE5VTEwsXG4gICAgICAgIGZpbmFuY2VfbmFtZSA9IE5VTEwsXG4gICAgICAgIGZpbmFuY2VfdGltZSA9IE5VTEwsXG4gICAgICAgIHNlY3JldGFyeV9vcGluaW9uID0gTlVMTCxcbiAgICAgICAgc2VjcmV0YXJ5X2FwcHJvdmVkID0gTlVMTCxcbiAgICAgICAgc2VjcmV0YXJ5X2lkID0gTlVMTCxcbiAgICAgICAgc2VjcmV0YXJ5X25hbWUgPSBOVUxMLFxuICAgICAgICBzZWNyZXRhcnlfdGltZSA9IE5VTEwsXG4gICAgICAgIHJlamVjdF9yZWFzb24gPSBOVUxMLFxuICAgICAgICB1cGRhdGVkX2F0ID0gQ1VSUkVOVF9USU1FU1RBTVBcbiAgICAgIFdIRVJFIGlkID0gP1xuICAgIGApLnJ1bihcbiAgICAgIHByb2plY3RfbmFtZSB8fCBjb250cmFjdC5wcm9qZWN0X25hbWUsXG4gICAgICBwYXJ0bmVyX2lkIHx8IGNvbnRyYWN0LnBhcnRuZXJfaWQsXG4gICAgICBwYXJ0bmVyX25hbWUsXG4gICAgICBjb250cmFjdF9jb250ZW50ICE9PSB1bmRlZmluZWQgPyBjb250cmFjdF9jb250ZW50IDogY29udHJhY3QuY29udHJhY3RfY29udGVudCxcbiAgICAgIGNvbnRyYWN0X3llYXJzICE9PSB1bmRlZmluZWQgPyBjb250cmFjdF95ZWFycyA6IGNvbnRyYWN0LmNvbnRyYWN0X3llYXJzLFxuICAgICAgY29udHJhY3RfYW1vdW50ICE9PSB1bmRlZmluZWQgPyBjb250cmFjdF9hbW91bnQgOiBjb250cmFjdC5jb250cmFjdF9hbW91bnQsXG4gICAgICBlc3RpbWF0ZWRfcHJvZml0ICE9PSB1bmRlZmluZWQgPyBlc3RpbWF0ZWRfcHJvZml0IDogY29udHJhY3QuZXN0aW1hdGVkX3Byb2ZpdCxcbiAgICAgIHBheW1lbnRfdHlwZSB8fCBjb250cmFjdC5wYXltZW50X3R5cGUsXG4gICAgICBzaWduX2RhdGUgIT09IHVuZGVmaW5lZCA/IHNpZ25fZGF0ZSA6IGNvbnRyYWN0LnNpZ25fZGF0ZSxcbiAgICAgIHByb2plY3RfbGVhZGVyICE9PSB1bmRlZmluZWQgPyBwcm9qZWN0X2xlYWRlciA6IGNvbnRyYWN0LnByb2plY3RfbGVhZGVyLFxuICAgICAgaWRcbiAgICApO1xuXG4gICAgY29uc3QgdXBkYXRlZCA9IGRiLnByZXBhcmUoJ1NFTEVDVCAqIEZST00gY29udHJhY3RzIFdIRVJFIGlkID0gPycpLmdldChpZCk7XG5cbiAgICAvLyDojrflj5bpmYTku7ZcbiAgICBjb25zdCBhdHRhY2htZW50cyA9IGRiLnByZXBhcmUoXG4gICAgICAnU0VMRUNUICogRlJPTSBjb250cmFjdF9hdHRhY2htZW50cyBXSEVSRSBjb250cmFjdF9pZCA9ID8gT1JERVIgQlkgY3JlYXRlZF9hdCBERVNDJ1xuICAgICkuYWxsKGlkKTtcblxuICAgIHJldHVybiBSZXNwb25zZS5qc29uKHtcbiAgICAgIC4uLnVwZGF0ZWQsXG4gICAgICBhdHRhY2htZW50cyxcbiAgICAgIG9waW5pb25zOiBidWlsZE9waW5pb25zKHVwZGF0ZWQpLFxuICAgIH0pO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoJ+abtOaWsOWQiOWQjOWksei0pTonLCBlcnJvcik7XG4gICAgcmV0dXJuIFJlc3BvbnNlLmpzb24oXG4gICAgICB7IGVycm9yOiAn5pyN5Yqh5Zmo5YaF6YOo6ZSZ6K+vJyB9LFxuICAgICAgeyBzdGF0dXM6IDUwMCB9XG4gICAgKTtcbiAgfVxufVxuIl0sIm5hbWVzIjpbImR5bmFtaWMiLCJnZXREYiIsImdldFVzZXJGcm9tUmVxdWVzdCIsInVuYXV0aG9yaXplZFJlc3BvbnNlIiwiYnVpbGRPcGluaW9ucyIsImNvbnRyYWN0Iiwib3BpbmlvbnMiLCJzdXBlcnZpc29yX2FwcHJvdmVkIiwicHVzaCIsImFwcHJvdmVyX25hbWUiLCJzdXBlcnZpc29yX25hbWUiLCJyb2xlIiwiY3JlYXRlZF9hdCIsInN1cGVydmlzb3JfdGltZSIsImFwcHJvdmVkIiwib3BpbmlvbiIsInN1cGVydmlzb3Jfb3BpbmlvbiIsImZpbmFuY2VfYXBwcm92ZWQiLCJmaW5hbmNlX25hbWUiLCJmaW5hbmNlX3RpbWUiLCJmaW5hbmNlX29waW5pb24iLCJzZWNyZXRhcnlfYXBwcm92ZWQiLCJzZWNyZXRhcnlfbmFtZSIsInNlY3JldGFyeV90aW1lIiwic2VjcmV0YXJ5X29waW5pb24iLCJHRVQiLCJyZXF1ZXN0IiwicGFyYW1zIiwidXNlciIsImlkIiwiZGIiLCJwcmVwYXJlIiwiZ2V0IiwiUmVzcG9uc2UiLCJqc29uIiwiZXJyb3IiLCJzdGF0dXMiLCJhdHRhY2htZW50cyIsImFsbCIsImNvbnNvbGUiLCJQVVQiLCJjcmVhdG9yX2lkIiwiYm9keSIsInByb2plY3RfbmFtZSIsInBhcnRuZXJfaWQiLCJjb250cmFjdF9jb250ZW50IiwiY29udHJhY3RfeWVhcnMiLCJjb250cmFjdF9hbW91bnQiLCJlc3RpbWF0ZWRfcHJvZml0IiwicGF5bWVudF90eXBlIiwic2lnbl9kYXRlIiwicHJvamVjdF9sZWFkZXIiLCJwYXJ0bmVyX25hbWUiLCJwYXJ0bmVyIiwibmFtZSIsInJ1biIsInVuZGVmaW5lZCIsInVwZGF0ZWQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./src/app/api/contracts/[id]/route.js\n"); /***/ }), /***/ "(rsc)/./src/lib/auth.js": /*!*************************!*\ !*** ./src/lib/auth.js ***! \*************************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ checkRole: () => (/* binding */ checkRole),\n/* harmony export */ forbiddenResponse: () => (/* binding */ forbiddenResponse),\n/* harmony export */ generateToken: () => (/* binding */ generateToken),\n/* harmony export */ getUserFromRequest: () => (/* binding */ getUserFromRequest),\n/* harmony export */ unauthorizedResponse: () => (/* binding */ unauthorizedResponse),\n/* harmony export */ verifyToken: () => (/* binding */ verifyToken)\n/* harmony export */ });\n/* harmony import */ var jsonwebtoken__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jsonwebtoken */ \"(rsc)/./node_modules/jsonwebtoken/index.js\");\n/* harmony import */ var jsonwebtoken__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jsonwebtoken__WEBPACK_IMPORTED_MODULE_0__);\n\nconst JWT_SECRET = process.env.JWT_SECRET || \"contract-approval-system-secret-key-2024\";\nconst TOKEN_EXPIRY = \"24h\";\n// 生成 JWT Token\nfunction generateToken(user) {\n return jsonwebtoken__WEBPACK_IMPORTED_MODULE_0___default().sign({\n id: user.id,\n username: user.username,\n real_name: user.real_name,\n role: user.role,\n department_id: user.department_id\n }, JWT_SECRET, {\n expiresIn: TOKEN_EXPIRY\n });\n}\n// 验证 JWT Token\nfunction verifyToken(token) {\n try {\n return jsonwebtoken__WEBPACK_IMPORTED_MODULE_0___default().verify(token, JWT_SECRET);\n } catch (error) {\n return null;\n }\n}\n// 从请求头获取用户信息\nfunction getUserFromRequest(request) {\n const authHeader = request.headers.get(\"Authorization\");\n if (!authHeader || !authHeader.startsWith(\"Bearer \")) {\n return null;\n }\n const token = authHeader.substring(7);\n return verifyToken(token);\n}\n// 检查是否有权限\nfunction checkRole(user, allowedRoles) {\n if (!user) return false;\n return allowedRoles.includes(user.role);\n}\n// 返回未授权响应\nfunction unauthorizedResponse() {\n return Response.json({\n error: \"未登录或登录已过期\"\n }, {\n status: 401\n });\n}\n// 返回无权限响应 \nfunction forbiddenResponse() {\n return Response.json({\n error: \"无权限访问\"\n }, {\n status: 403\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9zcmMvbGliL2F1dGguanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBK0I7QUFFL0IsTUFBTUMsYUFBYUMsUUFBUUMsR0FBRyxDQUFDRixVQUFVLElBQUk7QUFDN0MsTUFBTUcsZUFBZTtBQUVyQixlQUFlO0FBQ1IsU0FBU0MsY0FBY0MsSUFBSTtJQUNoQyxPQUFPTix3REFBUSxDQUNiO1FBQ0VRLElBQUlGLEtBQUtFLEVBQUU7UUFDWEMsVUFBVUgsS0FBS0csUUFBUTtRQUN2QkMsV0FBV0osS0FBS0ksU0FBUztRQUN6QkMsTUFBTUwsS0FBS0ssSUFBSTtRQUNmQyxlQUFlTixLQUFLTSxhQUFhO0lBQ25DLEdBQ0FYLFlBQ0E7UUFBRVksV0FBV1Q7SUFBYTtBQUU5QjtBQUVBLGVBQWU7QUFDUixTQUFTVSxZQUFZQyxLQUFLO0lBQy9CLElBQUk7UUFDRixPQUFPZiwwREFBVSxDQUFDZSxPQUFPZDtJQUMzQixFQUFFLE9BQU9nQixPQUFPO1FBQ2QsT0FBTztJQUNUO0FBQ0Y7QUFFQSxhQUFhO0FBQ04sU0FBU0MsbUJBQW1CQyxPQUFPO0lBQ3hDLE1BQU1DLGFBQWFELFFBQVFFLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDO0lBQ3ZDLElBQUksQ0FBQ0YsY0FBYyxDQUFDQSxXQUFXRyxVQUFVLENBQUMsWUFBWTtRQUNwRCxPQUFPO0lBQ1Q7SUFDQSxNQUFNUixRQUFRSyxXQUFXSSxTQUFTLENBQUM7SUFDbkMsT0FBT1YsWUFBWUM7QUFDckI7QUFFQSxVQUFVO0FBQ0gsU0FBU1UsVUFBVW5CLElBQUksRUFBRW9CLFlBQVk7SUFDMUMsSUFBSSxDQUFDcEIsTUFBTSxPQUFPO0lBQ2xCLE9BQU9vQixhQUFhQyxRQUFRLENBQUNyQixLQUFLSyxJQUFJO0FBQ3hDO0FBRUEsVUFBVTtBQUNILFNBQVNpQjtJQUNkLE9BQU9DLFNBQVNDLElBQUksQ0FDbEI7UUFBRWIsT0FBTztJQUFZLEdBQ3JCO1FBQUVjLFFBQVE7SUFBSTtBQUVsQjtBQUVBLFlBQVk7QUFDTCxTQUFTQztJQUNkLE9BQU9ILFNBQVNDLElBQUksQ0FDbEI7UUFBRWIsT0FBTztJQUFRLEdBQ2pCO1FBQUVjLFFBQVE7SUFBSTtBQUVsQiIsInNvdXJjZXMiOlsid2VicGFjazovL2NvbnRyYWN0LWFwcHJvdmFsLXN5c3RlbS8uL3NyYy9saWIvYXV0aC5qcz84N2JkIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBqd3QgZnJvbSAnanNvbndlYnRva2VuJztcblxuY29uc3QgSldUX1NFQ1JFVCA9IHByb2Nlc3MuZW52LkpXVF9TRUNSRVQgfHwgJ2NvbnRyYWN0LWFwcHJvdmFsLXN5c3RlbS1zZWNyZXQta2V5LTIwMjQnO1xuY29uc3QgVE9LRU5fRVhQSVJZID0gJzI0aCc7XG5cbi8vIOeUn+aIkCBKV1QgVG9rZW5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZVRva2VuKHVzZXIpIHtcbiAgcmV0dXJuIGp3dC5zaWduKFxuICAgIHtcbiAgICAgIGlkOiB1c2VyLmlkLFxuICAgICAgdXNlcm5hbWU6IHVzZXIudXNlcm5hbWUsXG4gICAgICByZWFsX25hbWU6IHVzZXIucmVhbF9uYW1lLFxuICAgICAgcm9sZTogdXNlci5yb2xlLFxuICAgICAgZGVwYXJ0bWVudF9pZDogdXNlci5kZXBhcnRtZW50X2lkLFxuICAgIH0sXG4gICAgSldUX1NFQ1JFVCxcbiAgICB7IGV4cGlyZXNJbjogVE9LRU5fRVhQSVJZIH1cbiAgKTtcbn1cblxuLy8g6aqM6K+BIEpXVCBUb2tlblxuZXhwb3J0IGZ1bmN0aW9uIHZlcmlmeVRva2VuKHRva2VuKSB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIGp3dC52ZXJpZnkodG9rZW4sIEpXVF9TRUNSRVQpO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIHJldHVybiBudWxsO1xuICB9XG59XG5cbi8vIOS7juivt+axguWktOiOt+WPlueUqOaIt+S/oeaBr1xuZXhwb3J0IGZ1bmN0aW9uIGdldFVzZXJGcm9tUmVxdWVzdChyZXF1ZXN0KSB7XG4gIGNvbnN0IGF1dGhIZWFkZXIgPSByZXF1ZXN0LmhlYWRlcnMuZ2V0KCdBdXRob3JpemF0aW9uJyk7XG4gIGlmICghYXV0aEhlYWRlciB8fCAhYXV0aEhlYWRlci5zdGFydHNXaXRoKCdCZWFyZXIgJykpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuICBjb25zdCB0b2tlbiA9IGF1dGhIZWFkZXIuc3Vic3RyaW5nKDcpO1xuICByZXR1cm4gdmVyaWZ5VG9rZW4odG9rZW4pO1xufVxuXG4vLyDmo4Dmn6XmmK/lkKbmnInmnYPpmZBcbmV4cG9ydCBmdW5jdGlvbiBjaGVja1JvbGUodXNlciwgYWxsb3dlZFJvbGVzKSB7XG4gIGlmICghdXNlcikgcmV0dXJuIGZhbHNlO1xuICByZXR1cm4gYWxsb3dlZFJvbGVzLmluY2x1ZGVzKHVzZXIucm9sZSk7XG59XG5cbi8vIOi/lOWbnuacquaOiOadg+WTjeW6lFxuZXhwb3J0IGZ1bmN0aW9uIHVuYXV0aG9yaXplZFJlc3BvbnNlKCkge1xuICByZXR1cm4gUmVzcG9uc2UuanNvbihcbiAgICB7IGVycm9yOiAn5pyq55m75b2V5oiW55m75b2V5bey6L+H5pyfJyB9LFxuICAgIHsgc3RhdHVzOiA0MDEgfVxuICApO1xufVxuXG4vLyDov5Tlm57ml6DmnYPpmZDlk43lupQgIFxuZXhwb3J0IGZ1bmN0aW9uIGZvcmJpZGRlblJlc3BvbnNlKCkge1xuICByZXR1cm4gUmVzcG9uc2UuanNvbihcbiAgICB7IGVycm9yOiAn5peg5p2D6ZmQ6K6/6ZeuJyB9LFxuICAgIHsgc3RhdHVzOiA0MDMgfVxuICApO1xufVxuIl0sIm5hbWVzIjpbImp3dCIsIkpXVF9TRUNSRVQiLCJwcm9jZXNzIiwiZW52IiwiVE9LRU5fRVhQSVJZIiwiZ2VuZXJhdGVUb2tlbiIsInVzZXIiLCJzaWduIiwiaWQiLCJ1c2VybmFtZSIsInJlYWxfbmFtZSIsInJvbGUiLCJkZXBhcnRtZW50X2lkIiwiZXhwaXJlc0luIiwidmVyaWZ5VG9rZW4iLCJ0b2tlbiIsInZlcmlmeSIsImVycm9yIiwiZ2V0VXNlckZyb21SZXF1ZXN0IiwicmVxdWVzdCIsImF1dGhIZWFkZXIiLCJoZWFkZXJzIiwiZ2V0Iiwic3RhcnRzV2l0aCIsInN1YnN0cmluZyIsImNoZWNrUm9sZSIsImFsbG93ZWRSb2xlcyIsImluY2x1ZGVzIiwidW5hdXRob3JpemVkUmVzcG9uc2UiLCJSZXNwb25zZSIsImpzb24iLCJzdGF0dXMiLCJmb3JiaWRkZW5SZXNwb25zZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./src/lib/auth.js\n"); /***/ }), /***/ "(rsc)/./src/lib/db.js": /*!***********************!*\ !*** ./src/lib/db.js ***! \***********************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ getDb)\n/* harmony export */ });\n/* harmony import */ var sql_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! sql.js */ \"sql.js\");\n/* harmony import */ var sql_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(sql_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var path__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! path */ \"path\");\n/* harmony import */ var path__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var fs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! fs */ \"fs\");\n/* harmony import */ var fs__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(fs__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var bcryptjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! bcryptjs */ \"(rsc)/./node_modules/bcryptjs/index.js\");\n/* harmony import */ var bcryptjs__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(bcryptjs__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\nconst DB_PATH = path__WEBPACK_IMPORTED_MODULE_1___default().join(process.cwd(), \"data\", \"database.sqlite\");\nlet db = null;\nlet SQL = null;\nlet initPromise = null;\nlet transactionDepth = 0;\nfunction saveDb() {\n if (transactionDepth > 0) {\n return;\n }\n if (db) {\n const data = db.export();\n const buffer = Buffer.from(data);\n const dir = path__WEBPACK_IMPORTED_MODULE_1___default().dirname(DB_PATH);\n if (!fs__WEBPACK_IMPORTED_MODULE_2___default().existsSync(dir)) {\n fs__WEBPACK_IMPORTED_MODULE_2___default().mkdirSync(dir, {\n recursive: true\n });\n }\n fs__WEBPACK_IMPORTED_MODULE_2___default().writeFileSync(DB_PATH, buffer);\n }\n}\nasync function ensureInit() {\n if (db) return;\n if (initPromise) {\n await initPromise;\n return;\n }\n initPromise = (async ()=>{\n SQL = await sql_js__WEBPACK_IMPORTED_MODULE_0___default()();\n const dir = path__WEBPACK_IMPORTED_MODULE_1___default().dirname(DB_PATH);\n if (!fs__WEBPACK_IMPORTED_MODULE_2___default().existsSync(dir)) {\n fs__WEBPACK_IMPORTED_MODULE_2___default().mkdirSync(dir, {\n recursive: true\n });\n }\n try {\n if (fs__WEBPACK_IMPORTED_MODULE_2___default().existsSync(DB_PATH)) {\n const fileBuffer = fs__WEBPACK_IMPORTED_MODULE_2___default().readFileSync(DB_PATH);\n db = new SQL.Database(fileBuffer);\n } else {\n db = new SQL.Database();\n }\n } catch {\n db = new SQL.Database();\n }\n initializeDatabase(db);\n saveDb();\n })();\n await initPromise;\n}\n// 异步获取 db 代理 - 所有 API 路由使用这个\nasync function getDb() {\n await ensureInit();\n return {\n prepare (sql) {\n return {\n get (...params) {\n const stmt = db.prepare(sql);\n if (params.length > 0) stmt.bind(params);\n if (stmt.step()) {\n const result = stmt.getAsObject();\n stmt.free();\n return result;\n }\n stmt.free();\n return undefined;\n },\n all (...params) {\n const results = [];\n const stmt = db.prepare(sql);\n if (params.length > 0) stmt.bind(params);\n while(stmt.step()){\n results.push(stmt.getAsObject());\n }\n stmt.free();\n return results;\n },\n run (...params) {\n db.run(sql, params);\n const lastId = db.exec(\"SELECT last_insert_rowid() as id\");\n const changes = db.getRowsModified();\n saveDb();\n return {\n lastInsertRowid: lastId[0]?.values[0]?.[0] || 0,\n changes\n };\n }\n };\n },\n exec (sql) {\n db.exec(sql);\n saveDb();\n },\n transaction (fn) {\n return (...args)=>{\n transactionDepth++;\n db.run(\"BEGIN TRANSACTION\");\n try {\n const result = fn(...args);\n transactionDepth--;\n db.run(\"COMMIT\");\n saveDb();\n return result;\n } catch (error) {\n transactionDepth--;\n console.error(\"TRANSACTION ERROR:\", error);\n try {\n db.run(\"ROLLBACK\");\n } catch (rollbackError) {\n console.error(\"ROLLBACK ERROR:\", rollbackError);\n }\n throw error;\n }\n };\n }\n };\n}\nfunction initializeDatabase(database) {\n database.run(`CREATE TABLE IF NOT EXISTS departments (\n id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL UNIQUE,\n created_at DATETIME DEFAULT CURRENT_TIMESTAMP)`);\n database.run(`CREATE TABLE IF NOT EXISTS users (\n id INTEGER PRIMARY KEY AUTOINCREMENT, username TEXT NOT NULL UNIQUE,\n password TEXT NOT NULL, real_name TEXT NOT NULL,\n role TEXT NOT NULL DEFAULT 'employee', department_id INTEGER,\n status INTEGER DEFAULT 1, created_at DATETIME DEFAULT CURRENT_TIMESTAMP,\n FOREIGN KEY (department_id) REFERENCES departments(id))`);\n database.run(`CREATE TABLE IF NOT EXISTS partners (\n id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL,\n short_name TEXT, english_name TEXT, website TEXT, logo TEXT,\n address TEXT, description TEXT, is_deleted INTEGER DEFAULT 0,\n created_at DATETIME DEFAULT CURRENT_TIMESTAMP)`);\n database.run(`CREATE TABLE IF NOT EXISTS contracts (\n id INTEGER PRIMARY KEY AUTOINCREMENT, project_name TEXT NOT NULL,\n partner_id INTEGER, partner_name TEXT NOT NULL, contract_content TEXT,\n contract_years INTEGER, contract_amount REAL DEFAULT 0,\n estimated_profit REAL DEFAULT 0, payment_type TEXT DEFAULT 'receive',\n sign_date TEXT, status TEXT DEFAULT 'pending_supervisor',\n creator_id INTEGER NOT NULL, creator_name TEXT NOT NULL,\n department_id INTEGER, department_name TEXT, project_leader TEXT,\n supervisor_opinion TEXT, supervisor_approved INTEGER,\n supervisor_id INTEGER, supervisor_name TEXT, supervisor_time DATETIME,\n finance_opinion TEXT, finance_approved INTEGER,\n finance_id INTEGER, finance_name TEXT, finance_time DATETIME,\n secretary_opinion TEXT, secretary_approved INTEGER,\n secretary_id INTEGER, secretary_name TEXT, secretary_time DATETIME,\n reject_reason TEXT, created_at DATETIME DEFAULT CURRENT_TIMESTAMP,\n updated_at DATETIME DEFAULT CURRENT_TIMESTAMP,\n FOREIGN KEY (creator_id) REFERENCES users(id),\n FOREIGN KEY (partner_id) REFERENCES partners(id),\n FOREIGN KEY (department_id) REFERENCES departments(id))`);\n database.run(`CREATE TABLE IF NOT EXISTS contract_attachments (\n id INTEGER PRIMARY KEY AUTOINCREMENT, contract_id INTEGER NOT NULL,\n file_name TEXT NOT NULL, file_path TEXT NOT NULL,\n file_size INTEGER DEFAULT 0, created_at DATETIME DEFAULT CURRENT_TIMESTAMP,\n FOREIGN KEY (contract_id) REFERENCES contracts(id))`);\n database.run(`CREATE TABLE IF NOT EXISTS system_config (\n id INTEGER PRIMARY KEY AUTOINCREMENT, config_key TEXT NOT NULL UNIQUE,\n config_value TEXT, updated_at DATETIME DEFAULT CURRENT_TIMESTAMP)`);\n database.run(`CREATE TABLE IF NOT EXISTS role_permissions (\n id INTEGER PRIMARY KEY AUTOINCREMENT, role TEXT NOT NULL,\n menu_key TEXT NOT NULL, visible INTEGER DEFAULT 1,\n UNIQUE(role, menu_key))`);\n initDefaultData(database);\n}\nfunction initDefaultData(database) {\n const dc = database.exec(\"SELECT COUNT(*) FROM departments\");\n if ((dc[0]?.values[0]?.[0] || 0) === 0) {\n for (const n of [\n \"技术部\",\n \"市场部\",\n \"销售部\",\n \"财务部\",\n \"行政部\"\n ]){\n database.run(\"INSERT INTO departments (name) VALUES (?)\", [\n n\n ]);\n }\n }\n const uc = database.exec(\"SELECT COUNT(*) FROM users\");\n if ((uc[0]?.values[0]?.[0] || 0) === 0) {\n const s = bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().genSaltSync(10);\n const users = [\n [\n \"admin\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"admin123\", s),\n \"系统管理员\",\n \"admin\",\n null\n ],\n [\n \"zhangsan\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"123456\", s),\n \"张三\",\n \"employee\",\n 1\n ],\n [\n \"lisi\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"123456\", s),\n \"李四\",\n \"supervisor\",\n 1\n ],\n [\n \"wangwu_emp\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"123456\", s),\n \"王五\",\n \"employee\",\n 2\n ],\n [\n \"maqi\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"123456\", s),\n \"马七\",\n \"supervisor\",\n 2\n ],\n [\n \"wangwu\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"123456\", s),\n \"赵六\",\n \"finance\",\n 4\n ],\n [\n \"qianba\",\n bcryptjs__WEBPACK_IMPORTED_MODULE_3___default().hashSync(\"123456\", s),\n \"钱八\",\n \"secretary\",\n null\n ]\n ];\n for (const u of users){\n database.run(\"INSERT INTO users (username, password, real_name, role, department_id) VALUES (?,?,?,?,?)\", u);\n }\n }\n const cc = database.exec(\"SELECT COUNT(*) FROM system_config\");\n if ((cc[0]?.values[0]?.[0] || 0) === 0) {\n database.run(\"INSERT INTO system_config (config_key, config_value) VALUES ('company_name','合同流转审批系统')\");\n database.run(\"INSERT INTO system_config (config_key, config_value) VALUES ('company_logo','')\");\n database.run(\"INSERT INTO system_config (config_key, config_value) VALUES ('profit_percentage','10')\");\n }\n const pc = database.exec(\"SELECT COUNT(*) FROM role_permissions\");\n if ((pc[0]?.values[0]?.[0] || 0) === 0) {\n const menus = [\n \"dashboard\",\n \"contracts\",\n \"partners\",\n \"users\",\n \"departments\",\n \"settings\",\n \"permissions\"\n ];\n const roles = {\n admin: menus,\n employee: [\n \"dashboard\",\n \"contracts\",\n \"partners\"\n ],\n supervisor: [\n \"dashboard\",\n \"contracts\",\n \"partners\"\n ],\n finance: [\n \"dashboard\",\n \"contracts\",\n \"partners\"\n ],\n secretary: [\n \"dashboard\",\n \"contracts\",\n \"partners\"\n ]\n };\n for (const [role, vm] of Object.entries(roles)){\n for (const m of menus){\n database.run(\"INSERT INTO role_permissions (role, menu_key, visible) VALUES (?,?,?)\", [\n role,\n m,\n vm.includes(m) ? 1 : 0\n ]);\n }\n }\n }\n const pac = database.exec(\"SELECT COUNT(*) FROM partners\");\n if ((pac[0]?.values[0]?.[0] || 0) === 0) {\n const defaultPartners = [\n [\n \"健帆生物科技集团股份有限公司\",\n \"健帆生物\",\n \"Jafron Biomedical Co., Ltd.\",\n \"http://www.jafron.com\",\n \"\",\n \"珠海市唐家湾科技创新海岸科技一路9号\",\n \"血液净化产品的研发、生产与销售\"\n ],\n [\n \"天士力医药集团股份有限公司\",\n \"天士力\",\n \"Tasly Pharmaceutical Group Co., Ltd.\",\n \"http://www.tasly.com\",\n \"\",\n \"天津市北辰科技园区科技东路1号\",\n \"现代中药、化学药、生物药的研发、生产与销售\"\n ],\n [\n \"雅培贸易(上海)有限公司\",\n \"雅培\",\n \"Abbott Laboratories Trading (Shanghai) Co., Ltd.\",\n \"http://www.abbott.com.cn\",\n \"\",\n \"中国(上海)自由贸易试验区外高桥保税区富特北路399号\",\n \"医疗健康、诊断、营养品及成熟药品\"\n ],\n [\n \"成都嗖嗖优速网络科技有限公司\",\n \"嗖嗖优速\",\n \"Chengdu Sousou Yousu Network Technology Co., Ltd.\",\n \"http://www.sousouyousu.com\",\n \"\",\n \"四川省成都市高新区吉泰五路88号\",\n \"互联网信息服务与网络技术研发\"\n ],\n [\n \"成都世纪城会展集团有限公司\",\n \"成都世纪城会展\",\n \"Chengdu Century City Exhibition Group Co., Ltd.\",\n \"http://www.centurycityexhibition.com\",\n \"\",\n \"四川省成都市高新区天府大道中段177号\",\n \"会展场馆运营、会议展览策划与执行\"\n ],\n [\n \"正大天晴药业集团股份有限公司\",\n \"正大天晴\",\n \"Chia Tai-Tianqing Pharmaceutical Group Co., Ltd.\",\n \"http://www.cttq.com\",\n \"\",\n \"江苏省连云港市新浦区巨龙北路16号\",\n \"抗肿瘤、肝病及呼吸系统药物研发与生产\"\n ],\n [\n \"国家卫生健康委能力建设和继续教育中心\",\n \"卫健委能建中心\",\n \"NCCHD, NHC\",\n \"http://www.ncchd.org.cn\",\n \"\",\n \"北京市海淀区学院路38号\",\n \"卫生健康行业人才队伍能力建设与继续医学教育\"\n ],\n [\n \"南京正大天晴制药有限公司\",\n \"南京正大天晴\",\n \"Nanjing Chia Tai-Tianqing Pharmaceutical Co., Ltd.\",\n \"http://www.njcttq.com\",\n \"\",\n \"江苏省南京市经济技术开发区恒广路36号\",\n \"心脑血管、外科及消化系统药物制造\"\n ],\n [\n \"西安盛博商务会展服务有限公司\",\n \"西安盛博会展\",\n \"Xi'an Shengbo Business Exhibition Service Co., Ltd.\",\n \"http://www.xashengbo.com\",\n \"\",\n \"陕西省西安市雁塔区朱雀大街南段2号\",\n \"会议展览服务与公关策划业务\"\n ]\n ];\n for (const p of defaultPartners){\n database.run(\"INSERT INTO partners (name, short_name, english_name, website, logo, address, description) VALUES (?,?,?,?,?,?,?)\", p);\n }\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,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O2dCQUFDO2dCQUFrQjtnQkFBUTtnQkFBcUQ7Z0JBQThCO2dCQUFJO2dCQUFvQjthQUFpQjtZQUN2SjtnQkFBQztnQkFBaUI7Z0JBQVc7Z0JBQW1EO2dCQUF3QztnQkFBSTtnQkFBdUI7YUFBbUI7WUFDdEs7Z0JBQUM7Z0JBQWtCO2dCQUFRO2dCQUFvRDtnQkFBdUI7Z0JBQUk7Z0JBQXFCO2FBQXFCO1lBQ3BKO2dCQUFDO2dCQUFzQjtnQkFBVztnQkFBYztnQkFBMkI7Z0JBQUk7Z0JBQWdCO2FBQXdCO1lBQ3ZIO2dCQUFDO2dCQUFnQjtnQkFBVTtnQkFBc0Q7Z0JBQXlCO2dCQUFJO2dCQUF1QjthQUFtQjtZQUN4SjtnQkFBQztnQkFBa0I7Z0JBQVU7Z0JBQXdEO2dCQUE0QjtnQkFBSTtnQkFBcUI7YUFBZ0I7U0FDM0o7UUFDRCxLQUFLLE1BQU1DLEtBQUtELGdCQUFpQjtZQUMvQjFCLFNBQVNiLEdBQUcsQ0FBQyxxSEFBcUh3QztRQUNwSTtJQUNGO0FBQ0YiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9jb250cmFjdC1hcHByb3ZhbC1zeXN0ZW0vLi9zcmMvbGliL2RiLmpzPzdmOWEiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGluaXRTcWxKcyBmcm9tICdzcWwuanMnO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IGJjcnlwdCBmcm9tICdiY3J5cHRqcyc7XG5cbmNvbnN0IERCX1BBVEggPSBwYXRoLmpvaW4ocHJvY2Vzcy5jd2QoKSwgJ2RhdGEnLCAnZGF0YWJhc2Uuc3FsaXRlJyk7XG5cbmxldCBkYiA9IG51bGw7XG5sZXQgU1FMID0gbnVsbDtcbmxldCBpbml0UHJvbWlzZSA9IG51bGw7XG5sZXQgdHJhbnNhY3Rpb25EZXB0aCA9IDA7XG5cbmZ1bmN0aW9uIHNhdmVEYigpIHtcbiAgaWYgKHRyYW5zYWN0aW9uRGVwdGggPiAwKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGlmIChkYikge1xuICAgIGNvbnN0IGRhdGEgPSBkYi5leHBvcnQoKTtcbiAgICBjb25zdCBidWZmZXIgPSBCdWZmZXIuZnJvbShkYXRhKTtcbiAgICBjb25zdCBkaXIgPSBwYXRoLmRpcm5hbWUoREJfUEFUSCk7XG4gICAgaWYgKCFmcy5leGlzdHNTeW5jKGRpcikpIHtcbiAgICAgIGZzLm1rZGlyU3luYyhkaXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuICAgIH1cbiAgICBmcy53cml0ZUZpbGVTeW5jKERCX1BBVEgsIGJ1ZmZlcik7XG4gIH1cbn1cblxuYXN5bmMgZnVuY3Rpb24gZW5zdXJlSW5pdCgpIHtcbiAgaWYgKGRiKSByZXR1cm47XG4gIGlmIChpbml0UHJvbWlzZSkge1xuICAgIGF3YWl0IGluaXRQcm9taXNlO1xuICAgIHJldHVybjtcbiAgfVxuICBpbml0UHJvbWlzZSA9IChhc3luYyAoKSA9PiB7XG4gICAgU1FMID0gYXdhaXQgaW5pdFNxbEpzKCk7XG4gICAgY29uc3QgZGlyID0gcGF0aC5kaXJuYW1lKERCX1BBVEgpO1xuICAgIGlmICghZnMuZXhpc3RzU3luYyhkaXIpKSB7XG4gICAgICBmcy5ta2RpclN5bmMoZGlyLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbiAgICB9XG4gICAgdHJ5IHtcbiAgICAgIGlmIChmcy5leGlzdHNTeW5jKERCX1BBVEgpKSB7XG4gICAgICAgIGNvbnN0IGZpbGVCdWZmZXIgPSBmcy5yZWFkRmlsZVN5bmMoREJfUEFUSCk7XG4gICAgICAgIGRiID0gbmV3IFNRTC5EYXRhYmFzZShmaWxlQnVmZmVyKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGRiID0gbmV3IFNRTC5EYXRhYmFzZSgpO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgZGIgPSBuZXcgU1FMLkRhdGFiYXNlKCk7XG4gICAgfVxuICAgIGluaXRpYWxpemVEYXRhYmFzZShkYik7XG4gICAgc2F2ZURiKCk7XG4gIH0pKCk7XG4gIGF3YWl0IGluaXRQcm9taXNlO1xufVxuXG4vLyDlvILmraXojrflj5YgZGIg5Luj55CGIC0g5omA5pyJIEFQSSDot6/nlLHkvb/nlKjov5nkuKpcbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdldERiKCkge1xuICBhd2FpdCBlbnN1cmVJbml0KCk7XG4gIHJldHVybiB7XG4gICAgcHJlcGFyZShzcWwpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGdldCguLi5wYXJhbXMpIHtcbiAgICAgICAgICBjb25zdCBzdG10ID0gZGIucHJlcGFyZShzcWwpO1xuICAgICAgICAgIGlmIChwYXJhbXMubGVuZ3RoID4gMCkgc3RtdC5iaW5kKHBhcmFtcyk7XG4gICAgICAgICAgaWYgKHN0bXQuc3RlcCgpKSB7XG4gICAgICAgICAgICBjb25zdCByZXN1bHQgPSBzdG10LmdldEFzT2JqZWN0KCk7XG4gICAgICAgICAgICBzdG10LmZyZWUoKTtcbiAgICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgICAgfVxuICAgICAgICAgIHN0bXQuZnJlZSgpO1xuICAgICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICAgIH0sXG4gICAgICAgIGFsbCguLi5wYXJhbXMpIHtcbiAgICAgICAgICBjb25zdCByZXN1bHRzID0gW107XG4gICAgICAgICAgY29uc3Qgc3RtdCA9IGRiLnByZXBhcmUoc3FsKTtcbiAgICAgICAgICBpZiAocGFyYW1zLmxlbmd0aCA+IDApIHN0bXQuYmluZChwYXJhbXMpO1xuICAgICAgICAgIHdoaWxlIChzdG10LnN0ZXAoKSkge1xuICAgICAgICAgICAgcmVzdWx0cy5wdXNoKHN0bXQuZ2V0QXNPYmplY3QoKSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHN0bXQuZnJlZSgpO1xuICAgICAgICAgIHJldHVybiByZXN1bHRzO1xuICAgICAgICB9LFxuICAgICAgICBydW4oLi4ucGFyYW1zKSB7XG4gICAgICAgICAgZGIucnVuKHNxbCwgcGFyYW1zKTtcbiAgICAgICAgICBjb25zdCBsYXN0SWQgPSBkYi5leGVjKCdTRUxFQ1QgbGFzdF9pbnNlcnRfcm93aWQoKSBhcyBpZCcpO1xuICAgICAgICAgIGNvbnN0IGNoYW5nZXMgPSBkYi5nZXRSb3dzTW9kaWZpZWQoKTtcbiAgICAgICAgICBzYXZlRGIoKTtcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbGFzdEluc2VydFJvd2lkOiBsYXN0SWRbMF0/LnZhbHVlc1swXT8uWzBdIHx8IDAsXG4gICAgICAgICAgICBjaGFuZ2VzXG4gICAgICAgICAgfTtcbiAgICAgICAgfVxuICAgICAgfTtcbiAgICB9LFxuICAgIGV4ZWMoc3FsKSB7XG4gICAgICBkYi5leGVjKHNxbCk7XG4gICAgICBzYXZlRGIoKTtcbiAgICB9LFxuICAgIHRyYW5zYWN0aW9uKGZuKSB7XG4gICAgICByZXR1cm4gKC4uLmFyZ3MpID0+IHtcbiAgICAgICAgdHJhbnNhY3Rpb25EZXB0aCsrO1xuICAgICAgICBkYi5ydW4oJ0JFR0lOIFRSQU5TQUNUSU9OJyk7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gZm4oLi4uYXJncyk7XG4gICAgICAgICAgdHJhbnNhY3Rpb25EZXB0aC0tO1xuICAgICAgICAgIGRiLnJ1bignQ09NTUlUJyk7XG4gICAgICAgICAgc2F2ZURiKCk7XG4gICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICB0cmFuc2FjdGlvbkRlcHRoLS07XG4gICAgICAgICAgY29uc29sZS5lcnJvcihcIlRSQU5TQUNUSU9OIEVSUk9SOlwiLCBlcnJvcik7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGRiLnJ1bignUk9MTEJBQ0snKTtcbiAgICAgICAgICB9IGNhdGNoIChyb2xsYmFja0Vycm9yKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKFwiUk9MTEJBQ0sgRVJST1I6XCIsIHJvbGxiYWNrRXJyb3IpO1xuICAgICAgICAgIH1cbiAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgfVxuICAgICAgfTtcbiAgICB9XG4gIH07XG59XG5cbmZ1bmN0aW9uIGluaXRpYWxpemVEYXRhYmFzZShkYXRhYmFzZSkge1xuICBkYXRhYmFzZS5ydW4oYENSRUFURSBUQUJMRSBJRiBOT1QgRVhJU1RTIGRlcGFydG1lbnRzIChcbiAgICBpZCBJTlRFR0VSIFBSSU1BUlkgS0VZIEFVVE9JTkNSRU1FTlQsIG5hbWUgVEVYVCBOT1QgTlVMTCBVTklRVUUsXG4gICAgY3JlYXRlZF9hdCBEQVRFVElNRSBERUZBVUxUIENVUlJFTlRfVElNRVNUQU1QKWApO1xuICBkYXRhYmFzZS5ydW4oYENSRUFURSBUQUJMRSBJRiBOT1QgRVhJU1RTIHVzZXJzIChcbiAgICBpZCBJTlRFR0VSIFBSSU1BUlkgS0VZIEFVVE9JTkNSRU1FTlQsIHVzZXJuYW1lIFRFWFQgTk9UIE5VTEwgVU5JUVVFLFxuICAgIHBhc3N3b3JkIFRFWFQgTk9UIE5VTEwsIHJlYWxfbmFtZSBURVhUIE5PVCBOVUxMLFxuICAgIHJvbGUgVEVYVCBOT1QgTlVMTCBERUZBVUxUICdlbXBsb3llZScsIGRlcGFydG1lbnRfaWQgSU5URUdFUixcbiAgICBzdGF0dXMgSU5URUdFUiBERUZBVUxUIDEsIGNyZWF0ZWRfYXQgREFURVRJTUUgREVGQVVMVCBDVVJSRU5UX1RJTUVTVEFNUCxcbiAgICBGT1JFSUdOIEtFWSAoZGVwYXJ0bWVudF9pZCkgUkVGRVJFTkNFUyBkZXBhcnRtZW50cyhpZCkpYCk7XG4gIGRhdGFiYXNlLnJ1bihgQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgcGFydG5lcnMgKFxuICAgIGlkIElOVEVHRVIgUFJJTUFSWSBLRVkgQVVUT0lOQ1JFTUVOVCwgbmFtZSBURVhUIE5PVCBOVUxMLFxuICAgIHNob3J0X25hbWUgVEVYVCwgZW5nbGlzaF9uYW1lIFRFWFQsIHdlYnNpdGUgVEVYVCwgbG9nbyBURVhULFxuICAgIGFkZHJlc3MgVEVYVCwgZGVzY3JpcHRpb24gVEVYVCwgaXNfZGVsZXRlZCBJTlRFR0VSIERFRkFVTFQgMCxcbiAgICBjcmVhdGVkX2F0IERBVEVUSU1FIERFRkFVTFQgQ1VSUkVOVF9USU1FU1RBTVApYCk7XG4gIGRhdGFiYXNlLnJ1bihgQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgY29udHJhY3RzIChcbiAgICBpZCBJTlRFR0VSIFBSSU1BUlkgS0VZIEFVVE9JTkNSRU1FTlQsIHByb2plY3RfbmFtZSBURVhUIE5PVCBOVUxMLFxuICAgIHBhcnRuZXJfaWQgSU5URUdFUiwgcGFydG5lcl9uYW1lIFRFWFQgTk9UIE5VTEwsIGNvbnRyYWN0X2NvbnRlbnQgVEVYVCxcbiAgICBjb250cmFjdF95ZWFycyBJTlRFR0VSLCBjb250cmFjdF9hbW91bnQgUkVBTCBERUZBVUxUIDAsXG4gICAgZXN0aW1hdGVkX3Byb2ZpdCBSRUFMIERFRkFVTFQgMCwgcGF5bWVudF90eXBlIFRFWFQgREVGQVVMVCAncmVjZWl2ZScsXG4gICAgc2lnbl9kYXRlIFRFWFQsIHN0YXR1cyBURVhUIERFRkFVTFQgJ3BlbmRpbmdfc3VwZXJ2aXNvcicsXG4gICAgY3JlYXRvcl9pZCBJTlRFR0VSIE5PVCBOVUxMLCBjcmVhdG9yX25hbWUgVEVYVCBOT1QgTlVMTCxcbiAgICBkZXBhcnRtZW50X2lkIElOVEVHRVIsIGRlcGFydG1lbnRfbmFtZSBURVhULCBwcm9qZWN0X2xlYWRlciBURVhULFxuICAgIHN1cGVydmlzb3Jfb3BpbmlvbiBURVhULCBzdXBlcnZpc29yX2FwcHJvdmVkIElOVEVHRVIsXG4gICAgc3VwZXJ2aXNvcl9pZCBJTlRFR0VSLCBzdXBlcnZpc29yX25hbWUgVEVYVCwgc3VwZXJ2aXNvcl90aW1lIERBVEVUSU1FLFxuICAgIGZpbmFuY2Vfb3BpbmlvbiBURVhULCBmaW5hbmNlX2FwcHJvdmVkIElOVEVHRVIsXG4gICAgZmluYW5jZV9pZCBJTlRFR0VSLCBmaW5hbmNlX25hbWUgVEVYVCwgZmluYW5jZV90aW1lIERBVEVUSU1FLFxuICAgIHNlY3JldGFyeV9vcGluaW9uIFRFWFQsIHNlY3JldGFyeV9hcHByb3ZlZCBJTlRFR0VSLFxuICAgIHNlY3JldGFyeV9pZCBJTlRFR0VSLCBzZWNyZXRhcnlfbmFtZSBURVhULCBzZWNyZXRhcnlfdGltZSBEQVRFVElNRSxcbiAgICByZWplY3RfcmVhc29uIFRFWFQsIGNyZWF0ZWRfYXQgREFURVRJTUUgREVGQVVMVCBDVVJSRU5UX1RJTUVTVEFNUCxcbiAgICB1cGRhdGVkX2F0IERBVEVUSU1FIERFRkFVTFQgQ1VSUkVOVF9USU1FU1RBTVAsXG4gICAgRk9SRUlHTiBLRVkgKGNyZWF0b3JfaWQpIFJFRkVSRU5DRVMgdXNlcnMoaWQpLFxuICAgIEZPUkVJR04gS0VZIChwYXJ0bmVyX2lkKSBSRUZFUkVOQ0VTIHBhcnRuZXJzKGlkKSxcbiAgICBGT1JFSUdOIEtFWSAoZGVwYXJ0bWVudF9pZCkgUkVGRVJFTkNFUyBkZXBhcnRtZW50cyhpZCkpYCk7XG4gIGRhdGFiYXNlLnJ1bihgQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgY29udHJhY3RfYXR0YWNobWVudHMgKFxuICAgIGlkIElOVEVHRVIgUFJJTUFSWSBLRVkgQVVUT0lOQ1JFTUVOVCwgY29udHJhY3RfaWQgSU5URUdFUiBOT1QgTlVMTCxcbiAgICBmaWxlX25hbWUgVEVYVCBOT1QgTlVMTCwgZmlsZV9wYXRoIFRFWFQgTk9UIE5VTEwsXG4gICAgZmlsZV9zaXplIElOVEVHRVIgREVGQVVMVCAwLCBjcmVhdGVkX2F0IERBVEVUSU1FIERFRkFVTFQgQ1VSUkVOVF9USU1FU1RBTVAsXG4gICAgRk9SRUlHTiBLRVkgKGNvbnRyYWN0X2lkKSBSRUZFUkVOQ0VTIGNvbnRyYWN0cyhpZCkpYCk7XG4gIGRhdGFiYXNlLnJ1bihgQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgc3lzdGVtX2NvbmZpZyAoXG4gICAgaWQgSU5URUdFUiBQUklNQVJZIEtFWSBBVVRPSU5DUkVNRU5ULCBjb25maWdfa2V5IFRFWFQgTk9UIE5VTEwgVU5JUVVFLFxuICAgIGNvbmZpZ192YWx1ZSBURVhULCB1cGRhdGVkX2F0IERBVEVUSU1FIERFRkFVTFQgQ1VSUkVOVF9USU1FU1RBTVApYCk7XG4gIGRhdGFiYXNlLnJ1bihgQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgcm9sZV9wZXJtaXNzaW9ucyAoXG4gICAgaWQgSU5URUdFUiBQUklNQVJZIEtFWSBBVVRPSU5DUkVNRU5ULCByb2xlIFRFWFQgTk9UIE5VTEwsXG4gICAgbWVudV9rZXkgVEVYVCBOT1QgTlVMTCwgdmlzaWJsZSBJTlRFR0VSIERFRkFVTFQgMSxcbiAgICBVTklRVUUocm9sZSwgbWVudV9rZXkpKWApO1xuICBpbml0RGVmYXVsdERhdGEoZGF0YWJhc2UpO1xufVxuXG5mdW5jdGlvbiBpbml0RGVmYXVsdERhdGEoZGF0YWJhc2UpIHtcbiAgY29uc3QgZGMgPSBkYXRhYmFzZS5leGVjKCdTRUxFQ1QgQ09VTlQoKikgRlJPTSBkZXBhcnRtZW50cycpO1xuICBpZiAoKGRjWzBdPy52YWx1ZXNbMF0/LlswXSB8fCAwKSA9PT0gMCkge1xuICAgIGZvciAoY29uc3QgbiBvZiBbJ+aKgOacr+mDqCcsICfluILlnLrpg6gnLCAn6ZSA5ZSu6YOoJywgJ+i0ouWKoemDqCcsICfooYzmlL/pg6gnXSkge1xuICAgICAgZGF0YWJhc2UucnVuKCdJTlNFUlQgSU5UTyBkZXBhcnRtZW50cyAobmFtZSkgVkFMVUVTICg/KScsIFtuXSk7XG4gICAgfVxuICB9XG4gIGNvbnN0IHVjID0gZGF0YWJhc2UuZXhlYygnU0VMRUNUIENPVU5UKCopIEZST00gdXNlcnMnKTtcbiAgaWYgKCh1Y1swXT8udmFsdWVzWzBdPy5bMF0gfHwgMCkgPT09IDApIHtcbiAgICBjb25zdCBzID0gYmNyeXB0LmdlblNhbHRTeW5jKDEwKTtcbiAgICBjb25zdCB1c2VycyA9IFtcbiAgICAgIFsnYWRtaW4nLCBiY3J5cHQuaGFzaFN5bmMoJ2FkbWluMTIzJywgcyksICfns7vnu5/nrqHnkIblkZgnLCAnYWRtaW4nLCBudWxsXSxcbiAgICAgIFsnemhhbmdzYW4nLCBiY3J5cHQuaGFzaFN5bmMoJzEyMzQ1NicsIHMpLCAn5byg5LiJJywgJ2VtcGxveWVlJywgMV0sXG4gICAgICBbJ2xpc2knLCBiY3J5cHQuaGFzaFN5bmMoJzEyMzQ1NicsIHMpLCAn5p2O5ZubJywgJ3N1cGVydmlzb3InLCAxXSxcbiAgICAgIFsnd2FuZ3d1X2VtcCcsIGJjcnlwdC5oYXNoU3luYygnMTIzNDU2JywgcyksICfnjovkupQnLCAnZW1wbG95ZWUnLCAyXSxcbiAgICAgIFsnbWFxaScsIGJjcnlwdC5oYXNoU3luYygnMTIzNDU2JywgcyksICfpqazkuIMnLCAnc3VwZXJ2aXNvcicsIDJdLFxuICAgICAgWyd3YW5nd3UnLCBiY3J5cHQuaGFzaFN5bmMoJzEyMzQ1NicsIHMpLCAn6LW15YWtJywgJ2ZpbmFuY2UnLCA0XSxcbiAgICAgIFsncWlhbmJhJywgYmNyeXB0Lmhhc2hTeW5jKCcxMjM0NTYnLCBzKSwgJ+mSseWFqycsICdzZWNyZXRhcnknLCBudWxsXSxcbiAgICBdO1xuICAgIGZvciAoY29uc3QgdSBvZiB1c2Vycykge1xuICAgICAgZGF0YWJhc2UucnVuKCdJTlNFUlQgSU5UTyB1c2VycyAodXNlcm5hbWUsIHBhc3N3b3JkLCByZWFsX25hbWUsIHJvbGUsIGRlcGFydG1lbnRfaWQpIFZBTFVFUyAoPyw/LD8sPyw/KScsIHUpO1xuICAgIH1cbiAgfVxuICBjb25zdCBjYyA9IGRhdGFiYXNlLmV4ZWMoJ1NFTEVDVCBDT1VOVCgqKSBGUk9NIHN5c3RlbV9jb25maWcnKTtcbiAgaWYgKChjY1swXT8udmFsdWVzWzBdPy5bMF0gfHwgMCkgPT09IDApIHtcbiAgICBkYXRhYmFzZS5ydW4oXCJJTlNFUlQgSU5UTyBzeXN0ZW1fY29uZmlnIChjb25maWdfa2V5LCBjb25maWdfdmFsdWUpIFZBTFVFUyAoJ2NvbXBhbnlfbmFtZScsJ+WQiOWQjOa1gei9rOWuoeaJueezu+e7nycpXCIpO1xuICAgIGRhdGFiYXNlLnJ1bihcIklOU0VSVCBJTlRPIHN5c3RlbV9jb25maWcgKGNvbmZpZ19rZXksIGNvbmZpZ192YWx1ZSkgVkFMVUVTICgnY29tcGFueV9sb2dvJywnJylcIik7XG4gICAgZGF0YWJhc2UucnVuKFwiSU5TRVJUIElOVE8gc3lzdGVtX2NvbmZpZyAoY29uZmlnX2tleSwgY29uZmlnX3ZhbHVlKSBWQUxVRVMgKCdwcm9maXRfcGVyY2VudGFnZScsJzEwJylcIik7XG4gIH1cbiAgY29uc3QgcGMgPSBkYXRhYmFzZS5leGVjKCdTRUxFQ1QgQ09VTlQoKikgRlJPTSByb2xlX3Blcm1pc3Npb25zJyk7XG4gIGlmICgocGNbMF0/LnZhbHVlc1swXT8uWzBdIHx8IDApID09PSAwKSB7XG4gICAgY29uc3QgbWVudXMgPSBbJ2Rhc2hib2FyZCcsJ2NvbnRyYWN0cycsJ3BhcnRuZXJzJywndXNlcnMnLCdkZXBhcnRtZW50cycsJ3NldHRpbmdzJywncGVybWlzc2lvbnMnXTtcbiAgICBjb25zdCByb2xlcyA9IHsgYWRtaW46IG1lbnVzLCBlbXBsb3llZTogWydkYXNoYm9hcmQnLCdjb250cmFjdHMnLCdwYXJ0bmVycyddLFxuICAgICAgc3VwZXJ2aXNvcjogWydkYXNoYm9hcmQnLCdjb250cmFjdHMnLCdwYXJ0bmVycyddLCBmaW5hbmNlOiBbJ2Rhc2hib2FyZCcsJ2NvbnRyYWN0cycsJ3BhcnRuZXJzJ10sXG4gICAgICBzZWNyZXRhcnk6IFsnZGFzaGJvYXJkJywnY29udHJhY3RzJywncGFydG5lcnMnXSB9O1xuICAgIGZvciAoY29uc3QgW3JvbGUsIHZtXSBvZiBPYmplY3QuZW50cmllcyhyb2xlcykpIHtcbiAgICAgIGZvciAoY29uc3QgbSBvZiBtZW51cykge1xuICAgICAgICBkYXRhYmFzZS5ydW4oJ0lOU0VSVCBJTlRPIHJvbGVfcGVybWlzc2lvbnMgKHJvbGUsIG1lbnVfa2V5LCB2aXNpYmxlKSBWQUxVRVMgKD8sPyw/KScsXG4gICAgICAgICAgW3JvbGUsIG0sIHZtLmluY2x1ZGVzKG0pID8gMSA6IDBdKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgY29uc3QgcGFjID0gZGF0YWJhc2UuZXhlYygnU0VMRUNUIENPVU5UKCopIEZST00gcGFydG5lcnMnKTtcbiAgaWYgKChwYWNbMF0/LnZhbHVlc1swXT8uWzBdIHx8IDApID09PSAwKSB7XG4gICAgY29uc3QgZGVmYXVsdFBhcnRuZXJzID0gW1xuICAgICAgWyflgaXluIbnlJ/niannp5HmioDpm4blm6LogqHku73mnInpmZDlhazlj7gnLCAn5YGl5biG55Sf54mpJywgJ0phZnJvbiBCaW9tZWRpY2FsIENvLiwgTHRkLicsICdodHRwOi8vd3d3LmphZnJvbi5jb20nLCAnJywgJ+ePoOa1t+W4guWUkOWutua5vuenkeaKgOWIm+aWsOa1t+WyuOenkeaKgOS4gOi3rznlj7cnLCAn6KGA5ray5YeA5YyW5Lqn5ZOB55qE56CU5Y+R44CB55Sf5Lqn5LiO6ZSA5ZSuJ10sXG4gICAgICBbJ+WkqeWjq+WKm+WMu+iNr+mbhuWbouiCoeS7veaciemZkOWFrOWPuCcsICflpKnlo6vlipsnLCAnVGFzbHkgUGhhcm1hY2V1dGljYWwgR3JvdXAgQ28uLCBMdGQuJywgJ2h0dHA6Ly93d3cudGFzbHkuY29tJywgJycsICflpKnmtKXluILljJfovrDnp5HmioDlm63ljLrnp5HmioDkuJzot68x5Y+3JywgJ+eOsOS7o+S4reiNr+OAgeWMluWtpuiNr+OAgeeUn+eJqeiNr+eahOeglOWPkeOAgeeUn+S6p+S4jumUgOWUriddLFxuICAgICAgWyfpm4Xln7notLjmmJPvvIjkuIrmtbfvvInmnInpmZDlhazlj7gnLCAn6ZuF5Z+5JywgJ0FiYm90dCBMYWJvcmF0b3JpZXMgVHJhZGluZyAoU2hhbmdoYWkpIENvLiwgTHRkLicsICdodHRwOi8vd3d3LmFiYm90dC5jb20uY24nLCAnJywgJ+S4reWbve+8iOS4iua1t++8ieiHqueUsei0uOaYk+ivlemqjOWMuuWklumrmOahpeS/neeojuWMuuWvjOeJueWMl+i3rzM5OeWPtycsICfljLvnlpflgaXlurfjgIHor4rmlq3jgIHokKXlhbvlk4Hlj4rmiJDnhp/oja/lk4EnXSxcbiAgICAgIFsn5oiQ6YO95ZeW5ZeW5LyY6YCf572R57uc56eR5oqA5pyJ6ZmQ5YWs5Y+4JywgJ+WXluWXluS8mOmAnycsICdDaGVuZ2R1IFNvdXNvdSBZb3VzdSBOZXR3b3JrIFRlY2hub2xvZ3kgQ28uLCBMdGQuJywgJ2h0dHA6Ly93d3cuc291c291eW91c3UuY29tJywgJycsICflm5vlt53nnIHmiJDpg73luILpq5jmlrDljLrlkInms7DkupTot684OOWPtycsICfkupLogZTnvZHkv6Hmga/mnI3liqHkuI7nvZHnu5zmioDmnK/noJTlj5EnXSxcbiAgICAgIFsn5oiQ6YO95LiW57qq5Z+O5Lya5bGV6ZuG5Zui5pyJ6ZmQ5YWs5Y+4JywgJ+aIkOmDveS4lue6quWfjuS8muWxlScsICdDaGVuZ2R1IENlbnR1cnkgQ2l0eSBFeGhpYml0aW9uIEdyb3VwIENvLiwgTHRkLicsICdodHRwOi8vd3d3LmNlbnR1cnljaXR5ZXhoaWJpdGlvbi5jb20nLCAnJywgJ+Wbm+W3neecgeaIkOmDveW4gumrmOaWsOWMuuWkqeW6nOWkp+mBk+S4reautTE3N+WPtycsICfkvJrlsZXlnLrppobov5DokKXjgIHkvJrorq7lsZXop4jnrZbliJLkuI7miafooYwnXSxcbiAgICAgIFsn5q2j5aSn5aSp5pm06I2v5Lia6ZuG5Zui6IKh5Lu95pyJ6ZmQ5YWs5Y+4JywgJ+ato+Wkp+WkqeaZtCcsICdDaGlhIFRhaS1UaWFucWluZyBQaGFybWFjZXV0aWNhbCBHcm91cCBDby4sIEx0ZC4nLCAnaHR0cDovL3d3dy5jdHRxLmNvbScsICcnLCAn5rGf6IuP55yB6L+e5LqR5riv5biC5paw5rWm5Yy65beo6b6Z5YyX6LevMTblj7cnLCAn5oqX6IK/55ik44CB6IKd55eF5Y+K5ZG85ZC457O757uf6I2v54mp56CU5Y+R5LiO55Sf5LqnJ10sXG4gICAgICBbJ+WbveWutuWNq+eUn+WBpeW6t+WnlOiDveWKm+W7uuiuvuWSjOe7p+e7reaVmeiCsuS4reW/gycsICfljavlgaXlp5Tog73lu7rkuK3lv4MnLCAnTkNDSEQsIE5IQycsICdodHRwOi8vd3d3Lm5jY2hkLm9yZy5jbicsICcnLCAn5YyX5Lqs5biC5rW35reA5Yy65a2m6Zmi6LevMzjlj7cnLCAn5Y2r55Sf5YGl5bq36KGM5Lia5Lq65omN6Zif5LyN6IO95Yqb5bu66K6+5LiO57un57ut5Yy75a2m5pWZ6IKyJ10sXG4gICAgICBbJ+WNl+S6rOato+Wkp+WkqeaZtOWItuiNr+aciemZkOWFrOWPuCcsICfljZfkuqzmraPlpKflpKnmmbQnLCAnTmFuamluZyBDaGlhIFRhaS1UaWFucWluZyBQaGFybWFjZXV0aWNhbCBDby4sIEx0ZC4nLCAnaHR0cDovL3d3dy5uamN0dHEuY29tJywgJycsICfmsZ/oi4/nnIHljZfkuqzluILnu4/mtY7mioDmnK/lvIDlj5HljLrmgZLlub/ot68zNuWPtycsICflv4PohJHooYDnrqHjgIHlpJbnp5Hlj4rmtojljJbns7vnu5/oja/nianliLbpgKAnXSxcbiAgICAgIFsn6KW/5a6J55ub5Y2a5ZWG5Yqh5Lya5bGV5pyN5Yqh5pyJ6ZmQ5YWs5Y+4JywgJ+ilv+Wuieebm+WNmuS8muWxlScsICdYaVxcJ2FuIFNoZW5nYm8gQnVzaW5lc3MgRXhoaWJpdGlvbiBTZXJ2aWNlIENvLiwgTHRkLicsICdodHRwOi8vd3d3Lnhhc2hlbmdiby5jb20nLCAnJywgJ+mZleilv+ecgeilv+WuieW4gumbgeWhlOWMuuacsembgOWkp+ihl+WNl+autTLlj7cnLCAn5Lya6K6u5bGV6KeI5pyN5Yqh5LiO5YWs5YWz562W5YiS5Lia5YqhJ11cbiAgICBdO1xuICAgIGZvciAoY29uc3QgcCBvZiBkZWZhdWx0UGFydG5lcnMpIHtcbiAgICAgIGRhdGFiYXNlLnJ1bignSU5TRVJUIElOVE8gcGFydG5lcnMgKG5hbWUsIHNob3J0X25hbWUsIGVuZ2xpc2hfbmFtZSwgd2Vic2l0ZSwgbG9nbywgYWRkcmVzcywgZGVzY3JpcHRpb24pIFZBTFVFUyAoPyw/LD8sPyw/LD8sPyknLCBwKTtcbiAgICB9XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJpbml0U3FsSnMiLCJwYXRoIiwiZnMiLCJiY3J5cHQiLCJEQl9QQVRIIiwiam9pbiIsInByb2Nlc3MiLCJjd2QiLCJkYiIsIlNRTCIsImluaXRQcm9taXNlIiwidHJhbnNhY3Rpb25EZXB0aCIsInNhdmVEYiIsImRhdGEiLCJleHBvcnQiLCJidWZmZXIiLCJCdWZmZXIiLCJmcm9tIiwiZGlyIiwiZGlybmFtZSIsImV4aXN0c1N5bmMiLCJta2RpclN5bmMiLCJyZWN1cnNpdmUiLCJ3cml0ZUZpbGVTeW5jIiwiZW5zdXJlSW5pdCIsImZpbGVCdWZmZXIiLCJyZWFkRmlsZVN5bmMiLCJEYXRhYmFzZSIsImluaXRpYWxpemVEYXRhYmFzZSIsImdldERiIiwicHJlcGFyZSIsInNxbCIsImdldCIsInBhcmFtcyIsInN0bXQiLCJsZW5ndGgiLCJiaW5kIiwic3RlcCIsInJlc3VsdCIsImdldEFzT2JqZWN0IiwiZnJlZSIsInVuZGVmaW5lZCIsImFsbCIsInJlc3VsdHMiLCJwdXNoIiwicnVuIiwibGFzdElkIiwiZXhlYyIsImNoYW5nZXMiLCJnZXRSb3dzTW9kaWZpZWQiLCJsYXN0SW5zZXJ0Um93aWQiLCJ2YWx1ZXMiLCJ0cmFuc2FjdGlvbiIsImZuIiwiYXJncyIsImVycm9yIiwiY29uc29sZSIsInJvbGxiYWNrRXJyb3IiLCJkYXRhYmFzZSIsImluaXREZWZhdWx0RGF0YSIsImRjIiwibiIsInVjIiwicyIsImdlblNhbHRTeW5jIiwidXNlcnMiLCJoYXNoU3luYyIsInUiLCJjYyIsInBjIiwibWVudXMiLCJyb2xlcyIsImFkbWluIiwiZW1wbG95ZWUiLCJzdXBlcnZpc29yIiwiZmluYW5jZSIsInNlY3JldGFyeSIsInJvbGUiLCJ2bSIsIk9iamVjdCIsImVudHJpZXMiLCJtIiwiaW5jbHVkZXMiLCJwYWMiLCJkZWZhdWx0UGFydG5lcnMiLCJwIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./src/lib/db.js\n"); /***/ }) }; ; // load runtime var __webpack_require__ = require("../../../../webpack-runtime.js"); __webpack_require__.C(exports); var __webpack_exec__ = (moduleId) => (__webpack_require__(__webpack_require__.s = moduleId)) var __webpack_exports__ = __webpack_require__.X(0, ["vendor-chunks/next","vendor-chunks/semver","vendor-chunks/bcryptjs","vendor-chunks/jsonwebtoken","vendor-chunks/lodash.includes","vendor-chunks/jws","vendor-chunks/lodash.once","vendor-chunks/jwa","vendor-chunks/lodash.isinteger","vendor-chunks/ecdsa-sig-formatter","vendor-chunks/lodash.isplainobject","vendor-chunks/ms","vendor-chunks/lodash.isstring","vendor-chunks/lodash.isnumber","vendor-chunks/lodash.isboolean","vendor-chunks/safe-buffer","vendor-chunks/buffer-equal-constant-time"], () => (__webpack_exec__("(rsc)/./node_modules/next/dist/build/webpack/loaders/next-app-loader.js?name=app%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&page=%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Fcontracts%2F%5Bid%5D%2Froute.js&appDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F%2Fsrc%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2FUsers%2Fgandanxiangzhao%2FDesktop%2F%E5%90%88%E5%90%8C%E6%B5%81%E8%BD%AC%E5%AE%A1%E6%89%B9%E7%B3%BB%E7%BB%9F&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D!"))); module.exports = __webpack_exports__; })();