From ab29b28125cb864ac70f05c8de6eefacb481c7cf Mon Sep 17 00:00:00 2001 From: qpismont Date: Wed, 10 Apr 2024 19:46:07 +0200 Subject: [PATCH 1/2] add srv params in handler + upgrade deps --- .woodpecker/.build.yml | 8 ++----- .woodpecker/.lint.yml | 2 +- .woodpecker/.test.yml | 5 ++++- bun.lockb | Bin 8404 -> 8413 bytes package.json | 48 ++++++++++++++++++++--------------------- src/service.ts | 4 ++-- src/types.ts | 2 ++ tests/service.test.ts | 15 +++++-------- 8 files changed, 40 insertions(+), 44 deletions(-) diff --git a/.woodpecker/.build.yml b/.woodpecker/.build.yml index dbe75f1..5f30941 100644 --- a/.woodpecker/.build.yml +++ b/.woodpecker/.build.yml @@ -3,11 +3,7 @@ when: steps: build: - image: oven/bun:${BUN_VERSION}-slim + image: oven/bun:1.1.3-slim commands: - bun install - - bun run build - -matrix: - BUN_VERSION: - - 1.1.0 \ No newline at end of file + - bun run build \ No newline at end of file diff --git a/.woodpecker/.lint.yml b/.woodpecker/.lint.yml index 5e06448..8005326 100644 --- a/.woodpecker/.lint.yml +++ b/.woodpecker/.lint.yml @@ -3,7 +3,7 @@ when: steps: lint: - image: oven/bun:1.0.33-slim + image: oven/bun:1.1.3-slim commands: - bun install - bun run ci diff --git a/.woodpecker/.test.yml b/.woodpecker/.test.yml index cc674e9..4f52a10 100644 --- a/.woodpecker/.test.yml +++ b/.woodpecker/.test.yml @@ -13,7 +13,10 @@ steps: matrix: BUN_VERSION: - 1.1.0 + - 1.1.1 + - 1.1.2 + - 1.1.3 services: nats: - image: nats \ No newline at end of file + image: nats:2-alpine \ No newline at end of file diff --git a/bun.lockb b/bun.lockb index 9b936975b504a3be4583980d9bc8364c7c3ba7f5..79ba9a04a38f0a7a78d179611a5467a4385183cb 100755 GIT binary patch delta 1977 zcmZWq3p`X=9KLr9F-%4tGZ%v~mW0b-Jn|T-t@I%4(V~Q6Rx+Nog*CKGDtUBRRPvZ* z*;T)Yina%-^bjhF@>o%pB=Y!WJ@%MPwLkawyXQOS`@Vb5cVGYW)V|X`4QH&quzp2j ztiFAwR`_-q(`!tr%`qe6kG1nX=X}oHQV80)HQkBLS3;1usE|F#!ol;6j1Xdw|Dgzc zZ$vX3NI@NX5E4Xu5!2C6e9t1bLX?KOI{`stAd1Es(7zmx8^jQV4)GjB6^NM-X%P8h zhyk(?AOI2=L??(;h~|q12E+wjCLwE+o~DXFFhU1V3xE+gWGw zvh1_h4|otcr~u>;Ipo*SWd&VuVnhO<6yciWei+hY32O_NbX&p#$T}@ydm+1d32Oj@ zJ1=2lA-i=6`v9^_=T(;Y|Gb9auVuv-YnBC}cFxk;1qhFnoSD7Ssr|Gz*OKB~+2m_; zidCzaS*|9Zs2#32HZMJJnQOOGHrJrT(+@ou-n5m zv?o4I2YGjsLQ~eI-#b2SS$rU&Xm@1IGh@cb+2T@SbJeiVz~rWoaEE00W>JKQP~e*- z!&7t+)$*k3y8cYDF_OB2P`Yk}&FGblJ;>Od#XWmG3YWc{G}hgnab+qFb9Lzo_Z*U% z2{+t9c_BZP(ET=$_1G|fKpPm4Y5cm9%ETKaF||F!VRV|u8zmL`INNLW9d*-7FEvl} z2ubv*a;=K+`%#x%I_pr*6KJjWN?&!LKKz&2%6_+kORL}qCrT$PiUyH*Q>^fifUJ3P zsGe&!FCStuU&qL{s_w7o^tSukwuhYi$Z)jeML7wR&-0xAK)OK5&asM4_BhxOGrrY9 zfp^4i9(2NVrR;($$+okvMpkdEpE$FtZ}6m4axh^^Ub{8GpF>-7DEoQJB`twl2XB}! zsCL)P+4gEYyKl7_>4DmLl`FF;cPn;hH2$XG|9cu=>n!~Cl znv1k*%Lg@EnLI5s8w zOzN(FU`qWu$LsO?nDVqriwG^V++If?=BxwH$Mp6)oi{;m5C360+3Z_ZKOcYsIZ6PS zkVwDgTQ{v;kZz+sIMfZjtvzfqR5-3+Vr764b{OBYaUry9mdiRB~^J z+Q=8>92li3sw}K1+Iiek?GB&c)XQA-00zcKAStf~ZXQF#m%bD*nwA2q!=uBwWnrciVhw#I-@7YDg&RN;sX r2GtZ{&sp6Bn5ff*y)8mTAE?l!L96;FpFY4e)Wl8kNNyA;pk)6C4hVUm delta 2006 zcmZuy3piA17(QoaFryd~b2)|?BFZq$q;V;BNKYu2wCI`InRLOfYx7VWHU^baLVp)D z>(&LWY|>?Ux{&B1Wi~5hs_mi+CS7Gw`?E9EvpUan&ijA=`=0NA|8x01rF*-34%hr) z=ApP4Wi4BI|E|vmS(N0r>MI|IY@BXAwNAZxPMZDW!d!nr%2WiACC08p#*diQ@o^Iv z8JZBsjfiW80SWR@gXluERAUDE-+YG}TOdw>ye|$x#`9@n8r18<_#z%bOd%eI$b`5H zA_L+^JYt7HkxUFHFo=sF(jjuy0tUo!p8SH>Y^L2S1w8Z_$^{rss3(TG`H+H3B2=J2 zIlur%M0bOHoDjVQx^O}Y6}obP3N5H0z!MKu))T4#Ai@jL9FPyM_dyq4NHK(I=0U9y z)WMw~x}UWoAR-9S0+3G-Qj}0NAF5ztMEmQElpbhQ^i4(pmk#Ivj9L=V(oxP9*AfV#AYp;pCJ4*F>I1 z7YMpUuegBOK_}=dT6Yp1#|jsGq#4{TWi9jIxkQYlcKFm(CwHFe-7!1$@A*GhPCYBn z*bG8RSKVxCls&Hth;<`_%}3H~Npihfhgcn4_U$K+eyhMMo4>$K}sxlY0PJ)m{U)f7o$ichAO)LDT~ z8%#VIQygYsx%h;nYZy6i)b{Ak{#9+*3EliAB-yt8O)KADJAj-qe9xLy{-8y#c&L#! z!vem16d@o6@Wt!FQ*#h-NsCCq^gvedy_B&)xsgKcK_d_*SHd3AK zz2*tF@B4&EobEouE=u)|)3aJ~ozmlSq>YWGe*il@Mhf=a?Odc$!?{(oJv*7Ij~fSj zW6nM{u6Xbw%G*;m@z6-ApKtZXthB2k~t z-0Qsg_JWnvXEe|Dg~m&@qNGi%O=@>C=*;kIcTBckms54FsshP!FXTu_!650BJ&8HCdv(PmIY#{`a?pf4o#lJt}RS3!*EX1)Bv90so#ROa}Kn&uRg?Uq)x_@RYb1I)1$lmtpJI_d&yF>CMw%fQ3u z0a8rZ02m)a?cvA@h?##9_*^~@%rUu++SiPkn4pk}Wz7M_rbH0PGMB`L i2-ueDk&CG=$YImek-n)m=wh3Ej!1xGMum~PnfzZbyM5pQ diff --git a/package.json b/package.json index 2a2d711..c8adcaa 100644 --- a/package.json +++ b/package.json @@ -1,26 +1,26 @@ { - "name": "@qpismont/nano-service", - "version": "0.0.2", - "module": "index.ts", - "type": "module", - "main": "./dist/index.js", - "types": "./dist/index.d.ts", - "files": ["/dist"], - "scripts": { - "ci": "biome ci . --error-on-warnings", - "test": "bun test", - "build": "tsc --project tsconfig.build.json" - }, - "devDependencies": { - "@biomejs/biome": "1.6.3", - "@types/bun": "latest", - "typescript": "^5.0.0" - }, - "peerDependencies": { - "typescript": "^5.0.0" - }, - "dependencies": { - "nats": "^2.19.0", - "zod": "^3.22.4" - } + "name": "@qpismont/nano-service", + "version": "0.0.2", + "module": "index.ts", + "type": "module", + "main": "./dist/index.js", + "types": "./dist/index.d.ts", + "files": ["/dist"], + "scripts": { + "ci": "biome ci . --error-on-warnings", + "test": "bun test", + "build": "tsc --project tsconfig.build.json" + }, + "devDependencies": { + "@biomejs/biome": "1.6.4", + "@types/bun": "latest", + "typescript": "^5.0.0" + }, + "peerDependencies": { + "typescript": "^5.0.0" + }, + "dependencies": { + "nats": "^2.22.0", + "zod": "^3.22.4" + } } diff --git a/src/service.ts b/src/service.ts index e57d05f..b754d69 100644 --- a/src/service.ts +++ b/src/service.ts @@ -29,7 +29,7 @@ export default class Service { adaptor: string, subject: string, fn: RouteSubscribeTypeFn, U>, - schema: T | undefined = undefined, + schema?: T, ) { this.adaptors[adaptor].subscribe( `${this.name}.${subject}`, @@ -64,7 +64,7 @@ export default class Service { } try { - const res = await fn(req); + const res = await fn(this, req); const internalResponse = { statusCode: res.statusCode, data: res.data, diff --git a/src/types.ts b/src/types.ts index 711a9f3..bb7e21e 100644 --- a/src/types.ts +++ b/src/types.ts @@ -1,6 +1,8 @@ import type { Request, Response } from "./messages.ts"; +import type Service from "./service.ts"; export type AdaptorSubscribeTypeFn = (msg: string) => Promise; export type RouteSubscribeTypeFn = ( + srv: Service, msg: Request, ) => Promise>; diff --git a/tests/service.test.ts b/tests/service.test.ts index d65524b..bc1101f 100644 --- a/tests/service.test.ts +++ b/tests/service.test.ts @@ -27,7 +27,7 @@ test("request success", async () => { srv.subscribe( adaptorName, subject, - async (msg) => { + async (srv, msg) => { return { data: msg.data, statusCode: statusCodeExpected }; }, z.string(), @@ -54,14 +54,9 @@ test("request error", async () => { const statusCodeExpected = 500; srv.addAdaptor(adaptorName, new NatsAdaptor({ servers: [natsServer] })); - srv.subscribe( - adaptorName, - subject, - async (msg) => { - throw new RequestError("request error", 500); - }, - z.string(), - ); + srv.subscribe(adaptorName, subject, async (srv, msg) => { + throw new RequestError("request error", 500); + }); await srv.listen(); expect(() => { @@ -82,7 +77,7 @@ test("request adaptor not found", async () => { const statusCodeExpected = 200; srv.addAdaptor(adaptorName, new NatsAdaptor({ servers: [natsServer] })); - srv.subscribe(adaptorName, subject, async (msg) => { + srv.subscribe(adaptorName, subject, async (srv, msg) => { return { data: msg.data, statusCode: statusCodeExpected }; }); From fb7cd0bf341e1c5fe98f6f77043d8a88fe5134a7 Mon Sep 17 00:00:00 2001 From: qpismont Date: Wed, 10 Apr 2024 19:48:26 +0200 Subject: [PATCH 2/2] fix package.json --- package.json | 48 ++++++++++++++++++++++++------------------------ 1 file changed, 24 insertions(+), 24 deletions(-) diff --git a/package.json b/package.json index c8adcaa..8dde485 100644 --- a/package.json +++ b/package.json @@ -1,26 +1,26 @@ { - "name": "@qpismont/nano-service", - "version": "0.0.2", - "module": "index.ts", - "type": "module", - "main": "./dist/index.js", - "types": "./dist/index.d.ts", - "files": ["/dist"], - "scripts": { - "ci": "biome ci . --error-on-warnings", - "test": "bun test", - "build": "tsc --project tsconfig.build.json" - }, - "devDependencies": { - "@biomejs/biome": "1.6.4", - "@types/bun": "latest", - "typescript": "^5.0.0" - }, - "peerDependencies": { - "typescript": "^5.0.0" - }, - "dependencies": { - "nats": "^2.22.0", - "zod": "^3.22.4" - } + "name": "@qpismont/nano-service", + "version": "0.0.2", + "module": "index.ts", + "type": "module", + "main": "./dist/index.js", + "types": "./dist/index.d.ts", + "files": ["/dist"], + "scripts": { + "ci": "biome ci . --error-on-warnings", + "test": "bun test", + "build": "tsc --project tsconfig.build.json" + }, + "devDependencies": { + "@biomejs/biome": "1.6.4", + "@types/bun": "latest", + "typescript": "^5.0.0" + }, + "peerDependencies": { + "typescript": "^5.0.0" + }, + "dependencies": { + "nats": "^2.22.0", + "zod": "^3.22.4" + } }