Merge pull request #278 from bipproduction/bagas/5-feb-25
Bagas/5 feb 25
This commit is contained in:
@@ -1 +1,26 @@
|
|||||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:30:14.963Z"}
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:30:14.963Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:44:11.043Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T03:13:24.349Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at new eS (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:26724)\n at e_ (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27574)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32507)\n at get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32603)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39714)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:33303)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36)\n at run (node:async_hooks:64:22)","timestamp":"2025-02-05T03:48:26.606Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T04:24:29.510Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T05:56:01.792Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:33.579Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:38.069Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:39.386Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:40.316Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:41.037Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:41.842Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:42.615Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:42.784Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:42.982Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:43.131Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:43.278Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:25:00.025Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:25:00.028Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:25:00.029Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:148:1500)\n at handleRequestError (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:258:7367)\n at handleAndLogRequestError (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:258:6687)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:258:6394)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:35:53.417Z"}
|
||||||
|
{"id":"c65237f0-e0cf-4961-9454-2405c4f4fe05","level":"info","message":"Success send message","status":"success","timestamp":"2025-02-05T06:41:30.785Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:53:59.012Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T07:23:58.983Z"}
|
||||||
|
{"id":"64e3a991-7e44-407c-94b4-1693dc8a4417","level":"info","message":"Success send message","status":"success","timestamp":"2025-02-05T09:14:22.961Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T09:43:37.753Z"}
|
||||||
|
|||||||
@@ -1 +1,24 @@
|
|||||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:30:14.963Z"}
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:30:14.963Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:44:11.043Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T03:13:24.349Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at new eS (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:26724)\n at e_ (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27574)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32507)\n at get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32603)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39714)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:33303)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36)\n at run (node:async_hooks:64:22)","timestamp":"2025-02-05T03:48:26.606Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T04:24:29.510Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.deleteMany()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T05:56:01.792Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:33.579Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:38.069Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:39.386Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:40.316Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:41.037Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:41.842Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:42.615Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:42.784Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:42.982Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:43.131Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:24:43.278Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:25:00.025Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:25:00.028Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"P2025","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.","meta":{"cause":"Record to delete does not exist.","modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nAn operation failed because it depends on one or more records that were required but not found. Record to delete does not exist.\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:25:00.029Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:148:1500)\n at handleRequestError (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:258:7367)\n at handleAndLogRequestError (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:258:6687)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/@prisma/client/runtime/binary.js:258:6394)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:35:53.417Z"}
|
||||||
|
{"clientVersion":"6.3.0","code":"UND_ERR_SOCKET","level":"error","message":"Error deleting OTP: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed","meta":{"modelName":"KodeOtp"},"name":"PrismaClientKnownRequestError","stack":"PrismaClientKnownRequestError: \nInvalid `prisma.kodeOtp.delete()` invocation:\n\n\nother side closed\n at new PrismaClientKnownRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:148:1505)\n at handleRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:7369)\n at handleAndLogRequestError (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6705)\n at <anonymous> (webpack-internal:///(ssr)/./node_modules/@prisma/client/runtime/binary.js:258:6418)\n at processTicksAndRejections (native:7:39)","timestamp":"2025-02-05T06:53:59.012Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T07:23:58.983Z"}
|
||||||
|
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T09:43:37.753Z"}
|
||||||
|
|||||||
@@ -1,8 +1,12 @@
|
|||||||
import { prisma } from "@/app/lib";
|
import { prisma } from "@/app/lib";
|
||||||
|
import backendLogger from "@/util/backendLogger";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
export { DELETE };
|
export { DELETE };
|
||||||
async function DELETE(request: Request) {
|
async function DELETE(
|
||||||
|
request: Request,
|
||||||
|
{ params }: { params: { id: string } }
|
||||||
|
) {
|
||||||
if (request.method !== "DELETE") {
|
if (request.method !== "DELETE") {
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{ success: false, message: "Method not allowed" },
|
{ success: false, message: "Method not allowed" },
|
||||||
@@ -10,39 +14,24 @@ async function DELETE(request: Request) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
// Ambil parameter nomor dari URL
|
// Ambil parameter id dari URL
|
||||||
const { searchParams } = new URL(request.url);
|
const { id } = params;
|
||||||
const nomor = searchParams.get("nomor");
|
|
||||||
|
|
||||||
// Validasi parameter nomor
|
if (!id) {
|
||||||
if (!nomor) {
|
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: false,
|
success: false,
|
||||||
message: "Parameter 'nomor' diperlukan",
|
message: "Parameter 'id' diperlukan",
|
||||||
},
|
},
|
||||||
{ status: 400 }
|
{ status: 400 }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cek apakah data OTP dengan nomor tersebut ada
|
|
||||||
const existingOtp = await prisma.kodeOtp.findFirst({
|
|
||||||
where: { nomor },
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!existingOtp) {
|
|
||||||
return NextResponse.json(
|
|
||||||
{
|
|
||||||
success: false,
|
|
||||||
message: "Data OTP tidak ditemukan",
|
|
||||||
},
|
|
||||||
{ status: 404 }
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hapus data OTP
|
// Hapus data OTP
|
||||||
await prisma.kodeOtp.deleteMany({
|
await prisma.kodeOtp.delete({
|
||||||
where: { nomor },
|
where: {
|
||||||
|
id: id,
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
@@ -53,7 +42,7 @@ async function DELETE(request: Request) {
|
|||||||
{ status: 200 }
|
{ status: 200 }
|
||||||
);
|
);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Error deleting OTP:", error);
|
backendLogger.error("Error deleting OTP:", error);
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: false,
|
success: false,
|
||||||
@@ -1,11 +1,19 @@
|
|||||||
import { sessionCreate } from "@/app/auth/_lib/session_create";
|
import { sessionCreate } from "@/app/(auth)/_lib/session_create";
|
||||||
import prisma from "@/app/lib/prisma";
|
import prisma from "@/app/lib/prisma";
|
||||||
import backendLogger from "@/util/backendLogger";
|
import backendLogger from "@/util/backendLogger";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
export async function POST(req: Request) {
|
export async function POST(req: Request) {
|
||||||
if (req.method === "POST") {
|
if (req.method !== "POST") {
|
||||||
|
return NextResponse.json(
|
||||||
|
{ success: false, message: "Method Not Allowed" },
|
||||||
|
{ status: 405 }
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
const { data } = await req.json();
|
const { data } = await req.json();
|
||||||
|
console.log("data api register", data);
|
||||||
|
|
||||||
const cekUsername = await prisma.user.findUnique({
|
const cekUsername = await prisma.user.findUnique({
|
||||||
where: {
|
where: {
|
||||||
@@ -13,46 +21,51 @@ export async function POST(req: Request) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
try {
|
if (cekUsername)
|
||||||
if (cekUsername)
|
return NextResponse.json({
|
||||||
return NextResponse.json(
|
success: false,
|
||||||
{ success: false, message: "Username sudah digunakan" },
|
message: "Username sudah digunakan",
|
||||||
{ status: 400 }
|
|
||||||
);
|
|
||||||
|
|
||||||
const createUser = await prisma.user.create({
|
|
||||||
data: {
|
|
||||||
username: data.username,
|
|
||||||
nomor: data.nomor,
|
|
||||||
active: false,
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const token = await sessionCreate({
|
const createUser = await prisma.user.create({
|
||||||
sessionKey: process.env.NEXT_PUBLIC_BASE_SESSION_KEY!,
|
data: {
|
||||||
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
username: data.username,
|
||||||
user: createUser as any,
|
nomor: data.nomor,
|
||||||
});
|
active: false,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!createUser)
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{ success: true, message: "Berhasil Login", data: createUser },
|
{ success: false, message: "Gagal Registrasi" },
|
||||||
{ status: 200 }
|
|
||||||
);
|
|
||||||
} catch (error) {
|
|
||||||
backendLogger.log("Error registrasi:", error);
|
|
||||||
return NextResponse.json(
|
|
||||||
{
|
|
||||||
success: false,
|
|
||||||
message: "Server Error",
|
|
||||||
reason: (error as Error).message,
|
|
||||||
},
|
|
||||||
{ status: 500 }
|
{ status: 500 }
|
||||||
);
|
);
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return NextResponse.json(
|
const token = await sessionCreate({
|
||||||
{ success: false, message: "Method Not Allowed" },
|
sessionKey: process.env.NEXT_PUBLIC_BASE_SESSION_KEY!,
|
||||||
{ status: 405 }
|
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
||||||
);
|
user: createUser as any,
|
||||||
|
});
|
||||||
|
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: true,
|
||||||
|
message: "Registrasi Berhasil, Anda Sedang Login",
|
||||||
|
// data: createUser,
|
||||||
|
},
|
||||||
|
{ status: 201 }
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
backendLogger.error("Error registrasi:", error);
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: false,
|
||||||
|
message: "Maaf, Terjadi Keselahan",
|
||||||
|
reason: (error as Error).message,
|
||||||
|
},
|
||||||
|
{ status: 500 }
|
||||||
|
);
|
||||||
|
} finally {
|
||||||
|
await prisma.$disconnect();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,69 +1,72 @@
|
|||||||
import { prisma } from "@/app/lib";
|
import { prisma } from "@/app/lib";
|
||||||
import { randomOTP } from "@/app_modules/auth/fun/rondom_otp";
|
import { randomOTP } from "@/app_modules/auth/fun/rondom_otp";
|
||||||
|
import backendLogger from "@/util/backendLogger";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
export async function POST(req: Request) {
|
export async function POST(req: Request) {
|
||||||
if (req.method === "POST") {
|
if (req.method !== "POST") {
|
||||||
|
return NextResponse.json(
|
||||||
|
{ success: false, message: "Method Not Allowed" },
|
||||||
|
{ status: 405 }
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
const codeOtp = randomOTP();
|
const codeOtp = randomOTP();
|
||||||
const body = await req.json();
|
const body = await req.json();
|
||||||
const { nomor } = body;
|
const { nomor } = body;
|
||||||
|
|
||||||
try {
|
const res = await fetch(
|
||||||
const res = await fetch(
|
`https://wa.wibudev.com/code?nom=${nomor}&text=HIPMI - Kode ini bersifat RAHASIA dan JANGAN DI BAGIKAN KEPADA SIAPAPUN, termasuk anggota ataupun pengurus HIPMI lainnya.
|
||||||
`https://wa.wibudev.com/code?nom=${nomor}&text=HIPMI - Kode ini bersifat RAHASIA dan JANGAN DI BAGIKAN KEPADA SIAPAPUN, termasuk anggota ataupun pengurus HIPMI lainnya.
|
|
||||||
\n
|
\n
|
||||||
>> Kode OTP anda: ${codeOtp}.
|
>> Kode OTP anda: ${codeOtp}.
|
||||||
`
|
`
|
||||||
);
|
);
|
||||||
|
|
||||||
const sendWa = await res.json();
|
|
||||||
if (sendWa.status !== "success")
|
|
||||||
return NextResponse.json(
|
|
||||||
{
|
|
||||||
success: false,
|
|
||||||
message: "Nomor Whatsapp Tidak Aktif",
|
|
||||||
},
|
|
||||||
{ status: 400 }
|
|
||||||
);
|
|
||||||
|
|
||||||
const createOtpId = await prisma.kodeOtp.create({
|
|
||||||
data: {
|
|
||||||
nomor: nomor,
|
|
||||||
otp: codeOtp,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!createOtpId)
|
|
||||||
return NextResponse.json(
|
|
||||||
{
|
|
||||||
success: false,
|
|
||||||
message: "Gagal Membuat Kode OTP",
|
|
||||||
},
|
|
||||||
{ status: 400 }
|
|
||||||
);
|
|
||||||
|
|
||||||
return NextResponse.json(
|
|
||||||
{
|
|
||||||
success: true,
|
|
||||||
message: "Kode Verifikasi Dikirim",
|
|
||||||
kodeId: createOtpId.id,
|
|
||||||
},
|
|
||||||
{ status: 200 }
|
|
||||||
);
|
|
||||||
} catch (error) {
|
|
||||||
console.log(error);
|
|
||||||
|
|
||||||
|
const sendWa = await res.json();
|
||||||
|
if (sendWa.status !== "success")
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: false,
|
success: false,
|
||||||
message: "Server Whatsapp Error !!",
|
message: "Nomor Whatsapp Tidak Aktif",
|
||||||
},
|
},
|
||||||
{ status: 500 }
|
{ status: 400 }
|
||||||
);
|
);
|
||||||
}
|
|
||||||
|
const createOtpId = await prisma.kodeOtp.create({
|
||||||
|
data: {
|
||||||
|
nomor: nomor,
|
||||||
|
otp: codeOtp,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!createOtpId)
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: false,
|
||||||
|
message: "Gagal Membuat Kode OTP",
|
||||||
|
},
|
||||||
|
{ status: 400 }
|
||||||
|
);
|
||||||
|
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: true,
|
||||||
|
message: "Kode Verifikasi Dikirim",
|
||||||
|
kodeId: createOtpId.id,
|
||||||
|
},
|
||||||
|
{ status: 200 }
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
backendLogger.error(" Error Resend OTP", error);
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: false,
|
||||||
|
message: "Server Whatsapp Error !!",
|
||||||
|
},
|
||||||
|
{ status: 500 }
|
||||||
|
);
|
||||||
|
} finally {
|
||||||
|
await prisma.$disconnect();
|
||||||
}
|
}
|
||||||
return NextResponse.json(
|
|
||||||
{ success: false, message: "Method Not Allowed" },
|
|
||||||
{ status: 405 }
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { sessionCreate } from "@/app/auth/_lib/session_create";
|
import { sessionCreate } from "@/app/(auth)/_lib/session_create";
|
||||||
import prisma from "@/app/lib/prisma";
|
import prisma from "@/app/lib/prisma";
|
||||||
import backendLogger from "@/util/backendLogger";
|
import backendLogger from "@/util/backendLogger";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
@@ -52,7 +52,7 @@ export async function POST(req: Request) {
|
|||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: false,
|
success: false,
|
||||||
message: "API Error or Server Error",
|
message: "Maaf, Terjadi Keselahan",
|
||||||
reason: (error as Error).message,
|
reason: (error as Error).message,
|
||||||
},
|
},
|
||||||
{ status: 500 }
|
{ status: 500 }
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { decrypt } from "@/app/auth/_lib/decrypt";
|
import { decrypt } from "@/app/(auth)/_lib/decrypt";
|
||||||
import { prisma } from "@/app/lib";
|
import { prisma } from "@/app/lib";
|
||||||
import { cookies } from "next/headers";
|
import { cookies } from "next/headers";
|
||||||
import { NextRequest, NextResponse } from "next/server";
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
@@ -32,7 +32,6 @@ export async function GET(req: NextRequest) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Disconnect after successful query
|
// Disconnect after successful query
|
||||||
await prisma.$disconnect();
|
|
||||||
|
|
||||||
return NextResponse.json({
|
return NextResponse.json({
|
||||||
success: true,
|
success: true,
|
||||||
@@ -41,7 +40,6 @@ export async function GET(req: NextRequest) {
|
|||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Ensure connection is closed even if error occurs
|
// Ensure connection is closed even if error occurs
|
||||||
await prisma.$disconnect();
|
|
||||||
|
|
||||||
console.error("Error in user validation:", error);
|
console.error("Error in user validation:", error);
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
@@ -51,5 +49,7 @@ export async function GET(req: NextRequest) {
|
|||||||
},
|
},
|
||||||
{ status: 500 }
|
{ status: 500 }
|
||||||
);
|
);
|
||||||
|
} finally {
|
||||||
|
await prisma.$disconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { decrypt } from "@/app/auth/_lib/decrypt";
|
import { decrypt } from "@/app/(auth)/_lib/decrypt";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import { cookies } from "next/headers";
|
import { cookies } from "next/headers";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
import { decrypt } from "@/app/auth/_lib/decrypt";
|
import { decrypt } from "@/app/(auth)/_lib/decrypt";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import { cookies } from "next/headers";
|
import { cookies } from "next/headers";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|||||||
@@ -1,10 +1,9 @@
|
|||||||
|
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
|
|
||||||
export async function GET(req: Request) {
|
export async function GET(req: Request) {
|
||||||
const auth = req.headers.get("Authorization");
|
const auth = req.headers.get("Authorization");
|
||||||
const token = auth?.split(" ")[1];
|
const token = auth?.split(" ")[1];
|
||||||
|
|
||||||
if (!token) return NextResponse.json({ success: false }, { status: 401 });
|
if (!token) return NextResponse.json({ success: false }, { status: 401 });
|
||||||
|
|
||||||
return NextResponse.json({ success: true });
|
return NextResponse.json({ success: true });
|
||||||
|
|||||||
@@ -1,25 +0,0 @@
|
|||||||
import { prisma } from "@/app/lib";
|
|
||||||
import { sessionCreate } from "../../_lib/session_create";
|
|
||||||
import { NextResponse } from "next/server";
|
|
||||||
|
|
||||||
export async function POST(req: Request) {
|
|
||||||
const user = await prisma.user.findUnique({
|
|
||||||
where: {
|
|
||||||
nomor: "6281339158911",
|
|
||||||
},
|
|
||||||
select: {
|
|
||||||
id: true,
|
|
||||||
nomor: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!user) return NextResponse.json({ success: false }, { status: 404 });
|
|
||||||
|
|
||||||
const token = await sessionCreate({
|
|
||||||
sessionKey: process.env.NEXT_PUBLIC_BASE_SESSION_KEY!,
|
|
||||||
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
|
||||||
user: user as any,
|
|
||||||
});
|
|
||||||
|
|
||||||
return NextResponse.json({ success: true, token });
|
|
||||||
}
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
import { cookies } from "next/headers";
|
|
||||||
import { NextResponse } from "next/server";
|
|
||||||
|
|
||||||
export async function GET() {
|
|
||||||
const del = cookies().delete(process.env.NEXT_PUBLIC_BASE_SESSION_KEY!);
|
|
||||||
|
|
||||||
return NextResponse.json({ success: true, message: "Logout Berhasil" });
|
|
||||||
}
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
"use client";
|
|
||||||
import { Button } from "@mantine/core";
|
|
||||||
import { useState } from "react";
|
|
||||||
|
|
||||||
export default function Page() {
|
|
||||||
const [loading, setLoading] = useState(false);
|
|
||||||
|
|
||||||
|
|
||||||
async function login() {
|
|
||||||
setLoading(true);
|
|
||||||
try {
|
|
||||||
const res = await fetch("/auth/api/login", {
|
|
||||||
method: "POST",
|
|
||||||
});
|
|
||||||
|
|
||||||
const dataText = await res.text();
|
|
||||||
|
|
||||||
if (!res.ok) {
|
|
||||||
console.error(dataText);
|
|
||||||
throw new Error(res.statusText);
|
|
||||||
}
|
|
||||||
|
|
||||||
const dataJson = JSON.parse(dataText);
|
|
||||||
console.log(dataJson);
|
|
||||||
// window.location.replace("/dev/home");
|
|
||||||
} catch (error) {
|
|
||||||
console.error(error);
|
|
||||||
} finally {
|
|
||||||
setLoading(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return (
|
|
||||||
<>
|
|
||||||
<Button loading={loading} onClick={login}>
|
|
||||||
Login
|
|
||||||
</Button>
|
|
||||||
</>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
"use server";
|
"use server";
|
||||||
|
|
||||||
import { cookies } from "next/headers";
|
import { cookies } from "next/headers";
|
||||||
import { decrypt } from "../../../../app/auth/_lib/decrypt";
|
import { decrypt } from "../../../../app/(auth)/_lib/decrypt";
|
||||||
|
|
||||||
export async function funGetUserIdByToken() {
|
export async function funGetUserIdByToken() {
|
||||||
const SESSION_KEY = process.env.NEXT_PUBLIC_BASE_SESSION_KEY!;
|
const SESSION_KEY = process.env.NEXT_PUBLIC_BASE_SESSION_KEY!;
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ export {
|
|||||||
apiGetCheckCodeOtp,
|
apiGetCheckCodeOtp,
|
||||||
apiPostVerifikasiCodeOtp,
|
apiPostVerifikasiCodeOtp,
|
||||||
apiDeleteAktivasiKodeOtpByNomor,
|
apiDeleteAktivasiKodeOtpByNomor,
|
||||||
|
apiFetchRegister,
|
||||||
};
|
};
|
||||||
|
|
||||||
const apiFetchLogin = async ({ nomor }: { nomor: string }) => {
|
const apiFetchLogin = async ({ nomor }: { nomor: string }) => {
|
||||||
@@ -35,14 +36,38 @@ const apiPostVerifikasiCodeOtp = async ({ nomor }: { nomor: string }) => {
|
|||||||
return await respone.json().catch(() => null);
|
return await respone.json().catch(() => null);
|
||||||
};
|
};
|
||||||
|
|
||||||
const apiDeleteAktivasiKodeOtpByNomor = async ({
|
const apiDeleteAktivasiKodeOtpByNomor = async ({ id }: { id: string }) => {
|
||||||
nomor,
|
const respone = await fetch(`/api/auth/code/${id}`, {
|
||||||
}: {
|
|
||||||
nomor: string;
|
|
||||||
}) => {
|
|
||||||
const respone = await fetch(`/api/auth/delete/${nomor}`, {
|
|
||||||
method: "DELETE",
|
method: "DELETE",
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
return await respone.json().catch(() => null);
|
return await respone.json().catch(() => null);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const apiFetchRegister = async ({
|
||||||
|
nomor,
|
||||||
|
username,
|
||||||
|
}: {
|
||||||
|
nomor: string;
|
||||||
|
username: string;
|
||||||
|
}) => {
|
||||||
|
const data = {
|
||||||
|
username: username,
|
||||||
|
nomor: nomor,
|
||||||
|
};
|
||||||
|
const respone = await fetch("/api/auth/register", {
|
||||||
|
method: "POST",
|
||||||
|
body: JSON.stringify({ data }),
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const result = await respone.json();
|
||||||
|
|
||||||
|
return result;
|
||||||
|
// return await respone.json().catch(() => null);
|
||||||
|
};
|
||||||
|
|||||||
@@ -14,8 +14,13 @@ import { useState } from "react";
|
|||||||
import { auth_funDeleteAktivasiKodeOtpByNomor } from "../fun/fun_edit_aktivasi_kode_otp_by_id";
|
import { auth_funDeleteAktivasiKodeOtpByNomor } from "../fun/fun_edit_aktivasi_kode_otp_by_id";
|
||||||
import Register_SkeletonView from "./skeleton";
|
import Register_SkeletonView from "./skeleton";
|
||||||
import { clientLogger } from "@/util/clientLogger";
|
import { clientLogger } from "@/util/clientLogger";
|
||||||
import { apiGetCheckCodeOtp } from "../_lib/api_fetch_auth";
|
import {
|
||||||
|
apiDeleteAktivasiKodeOtpByNomor,
|
||||||
|
apiFetchRegister,
|
||||||
|
apiGetCheckCodeOtp,
|
||||||
|
} from "../_lib/api_fetch_auth";
|
||||||
import CustomSkeleton from "@/app_modules/components/CustomSkeleton";
|
import CustomSkeleton from "@/app_modules/components/CustomSkeleton";
|
||||||
|
import { ComponentGlobal_NotifikasiGagal } from "@/app_modules/_global/notif_global";
|
||||||
|
|
||||||
export default function Register() {
|
export default function Register() {
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
@@ -24,82 +29,52 @@ export default function Register() {
|
|||||||
const [isValue, setIsValue] = useState(false);
|
const [isValue, setIsValue] = useState(false);
|
||||||
const focusTrapRef = useFocusTrap();
|
const focusTrapRef = useFocusTrap();
|
||||||
const [loading, setLoading] = useState(false);
|
const [loading, setLoading] = useState(false);
|
||||||
|
const [idCode, setIdCode] = useState("");
|
||||||
|
|
||||||
useShallowEffect(() => {
|
useShallowEffect(() => {
|
||||||
const kodeId = localStorage.getItem("hipmi_auth_code_id");
|
const kodeId = localStorage.getItem("hipmi_auth_code_id");
|
||||||
if (kodeId != null) {
|
if (kodeId != null) {
|
||||||
onCheckAuthCode({ kodeId: kodeId as string, onSetData: setNomor });
|
onCheckAuthCode({ kodeId: kodeId as string });
|
||||||
} else {
|
} else {
|
||||||
console.log("code id not found");
|
console.log("code id not found");
|
||||||
}
|
}
|
||||||
}, [setNomor]);
|
}, []);
|
||||||
|
|
||||||
async function onCheckAuthCode({
|
async function onCheckAuthCode({ kodeId }: { kodeId: string }) {
|
||||||
kodeId,
|
|
||||||
onSetData,
|
|
||||||
}: {
|
|
||||||
kodeId: string;
|
|
||||||
onSetData: any;
|
|
||||||
}) {
|
|
||||||
try {
|
try {
|
||||||
const respone = await apiGetCheckCodeOtp({ id: kodeId });
|
const respone = await apiGetCheckCodeOtp({ id: kodeId });
|
||||||
if (respone) {
|
if (respone) {
|
||||||
onSetData(respone.nomor);
|
setIdCode(kodeId);
|
||||||
|
setNomor(respone.nomor);
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
clientLogger.error("Error onCheckAuthCode:", error);
|
clientLogger.error("Error onCheckAuthCode:", error);
|
||||||
}
|
}
|
||||||
// const res = await fetch(`/api/auth/check?id=${kodeId}`);
|
|
||||||
// const result = await res.json();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function onRegistarsi() {
|
async function onRegistarsi() {
|
||||||
const data = {
|
|
||||||
username: value,
|
|
||||||
nomor: nomor,
|
|
||||||
};
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
setLoading(true);
|
setLoading(true);
|
||||||
const res = await fetch("/api/auth/register", {
|
const respone = await apiFetchRegister({ nomor: nomor, username: value });
|
||||||
method: "POST",
|
|
||||||
body: JSON.stringify({
|
|
||||||
data,
|
|
||||||
}),
|
|
||||||
headers: {
|
|
||||||
"Content-Type": "application/json",
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const result = await res.json();
|
|
||||||
|
|
||||||
if (res.status === 200) {
|
|
||||||
ComponentGlobal_NotifikasiBerhasil(result.message);
|
|
||||||
localStorage.removeItem("hipmi_auth_code_id");
|
|
||||||
await auth_funDeleteAktivasiKodeOtpByNomor({
|
|
||||||
nomor: data.nomor,
|
|
||||||
});
|
|
||||||
|
|
||||||
|
if (respone.success) {
|
||||||
router.push("/waiting-room", { scroll: false });
|
router.push("/waiting-room", { scroll: false });
|
||||||
return;
|
ComponentGlobal_NotifikasiBerhasil(respone.message);
|
||||||
}
|
|
||||||
|
|
||||||
if (res.status === 400) {
|
try {
|
||||||
setLoading(false);
|
const responeDelete = await apiDeleteAktivasiKodeOtpByNomor({
|
||||||
ComponentGlobal_NotifikasiPeringatan(result.message);
|
id: idCode,
|
||||||
return;
|
});
|
||||||
}
|
|
||||||
|
|
||||||
if (res.status === 405) {
|
if (responeDelete) {
|
||||||
|
localStorage.removeItem("hipmi_auth_code_id");
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
clientLogger.error("Error apiDeleteAktivasiKodeOtpByNomor:", error);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
ComponentGlobal_NotifikasiPeringatan(result.message);
|
ComponentGlobal_NotifikasiPeringatan(respone.message);
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (res.status === 500) {
|
|
||||||
setLoading(false);
|
|
||||||
ComponentGlobal_NotifikasiPeringatan(result.message);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
@@ -162,6 +137,7 @@ export default function Register() {
|
|||||||
value.length < 5 ||
|
value.length < 5 ||
|
||||||
_.values(value).includes(" ")
|
_.values(value).includes(" ")
|
||||||
}
|
}
|
||||||
|
style={{ transition: "0.5s" }}
|
||||||
loading={loading ? true : false}
|
loading={loading ? true : false}
|
||||||
loaderPosition="center"
|
loaderPosition="center"
|
||||||
radius={"md"}
|
radius={"md"}
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
"use client";
|
"use client";
|
||||||
|
|
||||||
import { RouterAdminDashboard } from "@/app/lib/router_hipmi/router_admin";
|
import { RouterAdminDashboard } from "@/app/lib/router_hipmi/router_admin";
|
||||||
import { RouterHome } from "@/app/lib/router_hipmi/router_home";
|
|
||||||
import {
|
import {
|
||||||
AccentColor,
|
AccentColor,
|
||||||
MainColor,
|
MainColor,
|
||||||
@@ -26,12 +25,9 @@ import { useRouter } from "next/navigation";
|
|||||||
import { useEffect, useState } from "react";
|
import { useEffect, useState } from "react";
|
||||||
|
|
||||||
import { ComponentGlobal_NotifikasiGagal } from "@/app_modules/_global/notif_global";
|
import { ComponentGlobal_NotifikasiGagal } from "@/app_modules/_global/notif_global";
|
||||||
import { auth_funDeleteAktivasiKodeOtpByNomor } from "../fun/fun_edit_aktivasi_kode_otp_by_id";
|
import CustomSkeleton from "@/app_modules/components/CustomSkeleton";
|
||||||
import Validasi_SkeletonView from "./skeleton";
|
|
||||||
import { clientLogger } from "@/util/clientLogger";
|
import { clientLogger } from "@/util/clientLogger";
|
||||||
import { IconChevronLeft } from "@tabler/icons-react";
|
import { IconChevronLeft } from "@tabler/icons-react";
|
||||||
import _ from "lodash";
|
|
||||||
import CustomSkeleton from "@/app_modules/components/CustomSkeleton";
|
|
||||||
import {
|
import {
|
||||||
apiDeleteAktivasiKodeOtpByNomor,
|
apiDeleteAktivasiKodeOtpByNomor,
|
||||||
apiGetCheckCodeOtp,
|
apiGetCheckCodeOtp,
|
||||||
@@ -46,6 +42,7 @@ export default function Validasi() {
|
|||||||
const [counter, setCounter] = useState(60);
|
const [counter, setCounter] = useState(60);
|
||||||
const [loadingResend, setLoadingResend] = useState(false);
|
const [loadingResend, setLoadingResend] = useState(false);
|
||||||
const [triggerOtp, setTriggerOtp] = useState(false);
|
const [triggerOtp, setTriggerOtp] = useState(false);
|
||||||
|
const [idCode, setIdCode] = useState("");
|
||||||
|
|
||||||
const [data, setData] = useState({
|
const [data, setData] = useState({
|
||||||
nomor: "",
|
nomor: "",
|
||||||
@@ -74,7 +71,9 @@ export default function Validasi() {
|
|||||||
async function onCheckAuthCode({ kodeId }: { kodeId: string }) {
|
async function onCheckAuthCode({ kodeId }: { kodeId: string }) {
|
||||||
try {
|
try {
|
||||||
const respone = await apiGetCheckCodeOtp({ id: kodeId });
|
const respone = await apiGetCheckCodeOtp({ id: kodeId });
|
||||||
|
|
||||||
if (respone) {
|
if (respone) {
|
||||||
|
setIdCode(kodeId);
|
||||||
setData({
|
setData({
|
||||||
nomor: respone.nomor,
|
nomor: respone.nomor,
|
||||||
code: respone.otp,
|
code: respone.otp,
|
||||||
@@ -101,21 +100,21 @@ export default function Validasi() {
|
|||||||
|
|
||||||
if (respone && respone.success == true) {
|
if (respone && respone.success == true) {
|
||||||
if (respone.roleId == "1") {
|
if (respone.roleId == "1") {
|
||||||
|
router.push("/login", { scroll: false });
|
||||||
ComponentGlobal_NotifikasiBerhasil(respone.message);
|
ComponentGlobal_NotifikasiBerhasil(respone.message);
|
||||||
localStorage.removeItem("hipmi_auth_code_id");
|
|
||||||
|
|
||||||
router.push(RouterHome.main_home, { scroll: false });
|
|
||||||
} else if (respone.roleId != "1") {
|
} else if (respone.roleId != "1") {
|
||||||
ComponentGlobal_NotifikasiBerhasil("Admin berhasil login");
|
|
||||||
localStorage.removeItem("hipmi_auth_code_id");
|
|
||||||
|
|
||||||
router.push(RouterAdminDashboard.splash_admin, { scroll: false });
|
router.push(RouterAdminDashboard.splash_admin, { scroll: false });
|
||||||
|
ComponentGlobal_NotifikasiBerhasil("Admin berhasil login");
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const responeDelete = await apiDeleteAktivasiKodeOtpByNomor({
|
const responeDelete = await apiDeleteAktivasiKodeOtpByNomor({
|
||||||
nomor: data.nomor,
|
id: idCode,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (responeDelete) {
|
||||||
|
localStorage.removeItem("hipmi_auth_code_id");
|
||||||
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
clientLogger.error("Error apiDeleteAktivasiKodeOtpByNomor:", error);
|
clientLogger.error("Error apiDeleteAktivasiKodeOtpByNomor:", error);
|
||||||
}
|
}
|
||||||
@@ -123,47 +122,6 @@ export default function Validasi() {
|
|||||||
router.push("/register", { scroll: false });
|
router.push("/register", { scroll: false });
|
||||||
ComponentGlobal_NotifikasiBerhasil(respone.message);
|
ComponentGlobal_NotifikasiBerhasil(respone.message);
|
||||||
}
|
}
|
||||||
|
|
||||||
// if (respone.status === 200 && result.roleId == "1") {
|
|
||||||
// ComponentGlobal_NotifikasiBerhasil(result.message);
|
|
||||||
// localStorage.removeItem("hipmi_auth_code_id");
|
|
||||||
// await auth_funDeleteAktivasiKodeOtpByNomor({
|
|
||||||
// nomor: data.nomor,
|
|
||||||
// });
|
|
||||||
|
|
||||||
// router.push(RouterHome.main_home, { scroll: false });
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (respone.status === 200 && result.roleId != "1") {
|
|
||||||
// ComponentGlobal_NotifikasiBerhasil("Admin Logged in");
|
|
||||||
// localStorage.removeItem("hipmi_auth_code_id");
|
|
||||||
// await auth_funDeleteAktivasiKodeOtpByNomor({
|
|
||||||
// nomor: data.nomor,
|
|
||||||
// });
|
|
||||||
|
|
||||||
// router.push(RouterAdminDashboard.splash_admin, { scroll: false });
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (respone.status === 404) {
|
|
||||||
// setLoading(false);
|
|
||||||
// router.push("/register", { scroll: false });
|
|
||||||
// ComponentGlobal_NotifikasiBerhasil(result.message);
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (respone.status === 400) {
|
|
||||||
// setLoading(false);
|
|
||||||
// ComponentGlobal_NotifikasiPeringatan(result.message);
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (respone.status == 500) {
|
|
||||||
// setLoading(false);
|
|
||||||
// ComponentGlobal_NotifikasiGagal(result.message);
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
clientLogger.error("Error validasi:", error);
|
clientLogger.error("Error validasi:", error);
|
||||||
@@ -171,9 +129,18 @@ export default function Validasi() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function onBack() {
|
async function onBack() {
|
||||||
localStorage.removeItem("hipmi_auth_code_id");
|
try {
|
||||||
await auth_funDeleteAktivasiKodeOtpByNomor({ nomor: data.nomor });
|
router.back();
|
||||||
router.back();
|
const responeDelete = await apiDeleteAktivasiKodeOtpByNomor({
|
||||||
|
id: idCode,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (responeDelete) {
|
||||||
|
localStorage.removeItem("hipmi_auth_code_id");
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
clientLogger.error("Error apiDeleteAktivasiKodeOtpByNomor:", error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function onResendCode() {
|
async function onResendCode() {
|
||||||
@@ -197,13 +164,12 @@ export default function Validasi() {
|
|||||||
setTriggerOtp(true);
|
setTriggerOtp(true);
|
||||||
setCounter(60);
|
setCounter(60);
|
||||||
setLoadingResend(false);
|
setLoadingResend(false);
|
||||||
// router.push("/validasi", { scroll: false });
|
|
||||||
} else {
|
} else {
|
||||||
setLoadingResend(false);
|
setLoadingResend(false);
|
||||||
ComponentGlobal_NotifikasiPeringatan(result.message);
|
ComponentGlobal_NotifikasiPeringatan(result.message);
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error(error);
|
clientLogger.error(" Error onResend", error);
|
||||||
setLoadingResend(false);
|
setLoadingResend(false);
|
||||||
ComponentGlobal_NotifikasiGagal("Terjadi Kesalahan");
|
ComponentGlobal_NotifikasiGagal("Terjadi Kesalahan");
|
||||||
}
|
}
|
||||||
@@ -213,7 +179,7 @@ export default function Validasi() {
|
|||||||
<>
|
<>
|
||||||
<UIGlobal_LayoutDefault>
|
<UIGlobal_LayoutDefault>
|
||||||
<Stack h={"100vh"}>
|
<Stack h={"100vh"}>
|
||||||
{/* <Box
|
<Box
|
||||||
pt={"md"}
|
pt={"md"}
|
||||||
px={"md"}
|
px={"md"}
|
||||||
style={{
|
style={{
|
||||||
@@ -222,9 +188,13 @@ export default function Validasi() {
|
|||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<ActionIcon variant="transparent" onClick={() => onBack()}>
|
<ActionIcon variant="transparent" onClick={() => onBack()}>
|
||||||
<IconChevronLeft color="white" />
|
{data && data.nomor !== "" ? (
|
||||||
|
<IconChevronLeft color="white" />
|
||||||
|
) : (
|
||||||
|
""
|
||||||
|
)}
|
||||||
</ActionIcon>
|
</ActionIcon>
|
||||||
</Box> */}
|
</Box>
|
||||||
|
|
||||||
<Stack align="center" justify="center" h={"100vh"} spacing={50}>
|
<Stack align="center" justify="center" h={"100vh"} spacing={50}>
|
||||||
<Title order={2} color={MainColor.yellow}>
|
<Title order={2} color={MainColor.yellow}>
|
||||||
@@ -260,31 +230,40 @@ export default function Validasi() {
|
|||||||
</Center>
|
</Center>
|
||||||
|
|
||||||
<Stack h={"5vh"} align="center" justify="center">
|
<Stack h={"5vh"} align="center" justify="center">
|
||||||
<Text fs="italic" c={MainColor.white}>
|
<Group position="center">
|
||||||
Tidak menerima kode ?{" "}
|
<Text fs="italic" c={MainColor.white}>
|
||||||
{counter > 0 ? (
|
Tidak menerima kode ?{" "}
|
||||||
<Text fw={"bold"} inherit span>
|
</Text>
|
||||||
{counter + "s"}
|
{data && data.nomor !== "" ? (
|
||||||
</Text>
|
counter > 0 ? (
|
||||||
) : loadingResend ? (
|
<Text fw={"bold"} c={MainColor.white}>
|
||||||
<Loader ml={"sm"} size={"xs"} color="yellow" />
|
{counter + "s"}
|
||||||
|
</Text>
|
||||||
|
) : loadingResend ? (
|
||||||
|
<Loader ml={"sm"} size={"xs"} color="yellow" />
|
||||||
|
) : (
|
||||||
|
<Text
|
||||||
|
c={MainColor.white}
|
||||||
|
onClick={() => {
|
||||||
|
onResendCode();
|
||||||
|
}}
|
||||||
|
fw={"bold"}
|
||||||
|
>
|
||||||
|
Kirim ulang
|
||||||
|
</Text>
|
||||||
|
)
|
||||||
) : (
|
) : (
|
||||||
<Text
|
<CustomSkeleton height={20} radius={"xl"} width={20} />
|
||||||
inherit
|
|
||||||
span
|
|
||||||
onClick={() => {
|
|
||||||
onResendCode();
|
|
||||||
}}
|
|
||||||
fw={"bold"}
|
|
||||||
>
|
|
||||||
Kirim ulang
|
|
||||||
</Text>
|
|
||||||
)}
|
)}
|
||||||
</Text>
|
</Group>
|
||||||
</Stack>
|
</Stack>
|
||||||
</Stack>
|
</Stack>
|
||||||
<Button
|
<Button
|
||||||
w={300}
|
w={300}
|
||||||
|
disabled={inputCode.length < 4 ? true : false}
|
||||||
|
style={{
|
||||||
|
transition: "all ease 0.3s",
|
||||||
|
}}
|
||||||
loading={loading ? true : false}
|
loading={loading ? true : false}
|
||||||
loaderPosition="center"
|
loaderPosition="center"
|
||||||
radius={"md"}
|
radius={"md"}
|
||||||
@@ -293,9 +272,6 @@ export default function Validasi() {
|
|||||||
c={"black"}
|
c={"black"}
|
||||||
bg={MainColor.yellow}
|
bg={MainColor.yellow}
|
||||||
color={"yellow"}
|
color={"yellow"}
|
||||||
style={{
|
|
||||||
borderColor: AccentColor.yellow,
|
|
||||||
}}
|
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
data.nomor == "" && data.code == ""
|
data.nomor == "" && data.code == ""
|
||||||
? null
|
? null
|
||||||
@@ -305,8 +281,6 @@ export default function Validasi() {
|
|||||||
<Text>VERIFIKASI</Text>
|
<Text>VERIFIKASI</Text>
|
||||||
</Button>
|
</Button>
|
||||||
</Stack>
|
</Stack>
|
||||||
|
|
||||||
{/* {data.nomor == "" && data.code == "" ? <Validasi_SkeletonView /> : ""} */}
|
|
||||||
</Stack>
|
</Stack>
|
||||||
</UIGlobal_LayoutDefault>
|
</UIGlobal_LayoutDefault>
|
||||||
</>
|
</>
|
||||||
|
|||||||
@@ -43,8 +43,6 @@ const middlewareConfig: MiddlewareConfig = {
|
|||||||
// "/api/admin/voting/dashboard/*",
|
// "/api/admin/voting/dashboard/*",
|
||||||
// "/api/admin/job/dashboard/*",
|
// "/api/admin/job/dashboard/*",
|
||||||
// "/api/admin/forum/dashboard/*",
|
// "/api/admin/forum/dashboard/*",
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Akses awal
|
// Akses awal
|
||||||
"/api/get-cookie",
|
"/api/get-cookie",
|
||||||
@@ -78,134 +76,142 @@ export const middleware = async (req: NextRequest) => {
|
|||||||
apiPath,
|
apiPath,
|
||||||
encodedKey,
|
encodedKey,
|
||||||
loginPath,
|
loginPath,
|
||||||
// validasiPath,
|
|
||||||
// registarasiPath,
|
|
||||||
publicRoutes,
|
publicRoutes,
|
||||||
sessionKey,
|
sessionKey,
|
||||||
validationApiRoute,
|
validationApiRoute,
|
||||||
userPath,
|
userPath,
|
||||||
} = middlewareConfig;
|
} = middlewareConfig;
|
||||||
|
|
||||||
const { pathname } = req.nextUrl;
|
const { pathname } = req.nextUrl;
|
||||||
|
|
||||||
// CORS handling
|
// Handle CORS
|
||||||
const corsResponse = handleCors(req);
|
const corsResponse = handleCors(req);
|
||||||
if (corsResponse) {
|
if (corsResponse) {
|
||||||
return setCorsHeaders(corsResponse);
|
return corsResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Skip authentication for public routes
|
// Check if route is public
|
||||||
const isPublicRoute = [
|
const isPublicRoute = isRoutePublic(pathname, publicRoutes, loginPath);
|
||||||
...publicRoutes,
|
if (isPublicRoute && pathname !== loginPath) {
|
||||||
loginPath,
|
|
||||||
// validasiPath,
|
|
||||||
// registarasiPath,
|
|
||||||
].some((route) => {
|
|
||||||
const pattern = route.replace(/\*/g, ".*");
|
|
||||||
return new RegExp(`^${pattern}$`).test(pathname);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Always protect validation endpoint
|
|
||||||
if (pathname === validationApiRoute) {
|
|
||||||
const reqToken = req.headers.get("Authorization")?.split(" ")[1];
|
|
||||||
if (!reqToken) {
|
|
||||||
return setCorsHeaders(unauthorizedResponse());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
|
||||||
isPublicRoute &&
|
|
||||||
pathname !== loginPath
|
|
||||||
// &&
|
|
||||||
// pathname !== validasiPath &&
|
|
||||||
// pathname !== registarasiPath
|
|
||||||
) {
|
|
||||||
return setCorsHeaders(NextResponse.next());
|
return setCorsHeaders(NextResponse.next());
|
||||||
}
|
}
|
||||||
|
|
||||||
const token =
|
// Get token from cookies or Authorization header
|
||||||
req.cookies.get(sessionKey)?.value ||
|
const token = getToken(req, sessionKey);
|
||||||
req.headers.get("Authorization")?.split(" ")[1];
|
|
||||||
|
|
||||||
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
// Verify token and get user data
|
||||||
// Token verification
|
|
||||||
const user = await verifyToken({ token, encodedKey });
|
const user = await verifyToken({ token, encodedKey });
|
||||||
|
|
||||||
// Handle login page access
|
// Handle login page access
|
||||||
if (pathname === loginPath) {
|
if (pathname === loginPath) {
|
||||||
if (user) {
|
if (user) {
|
||||||
return setCorsHeaders(NextResponse.redirect(new URL(userPath, req.url)));
|
const response = NextResponse.redirect(new URL(userPath, req.url));
|
||||||
|
// Preserve token in cookie when redirecting
|
||||||
|
if (token) {
|
||||||
|
response.cookies.set(sessionKey, token, {
|
||||||
|
httpOnly: true,
|
||||||
|
secure: process.env.NODE_ENV === "production",
|
||||||
|
sameSite: "lax",
|
||||||
|
path: "/",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return setCorsHeaders(response);
|
||||||
}
|
}
|
||||||
return setCorsHeaders(NextResponse.next());
|
return setCorsHeaders(NextResponse.next());
|
||||||
}
|
}
|
||||||
|
|
||||||
// // Handle validation page access
|
// Redirect to login if no user found
|
||||||
// if (pathname === validasiPath) {
|
|
||||||
// if (user) {
|
|
||||||
// return setCorsHeaders(NextResponse.redirect(new URL(userPath, req.url)));
|
|
||||||
// }
|
|
||||||
// return setCorsHeaders(NextResponse.next());
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // Handle register page access
|
|
||||||
// if (pathname === registarasiPath) {
|
|
||||||
// if (user) {
|
|
||||||
// return setCorsHeaders(NextResponse.redirect(new URL(userPath, req.url)));
|
|
||||||
// }
|
|
||||||
// return setCorsHeaders(NextResponse.next());
|
|
||||||
// }
|
|
||||||
|
|
||||||
// Handle protected routes
|
|
||||||
if (!user) {
|
if (!user) {
|
||||||
return setCorsHeaders(NextResponse.redirect(new URL(loginPath, req.url)));
|
const response = NextResponse.redirect(new URL(loginPath, req.url));
|
||||||
|
// Clear invalid token
|
||||||
|
response.cookies.delete(sessionKey);
|
||||||
|
return setCorsHeaders(response);
|
||||||
}
|
}
|
||||||
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
|
||||||
|
|
||||||
|
// Handle /dev routes that require active status
|
||||||
if (pathname.startsWith("/dev")) {
|
if (pathname.startsWith("/dev")) {
|
||||||
const userValidate = await fetch(new URL("/api/user-validate", req.url), {
|
try {
|
||||||
headers: {
|
const userValidate = await fetch(new URL("/api/user-validate", req.url), {
|
||||||
"Content-Type": "application/json",
|
|
||||||
Authorization: `Bearer ${token}`,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const userValidateJson = await userValidate.json();
|
|
||||||
|
|
||||||
if (!userValidateJson.data.active) {
|
|
||||||
return setCorsHeaders(
|
|
||||||
NextResponse.redirect(new URL("/waiting-room", req.url))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle authenticated API requests
|
|
||||||
if (pathname.startsWith(apiPath)) {
|
|
||||||
const reqToken = req.headers.get("Authorization")?.split(" ")[1];
|
|
||||||
if (!reqToken) {
|
|
||||||
return setCorsHeaders(unauthorizedResponse());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Validate user access with external API
|
|
||||||
const validationResponse = await fetch(
|
|
||||||
new URL(validationApiRoute, req.url),
|
|
||||||
{
|
|
||||||
headers: {
|
headers: {
|
||||||
"Content-Type": "application/json",
|
"Content-Type": "application/json",
|
||||||
Authorization: `Bearer ${reqToken}`,
|
Authorization: `Bearer ${token}`,
|
||||||
},
|
},
|
||||||
}
|
});
|
||||||
);
|
|
||||||
|
|
||||||
if (!validationResponse.ok) {
|
if (!userValidate.ok) {
|
||||||
|
throw new Error("Failed to validate user");
|
||||||
|
}
|
||||||
|
|
||||||
|
const userValidateJson = await userValidate.json();
|
||||||
|
|
||||||
|
if (!userValidateJson.data.active) {
|
||||||
|
return setCorsHeaders(
|
||||||
|
NextResponse.redirect(new URL("/waiting-room", req.url))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error validating user:", error);
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle API requests
|
||||||
|
if (pathname.startsWith(apiPath)) {
|
||||||
|
if (!token) {
|
||||||
return setCorsHeaders(unauthorizedResponse());
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
}
|
}
|
||||||
|
|
||||||
const dataJson = await validationResponse.json();
|
try {
|
||||||
|
const validationResponse = await fetch(
|
||||||
|
new URL(validationApiRoute, req.url),
|
||||||
|
{
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: `Bearer ${token}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!validationResponse.ok) {
|
||||||
|
throw new Error("Failed to validate API request");
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error validating API request:", error);
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Proceed with the request
|
const response = NextResponse.next();
|
||||||
return setCorsHeaders(NextResponse.next());
|
// Ensure token is preserved in cookie
|
||||||
|
if (token) {
|
||||||
|
response.cookies.set(sessionKey, token, {
|
||||||
|
httpOnly: true,
|
||||||
|
secure: process.env.NODE_ENV === "production",
|
||||||
|
sameSite: "lax",
|
||||||
|
path: "/",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return setCorsHeaders(response);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
function isRoutePublic(
|
||||||
|
pathname: string,
|
||||||
|
publicRoutes: string[],
|
||||||
|
loginPath: string
|
||||||
|
): boolean {
|
||||||
|
return [...publicRoutes, loginPath].some((route) => {
|
||||||
|
const pattern = route.replace(/\*/g, ".*");
|
||||||
|
return new RegExp(`^${pattern}$`).test(pathname);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function getToken(req: NextRequest, sessionKey: string): string | undefined {
|
||||||
|
return (
|
||||||
|
req.cookies.get(sessionKey)?.value ||
|
||||||
|
req.headers.get("Authorization")?.split(" ")[1]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
function unauthorizedResponse(): NextResponse {
|
function unauthorizedResponse(): NextResponse {
|
||||||
return new NextResponse(JSON.stringify({ error: "Unauthorized" }), {
|
return new NextResponse(JSON.stringify({ error: "Unauthorized" }), {
|
||||||
status: 401,
|
status: 401,
|
||||||
@@ -250,16 +256,6 @@ async function verifyToken({
|
|||||||
}): Promise<Record<string, unknown> | null> {
|
}): Promise<Record<string, unknown> | null> {
|
||||||
if (!token) return null;
|
if (!token) return null;
|
||||||
|
|
||||||
return await decrypt({ token, encodedKey });
|
|
||||||
}
|
|
||||||
|
|
||||||
async function decrypt({
|
|
||||||
token,
|
|
||||||
encodedKey,
|
|
||||||
}: {
|
|
||||||
token: string;
|
|
||||||
encodedKey: string;
|
|
||||||
}): Promise<Record<string, any> | null> {
|
|
||||||
try {
|
try {
|
||||||
const enc = new TextEncoder().encode(encodedKey);
|
const enc = new TextEncoder().encode(encodedKey);
|
||||||
const { payload } = await jwtVerify(token, enc, {
|
const { payload } = await jwtVerify(token, enc, {
|
||||||
@@ -267,7 +263,7 @@ async function decrypt({
|
|||||||
});
|
});
|
||||||
return (payload.user as Record<string, any>) || null;
|
return (payload.user as Record<string, any>) || null;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Gagal verifikasi session", error);
|
console.error("Token verification failed:", error);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -275,5 +271,3 @@ async function decrypt({
|
|||||||
export const config = {
|
export const config = {
|
||||||
matcher: ["/((?!_next|static|favicon.ico|manifest).*)"],
|
matcher: ["/((?!_next|static|favicon.ico|manifest).*)"],
|
||||||
};
|
};
|
||||||
|
|
||||||
// wibu:0.2.82
|
|
||||||
|
|||||||
284
src/middleware.v2.back.txt
Normal file
284
src/middleware.v2.back.txt
Normal file
@@ -0,0 +1,284 @@
|
|||||||
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
|
import { jwtVerify } from "jose";
|
||||||
|
import { apies, pages } from "./lib/routes";
|
||||||
|
|
||||||
|
type MiddlewareConfig = {
|
||||||
|
apiPath: string;
|
||||||
|
loginPath: string;
|
||||||
|
// validasiPath: string;
|
||||||
|
// registarasiPath: string;
|
||||||
|
userPath: string;
|
||||||
|
publicRoutes: string[];
|
||||||
|
encodedKey: string;
|
||||||
|
sessionKey: string;
|
||||||
|
validationApiRoute: string;
|
||||||
|
log: boolean;
|
||||||
|
};
|
||||||
|
|
||||||
|
const middlewareConfig: MiddlewareConfig = {
|
||||||
|
apiPath: "/api",
|
||||||
|
loginPath: "/login",
|
||||||
|
// validasiPath: "/validasi",
|
||||||
|
// registarasiPath: "/register",
|
||||||
|
userPath: "/dev/home",
|
||||||
|
publicRoutes: [
|
||||||
|
// API
|
||||||
|
"/",
|
||||||
|
"/api/voting/*",
|
||||||
|
"/api/collaboration/*",
|
||||||
|
"/api/notifikasi/*",
|
||||||
|
"/api/logs/*",
|
||||||
|
"/api/job/*",
|
||||||
|
"/api/auth/*",
|
||||||
|
"/api/origin-url",
|
||||||
|
"/api/event/*",
|
||||||
|
// "/api/master/*",
|
||||||
|
// "/api/image/*",
|
||||||
|
// "/api/user/*",
|
||||||
|
// "/api/new/*",
|
||||||
|
// ADMIN API
|
||||||
|
// "/api/admin/event/*",
|
||||||
|
// "/api/admin/investasi/*",
|
||||||
|
// "/api/admin/donasi/dashboard/*",
|
||||||
|
// "/api/admin/voting/dashboard/*",
|
||||||
|
// "/api/admin/job/dashboard/*",
|
||||||
|
// "/api/admin/forum/dashboard/*",
|
||||||
|
|
||||||
|
// Akses awal
|
||||||
|
"/api/get-cookie",
|
||||||
|
"/api/user/activation",
|
||||||
|
"/api/user-validate",
|
||||||
|
|
||||||
|
// PAGE
|
||||||
|
"/login",
|
||||||
|
"/register",
|
||||||
|
"/validasi",
|
||||||
|
"/splash",
|
||||||
|
"/job-vacancy",
|
||||||
|
"/preview-image",
|
||||||
|
"/auth/login",
|
||||||
|
"/auth/api/login",
|
||||||
|
"/waiting-room",
|
||||||
|
"/zCoba/*",
|
||||||
|
|
||||||
|
// ASSETS
|
||||||
|
"/aset/global/main_background.png",
|
||||||
|
"/aset/logo/logo-hipmi.png",
|
||||||
|
],
|
||||||
|
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
||||||
|
sessionKey: process.env.NEXT_PUBLIC_BASE_SESSION_KEY!,
|
||||||
|
validationApiRoute: "/api/validation",
|
||||||
|
log: false,
|
||||||
|
};
|
||||||
|
|
||||||
|
export const middleware = async (req: NextRequest) => {
|
||||||
|
const {
|
||||||
|
apiPath,
|
||||||
|
encodedKey,
|
||||||
|
loginPath,
|
||||||
|
// validasiPath,
|
||||||
|
// registarasiPath,
|
||||||
|
publicRoutes,
|
||||||
|
sessionKey,
|
||||||
|
validationApiRoute,
|
||||||
|
userPath,
|
||||||
|
} = middlewareConfig;
|
||||||
|
const { pathname } = req.nextUrl;
|
||||||
|
|
||||||
|
// CORS handling
|
||||||
|
const corsResponse = handleCors(req);
|
||||||
|
if (corsResponse) {
|
||||||
|
return setCorsHeaders(corsResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Skip authentication for public routes
|
||||||
|
const isPublicRoute = [
|
||||||
|
...publicRoutes,
|
||||||
|
loginPath,
|
||||||
|
// validasiPath,
|
||||||
|
// registarasiPath,
|
||||||
|
].some((route) => {
|
||||||
|
const pattern = route.replace(/\*/g, ".*");
|
||||||
|
return new RegExp(`^${pattern}$`).test(pathname);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Always protect validation endpoint
|
||||||
|
if (pathname === validationApiRoute) {
|
||||||
|
const reqToken = req.headers.get("Authorization")?.split(" ")[1];
|
||||||
|
if (!reqToken) {
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
isPublicRoute &&
|
||||||
|
pathname !== loginPath
|
||||||
|
// &&
|
||||||
|
// pathname !== validasiPath &&
|
||||||
|
// pathname !== registarasiPath
|
||||||
|
) {
|
||||||
|
return setCorsHeaders(NextResponse.next());
|
||||||
|
}
|
||||||
|
|
||||||
|
const token =
|
||||||
|
req.cookies.get(sessionKey)?.value ||
|
||||||
|
req.headers.get("Authorization")?.split(" ")[1];
|
||||||
|
|
||||||
|
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
||||||
|
// Token verification
|
||||||
|
const user = await verifyToken({ token, encodedKey });
|
||||||
|
console.log("middlaware console:", user);
|
||||||
|
|
||||||
|
// Handle login page access
|
||||||
|
if (pathname === loginPath) {
|
||||||
|
console.log("cek pathname >>", pathname);
|
||||||
|
if (user) {
|
||||||
|
console.log("sudah login, cek user >>", user);
|
||||||
|
return setCorsHeaders(NextResponse.redirect(new URL(userPath, req.url)));
|
||||||
|
}
|
||||||
|
return setCorsHeaders(NextResponse.next());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!user) {
|
||||||
|
return setCorsHeaders(NextResponse.redirect(new URL(loginPath, req.url)));
|
||||||
|
}
|
||||||
|
|
||||||
|
// // Handle validation page access
|
||||||
|
// if (pathname === validasiPath) {
|
||||||
|
// if (user) {
|
||||||
|
// return setCorsHeaders(NextResponse.redirect(new URL(userPath, req.url)));
|
||||||
|
// }
|
||||||
|
// return setCorsHeaders(NextResponse.next());
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // Handle register page access
|
||||||
|
// if (pathname === registarasiPath) {
|
||||||
|
// if (user) {
|
||||||
|
// return setCorsHeaders(NextResponse.redirect(new URL(userPath, req.url)));
|
||||||
|
// }
|
||||||
|
// return setCorsHeaders(NextResponse.next());
|
||||||
|
// }
|
||||||
|
|
||||||
|
// Handle protected routes
|
||||||
|
// if (!user) {
|
||||||
|
// return setCorsHeaders(NextResponse.redirect(new URL(loginPath, req.url)));
|
||||||
|
// }
|
||||||
|
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
||||||
|
|
||||||
|
if (pathname.startsWith("/dev")) {
|
||||||
|
const userValidate = await fetch(new URL("/api/user-validate", req.url), {
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: `Bearer ${token}`,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const userValidateJson = await userValidate.json();
|
||||||
|
|
||||||
|
if (!userValidateJson.data.active) {
|
||||||
|
return setCorsHeaders(
|
||||||
|
NextResponse.redirect(new URL("/waiting-room", req.url))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle authenticated API requests
|
||||||
|
if (pathname.startsWith(apiPath)) {
|
||||||
|
const reqToken = req.headers.get("Authorization")?.split(" ")[1];
|
||||||
|
if (!reqToken) {
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Validate user access with external API
|
||||||
|
const validationResponse = await fetch(
|
||||||
|
new URL(validationApiRoute, req.url),
|
||||||
|
{
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: `Bearer ${reqToken}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!validationResponse.ok) {
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
|
||||||
|
const dataJson = await validationResponse.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Proceed with the request
|
||||||
|
return setCorsHeaders(NextResponse.next());
|
||||||
|
};
|
||||||
|
|
||||||
|
function unauthorizedResponse(): NextResponse {
|
||||||
|
return new NextResponse(JSON.stringify({ error: "Unauthorized" }), {
|
||||||
|
status: 401,
|
||||||
|
headers: { "Content-Type": "application/json" },
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function setCorsHeaders(res: NextResponse): NextResponse {
|
||||||
|
res.headers.set("Access-Control-Allow-Origin", "*");
|
||||||
|
res.headers.set(
|
||||||
|
"Access-Control-Allow-Methods",
|
||||||
|
"GET, POST, PUT, DELETE, OPTIONS"
|
||||||
|
);
|
||||||
|
res.headers.set(
|
||||||
|
"Access-Control-Allow-Headers",
|
||||||
|
"Content-Type, Authorization"
|
||||||
|
);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleCors(req: NextRequest): NextResponse | null {
|
||||||
|
if (req.method === "OPTIONS") {
|
||||||
|
return new NextResponse(null, {
|
||||||
|
status: 204,
|
||||||
|
headers: {
|
||||||
|
"Access-Control-Allow-Origin": "*",
|
||||||
|
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE, OPTIONS",
|
||||||
|
"Access-Control-Allow-Headers": "Content-Type, Authorization",
|
||||||
|
"Access-Control-Max-Age": "86400",
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function verifyToken({
|
||||||
|
token,
|
||||||
|
encodedKey,
|
||||||
|
}: {
|
||||||
|
token: string | undefined;
|
||||||
|
encodedKey: string;
|
||||||
|
}): Promise<Record<string, unknown> | null> {
|
||||||
|
if (!token) return null;
|
||||||
|
|
||||||
|
return await decrypt({ token, encodedKey });
|
||||||
|
}
|
||||||
|
|
||||||
|
async function decrypt({
|
||||||
|
token,
|
||||||
|
encodedKey,
|
||||||
|
}: {
|
||||||
|
token: string;
|
||||||
|
encodedKey: string;
|
||||||
|
}): Promise<Record<string, any> | null> {
|
||||||
|
try {
|
||||||
|
const enc = new TextEncoder().encode(encodedKey);
|
||||||
|
const { payload } = await jwtVerify(token, enc, {
|
||||||
|
algorithms: ["HS256"],
|
||||||
|
});
|
||||||
|
return (payload.user as Record<string, any>) || null;
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Gagal verifikasi session", error);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const config = {
|
||||||
|
matcher: ["/((?!_next|static|favicon.ico|manifest).*)"],
|
||||||
|
};
|
||||||
|
|
||||||
|
// wibu:0.2.82
|
||||||
244
src/middleware.v3.back.txt
Normal file
244
src/middleware.v3.back.txt
Normal file
@@ -0,0 +1,244 @@
|
|||||||
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
|
import { jwtVerify } from "jose";
|
||||||
|
|
||||||
|
type MiddlewareConfig = {
|
||||||
|
apiPath: string;
|
||||||
|
loginPath: string;
|
||||||
|
userPath: string;
|
||||||
|
publicRoutes: string[];
|
||||||
|
encodedKey: string;
|
||||||
|
sessionKey: string;
|
||||||
|
validationApiRoute: string;
|
||||||
|
log: boolean;
|
||||||
|
};
|
||||||
|
|
||||||
|
const middlewareConfig: MiddlewareConfig = {
|
||||||
|
apiPath: "/api",
|
||||||
|
loginPath: "/login",
|
||||||
|
userPath: "/dev/home",
|
||||||
|
publicRoutes: [
|
||||||
|
"/",
|
||||||
|
"/api/voting/*",
|
||||||
|
"/api/collaboration/*",
|
||||||
|
"/api/notifikasi/*",
|
||||||
|
"/api/logs/*",
|
||||||
|
"/api/job/*",
|
||||||
|
"/api/auth/*",
|
||||||
|
"/api/origin-url",
|
||||||
|
"/api/event/*",
|
||||||
|
"/api/get-cookie",
|
||||||
|
"/api/user/activation",
|
||||||
|
"/api/user-validate",
|
||||||
|
"/login",
|
||||||
|
"/register",
|
||||||
|
"/validasi",
|
||||||
|
"/splash",
|
||||||
|
"/job-vacancy",
|
||||||
|
"/preview-image",
|
||||||
|
"/auth/login",
|
||||||
|
"/auth/api/login",
|
||||||
|
"/waiting-room",
|
||||||
|
"/zCoba/*",
|
||||||
|
"/aset/global/main_background.png",
|
||||||
|
"/aset/logo/logo-hipmi.png",
|
||||||
|
],
|
||||||
|
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
||||||
|
sessionKey: process.env.NEXT_PUBLIC_BASE_SESSION_KEY!,
|
||||||
|
validationApiRoute: "/api/validation",
|
||||||
|
log: false,
|
||||||
|
};
|
||||||
|
|
||||||
|
export const middleware = async (req: NextRequest) => {
|
||||||
|
const {
|
||||||
|
apiPath,
|
||||||
|
encodedKey,
|
||||||
|
loginPath,
|
||||||
|
publicRoutes,
|
||||||
|
sessionKey,
|
||||||
|
validationApiRoute,
|
||||||
|
userPath,
|
||||||
|
} = middlewareConfig;
|
||||||
|
|
||||||
|
const { pathname } = req.nextUrl;
|
||||||
|
|
||||||
|
// Handle CORS
|
||||||
|
const corsResponse = handleCors(req);
|
||||||
|
if (corsResponse) {
|
||||||
|
return corsResponse;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if route is public
|
||||||
|
const isPublicRoute = isRoutePublic(pathname, publicRoutes, loginPath);
|
||||||
|
if (isPublicRoute && pathname !== loginPath) {
|
||||||
|
return setCorsHeaders(NextResponse.next());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get token from cookies or Authorization header
|
||||||
|
const token = getToken(req, sessionKey);
|
||||||
|
|
||||||
|
// Verify token and get user data
|
||||||
|
const user = await verifyToken({ token, encodedKey });
|
||||||
|
|
||||||
|
// Handle login page access
|
||||||
|
if (pathname === loginPath) {
|
||||||
|
if (user) {
|
||||||
|
const response = NextResponse.redirect(new URL(userPath, req.url));
|
||||||
|
// Preserve token in cookie when redirecting
|
||||||
|
if (token) {
|
||||||
|
response.cookies.set(sessionKey, token, {
|
||||||
|
httpOnly: true,
|
||||||
|
secure: process.env.NODE_ENV === 'production',
|
||||||
|
sameSite: 'lax',
|
||||||
|
path: '/'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return setCorsHeaders(response);
|
||||||
|
}
|
||||||
|
return setCorsHeaders(NextResponse.next());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Redirect to login if no user found
|
||||||
|
if (!user) {
|
||||||
|
const response = NextResponse.redirect(new URL(loginPath, req.url));
|
||||||
|
// Clear invalid token
|
||||||
|
response.cookies.delete(sessionKey);
|
||||||
|
return setCorsHeaders(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle /dev routes that require active status
|
||||||
|
if (pathname.startsWith("/dev")) {
|
||||||
|
try {
|
||||||
|
const userValidate = await fetch(new URL("/api/user-validate", req.url), {
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: `Bearer ${token}`,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!userValidate.ok) {
|
||||||
|
throw new Error('Failed to validate user');
|
||||||
|
}
|
||||||
|
|
||||||
|
const userValidateJson = await userValidate.json();
|
||||||
|
|
||||||
|
if (!userValidateJson.data.active) {
|
||||||
|
return setCorsHeaders(
|
||||||
|
NextResponse.redirect(new URL("/waiting-room", req.url))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error validating user:', error);
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle API requests
|
||||||
|
if (pathname.startsWith(apiPath)) {
|
||||||
|
if (!token) {
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const validationResponse = await fetch(
|
||||||
|
new URL(validationApiRoute, req.url),
|
||||||
|
{
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: `Bearer ${token}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!validationResponse.ok) {
|
||||||
|
throw new Error('Failed to validate API request');
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error validating API request:', error);
|
||||||
|
return setCorsHeaders(unauthorizedResponse());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const response = NextResponse.next();
|
||||||
|
// Ensure token is preserved in cookie
|
||||||
|
if (token) {
|
||||||
|
response.cookies.set(sessionKey, token, {
|
||||||
|
httpOnly: true,
|
||||||
|
secure: process.env.NODE_ENV === 'production',
|
||||||
|
sameSite: 'lax',
|
||||||
|
path: '/'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return setCorsHeaders(response);
|
||||||
|
};
|
||||||
|
|
||||||
|
function isRoutePublic(pathname: string, publicRoutes: string[], loginPath: string): boolean {
|
||||||
|
return [...publicRoutes, loginPath].some((route) => {
|
||||||
|
const pattern = route.replace(/\*/g, ".*");
|
||||||
|
return new RegExp(`^${pattern}$`).test(pathname);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function getToken(req: NextRequest, sessionKey: string): string | undefined {
|
||||||
|
return req.cookies.get(sessionKey)?.value ||
|
||||||
|
req.headers.get("Authorization")?.split(" ")[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
function unauthorizedResponse(): NextResponse {
|
||||||
|
return new NextResponse(JSON.stringify({ error: "Unauthorized" }), {
|
||||||
|
status: 401,
|
||||||
|
headers: { "Content-Type": "application/json" },
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function setCorsHeaders(res: NextResponse): NextResponse {
|
||||||
|
res.headers.set("Access-Control-Allow-Origin", "*");
|
||||||
|
res.headers.set(
|
||||||
|
"Access-Control-Allow-Methods",
|
||||||
|
"GET, POST, PUT, DELETE, OPTIONS"
|
||||||
|
);
|
||||||
|
res.headers.set(
|
||||||
|
"Access-Control-Allow-Headers",
|
||||||
|
"Content-Type, Authorization"
|
||||||
|
);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleCors(req: NextRequest): NextResponse | null {
|
||||||
|
if (req.method === "OPTIONS") {
|
||||||
|
return new NextResponse(null, {
|
||||||
|
status: 204,
|
||||||
|
headers: {
|
||||||
|
"Access-Control-Allow-Origin": "*",
|
||||||
|
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE, OPTIONS",
|
||||||
|
"Access-Control-Allow-Headers": "Content-Type, Authorization",
|
||||||
|
"Access-Control-Max-Age": "86400",
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function verifyToken({
|
||||||
|
token,
|
||||||
|
encodedKey,
|
||||||
|
}: {
|
||||||
|
token: string | undefined;
|
||||||
|
encodedKey: string;
|
||||||
|
}): Promise<Record<string, unknown> | null> {
|
||||||
|
if (!token) return null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
const enc = new TextEncoder().encode(encodedKey);
|
||||||
|
const { payload } = await jwtVerify(token, enc, {
|
||||||
|
algorithms: ["HS256"],
|
||||||
|
});
|
||||||
|
return (payload.user as Record<string, any>) || null;
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Token verification failed:", error);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const config = {
|
||||||
|
matcher: ["/((?!_next|static|favicon.ico|manifest).*)"],
|
||||||
|
};
|
||||||
@@ -1,82 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "base",
|
|
||||||
"configs": [
|
|
||||||
{
|
|
||||||
"name": "bloc",
|
|
||||||
"commands": [
|
|
||||||
{
|
|
||||||
"name": "[FF] New Big Pack Bloc",
|
|
||||||
"templates": ["*"],
|
|
||||||
"key": "bigpack",
|
|
||||||
"files": [
|
|
||||||
"bloc",
|
|
||||||
"event",
|
|
||||||
"index",
|
|
||||||
"model",
|
|
||||||
"page",
|
|
||||||
"provider",
|
|
||||||
"repository",
|
|
||||||
"screen",
|
|
||||||
"state"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Small Pack Bloc",
|
|
||||||
"templates": ["*"],
|
|
||||||
"key": "smallpack",
|
|
||||||
"files": ["bloc", "event", "index", "page", "screen", "state"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Bloc",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["bloc"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Event",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["event"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Model",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["model"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Page",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["page"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Provider",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["provider"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Repository",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["repository"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Screen",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["screen"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New State",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["state"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Index",
|
|
||||||
"templates": ["*"],
|
|
||||||
"files": ["index"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "[FF] New Navigate(Navme)",
|
|
||||||
"templates": ["navigate"],
|
|
||||||
"files": ["navigate"]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
import 'package:ff_bloc/ff_bloc.dart';
|
|
||||||
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Bloc extends FFBloc<${upperName}Event, ${upperName}State> {
|
|
||||||
${upperName}Bloc({
|
|
||||||
required this.provider,
|
|
||||||
super.initialState = const ${upperName}State(),
|
|
||||||
});
|
|
||||||
/// Use this for all requests to backend - you can mock it in tests
|
|
||||||
final ${upperName}Provider provider;
|
|
||||||
|
|
||||||
@override
|
|
||||||
${upperName}State onErrorState(Object error) => state.copy(error: error, isLoading: false);
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
|
|
||||||
import 'package:flutter/widgets.dart';
|
|
||||||
import 'package:ff_bloc/ff_bloc.dart';
|
|
||||||
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
@immutable
|
|
||||||
abstract class ${upperName}Event implements FFBlocEvent<${upperName}State, ${upperName}Bloc> {}
|
|
||||||
|
|
||||||
/// Initial Event with load data
|
|
||||||
class Load${upperName}Event extends ${upperName}Event {
|
|
||||||
Load${upperName}Event({required this.id});
|
|
||||||
final String? id;
|
|
||||||
|
|
||||||
static const String _name = 'Load${upperName}Event';
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => _name;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync({required ${upperName}Bloc bloc}) async* {
|
|
||||||
// set loading true for show loading
|
|
||||||
yield bloc.state.copyWithoutError(isLoading: true);
|
|
||||||
// fetch data
|
|
||||||
final result = await bloc.provider.fetchAsync(id);
|
|
||||||
// set data to state
|
|
||||||
yield bloc.state.copyWithoutError(
|
|
||||||
isLoading: false,
|
|
||||||
data: ${upperName}ViewModel(items: result),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class Add${upperName}Event extends ${upperName}Event {
|
|
||||||
static const String _name = 'Add${upperName}Event';
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => _name;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync({required ${upperName}Bloc bloc}) async* {
|
|
||||||
yield bloc.state.copyWithoutError(isLoading: true);
|
|
||||||
final result = await bloc.provider.addMore(bloc.state.data?.items);
|
|
||||||
yield bloc.state.copyWithoutError(
|
|
||||||
isLoading: false,
|
|
||||||
data: ${upperName}ViewModel(items: result),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ErrorYouAwesomeEvent extends YouAwesomeEvent {
|
|
||||||
static const String _name = 'ErrorYouAwesomeEvent';
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => _name;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Stream<YouAwesomeState> applyAsync({required YouAwesomeBloc bloc}) async* {
|
|
||||||
throw Exception('Test error');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class Clear${upperName}Event extends ${upperName}Event {
|
|
||||||
static const String _name = 'Clear${upperName}Event';
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => _name;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync({required ${upperName}Bloc bloc}) async* {
|
|
||||||
yield bloc.state.copyWithoutError(isLoading: true);
|
|
||||||
yield bloc.state.copyWithoutData(
|
|
||||||
isLoading: false,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,51 +0,0 @@
|
|||||||
// ignore: depend_on_referenced_packages
|
|
||||||
import 'package:equatable/equatable.dart';
|
|
||||||
|
|
||||||
class ${upperName}Model extends Equatable {
|
|
||||||
const ${upperName}Model({
|
|
||||||
required this.name,
|
|
||||||
});
|
|
||||||
final String name;
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [ name];
|
|
||||||
|
|
||||||
Map<dynamic, dynamic> toMap() {
|
|
||||||
return {
|
|
||||||
'name': name,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
static ${upperName}Model? fromMap(Map<dynamic, dynamic>? map) {
|
|
||||||
if (map == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ${upperName}Model(
|
|
||||||
name: map['name']!.toString(),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
class ${upperName}ViewModel extends Equatable {
|
|
||||||
const ${upperName}ViewModel({
|
|
||||||
// TODO(all): add all required constructor parameters
|
|
||||||
required this.items,
|
|
||||||
});
|
|
||||||
|
|
||||||
// TODO(all): declare your fields here
|
|
||||||
final List<${upperName}Model>? items;
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object?> get props => [items /*TODO(all): List all fields here*/];
|
|
||||||
|
|
||||||
// TODO(all): implement copyWith
|
|
||||||
${upperName}ViewModel copyWith({
|
|
||||||
List<${upperName}Model>? items,
|
|
||||||
}) {
|
|
||||||
return ${upperName}ViewModel(
|
|
||||||
items: items ?? this.items,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
|
|
||||||
class ${upperName}Page extends StatefulWidget {
|
|
||||||
const ${upperName}Page({
|
|
||||||
required this.bloc,
|
|
||||||
super.key
|
|
||||||
});
|
|
||||||
static const String routeName = '/${privateName}';
|
|
||||||
|
|
||||||
final ${upperName}Bloc? bloc;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<${upperName}Page> createState() => _${upperName}PageState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _${upperName}PageState extends State<${upperName}Page> {
|
|
||||||
|
|
||||||
${upperName}Bloc? _bloc;
|
|
||||||
${upperName}Bloc get bloc {
|
|
||||||
// get it by DI in real code.
|
|
||||||
_bloc ??= widget.bloc ?? ${upperName}Bloc();
|
|
||||||
return _bloc!;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Scaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
centerTitle: true,
|
|
||||||
title: const Text('${upperName}'),
|
|
||||||
actions: [
|
|
||||||
IconButton(
|
|
||||||
icon: const Icon(Icons.error),
|
|
||||||
onPressed: () {
|
|
||||||
bloc.add(ErrorYouAwesomeEvent());
|
|
||||||
},
|
|
||||||
),
|
|
||||||
IconButton(
|
|
||||||
icon: const Icon(Icons.add),
|
|
||||||
onPressed: () {
|
|
||||||
bloc.add(Add${upperName}Event());
|
|
||||||
},
|
|
||||||
),
|
|
||||||
IconButton(
|
|
||||||
icon: const Icon(Icons.clear),
|
|
||||||
onPressed: () {
|
|
||||||
bloc.add(Clear${upperName}Event());
|
|
||||||
},
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
body: ${upperName}Screen(bloc: bloc),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
|
|
||||||
import 'dart:async';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Provider {
|
|
||||||
|
|
||||||
Future<List<${upperName}Model>?> fetchAsync(String? id) async {
|
|
||||||
// write logic here to send request to server
|
|
||||||
if (id == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return [${upperName}Model(name: id)];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Future<List<${upperName}Model>?> addMore(List<${upperName}Model>? now) async {
|
|
||||||
// write logic here to send request to server
|
|
||||||
final result = [
|
|
||||||
...(now ?? <${upperName}Model>[]),
|
|
||||||
${upperName}Model(name: now?.length.toString() ?? '0')
|
|
||||||
];
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,126 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
|
|
||||||
class ${upperName}Screen extends StatefulWidget {
|
|
||||||
const ${upperName}Screen({
|
|
||||||
required this.bloc,
|
|
||||||
super.key,
|
|
||||||
}) ;
|
|
||||||
|
|
||||||
@protected
|
|
||||||
final ${upperName}Bloc bloc;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<${upperName}Screen> createState() {
|
|
||||||
return ${upperName}ScreenState();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ${upperName}ScreenState extends State<${upperName}Screen> {
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
// load data on init widget if bloc has not data
|
|
||||||
if (!widget.bloc.state.hasData) {
|
|
||||||
_load();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void dispose() {
|
|
||||||
// dispose bloc if you use subscriptions in bloc
|
|
||||||
super.dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return BlocBuilder<${upperName}Bloc, ${upperName}State>(
|
|
||||||
bloc: widget.bloc,
|
|
||||||
builder: (
|
|
||||||
BuildContext context,
|
|
||||||
${upperName}State currentState,
|
|
||||||
) {
|
|
||||||
// declaration of bloc states
|
|
||||||
return currentState.when(
|
|
||||||
onLoading: ()=>const CircularProgressIndicator(),
|
|
||||||
onEmpty: (data) => _Empty(),
|
|
||||||
onData: (data) => _BodyList(data: data),
|
|
||||||
onError: (e) => Center(
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
Text(e.toString()),
|
|
||||||
TextButton(
|
|
||||||
onPressed: _load,
|
|
||||||
child: const Text('ReLoad'),
|
|
||||||
)
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
void _load() {
|
|
||||||
widget.bloc.add(Load${upperName}Event(id:'1'));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class _BodyList extends StatefulWidget {
|
|
||||||
const _BodyList({required this.data});
|
|
||||||
|
|
||||||
final ${upperName}ViewModel data;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<_BodyList> createState() => _BodyListState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _BodyListState extends State<_BodyList> {
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void dispose() {
|
|
||||||
super.dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
|
|
||||||
return CustomScrollView(
|
|
||||||
// primary: true,
|
|
||||||
slivers: [
|
|
||||||
const SliverToBoxAdapter(child: Divider()),
|
|
||||||
SliverList(
|
|
||||||
delegate: SliverChildBuilderDelegate(
|
|
||||||
(BuildContext context, int index) {
|
|
||||||
final item = widget.data.items![index];
|
|
||||||
if (index == 0) {
|
|
||||||
return Text('Header $index, id = '+item.name);
|
|
||||||
}
|
|
||||||
return Text('Index = $index, id = '+item.name);
|
|
||||||
},
|
|
||||||
childCount: widget.data.items!.length,
|
|
||||||
))]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class _Empty extends StatelessWidget {
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Column(
|
|
||||||
children: <Widget>[
|
|
||||||
Text('Empty'),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import 'package:ff_bloc/ff_bloc.dart';
|
|
||||||
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}State extends FFState<${upperName}State, ${upperName}ViewModel> {
|
|
||||||
const ${upperName}State({
|
|
||||||
super.version = 0,
|
|
||||||
super.isLoading = false,
|
|
||||||
super.data,
|
|
||||||
super.error,
|
|
||||||
});
|
|
||||||
|
|
||||||
@override
|
|
||||||
StateCopyFactory<${upperName}State, ${upperName}ViewModel> getCopyFactory() => ${upperName}State.new;
|
|
||||||
}
|
|
||||||
@@ -1,37 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
import 'dart:developer' as developer;
|
|
||||||
|
|
||||||
import 'package:bloc/bloc.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Bloc extends Bloc<${upperName}Event, ${upperName}State> {
|
|
||||||
// todo: check singleton for logic in project
|
|
||||||
// use GetIt for DI in projct
|
|
||||||
static final ${upperName}Bloc _${privateName}BlocSingleton = ${upperName}Bloc._internal();
|
|
||||||
factory ${upperName}Bloc() {
|
|
||||||
return _${privateName}BlocSingleton;
|
|
||||||
}
|
|
||||||
|
|
||||||
${upperName}Bloc._internal(): super(Un${upperName}State(0)){
|
|
||||||
on<${upperName}Event>((event, emit) {
|
|
||||||
return emit.forEach<${upperName}State>(
|
|
||||||
event.applyAsync(currentState: state, bloc: this),
|
|
||||||
onData: (state) => state,
|
|
||||||
onError: (error, stackTrace) {
|
|
||||||
developer.log('$error', name: '${upperName}Bloc', error: error, stackTrace: stackTrace);
|
|
||||||
return Error${upperName}State(0, error.toString());
|
|
||||||
},
|
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Future<void> close() async{
|
|
||||||
// dispose objects
|
|
||||||
await super.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
${upperName}State get initialState => Un${upperName}State(0);
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,42 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
import 'dart:developer' as developer;
|
|
||||||
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
import 'package:meta/meta.dart';
|
|
||||||
|
|
||||||
@immutable
|
|
||||||
abstract class ${upperName}Event {
|
|
||||||
Stream<${upperName}State> applyAsync(
|
|
||||||
{${upperName}State currentState, ${upperName}Bloc bloc});
|
|
||||||
final ${upperName}Repository _${privateName}Repository = ${upperName}Repository();
|
|
||||||
}
|
|
||||||
|
|
||||||
class Un${upperName}Event extends ${upperName}Event {
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync({${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
|
||||||
yield Un${upperName}State(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class Load${upperName}Event extends ${upperName}Event {
|
|
||||||
|
|
||||||
final bool isError;
|
|
||||||
@override
|
|
||||||
String toString() => 'Load${upperName}Event';
|
|
||||||
|
|
||||||
Load${upperName}Event(this.isError);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync(
|
|
||||||
{${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
|
||||||
try {
|
|
||||||
yield Un${upperName}State(0);
|
|
||||||
await Future.delayed(const Duration(seconds: 1));
|
|
||||||
_${privateName}Repository.test(isError);
|
|
||||||
yield In${upperName}State(0, 'Hello world');
|
|
||||||
} catch (_, stackTrace) {
|
|
||||||
developer.log('$_', name: 'Load${upperName}Event', error: _, stackTrace: stackTrace);
|
|
||||||
yield Error${upperName}State(0, _.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
import 'package:equatable/equatable.dart';
|
|
||||||
|
|
||||||
/// generate by https://javiercbk.github.io/json_to_dart/
|
|
||||||
class Autogenerated${upperName} {
|
|
||||||
final List<${upperName}Model> results;
|
|
||||||
|
|
||||||
Autogenerated${upperName}({required this.results});
|
|
||||||
|
|
||||||
factory Autogenerated${upperName}.fromJson(Map<String, dynamic> json) {
|
|
||||||
var temp = <YouAwesomeModel>[];
|
|
||||||
if (json['results'] != null) {
|
|
||||||
temp = <${upperName}Model>[];
|
|
||||||
json['results'].forEach((v) {
|
|
||||||
temp.add(${upperName}Model.fromJson(v as Map<String, dynamic>));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return Autogenerated${upperName}(results: temp);
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = <String, dynamic>{};
|
|
||||||
data['results'] = results.map((v) => v.toJson()).toList();
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ${upperName}Model extends Equatable {
|
|
||||||
final int id;
|
|
||||||
final String name;
|
|
||||||
|
|
||||||
${upperName}Model(this.id, this.name);
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [id, name];
|
|
||||||
|
|
||||||
factory ${upperName}Model.fromJson(Map<String, dynamic> json) {
|
|
||||||
return ${upperName}Model(json['id'] as int, json['name'] as String);
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = <String, dynamic>{};
|
|
||||||
data['id'] = id;
|
|
||||||
data['name'] = name;
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Page extends StatefulWidget {
|
|
||||||
static const String routeName = '/${privateName}';
|
|
||||||
|
|
||||||
@override
|
|
||||||
_${upperName}PageState createState() => _${upperName}PageState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _${upperName}PageState extends State<${upperName}Page> {
|
|
||||||
final _${privateName}Bloc = ${upperName}Bloc();
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Scaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
title: Text('${upperName}'),
|
|
||||||
),
|
|
||||||
body: ${upperName}Screen(${privateName}Bloc: _${privateName}Bloc),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
|
|
||||||
class ${upperName}Provider {
|
|
||||||
Future<void> loadAsync(String token) async {
|
|
||||||
/// write from keystore/keychain
|
|
||||||
await Future.delayed(Duration(seconds: 2));
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> saveAsync(String token) async {
|
|
||||||
/// write from keystore/keychain
|
|
||||||
await Future.delayed(Duration(seconds: 2));
|
|
||||||
}
|
|
||||||
|
|
||||||
void test(bool isError) {
|
|
||||||
if (isError == true){
|
|
||||||
throw Exception('manual error');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Repository {
|
|
||||||
final ${upperName}Provider _${privateName}Provider = ${upperName}Provider();
|
|
||||||
|
|
||||||
${upperName}Repository();
|
|
||||||
|
|
||||||
void test(bool isError) {
|
|
||||||
_${privateName}Provider.test(isError);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,97 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Screen extends StatefulWidget {
|
|
||||||
const ${upperName}Screen({
|
|
||||||
required ${upperName}Bloc ${privateName}Bloc,
|
|
||||||
Key? key,
|
|
||||||
}) : _${privateName}Bloc = ${privateName}Bloc,
|
|
||||||
super(key: key);
|
|
||||||
|
|
||||||
final ${upperName}Bloc _${privateName}Bloc;
|
|
||||||
|
|
||||||
@override
|
|
||||||
${upperName}ScreenState createState() {
|
|
||||||
return ${upperName}ScreenState();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ${upperName}ScreenState extends State<${upperName}Screen> {
|
|
||||||
${upperName}ScreenState();
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
_load();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void dispose() {
|
|
||||||
super.dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return BlocBuilder<${upperName}Bloc, ${upperName}State>(
|
|
||||||
bloc: widget._${privateName}Bloc,
|
|
||||||
builder: (
|
|
||||||
BuildContext context,
|
|
||||||
${upperName}State currentState,
|
|
||||||
) {
|
|
||||||
if (currentState is Un${upperName}State) {
|
|
||||||
return Center(
|
|
||||||
child: CircularProgressIndicator(),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if (currentState is Error${upperName}State) {
|
|
||||||
return Center(
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
children: <Widget>[
|
|
||||||
Text(currentState.errorMessage),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(top: 32.0),
|
|
||||||
child: ElevatedButton(
|
|
||||||
style: ElevatedButton.styleFrom(
|
|
||||||
backgroundColor: Colors.blue,
|
|
||||||
),
|
|
||||||
child: Text('reload'),
|
|
||||||
onPressed: _load,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
));
|
|
||||||
}
|
|
||||||
if (currentState is In${upperName}State) {
|
|
||||||
return Center(
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
children: <Widget>[
|
|
||||||
Text(currentState.hello),
|
|
||||||
const Text('Flutter files: done'),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(top: 32.0),
|
|
||||||
child: ElevatedButton(
|
|
||||||
style: ElevatedButton.styleFrom(
|
|
||||||
backgroundColor: Colors.red,
|
|
||||||
),
|
|
||||||
child: Text('throw error'),
|
|
||||||
onPressed: () => _load(true),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return Center(
|
|
||||||
child: CircularProgressIndicator(),
|
|
||||||
);
|
|
||||||
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void _load([bool isError = false]) {
|
|
||||||
widget._${privateName}Bloc.add(Load${upperName}Event(isError));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,83 +0,0 @@
|
|||||||
import 'package:equatable/equatable.dart';
|
|
||||||
|
|
||||||
abstract class ${upperName}State extends Equatable {
|
|
||||||
${upperName}State(this.version);
|
|
||||||
|
|
||||||
/// notify change state without deep clone state
|
|
||||||
final int version;
|
|
||||||
|
|
||||||
/// Copy object for use in action
|
|
||||||
/// if need use deep clone
|
|
||||||
${upperName}State getStateCopy();
|
|
||||||
|
|
||||||
${upperName}State getNewVersion();
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [version];
|
|
||||||
}
|
|
||||||
|
|
||||||
/// UnInitialized
|
|
||||||
class Un${upperName}State extends ${upperName}State {
|
|
||||||
|
|
||||||
Un${upperName}State(int version) : super(version);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => 'Un${upperName}State';
|
|
||||||
|
|
||||||
@override
|
|
||||||
Un${upperName}State getStateCopy() {
|
|
||||||
return Un${upperName}State(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Un${upperName}State getNewVersion() {
|
|
||||||
return Un${upperName}State(version+1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Initialized
|
|
||||||
class In${upperName}State extends ${upperName}State {
|
|
||||||
|
|
||||||
In${upperName}State(int version, this.hello) : super(version);
|
|
||||||
|
|
||||||
final String hello;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => 'In${upperName}State $hello';
|
|
||||||
|
|
||||||
@override
|
|
||||||
In${upperName}State getStateCopy() {
|
|
||||||
return In${upperName}State(version, hello);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
In${upperName}State getNewVersion() {
|
|
||||||
return In${upperName}State(version+1, hello);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [version, hello];
|
|
||||||
}
|
|
||||||
|
|
||||||
class Error${upperName}State extends ${upperName}State {
|
|
||||||
Error${upperName}State(int version, this.errorMessage): super(version);
|
|
||||||
|
|
||||||
final String errorMessage;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => 'Error${upperName}State';
|
|
||||||
|
|
||||||
@override
|
|
||||||
Error${upperName}State getStateCopy() {
|
|
||||||
return Error${upperName}State(version, errorMessage);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Error${upperName}State getNewVersion() {
|
|
||||||
return Error${upperName}State(version+1,
|
|
||||||
errorMessage);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [version, errorMessage];
|
|
||||||
}
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:navme/navme.dart';
|
|
||||||
import 'package:navme/helpers.dart';
|
|
||||||
|
|
||||||
import 'index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Navigate {
|
|
||||||
// base path
|
|
||||||
static String path = '${privateName}';
|
|
||||||
|
|
||||||
// config for configurate Router
|
|
||||||
static RouteConfig routeConfig = RouteConfig(
|
|
||||||
state: (Uri? uri) => RouteState(uri: path.toUri()),
|
|
||||||
// condition for using this page
|
|
||||||
isThisPage: (RouteState state) {
|
|
||||||
if (state?.firstPath == path) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
// settigs from url
|
|
||||||
settings: (RouteState state) {
|
|
||||||
return null;
|
|
||||||
},
|
|
||||||
// get Page for Router
|
|
||||||
page: ({RouteState? state}) {
|
|
||||||
return MaterialPage(
|
|
||||||
key: const ValueKey('${upperName}Page'),
|
|
||||||
child: ${upperName}Page(),
|
|
||||||
name: '${upperName}Page');
|
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
import 'dart:developer' as developer;
|
|
||||||
|
|
||||||
import 'package:bloc/bloc.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Bloc extends Bloc<${upperName}Event, ${upperName}State> {
|
|
||||||
|
|
||||||
${upperName}Bloc(${upperName}State initialState) : super(initialState){
|
|
||||||
on<${upperName}Event>((event, emit) {
|
|
||||||
return emit.forEach<${upperName}State>(
|
|
||||||
event.applyAsync(currentState: state, bloc: this),
|
|
||||||
onData: (state) => state,
|
|
||||||
onError: (error, stackTrace) {
|
|
||||||
developer.log('$error', name: '${upperName}Bloc', error: error, stackTrace: stackTrace);
|
|
||||||
return Error${upperName}State(error.toString());
|
|
||||||
},
|
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
import 'dart:developer' as developer;
|
|
||||||
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
import 'package:meta/meta.dart';
|
|
||||||
|
|
||||||
@immutable
|
|
||||||
abstract class ${upperName}Event {
|
|
||||||
Stream<${upperName}State> applyAsync(
|
|
||||||
{${upperName}State currentState, ${upperName}Bloc bloc});
|
|
||||||
}
|
|
||||||
|
|
||||||
class Un${upperName}Event extends ${upperName}Event {
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync({${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
|
||||||
yield Un${upperName}State();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class Load${upperName}Event extends ${upperName}Event {
|
|
||||||
|
|
||||||
@override
|
|
||||||
Stream<${upperName}State> applyAsync(
|
|
||||||
{${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
|
||||||
try {
|
|
||||||
yield Un${upperName}State();
|
|
||||||
await Future.delayed(const Duration(seconds: 1));
|
|
||||||
yield In${upperName}State('Hello world');
|
|
||||||
} catch (_, stackTrace) {
|
|
||||||
developer.log('$_', name: 'Load${upperName}Event', error: _, stackTrace: stackTrace);
|
|
||||||
yield Error${upperName}State( _.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,13 +0,0 @@
|
|||||||
import 'package:equatable/equatable.dart';
|
|
||||||
|
|
||||||
/// use https://marketplace.visualstudio.com/items?itemName=BendixMa.dart-data-class-generator
|
|
||||||
class ${upperName}Model extends Equatable {
|
|
||||||
final int id;
|
|
||||||
final String name;
|
|
||||||
|
|
||||||
${upperName}Model(this.id, this.name);
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [id, name];
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Page extends StatefulWidget {
|
|
||||||
static const String routeName = '/${privateName}';
|
|
||||||
|
|
||||||
@override
|
|
||||||
_${upperName}PageState createState() => _${upperName}PageState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _${upperName}PageState extends State<${upperName}Page> {
|
|
||||||
final _${privateName}Bloc = ${upperName}Bloc(Un${upperName}State());
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Scaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
title: Text('${upperName}'),
|
|
||||||
),
|
|
||||||
body: ${upperName}Screen(${privateName}Bloc: _${privateName}Bloc),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
import 'dart:async';
|
|
||||||
|
|
||||||
class ${upperName}Provider {
|
|
||||||
Future<void> loadAsync(String token) async {
|
|
||||||
/// write from keystore/keychain
|
|
||||||
await Future.delayed(Duration(seconds: 2));
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> saveAsync(String token) async {
|
|
||||||
/// write from keystore/keychain
|
|
||||||
await Future.delayed(Duration(seconds: 2));
|
|
||||||
}
|
|
||||||
|
|
||||||
void test(bool isError) {
|
|
||||||
if (isError == true){
|
|
||||||
throw Exception('manual error');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Repository {
|
|
||||||
final ${upperName}Provider _${privateName}Provider = ${upperName}Provider();
|
|
||||||
|
|
||||||
${upperName}Repository();
|
|
||||||
|
|
||||||
void test(bool isError) {
|
|
||||||
_${privateName}Provider.test(isError);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,84 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
||||||
import 'package:${appName}${relative}/index.dart';
|
|
||||||
|
|
||||||
class ${upperName}Screen extends StatefulWidget {
|
|
||||||
const ${upperName}Screen({
|
|
||||||
required ${upperName}Bloc ${privateName}Bloc,
|
|
||||||
Key? key,
|
|
||||||
}) : _${privateName}Bloc = ${privateName}Bloc,
|
|
||||||
super(key: key);
|
|
||||||
|
|
||||||
final ${upperName}Bloc _${privateName}Bloc;
|
|
||||||
|
|
||||||
@override
|
|
||||||
${upperName}ScreenState createState() {
|
|
||||||
return ${upperName}ScreenState();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ${upperName}ScreenState extends State<${upperName}Screen> {
|
|
||||||
${upperName}ScreenState();
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
_load();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void dispose() {
|
|
||||||
super.dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return BlocBuilder<${upperName}Bloc, ${upperName}State>(
|
|
||||||
bloc: widget._${privateName}Bloc,
|
|
||||||
builder: (
|
|
||||||
BuildContext context,
|
|
||||||
${upperName}State currentState,
|
|
||||||
) {
|
|
||||||
if (currentState is Un${upperName}State) {
|
|
||||||
return Center(
|
|
||||||
child: CircularProgressIndicator(),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if (currentState is Error${upperName}State) {
|
|
||||||
return Center(
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
children: <Widget>[
|
|
||||||
Text(currentState.errorMessage ),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(top: 32.0),
|
|
||||||
child: RaisedButton(
|
|
||||||
color: Colors.blue,
|
|
||||||
child: Text('reload'),
|
|
||||||
onPressed: _load,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
));
|
|
||||||
}
|
|
||||||
if (currentState is In${upperName}State) {
|
|
||||||
return Center(
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
children: <Widget>[
|
|
||||||
Text(currentState.hello),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return Center(
|
|
||||||
child: CircularProgressIndicator(),
|
|
||||||
);
|
|
||||||
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void _load() {
|
|
||||||
widget._${privateName}Bloc.add(Load${upperName}Event());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,42 +0,0 @@
|
|||||||
import 'package:equatable/equatable.dart';
|
|
||||||
|
|
||||||
abstract class ${upperName}State extends Equatable {
|
|
||||||
${upperName}State();
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [];
|
|
||||||
}
|
|
||||||
|
|
||||||
/// UnInitialized
|
|
||||||
class Un${upperName}State extends ${upperName}State {
|
|
||||||
|
|
||||||
Un${upperName}State();
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => 'Un${upperName}State';
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Initialized
|
|
||||||
class In${upperName}State extends ${upperName}State {
|
|
||||||
In${upperName}State(this.hello);
|
|
||||||
|
|
||||||
final String hello;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => 'In${upperName}State $hello';
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [hello];
|
|
||||||
}
|
|
||||||
|
|
||||||
class Error${upperName}State extends ${upperName}State {
|
|
||||||
Error${upperName}State(this.errorMessage);
|
|
||||||
|
|
||||||
final String errorMessage;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() => 'Error${upperName}State';
|
|
||||||
|
|
||||||
@override
|
|
||||||
List<Object> get props => [errorMessage];
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user