Skip to content

Commit

Permalink
ok for CURD item
Browse files Browse the repository at this point in the history
  • Loading branch information
mingder78 committed Dec 12, 2023
1 parent 2d8b772 commit 7fb7caf
Show file tree
Hide file tree
Showing 17 changed files with 424 additions and 3 deletions.
Binary file modified bun.lockb
Binary file not shown.
176 changes: 176 additions & 0 deletions example/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,176 @@
# 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*

# 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/)

.cache
.parcel-cache

# Next.js build output

.next
out

# Nuxt.js build / generate output

.nuxt
dist

# Gatsby files

.cache/

# 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
.cache

# 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

15 changes: 15 additions & 0 deletions example/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# example

To install dependencies:

```bash
bun install
```

To run:

```bash
bun run index.ts
```

This project was created using `bun init` in bun v1.0.10. [Bun](https://bun.sh) is a fast all-in-one JavaScript runtime.
Binary file added example/bun.lockb
Binary file not shown.
18 changes: 18 additions & 0 deletions example/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"name": "example",
"module": "index.ts",
"type": "module",
"scripts": {
"dev": "bun --watch run ./src/index.ts",
"test": "bun --watch test"
},
"devDependencies": {
"bun-types": "latest"
},
"peerDependencies": {
"typescript": "^5.0.0"
},
"dependencies": {
"@muzamint/erica-items-db": "^0.0.0"
}
}
8 changes: 8 additions & 0 deletions example/src/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
console.log("Hello via Bun!");
import { router } from '@muzamint/erica-items-db'

export default {
async fetch(request: Request, server: Server) {
return router.handle(request)
},
}
22 changes: 22 additions & 0 deletions example/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"compilerOptions": {
"lib": ["ESNext"],
"module": "esnext",
"target": "esnext",
"moduleResolution": "bundler",
"moduleDetection": "force",
"allowImportingTsExtensions": true,
"noEmit": true,
"composite": true,
"strict": true,
"downlevelIteration": true,
"skipLibCheck": true,
"jsx": "react-jsx",
"allowSyntheticDefaultImports": true,
"forceConsistentCasingInFileNames": true,
"allowJs": true,
"types": [
"bun-types" // add Bun global
]
}
}
12 changes: 10 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
{
"name": "pkg-name",
"version": "0.0.0",
"name": "@muzamint/erica-items-db",
"version": "0.0.1",
"main": "dist/index.js",
"types": "dist/index.d.ts",
"description": "",
"scripts": {
"build": "bun run build.mjs",
"dev": "bun --watch run ./src/index.ts",
"test": "bun --watch test",
"prepublishOnly": "bun run build"
},
"files": [
Expand All @@ -26,5 +28,11 @@
"bun-plugin-dts": "^0.2.1",
"bun-types": "^1.0.7",
"typescript": "^5.2.2"
},
"dependencies": {
"@elysiajs/cors": "^0.7.2",
"@elysiajs/swagger": "^0.7.4",
"elysia": "^0.7.30",
"viem": "^1.19.13"
}
}
20 changes: 20 additions & 0 deletions src/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,22 @@
export const one = 1
export const two = 2
import { http, createPublicClient, webSocket } from 'viem'
import { mainnet } from 'viem/chains'
export * from './items'

const client = createPublicClient({
chain: mainnet,
transport: http(),
})

const webSocketClient = createPublicClient({
chain: mainnet,
transport: webSocket(
'wss://eth-mainnet.g.alchemy.com/v2/4iIl6mDHqX3GFrpzmfj2Soirf3MPoAcH',
),
})

const bn = await client.getBlockNumber()
const bn2 = await webSocketClient.getBlockNumber()
console.log({ bn, bn2 })

4 changes: 4 additions & 0 deletions src/items/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
export * from './router/items.js'
export * from './service/items.js'
export * from './interface/items.js'
export * from './interface/item.js'
12 changes: 12 additions & 0 deletions src/items/interface/item.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
// src/items/item.interface.ts

export interface BaseItem {
name: string;
price: number;
description: string;
image: string;
}

export interface Item extends BaseItem {
id: number;
}
7 changes: 7 additions & 0 deletions src/items/interface/items.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
// src/items/items.interface.ts

import { Item } from "./item";

export interface Items {
[key: number]: Item;
}
6 changes: 6 additions & 0 deletions src/items/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
{
"type": "module",
"types": "../_types/items/index.d.ts",
"module": "../_esm/items/index.js",
"main": "../_cjs/items/index.js"
}
50 changes: 50 additions & 0 deletions src/items/router/items.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
// src/items/items.router.ts

import { cors } from '@elysiajs/cors'
import { swagger } from '@elysiajs/swagger'

// interfaces

import * as ItemService from "../service/items";
import { BaseItem, Item } from "../interface/item";
import { Elysia } from "elysia";

class CustomError extends Error {
constructor(public message: string) {
super(message)
}
}

export const router = new Elysia()
.use(swagger())
.use(cors())
.onError(({ code, error }) => {
return new Response(error.toString())
})
.get('/ping', () => 'pong')
.group("/items", app => {
return app
.get('/', async () => await ItemService.findAll() )
.post('/', async ({ body, set }) => {
const newItem: Item = await ItemService.create(body as BaseItem);
set.status = 200
return new Response(newItem as any, {
headers: {
'Content-Type': 'application/json'
}
})
})
.delete("/:id", async ({ params }) => {
try {
await ItemService.remove(parseInt(params.id));
return { success: true };
} catch (e) {
return { success: false };
}
})
})
.get('/', () => {
throw new CustomError('Hello Error');
})


Loading

0 comments on commit 7fb7caf

Please sign in to comment.