Skip to content

Commit

Permalink
fix: πŸ› allow typed server methods access cache methods
Browse files Browse the repository at this point in the history
also fix pre typing issue

fix: πŸ› reflect reality of Hapi methods in types
  • Loading branch information
damusix committed Jan 17, 2025
1 parent 9aa775f commit d60f5dc
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 6 deletions.
23 changes: 20 additions & 3 deletions lib/types/server/methods.d.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,13 @@
import { PolicyOptions } from "@hapi/catbox";
import { CacheStatisticsObject, PolicyOptions } from "@hapi/catbox";

type AnyMethod = (...args: any[]) => any;

export type CachedServerMethod<T extends AnyMethod> = T & {
cache?: {
drop(...args: Parameters<T>): Promise<void>;
stats: CacheStatisticsObject
}
}

/**
* The method function with a signature async function(...args, [flags]) where:
Expand All @@ -7,7 +16,7 @@ import { PolicyOptions } from "@hapi/catbox";
* * * ttl - 0 if result is valid but cannot be cached. Defaults to cache policy.
* For reference [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-servermethodname-method-options)
*/
export type ServerMethod = (...args: any[]) => any;
export type ServerMethod = AnyMethod

/**
* The same cache configuration used in server.cache().
Expand Down Expand Up @@ -71,8 +80,16 @@ export interface ServerMethodConfigurationObject {
options?: ServerMethodOptions | undefined;
}

interface BaseServerMethods {
[name: string]: (
ServerMethod |
CachedServerMethod<ServerMethod> |
BaseServerMethods
);
}

/**
* An empty interface to allow typings of custom server.methods.
*/
export interface ServerMethods extends Record<string, ServerMethod> {
export interface ServerMethods extends BaseServerMethods {
}
3 changes: 2 additions & 1 deletion lib/types/server/server.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ import {
} from './methods';
import { ServerOptions } from './options';
import { ServerState, ServerStateCookieOptions } from './state';
import { CacheStatisticsObject } from '@hapi/catbox';

/**
* User-extensible type for application specific state (`server.app`).
Expand Down Expand Up @@ -203,7 +204,7 @@ export class Server<A = ServerApplicationState> {
* server method name is an object property.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-servermethods
*/
readonly methods: ServerMethods;
readonly methods: ServerMethods

/**
* Provides access to the server MIME database used for setting content-type information. The object must not be
Expand Down
15 changes: 13 additions & 2 deletions test/types/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ import {
Server,
ServerRoute,
server as createServer,
ServerRegisterPluginObject
Lifecycle,
CachedServerMethod
} from '../..';

const { expect: check } = lab;
Expand Down Expand Up @@ -114,6 +115,14 @@ server.cache.provision({
}
})

declare module '../..' {
interface ServerMethods {
test: {
add: CachedServerMethod<((a: number, b: number) => number)>;
}
}
}

server.method('test.add', (a: number, b: number) => a + b, {
bind: server,
cache: {
Expand All @@ -123,4 +132,6 @@ server.method('test.add', (a: number, b: number) => a + b, {
segment: 'test-segment',
},
generateKey: (a: number, b: number) => `${a}${b}`
});
});

server.methods.test.add.cache?.drop(1, 2);

0 comments on commit d60f5dc

Please sign in to comment.