repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
build(deps-dev): bump typescript
[poolifier.git]
/
examples
/
typescript
/
http-server-pool
/
fastify-hybrid
/
src
/
fastify-worker.ts
diff --git
a/examples/typescript/http-server-pool/fastify-hybrid/src/fastify-worker.ts
b/examples/typescript/http-server-pool/fastify-hybrid/src/fastify-worker.ts
index dd77f1238a90a203185f1fe2a9ae4b803d378e5f..8e4713cfae2df7e3a158c6191a3ec57fc3d8060f 100644
(file)
--- a/
examples/typescript/http-server-pool/fastify-hybrid/src/fastify-worker.ts
+++ b/
examples/typescript/http-server-pool/fastify-hybrid/src/fastify-worker.ts
@@
-1,8
+1,10
@@
import type { AddressInfo } from 'node:net'
import type { AddressInfo } from 'node:net'
-import { ClusterWorker } from 'poolifier'
+
import Fastify, { type FastifyInstance } from 'fastify'
import Fastify, { type FastifyInstance } from 'fastify'
-import type { ClusterWorkerData, ClusterWorkerResponse } from './types.js'
+import { ClusterWorker } from 'poolifier'
+
import { fastifyPoolifier } from './fastify-poolifier.js'
import { fastifyPoolifier } from './fastify-poolifier.js'
+import type { ClusterWorkerData, ClusterWorkerResponse } from './types.js'
class FastifyWorker extends ClusterWorker<
ClusterWorkerData,
class FastifyWorker extends ClusterWorker<
ClusterWorkerData,
@@
-13,17
+15,21
@@
ClusterWorkerResponse
private static readonly startFastify = async (
workerData?: ClusterWorkerData
): Promise<ClusterWorkerResponse> => {
private static readonly startFastify = async (
workerData?: ClusterWorkerData
): Promise<ClusterWorkerResponse> => {
- const { port } = workerData as ClusterWorkerData
+ const { port, ...fastifyPoolifierOptions } = workerData!
+
FastifyWorker.fastify = Fastify({
logger: true
})
FastifyWorker.fastify = Fastify({
logger: true
})
- await FastifyWorker.fastify.register(fastifyPoolifier, workerData)
+ await FastifyWorker.fastify.register(
+ fastifyPoolifier,
+ fastifyPoolifierOptions
+ )
FastifyWorker.fastify.all('/api/echo', async request => {
return (
FastifyWorker.fastify.all('/api/echo', async request => {
return (
- await FastifyWorker.fastify.execute({
body
: request.body }, 'echo')
- ).
body
+ await FastifyWorker.fastify.execute({
data
: request.body }, 'echo')
+ ).
data
})
FastifyWorker.fastify.get<{
})
FastifyWorker.fastify.get<{
@@
-31,8
+37,8
@@
ClusterWorkerResponse
}>('/api/factorial/:number', async request => {
const { number } = request.params
return (
}>('/api/factorial/:number', async request => {
const { number } = request.params
return (
- await FastifyWorker.fastify.execute({
body
: { number } }, 'factorial')
- ).
body
+ await FastifyWorker.fastify.execute({
data
: { number } }, 'factorial')
+ ).
data
})
await FastifyWorker.fastify.listen({ port })
})
await FastifyWorker.fastify.listen({ port })
@@
-43,7
+49,12
@@
ClusterWorkerResponse
}
public constructor () {
}
public constructor () {
- super(FastifyWorker.startFastify)
+ super(FastifyWorker.startFastify, {
+ killHandler: async () => {
+ await FastifyWorker.fastify.pool.destroy()
+ await FastifyWorker.fastify.close()
+ }
+ })
}
}
}
}