@nmtjs/contract 0.15.0-beta.1 → 0.15.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ export declare const Kind: unique symbol;
@@ -0,0 +1,2 @@
1
+ export const Kind = Symbol.for('neemata:kind');
2
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA"}
@@ -0,0 +1,39 @@
1
+ export * from './schemas/event.ts';
2
+ export * from './schemas/procedure.ts';
3
+ export * from './schemas/router.ts';
4
+ export * from './schemas/subscription.ts';
5
+ export declare namespace contract {
6
+ const procedure: <const Options extends {
7
+ input?: import("@nmtjs/type").BaseType;
8
+ output?: import("@nmtjs/type").BaseType;
9
+ stream?: true | undefined;
10
+ timeout?: number;
11
+ schemaOptions?: import("./utils.ts").ContractSchemaOptions;
12
+ name?: string;
13
+ }>(options: Options) => import("./schemas/procedure.ts").TProcedureContract<Options["input"] extends import("@nmtjs/type").BaseType ? Options["input"] : import("@nmtjs/type/never").NeverType, Options["output"] extends import("@nmtjs/type").BaseType ? Options["output"] : import("@nmtjs/type/never").NeverType, Options["stream"] extends true ? true : undefined, Options["name"] extends string ? Options["name"] : undefined>;
14
+ const event: <Payload extends import("@nmtjs/type").BaseType, Name extends string | undefined = undefined, Options extends import("./schemas/subscription.ts").SubcriptionOptions | undefined = undefined>(options?: {
15
+ payload?: Payload;
16
+ schemaOptions?: import("./utils.ts").ContractSchemaOptions;
17
+ name?: Name;
18
+ }) => import("./schemas/event.ts").TEventContract<Payload, Name, Options>;
19
+ const subscription: (<const Options extends {
20
+ events: Record<string, import("./schemas/event.ts").TAnyEventContract>;
21
+ name?: string;
22
+ schemaOptions?: import("./utils.ts").ContractSchemaOptions;
23
+ }, SubOpt extends import("./schemas/subscription.ts").SubcriptionOptions = null>(options: Options) => import("./schemas/subscription.ts").TSubscriptionContract<SubOpt, Options["events"], Options["name"]>) & {
24
+ withOptions: <Options extends import("./schemas/subscription.ts").SubcriptionOptions>() => <T extends {
25
+ events: Record<string, import("./schemas/event.ts").TAnyEventContract>;
26
+ name?: string;
27
+ schemaOptions?: import("./utils.ts").ContractSchemaOptions;
28
+ }>(options: T) => import("./schemas/subscription.ts").TSubscriptionContract<Options, T["events"], T["name"]>;
29
+ };
30
+ const router: <const Options extends {
31
+ routes: Record<string, import("./schemas/router.ts").TRouteContract>;
32
+ name?: string;
33
+ timeout?: number;
34
+ schemaOptions?: import("./utils.ts").ContractSchemaOptions;
35
+ }>(options: Options) => import("./schemas/router.ts").TRouterContract<Options["routes"], Options["name"] extends string ? Options["name"] : undefined>;
36
+ const blob: (options?: import("./types/blob.ts").BlobOptions) => import("@nmtjs/type/custom").CustomType<import("@nmtjs/protocol").ProtocolBlobInterface>;
37
+ }
38
+ export { contract as c };
39
+ export default contract;
package/dist/index.js ADDED
@@ -0,0 +1,20 @@
1
+ import { EventContract } from "./schemas/event.js";
2
+ import { ProcedureContract } from "./schemas/procedure.js";
3
+ import { RouterContract } from "./schemas/router.js";
4
+ import { SubscriptionContract } from "./schemas/subscription.js";
5
+ import { BlobType } from "./types/blob.js";
6
+ export * from "./schemas/event.js";
7
+ export * from "./schemas/procedure.js";
8
+ export * from "./schemas/router.js";
9
+ export * from "./schemas/subscription.js";
10
+ export var contract;
11
+ (function (contract) {
12
+ contract.procedure = ProcedureContract;
13
+ contract.event = EventContract;
14
+ contract.subscription = SubscriptionContract;
15
+ contract.router = RouterContract;
16
+ contract.blob = BlobType;
17
+ })(contract || (contract = {}));
18
+ export { contract as c };
19
+ export default contract;
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AAChE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAE1C,cAAc,oBAAoB,CAAA;AAClC,cAAc,wBAAwB,CAAA;AACtC,cAAc,qBAAqB,CAAA;AACnC,cAAc,2BAA2B,CAAA;AAEzC,MAAM,KAAW,QAAQ,CAMxB;AAND,WAAiB,QAAQ;IACV,kBAAS,GAAG,iBAAiB,CAAA;IAC7B,cAAK,GAAG,aAAa,CAAA;IACrB,qBAAY,GAAG,oBAAoB,CAAA;IACnC,eAAM,GAAG,cAAc,CAAA;IACvB,aAAI,GAAG,QAAQ,CAAA;AAC9B,CAAC,EANgB,QAAQ,KAAR,QAAQ,QAMxB;AAED,OAAO,EAAE,QAAQ,IAAI,CAAC,EAAE,CAAA;AAExB,eAAe,QAAQ,CAAA"}
@@ -0,0 +1,20 @@
1
+ import type { BaseType } from '@nmtjs/type';
2
+ import { t } from '@nmtjs/type';
3
+ import type { ContractSchemaOptions } from '../utils.ts';
4
+ import type { SubcriptionOptions } from './subscription.ts';
5
+ import { Kind } from '../constants.ts';
6
+ export declare const EventKind: unique symbol;
7
+ export type TAnyEventContract = TEventContract<BaseType, string | undefined, SubcriptionOptions | undefined>;
8
+ export interface TEventContract<Payload extends BaseType = t.NeverType, Name extends string | undefined = undefined, Options extends SubcriptionOptions | undefined = undefined> {
9
+ readonly [Kind]: typeof EventKind;
10
+ readonly type: 'neemata:event';
11
+ readonly name: Name;
12
+ readonly payload: Payload;
13
+ readonly options: Options;
14
+ }
15
+ export declare const EventContract: <Payload extends BaseType, Name extends string | undefined = undefined, Options extends SubcriptionOptions | undefined = undefined>(options?: {
16
+ payload?: Payload;
17
+ schemaOptions?: ContractSchemaOptions;
18
+ name?: Name;
19
+ }) => TEventContract<Payload, Name, Options>;
20
+ export declare function IsEventContract(value: any): value is TAnyEventContract;
@@ -0,0 +1,19 @@
1
+ import { t } from '@nmtjs/type';
2
+ import { Kind } from "../constants.js";
3
+ import { createSchema } from "../utils.js";
4
+ export const EventKind = Symbol('NeemataEvent');
5
+ export const EventContract = (options) => {
6
+ const { payload = t.never(), schemaOptions = {}, name = undefined, } = options ?? {};
7
+ return createSchema({
8
+ ...schemaOptions,
9
+ [Kind]: EventKind,
10
+ type: 'neemata:event',
11
+ payload,
12
+ name,
13
+ options: undefined,
14
+ });
15
+ };
16
+ export function IsEventContract(value) {
17
+ return Kind in value && value[Kind] === EventKind;
18
+ }
19
+ //# sourceMappingURL=event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event.js","sourceRoot":"","sources":["../../src/schemas/event.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,aAAa,CAAA;AAI/B,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAE1C,MAAM,CAAC,MAAM,SAAS,GAAG,MAAM,CAAC,cAAc,CAAC,CAAA;AAoB/C,MAAM,CAAC,MAAM,aAAa,GAAG,CAI3B,OAID,EAAE,EAAE;IACH,MAAM,EACJ,OAAO,GAAG,CAAC,CAAC,KAAK,EAAwB,EACzC,aAAa,GAAG,EAAE,EAClB,IAAI,GAAG,SAAgB,GACxB,GAAG,OAAO,IAAI,EAAE,CAAA;IACjB,OAAO,YAAY,CAAyC;QAC1D,GAAG,aAAa;QAChB,CAAC,IAAI,CAAC,EAAE,SAAS;QACjB,IAAI,EAAE,eAAe;QACrB,OAAO;QACP,IAAI;QACJ,OAAO,EAAE,SAAoB;KAC9B,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,MAAM,UAAU,eAAe,CAAC,KAAU;IACxC,OAAO,IAAI,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,SAAS,CAAA;AACnD,CAAC"}
@@ -0,0 +1,25 @@
1
+ import type { BaseType } from '@nmtjs/type';
2
+ import type { NeverType } from '@nmtjs/type/never';
3
+ import type { ContractSchemaOptions } from '../utils.ts';
4
+ import { Kind } from '../constants.ts';
5
+ export type TAnyProcedureContract = TProcedureContract<BaseType, BaseType, true | undefined, string | undefined>;
6
+ export declare const ProcedureKind: unique symbol;
7
+ export interface TProcedureContract<Input extends BaseType, Output extends BaseType, Stream extends true | undefined = undefined, Name extends string | undefined = undefined> {
8
+ readonly [Kind]: typeof ProcedureKind;
9
+ readonly type: 'neemata:procedure';
10
+ readonly name: Name;
11
+ readonly input: Input;
12
+ readonly output: Output;
13
+ readonly stream: Stream;
14
+ readonly timeout?: number;
15
+ }
16
+ export declare const ProcedureContract: <const Options extends {
17
+ input?: BaseType;
18
+ output?: BaseType;
19
+ stream?: true | undefined;
20
+ timeout?: number;
21
+ schemaOptions?: ContractSchemaOptions;
22
+ name?: string;
23
+ }>(options: Options) => TProcedureContract<Options["input"] extends BaseType ? Options["input"] : NeverType, Options["output"] extends BaseType ? Options["output"] : NeverType, Options["stream"] extends true ? true : undefined, Options["name"] extends string ? Options["name"] : undefined>;
24
+ export declare function IsProcedureContract(contract: any): contract is TAnyProcedureContract;
25
+ export declare function IsStreamProcedureContract(contract: any): contract is TAnyProcedureContract;
@@ -0,0 +1,24 @@
1
+ import { t } from '@nmtjs/type';
2
+ import { Kind } from "../constants.js";
3
+ import { createSchema } from "../utils.js";
4
+ export const ProcedureKind = Symbol('NeemataProcedure');
5
+ export const ProcedureContract = (options) => {
6
+ const { input = t.never(), output = t.never(), stream = undefined, name = undefined, timeout, schemaOptions = {}, } = options;
7
+ return createSchema({
8
+ ...schemaOptions,
9
+ [Kind]: ProcedureKind,
10
+ type: 'neemata:procedure',
11
+ input,
12
+ output,
13
+ stream,
14
+ name,
15
+ timeout,
16
+ });
17
+ };
18
+ export function IsProcedureContract(contract) {
19
+ return Kind in contract && contract[Kind] === ProcedureKind;
20
+ }
21
+ export function IsStreamProcedureContract(contract) {
22
+ return IsProcedureContract(contract) && typeof contract.stream !== 'undefined';
23
+ }
24
+ //# sourceMappingURL=procedure.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"procedure.js","sourceRoot":"","sources":["../../src/schemas/procedure.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,CAAC,EAAE,MAAM,aAAa,CAAA;AAG/B,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAS1C,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAA;AAiBvD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAU/B,OAAgB,EAMhB,EAAE;IACF,MAAM,EACJ,KAAK,GAAG,CAAC,CAAC,KAAK,EAAS,EACxB,MAAM,GAAG,CAAC,CAAC,KAAK,EAAS,EACzB,MAAM,GAAG,SAAgB,EACzB,IAAI,GAAG,SAAgB,EACvB,OAAO,EACP,aAAa,GAAG,EAAE,GACnB,GAAG,OAAO,CAAA;IACX,OAAO,YAAY,CAAC;QAClB,GAAG,aAAa;QAChB,CAAC,IAAI,CAAC,EAAE,aAAa;QACrB,IAAI,EAAE,mBAAmB;QACzB,KAAK;QACL,MAAM;QACN,MAAM;QACN,IAAI;QACJ,OAAO;KACR,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,MAAM,UAAU,mBAAmB,CACjC,QAAa;IAEb,OAAO,IAAI,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,aAAa,CAAA;AAC7D,CAAC;AAED,MAAM,UAAU,yBAAyB,CACvC,QAAa;IAEb,OAAO,mBAAmB,CAAC,QAAQ,CAAC,IAAI,OAAO,QAAQ,CAAC,MAAM,KAAK,WAAW,CAAA;AAChF,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { ContractSchemaOptions } from '../utils.ts';
2
+ import type { TAnyProcedureContract, TProcedureContract } from './procedure.ts';
3
+ import { Kind } from '../constants.ts';
4
+ export declare const RouterKind: unique symbol;
5
+ export type TAnyRouterContract<RouteContracts extends Record<string, TRouteContract> = Record<string, TRouteContract>, RouterName extends string | undefined = string | undefined> = TRouterContract<RouteContracts, RouterName>;
6
+ export type TRouteContract = TAnyProcedureContract | TRouterContract<Record<string, TRouteContract>, string | undefined>;
7
+ export interface TRouterContract<Routes extends Record<string, TRouteContract> = {}, Name extends string | undefined = undefined> {
8
+ readonly [Kind]: typeof RouterKind;
9
+ readonly type: 'neemata:router';
10
+ readonly name: Name;
11
+ readonly routes: {
12
+ [K in keyof Routes]: Routes[K] extends TAnyRouterContract ? TRouterContract<Routes[K]['routes'], Name extends string ? `${Name}/${Extract<K, string>}` : Extract<K, string>> : Routes[K] extends TAnyProcedureContract ? TProcedureContract<Routes[K]['input'], Routes[K]['output'], Routes[K]['stream'], Name extends string ? `${Name}/${Extract<K, string>}` : Extract<K, string>> : never;
13
+ };
14
+ readonly timeout?: number;
15
+ }
16
+ export declare const RouterContract: <const Options extends {
17
+ routes: Record<string, TRouteContract>;
18
+ name?: string;
19
+ timeout?: number;
20
+ schemaOptions?: ContractSchemaOptions;
21
+ }>(options: Options) => TRouterContract<Options["routes"], Options["name"] extends string ? Options["name"] : undefined>;
22
+ export declare function IsRouterContract(value: any): value is TAnyRouterContract;
@@ -0,0 +1,42 @@
1
+ import { Kind } from "../constants.js";
2
+ import { concatFullName, createSchema } from "../utils.js";
3
+ import { IsProcedureContract } from "./procedure.js";
4
+ export const RouterKind = Symbol('NeemataRouter');
5
+ export const RouterContract = (options) => {
6
+ const { name = undefined, timeout, schemaOptions = {}, } = options;
7
+ const routes = processNestedRoutes(options.routes, name);
8
+ return createSchema({
9
+ ...schemaOptions,
10
+ [Kind]: RouterKind,
11
+ type: 'neemata:router',
12
+ name,
13
+ routes,
14
+ timeout,
15
+ });
16
+ };
17
+ function processNestedRoutes(routes, parentName) {
18
+ const processed = {};
19
+ for (const routeName in routes) {
20
+ const route = routes[routeName];
21
+ if (IsRouterContract(route)) {
22
+ const nestedName = concatFullName(parentName, routeName);
23
+ processed[routeName] = createSchema({
24
+ ...route,
25
+ name: nestedName,
26
+ routes: processNestedRoutes(route.routes, nestedName),
27
+ });
28
+ }
29
+ else if (IsProcedureContract(route)) {
30
+ const fullName = concatFullName(parentName, routeName);
31
+ processed[routeName] = createSchema({ ...route, name: fullName });
32
+ }
33
+ else {
34
+ throw new Error(`Invalid route type for ${routeName}`);
35
+ }
36
+ }
37
+ return processed;
38
+ }
39
+ export function IsRouterContract(value) {
40
+ return Kind in value && value[Kind] === RouterKind;
41
+ }
42
+ //# sourceMappingURL=router.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.js","sourceRoot":"","sources":["../../src/schemas/router.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAA;AAEpD,MAAM,CAAC,MAAM,UAAU,GAAG,MAAM,CAAC,eAAe,CAAC,CAAA;AA2CjD,MAAM,CAAC,MAAM,cAAc,GAAG,CAQ5B,OAAgB,EAChB,EAAE;IACF,MAAM,EACJ,IAAI,GAAG,SAAgB,EACvB,OAAO,EACP,aAAa,GAAG,EAA2B,GAC5C,GAAG,OAAO,CAAA;IAEX,MAAM,MAAM,GAAQ,mBAAmB,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;IAE7D,OAAO,YAAY,CAKjB;QACA,GAAG,aAAa;QAChB,CAAC,IAAI,CAAC,EAAE,UAAU;QAClB,IAAI,EAAE,gBAAgB;QACtB,IAAI;QACJ,MAAM;QACN,OAAO;KACR,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,SAAS,mBAAmB,CAC1B,MAAkE,EAClE,UAA8B;IAE9B,MAAM,SAAS,GAAwB,EAAE,CAAA;IAEzC,KAAK,MAAM,SAAS,IAAI,MAAM,EAAE,CAAC;QAC/B,MAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAAC,CAAA;QAE/B,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,MAAM,UAAU,GAAG,cAAc,CAAC,UAAU,EAAE,SAAS,CAAC,CAAA;YACxD,SAAS,CAAC,SAAS,CAAC,GAAG,YAAY,CAAC;gBAClC,GAAG,KAAK;gBACR,IAAI,EAAE,UAAU;gBAChB,MAAM,EAAE,mBAAmB,CAAC,KAAK,CAAC,MAAM,EAAE,UAAU,CAAC;aACtD,CAAC,CAAA;QACJ,CAAC;aAAM,IAAI,mBAAmB,CAAC,KAAK,CAAC,EAAE,CAAC;YACtC,MAAM,QAAQ,GAAG,cAAc,CAAC,UAAU,EAAE,SAAS,CAAC,CAAA;YACtD,SAAS,CAAC,SAAS,CAAC,GAAG,YAAY,CAAC,EAAE,GAAG,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAA;QACnE,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,0BAA0B,SAAS,EAAE,CAAC,CAAA;QACxD,CAAC;IACH,CAAC;IAED,OAAO,SAAS,CAAA;AAClB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAU;IACzC,OAAO,IAAI,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,UAAU,CAAA;AACpD,CAAC"}
@@ -0,0 +1,27 @@
1
+ import type { ContractSchemaOptions } from '../utils.ts';
2
+ import type { TAnyEventContract, TEventContract } from './event.ts';
3
+ import { Kind } from '../constants.ts';
4
+ export declare const SubscriptionKind: unique symbol;
5
+ export type SubcriptionOptions = Record<string, string | number | boolean> | null;
6
+ export type TAnySubscriptionContract = TSubscriptionContract<SubcriptionOptions, Record<string, TAnyEventContract>, string | undefined>;
7
+ export interface TSubscriptionContract<Options extends SubcriptionOptions = null, Events extends Record<string, unknown> = {}, Name extends string | undefined = undefined> {
8
+ readonly [Kind]: typeof SubscriptionKind;
9
+ readonly type: 'neemata:subscription';
10
+ readonly name: Name;
11
+ readonly options: Options;
12
+ readonly events: {
13
+ [K in keyof Events]: Events[K] extends TAnyEventContract ? TEventContract<Events[K]['payload'], Name extends string ? `${Name}/${Extract<K, string>}` : Extract<K, string>, Options> : never;
14
+ };
15
+ }
16
+ export declare const SubscriptionContract: (<const Options extends {
17
+ events: Record<string, TAnyEventContract>;
18
+ name?: string;
19
+ schemaOptions?: ContractSchemaOptions;
20
+ }, SubOpt extends SubcriptionOptions = null>(options: Options) => TSubscriptionContract<SubOpt, Options["events"], Options["name"]>) & {
21
+ withOptions: <Options extends SubcriptionOptions>() => <T extends {
22
+ events: Record<string, TAnyEventContract>;
23
+ name?: string;
24
+ schemaOptions?: ContractSchemaOptions;
25
+ }>(options: T) => TSubscriptionContract<Options, T["events"], T["name"]>;
26
+ };
27
+ export declare function IsSubscriptionContract(contract: any): contract is TAnySubscriptionContract;
@@ -0,0 +1,29 @@
1
+ import { Kind } from "../constants.js";
2
+ import { concatFullName, createSchema } from "../utils.js";
3
+ export const SubscriptionKind = Symbol('NeemataSubscription');
4
+ const _SubscriptionContract = (options) => {
5
+ const { schemaOptions = {}, name } = options;
6
+ const _events = {};
7
+ for (const key in options.events) {
8
+ const event = options.events[key];
9
+ const fullName = concatFullName(name, key);
10
+ _events[key] = createSchema({ ...event, name: fullName });
11
+ }
12
+ return createSchema({
13
+ ...schemaOptions,
14
+ [Kind]: SubscriptionKind,
15
+ type: 'neemata:subscription',
16
+ events: _events,
17
+ name: name,
18
+ options: undefined,
19
+ });
20
+ };
21
+ export const SubscriptionContract = Object.assign(_SubscriptionContract, {
22
+ withOptions: () => {
23
+ return (options) => _SubscriptionContract(options);
24
+ },
25
+ });
26
+ export function IsSubscriptionContract(contract) {
27
+ return Kind in contract && contract[Kind] === SubscriptionKind;
28
+ }
29
+ //# sourceMappingURL=subscription.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"subscription.js","sourceRoot":"","sources":["../../src/schemas/subscription.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAE1D,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAA;AAmC7D,MAAM,qBAAqB,GAAG,CAQ5B,OAAgB,EAChB,EAAE;IACF,MAAM,EAAE,aAAa,GAAG,EAAE,EAAE,IAAI,EAAE,GAAG,OAAO,CAAA;IAC5C,MAAM,OAAO,GAAG,EAAS,CAAA;IACzB,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;QACjC,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QACjC,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;QAC1C,OAAO,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC,EAAE,GAAG,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAA;IAC3D,CAAC;IACD,OAAO,YAAY,CAEjB;QACA,GAAG,aAAa;QAChB,CAAC,IAAI,CAAC,EAAE,gBAAgB;QACxB,IAAI,EAAE,sBAAsB;QAC5B,MAAM,EAAE,OAAO;QACf,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,SAA8B;KACxC,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,oBAAoB,GAAG,MAAM,CAAC,MAAM,CAAC,qBAAqB,EAAE;IACvE,WAAW,EAAE,GAAuC,EAAE;QACpD,OAAO,CAOL,OAAU,EACV,EAAE,CAAC,qBAAqB,CAAa,OAAO,CAAC,CAAA;IACjD,CAAC;CACF,CAAC,CAAA;AAEF,MAAM,UAAU,sBAAsB,CACpC,QAAa;IAEb,OAAO,IAAI,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,gBAAgB,CAAA;AAChE,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { ProtocolBlobInterface } from '@nmtjs/protocol';
2
+ import { CustomType } from '@nmtjs/type/custom';
3
+ export interface BlobOptions {
4
+ maxSize?: number;
5
+ contentType?: string;
6
+ }
7
+ export declare const BlobType: (options?: BlobOptions) => CustomType<ProtocolBlobInterface>;
@@ -0,0 +1,36 @@
1
+ import { isBlobInterface } from '@nmtjs/protocol';
2
+ import { CustomType } from '@nmtjs/type/custom';
3
+ export const BlobType = (options = {}) => CustomType.factory({
4
+ decode: (value) => value,
5
+ encode: (value) => value,
6
+ validation: {
7
+ decode(value, { addIssue }) {
8
+ if (isBlobInterface(value)) {
9
+ if (options.maxSize) {
10
+ const size = value.metadata.size;
11
+ if (typeof size !== 'undefined' && size > options.maxSize) {
12
+ addIssue({
13
+ code: 'custom',
14
+ message: `Blob size unknown or exceeds maximum allowed size of ${options.maxSize} bytes`,
15
+ });
16
+ }
17
+ }
18
+ }
19
+ else {
20
+ addIssue({
21
+ code: 'custom',
22
+ message: 'Value is not a Neemata Blob. Make sure to use transport that supports encoded streams.',
23
+ });
24
+ }
25
+ },
26
+ encode(value, { addIssue }) {
27
+ if (!isBlobInterface(value)) {
28
+ addIssue({
29
+ code: 'custom',
30
+ message: 'Value is not a Neemata Blob. Make sure to use transport that supports encoded streams.',
31
+ });
32
+ }
33
+ },
34
+ },
35
+ });
36
+ //# sourceMappingURL=blob.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blob.js","sourceRoot":"","sources":["../../src/types/blob.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAO/C,MAAM,CAAC,MAAM,QAAQ,GAAG,CACtB,UAAuB,EAAE,EACU,EAAE,CACrC,UAAU,CAAC,OAAO,CAAC;IACjB,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK;IACxB,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK;IACxB,UAAU,EAAE;QACV,MAAM,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE;YACxB,IAAI,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC3B,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;oBACpB,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAA;oBAChC,IAAI,OAAO,IAAI,KAAK,WAAW,IAAI,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;wBAC1D,QAAQ,CAAC;4BACP,IAAI,EAAE,QAAQ;4BACd,OAAO,EAAE,wDAAwD,OAAO,CAAC,OAAO,QAAQ;yBACzF,CAAC,CAAA;oBACJ,CAAC;gBACH,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC;oBACP,IAAI,EAAE,QAAQ;oBACd,OAAO,EACL,wFAAwF;iBAC3F,CAAC,CAAA;YACJ,CAAC;QACH,CAAC;QACD,MAAM,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC5B,QAAQ,CAAC;oBACP,IAAI,EAAE,QAAQ;oBACd,OAAO,EACL,wFAAwF;iBAC3F,CAAC,CAAA;YACJ,CAAC;QACH,CAAC;KACF;CACF,CAAC,CAAA"}
@@ -0,0 +1,18 @@
1
+ export type ContractSchemaOptions = {
2
+ title?: string;
3
+ description?: string;
4
+ };
5
+ export declare const applyNames: <T extends Record<string, {
6
+ serviceName?: string;
7
+ }>>(params: T, opts: {
8
+ serviceName?: string;
9
+ subscriptionName?: string;
10
+ }) => {
11
+ [k: string]: {
12
+ serviceName?: string;
13
+ subscriptionName?: string;
14
+ name: string;
15
+ };
16
+ };
17
+ export declare const createSchema: <T>(schema: T) => T;
18
+ export declare const concatFullName: (parent: string | undefined, name: string) => string;
package/dist/utils.js ADDED
@@ -0,0 +1,8 @@
1
+ export const applyNames = (params, opts) => {
2
+ return Object.fromEntries(Object.entries(params).map(([k, v]) => [k, { ...v, name: k, ...opts }]));
3
+ };
4
+ export const createSchema = (schema) => Object.freeze(schema);
5
+ export const concatFullName = (parent, name) => {
6
+ return parent ? `${parent}/${name}` : name;
7
+ };
8
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,MAAS,EACT,IAAyD,EACzD,EAAE;IACF,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,CACxE,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,CAAI,MAAS,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAM,CAAA;AAExE,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,MAA0B,EAAE,IAAY,EAAE,EAAE;IACzE,OAAO,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;AAC5C,CAAC,CAAA"}
package/package.json CHANGED
@@ -5,8 +5,8 @@
5
5
  ".": "./dist/index.js"
6
6
  },
7
7
  "dependencies": {
8
- "@nmtjs/protocol": "0.15.0-beta.1",
9
- "@nmtjs/type": "0.15.0-beta.1"
8
+ "@nmtjs/type": "0.15.0-beta.3",
9
+ "@nmtjs/protocol": "0.15.0-beta.3"
10
10
  },
11
11
  "devDependencies": {
12
12
  "zod": "^4.1.0"
@@ -16,10 +16,10 @@
16
16
  "LICENSE.md",
17
17
  "README.md"
18
18
  ],
19
- "version": "0.15.0-beta.1",
19
+ "version": "0.15.0-beta.3",
20
20
  "scripts": {
21
21
  "clean-build": "rm -rf ./dist",
22
- "build": "tsc",
22
+ "build": "tsc --declaration --sourcemap",
23
23
  "dev": "tsc --watch",
24
24
  "type-check": "tsc --noEmit"
25
25
  }