repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge dependabot/npm_and_yarn/types/node-20.12.10 into combined-prs-branch
[poolifier.git]
/
examples
/
typescript
/
http-server-pool
/
express-cluster
/
src
/
worker.ts
diff --git
a/examples/typescript/http-server-pool/express-cluster/src/worker.ts
b/examples/typescript/http-server-pool/express-cluster/src/worker.ts
index e04900ab2474afa7833c6bde6c5086030ab3882f..98ca45deea0be0c1dab6bb92ff558555d9eee271 100644
(file)
--- a/
examples/typescript/http-server-pool/express-cluster/src/worker.ts
+++ b/
examples/typescript/http-server-pool/express-cluster/src/worker.ts
@@
-9,11
+9,17
@@
import type { WorkerData, WorkerResponse } from './types.js'
class ExpressWorker extends ClusterWorker<WorkerData, WorkerResponse> {
private static server: Server
class ExpressWorker extends ClusterWorker<WorkerData, WorkerResponse> {
private static server: Server
- private static readonly factorial = (n: number): number => {
- if (n === 0) {
- return 1
+ private static readonly factorial = (n: number | bigint): bigint => {
+ if (n === 0 || n === 1) {
+ return 1n
+ } else {
+ n = BigInt(n)
+ let factorial = 1n
+ for (let i = 1n; i <= n; i++) {
+ factorial *= i
+ }
+ return factorial
}
}
- return ExpressWorker.factorial(n - 1) * n
}
private static readonly startExpress = (
}
private static readonly startExpress = (
@@
-32,17
+38,21
@@
class ExpressWorker extends ClusterWorker<WorkerData, WorkerResponse> {
application.get('/api/factorial/:number', (req: Request, res: Response) => {
const { number } = req.params
application.get('/api/factorial/:number', (req: Request, res: Response) => {
const { number } = req.params
- res.send({ number: ExpressWorker.factorial(parseInt(number)) }).end()
+ res
+ .send({ number: ExpressWorker.factorial(parseInt(number)).toString() })
+ .end()
})
})
+ let listenerPort: number | undefined
ExpressWorker.server = application.listen(port, () => {
ExpressWorker.server = application.listen(port, () => {
+ listenerPort = (ExpressWorker.server.address() as AddressInfo).port
console.info(
console.info(
- `⚡️[express server]: Express server is started in cluster worker at http://localhost:${
p
ort}/`
+ `⚡️[express server]: Express server is started in cluster worker at http://localhost:${
listenerP
ort}/`
)
})
return {
status: true,
)
})
return {
status: true,
- port:
(ExpressWorker.server.address() as AddressInfo).
port
+ port:
listenerPort ??
port
}
}
}
}