From 0c6d784eec608783ce5d097cbfc3a46a3947bd52 Mon Sep 17 00:00:00 2001 From: Jo Date: Wed, 11 Sep 2024 00:29:09 +0200 Subject: [PATCH] chore: setup base structure and hono server --- .gitignore | 175 +++++++++++++++++++++++++++++++++++ LICENSE | 2 +- bun.lockb | Bin 0 -> 2248 bytes package.json | 12 +++ src/index.ts | 12 +++ src/routes/v1/users/index.ts | 23 +++++ tsconfig.json | 27 ++++++ 7 files changed, 250 insertions(+), 1 deletion(-) create mode 100644 .gitignore create mode 100644 bun.lockb create mode 100644 package.json create mode 100644 src/index.ts create mode 100644 src/routes/v1/users/index.ts create mode 100644 tsconfig.json diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..9b1ee42 --- /dev/null +++ b/.gitignore @@ -0,0 +1,175 @@ +# Based on https://raw.githubusercontent.com/github/gitignore/main/Node.gitignore + +# Logs + +logs +_.log +npm-debug.log_ +yarn-debug.log* +yarn-error.log* +lerna-debug.log* +.pnpm-debug.log* + +# Caches + +.cache + +# Diagnostic reports (https://nodejs.org/api/report.html) + +report.[0-9]_.[0-9]_.[0-9]_.[0-9]_.json + +# Runtime data + +pids +_.pid +_.seed +*.pid.lock + +# Directory for instrumented libs generated by jscoverage/JSCover + +lib-cov + +# Coverage directory used by tools like istanbul + +coverage +*.lcov + +# nyc test coverage + +.nyc_output + +# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) + +.grunt + +# Bower dependency directory (https://bower.io/) + +bower_components + +# node-waf configuration + +.lock-wscript + +# Compiled binary addons (https://nodejs.org/api/addons.html) + +build/Release + +# Dependency directories + +node_modules/ +jspm_packages/ + +# Snowpack dependency directory (https://snowpack.dev/) + +web_modules/ + +# TypeScript cache + +*.tsbuildinfo + +# Optional npm cache directory + +.npm + +# Optional eslint cache + +.eslintcache + +# Optional stylelint cache + +.stylelintcache + +# Microbundle cache + +.rpt2_cache/ +.rts2_cache_cjs/ +.rts2_cache_es/ +.rts2_cache_umd/ + +# Optional REPL history + +.node_repl_history + +# Output of 'npm pack' + +*.tgz + +# Yarn Integrity file + +.yarn-integrity + +# dotenv environment variable files + +.env +.env.development.local +.env.test.local +.env.production.local +.env.local + +# parcel-bundler cache (https://parceljs.org/) + +.parcel-cache + +# Next.js build output + +.next +out + +# Nuxt.js build / generate output + +.nuxt +dist + +# Gatsby files + +# Comment in the public line in if your project uses Gatsby and not Next.js + +# https://nextjs.org/blog/next-9-1#public-directory-support + +# public + +# vuepress build output + +.vuepress/dist + +# vuepress v2.x temp and cache directory + +.temp + +# Docusaurus cache and generated files + +.docusaurus + +# Serverless directories + +.serverless/ + +# FuseBox cache + +.fusebox/ + +# DynamoDB Local files + +.dynamodb/ + +# TernJS port file + +.tern-port + +# Stores VSCode versions used for testing VSCode extensions + +.vscode-test + +# yarn v2 + +.yarn/cache +.yarn/unplugged +.yarn/build-state.yml +.yarn/install-state.gz +.pnp.* + +# IntelliJ based IDEs +.idea + +# Finder (MacOS) folder config +.DS_Store diff --git a/LICENSE b/LICENSE index 6b1e3cd..6529bd0 100644 --- a/LICENSE +++ b/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2024 HomeSpace +Copyright (c) 2024 Johannes Reckers, Danil Schumin and the HomeSpace contributors Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: diff --git a/bun.lockb b/bun.lockb new file mode 100644 index 0000000000000000000000000000000000000000..edc9ee64aa4c9b4df91409d120cca58c0d27eaad GIT binary patch literal 2248 zcmY#Z)GsYA(of3F(@)JSQ%EY!;{sycoc!eMw9K4T-L(9o+{6;yG6OCq1_p*-+g{Dx z{(F1Z_L$EpQ@?wkS#;_0r3c$Z9j32%n?CXRRS^pgpduh(flv%kE}U+FikH9?fccyZ z3=Jkg7B7&N0MY_LIwLzCtU$~S#KZ!S88CA|G$>4% zku>9%|HuE2(m+JA3(N$X$H)LNm#Ri1nG5qTy47Uyk<3L7HQ{;YdrM`9E+*t);=|}b@IR*56T#!-kwfB&O!g;PV!*IS2 zfmHQ8Sv~`&1(I}<>}HZRFzkTl{xeXT%ci&}SuZoMxFj(rM-Nu?=!F!errIeO87LHI zR;A{r=_r^eB<5tM=jEqyL45S@KLmhypm_TMHID_9fq;O^rqtNT4yX->0U(!y(vbmF zy$uoikn>joRQ*1~!%m4&b} zPYIs*IoLq{WMF{Ns3BRLnp>7yq~}^ul3J9Pm=j!5l$n=qr(lS1oCVx*7EqH`L1|#v z0sUc!%Nq}6Y q9>CpMipQ6j{?y=rxCK@-WA!I2WgvWsmTDOoV5t + +// Demo Data for usage before integrating Prisma ORM +const userArray = [ + { id: 1, name: "Jo", email: "jo@thevoid.cafe", hashedPassword: "jo-hash" }, + { id: 2, name: "Danil", email: "semiko@thevoid.cafe", hashedPassword: "semiko-hash" }, + { id: 3, name: "Rhys", email: "rhys@thevoid.cafe", passwordAsHash: "rhys-hash" } +]; + +//====================================================> + +// Fetch user information by ID +app.get("/:id", (ctx) => { + return ctx.json(userArray.filter(user => user.id === parseInt(ctx.req.param("id")))); +}); + +//====================================================> + +export default app; \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..238655f --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,27 @@ +{ + "compilerOptions": { + // Enable latest features + "lib": ["ESNext", "DOM"], + "target": "ESNext", + "module": "ESNext", + "moduleDetection": "force", + "jsx": "react-jsx", + "allowJs": true, + + // Bundler mode + "moduleResolution": "bundler", + "allowImportingTsExtensions": true, + "verbatimModuleSyntax": true, + "noEmit": true, + + // Best practices + "strict": true, + "skipLibCheck": true, + "noFallthroughCasesInSwitch": true, + + // Some stricter flags (disabled by default) + "noUnusedLocals": false, + "noUnusedParameters": false, + "noPropertyAccessFromIndexSignature": false + } +}