|
1 | 1 | import { HookContext, NextFunction } from '@feathersjs/feathers'; |
2 | | -import { BadRequest } from '../../errors/lib'; |
3 | | -import { Resolver, ResolverStatus } from './resolver'; |
4 | | -import { Schema } from './schema'; |
| 2 | +import { compose } from '@feathersjs/hooks'; |
| 3 | +import { Resolver, ResolverStatus } from '../resolver'; |
5 | 4 |
|
6 | 5 | const getContext = <H extends HookContext> (context: H) => { |
7 | 6 | return { |
@@ -55,18 +54,21 @@ export const resolveQuery = <T, H extends HookContext> (...resolvers: Resolver<T |
55 | 54 |
|
56 | 55 | export const resolveData = <T, H extends HookContext> (...resolvers: Resolver<T, H>[]) => |
57 | 56 | async (context: H, next?: NextFunction) => { |
58 | | - const ctx = getContext(context); |
59 | | - const data = context.data; |
60 | | - const status = { |
61 | | - originalContext: context |
62 | | - }; |
63 | | - |
64 | | - if (Array.isArray(data)) { |
65 | | - context.data = await Promise.all(data.map(current => |
66 | | - runResolvers(resolvers, current, ctx, status) |
67 | | - )); |
68 | | - } else { |
69 | | - context.data = await runResolvers(resolvers, data, ctx, status); |
| 57 | + if (context.method === 'create' || context.method === 'patch' || context.method === 'update') { |
| 58 | + const ctx = getContext(context); |
| 59 | + const data = context.data; |
| 60 | + |
| 61 | + const status = { |
| 62 | + originalContext: context |
| 63 | + }; |
| 64 | + |
| 65 | + if (Array.isArray(data)) { |
| 66 | + context.data = await Promise.all(data.map(current => |
| 67 | + runResolvers(resolvers, current, ctx, status) |
| 68 | + )); |
| 69 | + } else { |
| 70 | + context.data = await runResolvers(resolvers, data, ctx, status); |
| 71 | + } |
70 | 72 | } |
71 | 73 |
|
72 | 74 | if (typeof next === 'function') { |
@@ -144,43 +146,25 @@ export const resolveDispatch = <T, H extends HookContext> (...resolvers: Resolve |
144 | 146 | }); |
145 | 147 | }; |
146 | 148 |
|
147 | | -export const validateQuery = <H extends HookContext> (schema: Schema<any>) => |
148 | | - async (context: H, next?: NextFunction) => { |
149 | | - const data = context?.params?.query || {}; |
150 | | - |
151 | | - try { |
152 | | - const query = await schema.validate(data); |
153 | | - |
154 | | - context.params = { |
155 | | - ...context.params, |
156 | | - query |
157 | | - } |
158 | | - |
159 | | - if (typeof next === 'function') { |
160 | | - return next(); |
161 | | - } |
162 | | - } catch (error: any) { |
163 | | - throw (error.ajv ? new BadRequest(error.message, error.errors) : error); |
164 | | - } |
165 | | - }; |
| 149 | +export type ResolveAllSettings<H extends HookContext> = { |
| 150 | + data?: Resolver<any, H>|Resolver<any, H>[] |
| 151 | + query?: Resolver<any, H>|Resolver<any, H>[] |
| 152 | + result?: Resolver<any, H>|Resolver<any, H>[] |
| 153 | + dispatch?: Resolver<any, H>|Resolver<any, H>[] |
| 154 | +} |
166 | 155 |
|
167 | | -export const validateData = <H extends HookContext> (schema: Schema<any>) => |
168 | | - async (context: H, next?: NextFunction) => { |
169 | | - const data = context.data; |
| 156 | +const getResolvers = <H extends HookContext> ( |
| 157 | + map: ResolveAllSettings<H>, |
| 158 | + name: keyof ResolveAllSettings<H> |
| 159 | +) => { |
| 160 | + const value = map[name]; |
170 | 161 |
|
171 | | - try { |
172 | | - if (Array.isArray(data)) { |
173 | | - context.data = await Promise.all(data.map(current => |
174 | | - schema.validate(current) |
175 | | - )); |
176 | | - } else { |
177 | | - context.data = await schema.validate(data); |
178 | | - } |
179 | | - } catch (error: any) { |
180 | | - throw (error.ajv ? new BadRequest(error.message, error.errors) : error); |
181 | | - } |
| 162 | + return Array.isArray(value) ? value : (value !== undefined ? [ value ] : []); |
| 163 | +} |
182 | 164 |
|
183 | | - if (typeof next === 'function') { |
184 | | - return next(); |
185 | | - } |
186 | | - }; |
| 165 | +export const resolveAll = <H extends HookContext> (map: ResolveAllSettings<H>) => compose([ |
| 166 | + resolveDispatch(...getResolvers(map, 'dispatch')), |
| 167 | + resolveResult(...getResolvers(map, 'result')), |
| 168 | + resolveQuery(...getResolvers(map, 'query')), |
| 169 | + resolveData(...getResolvers(map, 'data')) |
| 170 | +]) |
0 commit comments