Compare commits

...

223 Commits

Author SHA1 Message Date
Kamil Myśliwiec
2f535c33ae chore(@nestjs) publish v5.3.5 release 2018-09-05 10:04:15 +02:00
Kamil Myśliwiec
20dd9fc8ca bugfix(common) remove useless parts of cache interceptor 2018-09-05 10:03:28 +02:00
Kamil Myśliwiec
6110526402 chore(@nestjs) publish v5.3.4 release 2018-09-05 09:38:05 +02:00
Kamil Myśliwiec
0a1f44ac4d bugfix(common) export CACHE_MANAGER, fix trackBy method 2018-09-05 09:37:33 +02:00
Kamil Myśliwiec
d048f23ff8 improvement(microservices) ensure that connection is shared across promises 2018-09-05 09:37:09 +02:00
Kamil Myśliwiec
f5f8255a37 bugfix(core) check bootstrap lifecycle hook 2018-09-05 09:36:23 +02:00
Kamil Myśliwiec
cc4d91fcb3 chore(@nestjs) publish v5.3.3 release 2018-09-04 11:48:10 +02:00
Kamil Myśliwiec
89c76a682e chore(nestjs) publish 5.3.2 release 2018-09-03 18:05:35 +02:00
Kamil Myśliwiec
63577b9986 chore(@nestjs) publish v5.3.2 release 2018-09-03 18:01:18 +02:00
Kamil Myśliwiec
713e97f6c3 chore(nestjs) publish 5.3.1 release 2018-09-03 17:10:59 +02:00
Kamil Myśliwiec
c392da09a6 Merge branch 'master' of https://github.com/nestjs/nest 2018-09-03 17:10:16 +02:00
Kamil Myśliwiec
02d4841d05 chore(@nestjs) publish v5.3.1 release 2018-09-03 17:09:48 +02:00
Kamil Myśliwiec
cbe9ed4980 Merge pull request #1036 from cschroeter/master
sample(nestjs) update GraphQL example
2018-09-03 12:52:59 +02:00
Kamil Myśliwiec
d654e5e84f deps(nestjs) replace generate-safe-id with uuid 2018-09-03 12:52:25 +02:00
Christian Schröter
9d2bd82173 Enable subscriptions in GraphQLModule 2018-09-03 12:25:53 +02:00
Christian Schröter
02affa5677 Update and clean up dependencies 2018-09-03 12:25:07 +02:00
Kamil Myśliwiec
71a023ebae Merge branch 'master' of https://github.com/nestjs/nest 2018-09-02 22:47:57 +02:00
Kamil Myśliwiec
aa75b52255 build(nestjs) fix package-lock.json 2018-09-02 22:47:47 +02:00
Kamil Myśliwiec
6cf7cdc2a6 Merge pull request #1008 from jbpionnier/refactor/unnecessary_instanceof_promise
refactor(nestjs) unnecessary instanceOf Promise deletion
2018-09-02 22:43:37 +02:00
Kamil Myśliwiec
5b804f5a35 tests(microservices) fix broken options unit tests 2018-09-02 22:42:05 +02:00
Kamil Myśliwiec
b348920d25 build(nestjs) update bundle, add opencollective 2018-09-02 22:31:39 +02:00
Kamil Myśliwiec
b6fe9b06cc refactor(microservices) remove unecessary options object 2018-09-02 22:31:11 +02:00
Kamil Myśliwiec
fde2041f17 sample(nestjs) update framework to 5.3.0 in all samples 2018-08-31 16:30:03 +02:00
Kamil Myśliwiec
7a4b0e64ad Merge branch '5.3.0' 2018-08-31 13:18:21 +02:00
Kamil Myśliwiec
afe9c4b5f4 sample(@nestjs) update auth and graphql sample 2018-08-31 13:18:02 +02:00
Kamil Myśliwiec
5e6694cb8b Merge pull request #1024 from nestjs/5.3.0
chore(nestjs) publish minor release 5.3.0
2018-08-31 13:09:39 +02:00
Kamil Myśliwiec
d20f6bb653 chore(nestjs) publish 5.3.0 minor release 2018-08-31 12:47:11 +02:00
Kamil Myśliwiec
e8032f37fc chore(@nestjs) publish v5.3.0 release 2018-08-31 12:46:22 +02:00
Kamil Myśliwiec
cae159e77c sample(@nestjs) update gateways and graphql sample 2018-08-31 12:24:50 +02:00
Kamil Myśliwiec
47812f5822 refactor(@nestsjs) replace underlying http server (express) 2018-08-31 12:24:29 +02:00
Kamil Myśliwiec
afa9903882 refactor(@nestjs/common) rename class serializer 2018-08-31 12:23:51 +02:00
Kamil Myśliwiec
a7d465bfa1 enhancement(@nestjs/core) injector improvements (circular dependencies) 2018-08-31 12:23:22 +02:00
Kamil Myśliwiec
95dfd59e4e sample(@nestjs) add class serializer sample 2018-08-27 16:58:39 +02:00
Kamil Myśliwiec
08e6278a77 sample(common) add cache module sample 2018-08-27 16:58:24 +02:00
Kamil Myśliwiec
fbf47a2825 feature(common) add class serializer interceptor 2018-08-27 16:57:46 +02:00
Kamil Myśliwiec
643e84c49a feature(common) cache module 2018-08-27 16:57:12 +02:00
Kamil Myśliwiec
25c7e8909e enhancement(common) add default options to MulterModule 2018-08-27 16:56:41 +02:00
Kamil Myśliwiec
0d5972c66b build(@nestjs) force compilation (new bundle) 2018-08-27 16:55:46 +02:00
Kamil Myśliwiec
394d7f23bf refactor(common) move multer module spec files 2018-08-27 12:25:29 +02:00
Kamil Myśliwiec
09d9c6597f refactor(common) move file interceptors to files module 2018-08-27 08:59:40 +02:00
Kamil Myśliwiec
1d8c8ee264 refactor(@nestjs) update dependencies 2018-08-27 08:59:15 +02:00
Kamil Myśliwiec
5a9d6d6d14 sample(nestjs) update auth sample 2018-08-27 00:01:57 +02:00
Kamil Myśliwiec
4d13ee8100 feature(common) add MulterModule 2018-08-27 00:00:51 +02:00
Kamil Myśliwiec
6b0ae0602c feature(websockets) support ack in socketio, enhancements 2018-08-26 23:59:30 +02:00
Kamil Myśliwiec
d0bd2f7b20 Update CONTRIBUTING.md 2018-08-26 23:59:10 +02:00
Jean-Baptiste Pionnier
5f965cf174 refactor: unnecessary instanceOf Promise deletion 2018-08-26 21:05:14 +02:00
Kamil Myśliwiec
504a10ce5e Merge branch 'master' of https://github.com/nestjs/nest 2018-08-25 15:48:03 +02:00
Kamil Myśliwiec
a9abd1c2ea sample(@nestjs) update graphql example, add integration test 2018-08-25 15:47:46 +02:00
Kamil Myśliwiec
e7e859adce Merge pull request #989 from BrunnerLivio/feature/add-im-a-teapot-exception
feature(@nestjs/common) add im a teapot exception
2018-08-25 14:44:08 +02:00
Kamil Myśliwiec
0c98a65e79 chore(@nestjs) publish 5.2.2 release 2018-08-24 12:43:03 +02:00
Kamil Myśliwiec
cd30d7a4a5 chore(@nestjs) publish v5.2.2 release 2018-08-24 12:42:29 +02:00
Kamil Myśliwiec
a6d837e64a bugfix(@nestjs/common) fix custom decorators (data isnt always string) 2018-08-24 12:13:48 +02:00
Kamil Myśliwiec
0904b0ba56 Merge branch 'master' of https://github.com/nestjs/nest 2018-08-24 10:38:12 +02:00
Kamil Myśliwiec
150c81e397 feature(@nestjs/core) add prefix property to ServeStaticOptions 2018-08-24 10:35:04 +02:00
Kamil Myśliwiec
1717f35717 Merge pull request #997 from alerosa/fix-auth-sample-missing-dependency
example(@nestjs) add @nestjs/jwt to auth sample dependencies
2018-08-23 08:53:01 +02:00
alerosa
61b6b346da add @nestjs/jwt to auth sample dependencies 2018-08-23 00:55:19 +01:00
Kamil Myśliwiec
b02fb57d8f chore(@nestjs) publish 2.3.1 patch release 2018-08-22 22:00:42 +02:00
Kamil Myśliwiec
cb302e6719 chore(@nestjs) publish v5.2.1 release 2018-08-22 21:59:35 +02:00
Kamil Myśliwiec
1f9030c504 Merge branch 'master' of https://github.com/nestjs/nest 2018-08-22 21:58:18 +02:00
Kamil Myśliwiec
af5a4af675 chore(@nestjs) publish v5.2.1 release 2018-08-22 21:57:52 +02:00
Kamil Myśliwiec
664321465c Update Readme.md 2018-08-22 21:16:43 +02:00
Kamil Myśliwiec
f6d4b5e82a test(@nestjs/common) exclude load package 2018-08-22 20:21:55 +02:00
Kamil Myśliwiec
09c9f704e5 Merge pull request #909 from nestjs/5.2.0
chore(@nestjs) publish 5.2.0 minor release
2018-08-22 15:47:53 +02:00
Kamil Myśliwiec
8a8b780273 chore(@nestjs) publish 5.2.0 minor release 2018-08-22 15:44:30 +02:00
Kamil Myśliwiec
1f0de4923e chore(@nestjs) publish v5.2.0 release 2018-08-22 15:37:56 +02:00
Kamil Myśliwiec
d5833e3e4b feature(@nestjs/core) extract helpers to context utils class 2018-08-22 14:37:07 +02:00
Kamil Myśliwiec
deffcdcd84 example(@nestjs) update examples - auth, graphql 2018-08-22 14:36:43 +02:00
Livio Brunner
ba2eeeeac7 feature(@nestjs/common) add im a teapot exception
"It’s a reminder that the underlying
processes of computers
are still made by humans.
It'd be a real shame to see 418 go."
2018-08-21 13:43:50 +02:00
Kamil Myśliwiec
36b94b37d0 feature: add enhancers to custom decorator factory, fixes 2018-08-17 14:55:27 +02:00
Kamil Myśliwiec
85b93260e2 refactor(@nestjs) resolve merge conflicts 2018-08-16 16:30:33 +02:00
Kamil Myśliwiec
94f74a485b packages(@nestjs/core) add path-to-regexp to dependencies 2018-08-16 16:29:53 +02:00
Kamil Myśliwiec
b4253525fe Merge pull request #977 from nestjs/feature/938-hierarchical-lifecycle
feature(@nestjs/core) add hierarchical lifecycle hooks #938
2018-08-16 16:23:25 +02:00
Kamil Myśliwiec
c38c91217c feature(@nestjs/core) add hierarchical lifecycle hooks #938 2018-08-16 16:11:18 +02:00
Kamil Myśliwiec
f024af4912 Merge pull request #975 from nestjs/bugfix/fastify-wildcard
bugfix(@nestjs/core) middleware wildcard is not working with fastify
2018-08-16 15:11:43 +02:00
Kamil Myśliwiec
6976ffe079 bugfix(@nestjs/core) middleware wildcard is not working with fastify 2018-08-16 15:08:50 +02:00
Kamil Myśliwiec
2812c3863d Merge pull request #895 from jbpionnier/feature/grpc-loader
feature(@nestjs/microservices) load proto with proto-loader
2018-08-16 14:13:52 +02:00
Kamil Myśliwiec
9ad7927c4c Merge pull request #974 from nestjs/bugfix/948-nats-wildcards
bugfix(@nestjs/microservices) fix nats wildcards
2018-08-16 14:13:32 +02:00
Kamil Myśliwiec
afae462b6e Merge pull request #955 from jbpionnier/refactor/use_some_method
refactor(@nestjs) use some() method (arrays)
2018-08-16 14:08:36 +02:00
Kamil Myśliwiec
62e733c018 test(@nestjs/microservices) fix failing unit tests 2018-08-16 14:07:37 +02:00
Kamil Myśliwiec
d446a56381 bugfix(@nestjs/microservices) fix nats wildcards 2018-08-16 13:50:56 +02:00
Jean-Baptiste Pionnier
2bdf47a572 refactor: use some method 2018-08-09 08:27:39 +02:00
Jean-Baptiste Pionnier
caf99c6cf8 bugfix(@nestjs/microservice) fix invalid proto 2018-08-09 07:45:33 +02:00
Jean-Baptiste Pionnier
5415659fb9 feature(@nestjs/microservices) use grpc/proto-loader 2018-08-08 16:58:09 +02:00
Kamil Myśliwiec
e967ba15cf Merge pull request #936 from nestjs/bugfix/935-file-interceptor
bugfix(@nestjs/common) fix multiple file interceptors issue
2018-08-02 09:33:10 +02:00
Kamil Myśliwiec
0b191fbd17 bugfix(@nestjs/common) fix multiple file interceptors issue 2018-08-02 09:32:12 +02:00
Kamil Myśliwiec
2ea58acc70 sample(@nestjs) fix paths join usage 2018-08-01 22:38:47 +02:00
Kamil Myśliwiec
1f59a81c28 Merge branch 'master' into 5.2.0 2018-08-01 22:38:23 +02:00
Kamil Myśliwiec
fbcb18c978 Merge pull request #934 from nestjs/feature/926-use-logger
feature(@nestjs/core) add useLogger() to Nest context #926
2018-08-01 22:34:48 +02:00
Kamil Myśliwiec
dd7bb313f4 Merge pull request #933 from nestjs/feature/847-optional-decorator
feature(@nestjs/core) add @Optional() decorator #847
2018-08-01 22:34:16 +02:00
Kamil Myśliwiec
946ed2e339 feature(@nestjs/core) add useLogger() to Nest context #926 2018-08-01 22:33:02 +02:00
Kamil Myśliwiec
96da5bd9c5 feature(@nestjs/core) add @Optional() decorator #847 2018-08-01 22:31:39 +02:00
Kamil Myśliwiec
9f77d5f550 bugfix(@nestjs/common) revert @Catch() validation 2018-08-01 21:09:12 +02:00
Kamil Myśliwiec
9e6cf1f1aa Merge pull request #911 from Patrick-Remy/patch-1
sample(@nestjs) fix path.join arguments seperation
2018-08-01 20:34:32 +02:00
Kamil Myśliwiec
d92fa0dee1 Merge branch 'master' into 5.2.0 2018-08-01 20:10:53 +02:00
Kamil Myśliwiec
63109f5717 bugfix(@nestjs/common) fix pipes typing issue 2018-08-01 20:09:19 +02:00
Kamil Myśliwiec
dc33ea57ef Merge pull request #903 from nestjs/feature/module-ref
feature(@nestjs/core) expose container to ModuleRef, add close()
2018-08-01 20:08:49 +02:00
Kamil Myśliwiec
780bd9c0f9 Merge pull request #904 from nestjs/feature/846-axios
feature(@nestjs/common) add configurable dynamic module (HttpModule)
2018-08-01 20:08:06 +02:00
Kamil Myśliwiec
a79041d211 Merge pull request #908 from nestjs/feature/860-default-filter
feature(@nestjs) expose default exception filters #860
2018-08-01 19:55:16 +02:00
Kamil Myśliwiec
eda8e293c3 chore(@nestjs) add package-lock.json 2018-08-01 19:52:25 +02:00
Kamil Myśliwiec
fd797b1a69 chore(@nestjs) fix gulpfile 2018-08-01 19:47:33 +02:00
Kamil Myśliwiec
fd098fc3f7 chore(@nestjs) fix gulp scripts 2018-08-01 19:40:18 +02:00
Kamil Myśliwiec
1be2ccdb0b Update Readme.md 2018-07-31 13:43:07 +02:00
Kamil Myśliwiec
cb46174bae Merge pull request #906 from nestjs/bugfix/892-custom-decorators
bugfix(@nestjs/common) data parameter is not required (custom decorators)
2018-07-26 15:04:14 +02:00
Kamil Myśliwiec
ac1578793f Merge pull request #902 from nestjs/feature/720-decorators-validation
enhancement(@nestjs/common) add validation to @catch() decorator
2018-07-26 14:55:11 +02:00
Kamil Myśliwiec
525922ee69 Merge pull request #907 from nestjs/bugfix/879-injectable-inheritance
bugfix(@nestjs/core) inherited metadata is not applied #879
2018-07-26 14:54:32 +02:00
Patrick-Remy
5327979745 Fix path.join arguments seperation 2018-07-26 10:40:50 +02:00
Kamil Myśliwiec
3a0e404832 Merge pull request #901 from nestjs/bugfix/854-mixing-testing
bugfix(@nestjs/common) fix mixin testing issue #854
2018-07-25 20:08:24 +02:00
Kamil Myśliwiec
55b1f1e08e Merge pull request #900 from nestjs/bugfix/671-dynamic-modules
bugfix(@nestjs/core) enable dynamic modules recursive imports #671
2018-07-25 20:03:40 +02:00
Kamil Myśliwiec
a05383c635 Merge pull request #644 from DanielRuf/chore/add-nodejs-10
chore(@nestjs): add Node.js 10 (travis)
2018-07-25 19:57:09 +02:00
Kamil Myśliwiec
86abc0001c Merge branch '5.2.0' into chore/add-nodejs-10 2018-07-25 19:56:49 +02:00
Kamil Myśliwiec
c4ff2e736a Merge pull request #642 from DanielRuf/chore/cache-node-modules
chore(@nestjs): cache node_modules
2018-07-25 19:54:42 +02:00
Kamil Myśliwiec
d00d5f2996 Merge branch '5.2.0' into chore/cache-node-modules 2018-07-25 19:54:28 +02:00
Kamil Myśliwiec
5f0f6e5b61 Merge pull request #878 from wbhob/npm6-scripts
chore(): rename prepublish commands to prepare
2018-07-25 19:53:40 +02:00
Kamil Myśliwiec
f39573007c Merge pull request #877 from wbhob/master
refactor(): reduce complexity of NestFactory.create signature
2018-07-25 19:49:50 +02:00
Kamil Myśliwiec
f7a367e895 Merge pull request #814 from BrunnerLivio/master
feature(@nestjs/core) display known dependency names in unknown dependency exception
2018-07-25 19:43:21 +02:00
Kamil Myśliwiec
dcba92190f feature(@nestjs) add barrel files 2018-07-25 18:49:24 +02:00
Kamil Myśliwiec
614d57f130 feature(@nestjs) expose default exception filters 2018-07-25 18:47:40 +02:00
Kamil Myśliwiec
9e170c4ae4 bugfix(@nestjs/core) inherited metadata is not applied #879 2018-07-25 13:57:45 +02:00
Kamil Myśliwiec
85070a5c9c refactor: cleanup 2018-07-25 13:17:29 +02:00
Kamil Myśliwiec
f86fc35fa7 refactor: cleanup 2018-07-25 13:16:58 +02:00
Kamil Myśliwiec
53184b8df0 bugfix(@nestjs/common) data parameter is not required (custom decorators) #892 2018-07-25 13:16:05 +02:00
Kamil Myśliwiec
f385d5c47d feature(@nestjs/common) add configurable dynamic module (HttpModule) 2018-07-24 22:32:10 +02:00
Kamil Myśliwiec
1527e12013 feature(@nestjs/core) expose container to ModuleRef, add close() to NestContext 2018-07-24 22:07:14 +02:00
Kamil Myśliwiec
58800f69b1 enhancement(@nestjs/common) add validation to @Catch() decorator 2018-07-24 20:18:10 +02:00
Kamil Myśliwiec
049da42d4a enhancement(@nestjs/common) add validation to @Catch() decorator 2018-07-24 20:17:54 +02:00
Kamil Myśliwiec
21f2e8a9f7 bugfix(@nestjs/common) fix mixin testing issue #854 2018-07-24 19:55:09 +02:00
Kamil Myśliwiec
432b777f2c bugfix(@nestjs/core) enable dynamic modules recursive imports #671 2018-07-24 16:47:53 +02:00
Kamil Myśliwiec
e39c9d920d bugfix(@nestjs/core) add circular dependency (related modules) check 2018-07-24 16:23:53 +02:00
Kamil Myśliwiec
b84c2b0884 bugfix(@nestjs/core) add circular dependency (related modules) check 2018-07-24 16:10:10 +02:00
Livio Brunner
e4d0118e9d refactor(@nestjs/core) change any[] types to a custom interface 2018-07-16 10:45:33 +02:00
Wilson Hobbs
0bf98c46cb chore(): rename prepublish commands to prepare, to comply with https://docs.npmjs.com/misc/scripts#deprecation-note 2018-07-15 12:43:12 -04:00
Wilson Hobbs
442b08fdb9 refactor(): reduce complexity of NestFactory.create signature 2018-07-15 12:30:55 -04:00
Livio Brunner
9c2a9d76d2 refactor(@nestjs/core) rename args parameter to dependencies 2018-07-15 13:25:17 +02:00
Livio Brunner
a354741c31 fix(@nestjs/core) show token name in unk. dep. exception message 2018-07-09 17:49:32 +02:00
Kamil Myśliwiec
8d62307987 sample(@nestjs) update packages 2018-07-05 17:37:44 +02:00
Kamil Myśliwiec
e2de979081 build(@nestjs) fix README copy&move 2018-07-05 14:38:30 +02:00
Kamil Myśliwiec
0f62bcd41f chore(@nestjs) publish 5.1.0 release 2018-07-05 14:31:21 +02:00
Kamil Myśliwiec
d4c9644368 chore(@nestjs) publish v5.1.0 release 2018-07-05 14:28:27 +02:00
Kamil Myśliwiec
0c4fe26c21 sample(@nestjs) move public and views dirs outside of the src 2018-07-05 09:10:10 +02:00
Kamil Myśliwiec
3cf8607b20 enhancement(@nestjs/microservices) disable internal gRPC errors swallow 2018-07-04 23:17:02 +02:00
Kamil Myśliwiec
3d2d838bd1 bugfix(@nestjs/core) multi global providers issue #812 2018-07-04 19:36:29 +02:00
Kamil Myśliwiec
a9204cb399 bugfix(@nestjs/testing) await scan() operation 2018-07-04 18:30:08 +02:00
Kamil Myśliwiec
bd3b102c2f Merge branch 'master' of https://github.com/nestjs/nest 2018-07-04 17:46:44 +02:00
Kamil Myśliwiec
9cf27a35dd feature(@nestjs/core) add axiosRef to the HttpService #842 2018-07-04 17:46:14 +02:00
Kamil Myśliwiec
c1c5b15859 Merge pull request #839 from Y0hy0h/patch-1
refactor(@nestjs/core) rephrase error messages
2018-07-04 16:33:58 +02:00
Y0hy0h
3e55de545f refactor(core) rephrase error messages
Fixes typo, clarifies what actions are expected.
2018-07-03 17:11:33 +02:00
Kamil Myśliwiec
ced6729157 Update Readme.md 2018-06-29 20:44:34 +02:00
Kamil Myśliwiec
a57eb17640 Update Readme.md 2018-06-29 20:44:13 +02:00
Kamil Myśliwiec
6c2863d709 Merge pull request #823 from ZQun/patch-2
Update Chinese guide format
2018-06-29 18:39:26 +02:00
Kamil Myśliwiec
fc05b244a8 Merge pull request #822 from ZQun/patch-1
Update Chinese guide format
2018-06-29 18:38:58 +02:00
ZQun
c80fd77416 Update Chinese guide format
Update Chinese guide format
2018-06-28 11:10:02 +08:00
ZQun
e2d15db3f4 Update Chinese guide format
Update Chinese guide format
2018-06-28 11:02:39 +08:00
Livio Brunner
8057a5cf19 feature(@nestjs/core) display dependency names in unknown dependency ex
This feature displays the found dependency names when any unknown
dependency is getting injected. Before this feature the error message
gets displayed like (?, +). After this implementation, like this e.g.
(?, CatsService).
2018-06-26 10:49:16 +02:00
Kamil Myśliwiec
a6ab849df2 Merge pull request #808 from autaut03/autaut03-fix/forbiddenNotHttpException
bugfix(@nestjs/core): use ForbiddenException instead of HttpException
2018-06-25 13:41:09 +02:00
Alex_Wells
7143d3b8ac bugfix(@nestjs/core): use ForbiddenException instead of HttpException
Two modified files are the only places in the whole framework where HttpException specifically is used
and used to be used wrong. It's easier to handle and catch ForbiddenException (and other HttpException
child) rather than having to compare HttpStatus to catch it. As ForbiddenException extends HttpException
and provides same HttpStatus, old code catching HttpException still works.
2018-06-24 20:50:30 +03:00
Kamil Myśliwiec
be6d90ace2 feature(@nestjs/core) enable deffered dynamic modules 2018-06-24 13:26:55 +02:00
Kamil Myśliwiec
7023905b53 feature(@nestjs/core) FastifyAdapter matches URL and request method 2018-06-22 10:41:52 +02:00
Kamil Myśliwiec
f4817ee4eb feature(@nestjs/common) add error messages disabled mode (ValidationPipe) 2018-06-21 23:00:33 +02:00
Kamil Myśliwiec
a87eee0849 example(@nestjs) fix HttpExceptionFilter example (missing status) 2018-06-21 22:43:50 +02:00
Kamil Myśliwiec
a8803fd166 Merge branch 'master' of https://github.com/nestjs/nest 2018-06-21 22:19:43 +02:00
Kamil Myśliwiec
18f68d96b7 Merge branch 'thg303-feature/add-FileFieldsInterceptor' 2018-06-21 22:19:18 +02:00
Kamil Myśliwiec
ecd61e3777 feature(@nestjs/common) add field name to the @UploadedFile() decorator 2018-06-21 22:18:55 +02:00
Kamil Myśliwiec
10eeac9ae7 Merge branch 'feature/add-FileFieldsInterceptor' of https://github.com/thg303/nest into thg303-feature/add-FileFieldsInterceptor 2018-06-21 22:02:46 +02:00
Kamil Myśliwiec
59e6a3d262 Merge pull request #802 from nestjs/790-feature-middleware
feature(@nestjs/core) superior MiddlewareConsumer, add exclude
2018-06-21 21:59:08 +02:00
Kamil Myśliwiec
292fe2136c Merge branch 'micmro-feature/grpc-cancellation' 2018-06-21 21:53:43 +02:00
Kamil Myśliwiec
f80cd9edd1 refactor(@nestjs/microservices) extract magic strings into constants 2018-06-21 21:51:48 +02:00
Kamil Myśliwiec
adbfae2b71 Merge branch 'feature/grpc-cancellation' of https://github.com/micmro/nest into micmro-feature/grpc-cancellation 2018-06-21 21:23:40 +02:00
Kamil Myśliwiec
4cfda07b2a tests(@nestjs/core) fix failing unit tests 2018-06-21 21:22:14 +02:00
Kamil Myśliwiec
3ac7802315 Merge branch 'master' of https://github.com/nestjs/nest 2018-06-21 20:51:04 +02:00
Kamil Myśliwiec
1813e5a09c build(@nestjs) add copy README gulp script 2018-06-21 20:50:50 +02:00
Kamil Myśliwiec
c9184acee1 feature(@nestjs/core) superior MiddlewareConsumer, add exclude 2018-06-21 15:48:31 +02:00
Kamil Myśliwiec
1c98d6b18c Merge pull request #795 from nestjs/734-bugfix-validation
bugfix(@nestjs/common) ValidationPipe throws 500 error
2018-06-20 17:51:18 +02:00
Kamil
7172671dcc Merge branch 'master' of https://github.com/nestjs/nest 2018-06-20 17:49:14 +02:00
Kamil
294e269ede Merge branch 'RivaCode-message_pattern_string-key' 2018-06-20 17:48:54 +02:00
Kamil
00c98501ff enhancement(@nestjs/microservices) use isString helper instead 2018-06-20 17:47:17 +02:00
Kamil Myśliwiec
51d5be4e9d Merge pull request #794 from nestjs/772-bugfix-testing
bugfix(@nestjs/core) issue #772 testing - too restrictive typings
2018-06-20 17:37:59 +02:00
Kamil
f86c0e33c4 Merge branch 'message_pattern_string-key' of https://github.com/RivaCode/nest into RivaCode-message_pattern_string-key 2018-06-20 17:36:58 +02:00
Kamil
3888d8ee8b bugfix(@nestjs/common) ValidationPipe throws 500 error 2018-06-20 17:34:00 +02:00
Kamil
8029796193 bugfix(@nestjs/core) testing utilities typings are too restrictive 2018-06-20 17:33:13 +02:00
Kamil
f3c28f57ac refactor(@nestjs/common) reorganize imports in create route param 2018-06-20 17:21:56 +02:00
Kamil
03db0d357a improvement(@nestjs/common) add missing typings to custom param factory 2018-06-20 17:15:55 +02:00
Kamil
7ad6095e16 Merge branch 'master' of https://github.com/nestjs/nest 2018-06-20 17:13:10 +02:00
Kamil Myśliwiec
617bc70944 Merge pull request #788 from Defenderbass/bugfix/types_in_createParamDecorator
bugfix(@nestjs/common) changes the types of arguments in createParamD…
2018-06-20 17:12:49 +02:00
Kamil
f2d2d56111 bundle(@nestjs/core) remove needless middlewares directory 2018-06-20 17:11:08 +02:00
Kamil Myśliwiec
84d31f9449 Update Readme.md 2018-06-19 09:54:59 +02:00
Igor Katsuba
da3745f386 bugfix(@nestjs/common) changes the types of arguments in createParamDecorator 2018-06-18 10:39:27 +03:00
Stas Rivkin
7e47100d3e bugfix(@nestjs/microservices): messagePattern string key
stringify on a string key added an extra parentheses to the pattern
2018-06-17 14:32:15 +03:00
Michael
0c8e8fb4f7 chore(@nestjs/microservices) add tests to grpc clients disconnection 2018-06-10 23:38:21 +02:00
Michael Mrowetz
f337206785 chore(microservice) tests for grpc cancelling - server side 2018-06-09 17:25:58 +02:00
Michael Mrowetz
3984bc92f2 fix(tests) fix the grpc tests 2018-06-08 17:51:31 +02:00
Michael
89fe60a213 chore(@nestjs/microservices) improve ClientGrpcProxy.getService typing 2018-06-08 15:24:24 +02:00
Michael
3ebec419fe feature(@nestjs/microservices) allow grpc clients to disconnect
- when client cancels the server stream gets completed too
- client introduced disconnection does not throw errors on the client side
- release client's event listener on 'end'
2018-06-08 15:21:37 +02:00
Kamil Myśliwiec
fed2459677 Merge pull request #750 from ltciro/fix_typo_01catsapp_guard
sample(@nestjs) fix hasRole is not a function (01-cats-app)
2018-06-04 22:34:18 +02:00
Kamil Myśliwiec
33c7049d71 Merge pull request #760 from yingye/master
Update readme_zh.md
2018-06-04 21:43:14 +02:00
yingye
e44f51d647 update readme_zh.md 2018-06-04 18:52:04 +08:00
Laura Ciro
31aa2f09c5 sample(@nestjs) fix hasRole is not a function (01-cats-app) 2018-05-30 23:37:36 -05:00
Ali Ghanavatian
3fffc01890 feature(@nestjs/common) add file-fields interceptor
usage will be like:
```import {FileFieldsInterceptor} from '@nest/common';

@UseInterceptors(FileFieldsInterceptor([{name: 'avatar', maxCount: 1},
{name: 'passport', maxCount: 1}]))
```
2018-05-30 19:32:05 +04:30
Kamil Myśliwiec
e1abf80569 Update Readme.md 2018-05-28 09:44:41 +02:00
Kamil Myśliwiec
a7fde9b6cc Update Readme.md 2018-05-26 20:44:02 +02:00
Kamil Myśliwiec
92d3ed48db integration(@nestjs) add mongoose integration test 2018-05-26 14:51:10 +02:00
Kamil Myśliwiec
c5455de9d1 chore(@nestjs) publish v5.0.1 release 2018-05-25 13:26:37 +02:00
Kamil Myśliwiec
7b5b054818 integration(@nestjs) add typeorm integration test 2018-05-25 12:48:38 +02:00
Kamil Myśliwiec
17a609cd9c feature(@nestjs/microservices) grpc improvements (add root), cleanup 2018-05-25 12:44:18 +02:00
Kamil Myśliwiec
ae128f6e91 feature(@nestjs/testing) add error logs in the testing mode (#709, #713) 2018-05-20 15:06:03 +02:00
Kamil Myśliwiec
cb24ca9ee5 bugfix(@nestjs/websockets) handle invalid payloads (#683) 2018-05-20 15:04:04 +02:00
Kamil Myśliwiec
e37b9f7d81 bugfix(@nestjs/core) support circular deps in dynamic modules (#678) 2018-05-20 15:02:32 +02:00
Kamil Myśliwiec
55600edb2d docs(@nestjs) add PULL_REQUEST_TEMPLATE 2018-05-19 10:32:27 +02:00
Kamil Myśliwiec
033068b5d7 Update CONTRIBUTING.md 2018-05-19 10:30:09 +02:00
Kamil Myśliwiec
9ea7db9160 Merge branch 'master' of https://github.com/nestjs/nest 2018-05-19 10:25:54 +02:00
Kamil Myśliwiec
1801bf86b6 Update readme_zh.md 2018-05-19 10:25:32 +02:00
Kamil Myśliwiec
ba5c59bc34 Merge pull request #700 from zuohuadong/patch-1
chore(readme) upgrade chinese
2018-05-19 10:23:51 +02:00
Kamil Myśliwiec
bf30a304d8 Merge pull request #702 from alQlagin/patch-1
bugfix(@nestjs/common) incorrect aixos methods in HttpService
2018-05-19 10:23:25 +02:00
Alex Kulagin
310d530308 Fix: incorrect aixos methods in HttpService
HttpService.put and HttpService.patch use axios.post 
Changed to axios.put and axios.patch
2018-05-17 14:36:38 +05:00
huadong zuo
75775d6ea1 chore(readme) upgrade chinese
update 5.0
2018-05-17 13:16:06 +08:00
Kamil Myśliwiec
f9e02b60fa feature(@nestjs/core) add getInstance() to HTTP adapters 2018-05-16 15:17:30 +02:00
Kamil Myśliwiec
c5a3385156 ci(@nestjs) add package-lock.json 2018-05-13 14:01:23 +02:00
Kamil Myśliwiec
403a137847 ci: remove package-lock.json 2018-05-13 13:42:55 +02:00
Kamil Myśliwiec
c7bd1afc39 sample(@nestjs) update samples package.json 2018-05-13 13:30:10 +02:00
Kamil Myśliwiec
fcf24d32c9 chore(@nestjs) update README in bundle directory 2018-05-13 11:05:26 +02:00
Daniel Ruf
aba394f742 chore: migrate to gulp 4 2018-05-06 17:58:31 +02:00
Daniel Ruf
6a49b833ca chore: trigger new build 2018-05-06 16:51:48 +02:00
Daniel Ruf
7e022be24a chore: cache node_modules 2018-05-06 16:23:14 +02:00
Daniel Ruf
fb860c70e3 chore: add Node.js 10 2018-05-06 16:17:49 +02:00
684 changed files with 85849 additions and 7246 deletions

41
.github/PULL_REQUEST_TEMPLATE.md vendored Normal file
View File

@@ -0,0 +1,41 @@
## PR Checklist
Please check if your PR fulfills the following requirements:
- [ ] The commit message follows our guidelines: https://github.com/nestjs/nest/blob/master/CONTRIBUTING.md
- [ ] Tests for the changes have been added (for bug fixes / features)
- [ ] Docs have been added / updated (for bug fixes / features)
## PR Type
What kind of change does this PR introduce?
<!-- Please check the one that applies to this PR using "x". -->
```
[ ] Bugfix
[ ] Feature
[ ] Code style update (formatting, local variables)
[ ] Refactoring (no functional changes, no api changes)
[ ] Build related changes
[ ] CI related changes
[ ] Other... Please describe:
```
## What is the current behavior?
<!-- Please describe the current behavior that you are modifying, or link to a relevant issue. -->
Issue Number: N/A
## What is the new behavior?
## Does this PR introduce a breaking change?
```
[ ] Yes
[ ] No
```
<!-- If this PR contains a breaking change, please describe the impact and migration path for existing applications below. -->
## Other information

1
.gitignore vendored
View File

@@ -1,6 +1,5 @@
# dependencies
node_modules/
package-lock.json
# IDE
/.idea

View File

@@ -2,6 +2,10 @@ language: node_js
node_js:
- "8"
- "9"
- "10"
cache:
directories:
- "node_modules"
git:
depth: 5
addons:

View File

@@ -183,10 +183,10 @@ Footer should contain a [closing reference to an issue](https://help.github.com/
Samples: (even more [samples](https://github.com/nestjs/nest/commits/master))
```
docs(changelog): update change log to beta.5
docs(changelog) update change log to beta.5
```
```
fix(release): need to depend on latest rxjs and zone.js
bugfix(core) need to depend on latest rxjs and zone.js
The version in our package.json gets copied to the one we publish, and users need the latest of these.
```
@@ -200,8 +200,8 @@ Must be one of the following:
* **build**: Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm)
* **ci**: Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs)
* **docs**: Documentation only changes
* **feat**: A new feature
* **fix**: A bug fix
* **feature**: A new feature
* **bugfix**: A bug fix
* **perf**: A code change that improves performance
* **refactor**: A code change that neither fixes a bug nor adds a feature
* **style**: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
@@ -214,7 +214,7 @@ The following is the list of supported scopes:
* **common**
* **core**
* **examples**
* **sample**
* **microservices**
* **testing**
* **websockets**
@@ -223,7 +223,7 @@ There are currently a few exceptions to the "use package name" rule:
* **packaging**: used for changes that change the npm package layout in all of our packages, e.g. public path changes, package.json changes done to all packages, d.ts file/format changes, changes to bundles, etc.
* **changelog**: used for updating the release notes in CHANGELOG.md
* **examples/#**: for the example apps directory, replacing # with the example app number
* **sample/#**: for the example apps directory, replacing # with the example app number
<!-- * **aio**: used for docs-app (angular.io) related changes within the /aio directory of the repo -->
* none/empty string: useful for `style`, `test` and `refactor` changes that are done across all packages (e.g. `style: add missing semicolons`)

View File

@@ -14,7 +14,7 @@
<a href="https://www.npmjs.com/~nestjscore"><img src="https://img.shields.io/npm/dm/@nestjs/core.svg" alt="NPM Downloads" /></a>
<a href="https://travis-ci.org/nestjs/nest"><img src="https://api.travis-ci.org/nestjs/nest.svg?branch=master" alt="Travis" /></a>
<a href="https://travis-ci.org/nestjs/nest"><img src="https://img.shields.io/travis/nestjs/nest/master.svg?label=linux" alt="Linux" /></a>
<a href="https://coveralls.io/github/nestjs/nest?branch=master"><img src="https://coveralls.io/repos/github/nestjs/nest/badge.svg?branch=master#6" alt="Coverage" /></a>
<a href="https://coveralls.io/github/nestjs/nest?branch=master"><img src="https://coveralls.io/repos/github/nestjs/nest/badge.svg?branch=master#7" alt="Coverage" /></a>
<a href="https://gitter.im/nestjs/nestjs?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=body_badge"><img src="https://badges.gitter.im/nestjs/nestjs.svg" alt="Gitter" /></a>
<a href="https://opencollective.com/nest#backer"><img src="https://opencollective.com/nest/backers/badge.svg" alt="Backers on Open Collective" /></a>
<a href="https://opencollective.com/nest#sponsor"><img src="https://opencollective.com/nest/sponsors/badge.svg" alt="Sponsors on Open Collective" /></a>
@@ -37,7 +37,8 @@
## Getting started
To check out the [guide](https://docs.nestjs.com), visit [docs.nestjs.com](https://docs.nestjs.com). :books:
* To check out the [guide](https://docs.nestjs.com), visit [docs.nestjs.com](https://docs.nestjs.com). :books:
* 要查看中文 [指南](readme_zh.md), 请访问 [docs.nestjs.cn](https://docs.nestjs.cn). :books:
## Support
@@ -45,11 +46,19 @@ Nest is an MIT-licensed open source project. It can grow thanks to the sponsors
#### Principal Sponsor
<a href="https://valor-software.com/"><img src="https://docs.nestjs.com/assets/sponsors/valor-software.png" width="300" /></a>
<a href="https://valor-software.com/"><img src="https://docs.nestjs.com/assets/sponsors/valor-software.png" width="320" /></a>
#### Gold Sponsors
<a href="http://xtremis.com/"><img src="https://nestjs.com/img/logo-xtremis.svg" width="220" /></a>
#### Silver Sponsors
<a href="https://neoteric.eu/"><img src="https://nestjs.com/img/neoteric-cut.png" width="120" /></a> &nbsp; <a href="https://www.swingdev.io"><img src="https://nestjs.com/img/swingdev-logo.svg#1" width="150" /></a>
#### Sponsors
<a href="https://scal.io"><img src="https://nestjs.com/img/scalio-logo.svg" width="120" /></a> &nbsp; <a href="https://www.swingdev.io"><img src="https://nestjs.com/img/swingdev-logo.svg#1" width="120" /></a> &nbsp; <a href="http://angularity.io"><img src="http://angularity.io/media/logo.svg" height="32" /></a> &nbsp; <a href="http://gojob.com"><img src="https://gojob.com/w/wp-content/uploads/2017/02/cropped-Logo-web-home.png" height="44" /></a>
<a href="https://scal.io"><img src="https://nestjs.com/img/scalio-logo.svg" width="110" /></a> &nbsp; <a href="http://angularity.io"><img src="http://angularity.io/media/logo.svg" height="30" /></a> &nbsp; <a href="http://gojob.com"><img src="https://gojob.com/w/wp-content/uploads/2017/02/cropped-Logo-web-home.png" height="40" /> &nbsp; <!--<a href="https://keycdn.com"><img src="https://nestjs.com/img/keycdn.svg" height="30" /></a> &nbsp;--> <a href="https://hostpresto.com"><img src="https://nestjs.com/img/hostpresto.png" height="30" /></a>
## Backers
@@ -64,5 +73,3 @@ Nest is an MIT-licensed open source project. It can grow thanks to the sponsors
## License
Nest is [MIT licensed](LICENSE).
<h4 align="center"> <a href="readme_zh.md">中文说明</a></h4>

View File

@@ -14,7 +14,7 @@
<a href="https://www.npmjs.com/~nestjscore"><img src="https://img.shields.io/npm/dm/@nestjs/core.svg" alt="NPM Downloads" /></a>
<a href="https://travis-ci.org/nestjs/nest"><img src="https://api.travis-ci.org/nestjs/nest.svg?branch=master" alt="Travis" /></a>
<a href="https://travis-ci.org/nestjs/nest"><img src="https://img.shields.io/travis/nestjs/nest/master.svg?label=linux" alt="Linux" /></a>
<a href="https://coveralls.io/github/nestjs/nest?branch=master"><img src="https://coveralls.io/repos/github/nestjs/nest/badge.svg?branch=master#5" alt="Coverage" /></a>
<a href="https://coveralls.io/github/nestjs/nest?branch=master"><img src="https://coveralls.io/repos/github/nestjs/nest/badge.svg?branch=master#7" alt="Coverage" /></a>
<a href="https://gitter.im/nestjs/nestjs?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=body_badge"><img src="https://badges.gitter.im/nestjs/nestjs.svg" alt="Gitter" /></a>
<a href="https://opencollective.com/nest#backer"><img src="https://opencollective.com/nest/backers/badge.svg" alt="Backers on Open Collective" /></a>
<a href="https://opencollective.com/nest#sponsor"><img src="https://opencollective.com/nest/sponsors/badge.svg" alt="Sponsors on Open Collective" /></a>
@@ -37,7 +37,8 @@
## Getting started
To check out the [guide](https://docs.nestjs.com), visit [docs.nestjs.com](https://docs.nestjs.com). :books:
* To check out the [guide](https://docs.nestjs.com), visit [docs.nestjs.com](https://docs.nestjs.com). :books:
* 要查看中文 [指南](readme_zh.md), 请访问 [docs.nestjs.cn](https://docs.nestjs.cn). :books:
## Support
@@ -45,58 +46,23 @@ Nest is an MIT-licensed open source project. It can grow thanks to the sponsors
#### Principal Sponsor
<a href="https://valor-software.com/"><img src="https://docs.nestjs.com/assets/sponsors/valor-software.png" width="300" /></a>
<a href="https://valor-software.com/"><img src="https://docs.nestjs.com/assets/sponsors/valor-software.png" width="320" /></a>
#### Gold Sponsors
<a href="http://xtremis.com/"><img src="https://nestjs.com/img/logo-xtremis.svg" width="220" /></a>
#### Silver Sponsors
<a href="https://neoteric.eu/"><img src="https://nestjs.com/img/neoteric-cut.png" width="120" /></a> &nbsp; <a href="https://www.swingdev.io"><img src="https://nestjs.com/img/swingdev-logo.svg#1" width="150" /></a>
#### Sponsors
<a href="https://scal.io"><img src="https://nestjs.com/img/scalio-logo.svg" width="150" /></a> &nbsp; <a href="https://www.swingdev.io"><img src="https://nestjs.com/img/swingdev-logo.svg#1" width="150" /></a>
<a href="https://scal.io"><img src="https://nestjs.com/img/scalio-logo.svg" width="110" /></a> &nbsp; <a href="http://angularity.io"><img src="http://angularity.io/media/logo.svg" height="30" /></a> &nbsp; <a href="http://gojob.com"><img src="https://gojob.com/w/wp-content/uploads/2017/02/cropped-Logo-web-home.png" height="40" /> &nbsp; <!--<a href="https://keycdn.com"><img src="https://nestjs.com/img/keycdn.svg" height="30" /></a> &nbsp;--> <a href="https://hostpresto.com"><img src="https://nestjs.com/img/hostpresto.png" height="30" /></a>
## Backers
<a href="https://opencollective.com/nest/backer/0/website" target="_blank"><img src="https://opencollective.com/nest/backer/0/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/1/website" target="_blank"><img src="https://opencollective.com/nest/backer/1/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/2/website" target="_blank"><img src="https://opencollective.com/nest/backer/2/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/3/website" target="_blank"><img src="https://opencollective.com/nest/backer/3/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/4/website" target="_blank"><img src="https://opencollective.com/nest/backer/4/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/5/website" target="_blank"><img src="https://opencollective.com/nest/backer/5/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/6/website" target="_blank"><img src="https://opencollective.com/nest/backer/6/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/7/website" target="_blank"><img src="https://opencollective.com/nest/backer/7/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/8/website" target="_blank"><img src="https://opencollective.com/nest/backer/8/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/9/website" target="_blank"><img src="https://opencollective.com/nest/backer/9/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/10/website" target="_blank"><img src="https://opencollective.com/nest/backer/10/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/11/website" target="_blank"><img src="https://opencollective.com/nest/backer/11/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/12/website" target="_blank"><img src="https://opencollective.com/nest/backer/12/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/13/website" target="_blank"><img src="https://opencollective.com/nest/backer/13/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/14/website" target="_blank"><img src="https://opencollective.com/nest/backer/14/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/15/website" target="_blank"><img src="https://opencollective.com/nest/backer/15/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/16/website" target="_blank"><img src="https://opencollective.com/nest/backer/16/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/17/website" target="_blank"><img src="https://opencollective.com/nest/backer/17/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/18/website" target="_blank"><img src="https://opencollective.com/nest/backer/18/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/19/website" target="_blank"><img src="https://opencollective.com/nest/backer/19/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/20/website" target="_blank"><img src="https://opencollective.com/nest/backer/20/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/21/website" target="_blank"><img src="https://opencollective.com/nest/backer/21/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/22/website" target="_blank"><img src="https://opencollective.com/nest/backer/22/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/23/website" target="_blank"><img src="https://opencollective.com/nest/backer/23/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/24/website" target="_blank"><img src="https://opencollective.com/nest/backer/24/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/25/website" target="_blank"><img src="https://opencollective.com/nest/backer/25/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/26/website" target="_blank"><img src="https://opencollective.com/nest/backer/26/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/27/website" target="_blank"><img src="https://opencollective.com/nest/backer/27/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/28/website" target="_blank"><img src="https://opencollective.com/nest/backer/28/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/29/website" target="_blank"><img src="https://opencollective.com/nest/backer/29/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/30/website" target="_blank"><img src="https://opencollective.com/nest/backer/30/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/31/website" target="_blank"><img src="https://opencollective.com/nest/backer/31/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/32/website" target="_blank"><img src="https://opencollective.com/nest/backer/32/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/33/website" target="_blank"><img src="https://opencollective.com/nest/backer/33/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/34/website" target="_blank"><img src="https://opencollective.com/nest/backer/34/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/35/website" target="_blank"><img src="https://opencollective.com/nest/backer/35/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/36/website" target="_blank"><img src="https://opencollective.com/nest/backer/36/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/37/website" target="_blank"><img src="https://opencollective.com/nest/backer/37/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/38/website" target="_blank"><img src="https://opencollective.com/nest/backer/38/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/39/website" target="_blank"><img src="https://opencollective.com/nest/backer/39/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/40/website" target="_blank"><img src="https://opencollective.com/nest/backer/40/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/41/website" target="_blank"><img src="https://opencollective.com/nest/backer/41/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/42/website" target="_blank"><img src="https://opencollective.com/nest/backer/42/avatar.svg"></a>
<a href="https://opencollective.com/nest/backer/43/website" target="_blank"><img src="https://opencollective.com/nest/backer/43/avatar.svg"></a>
<a href="https://opencollective.com/nest"><img src="https://opencollective.com/nest/backers.svg?width=890"></a>
## Stay in touch
@@ -107,5 +73,3 @@ Nest is an MIT-licensed open source project. It can grow thanks to the sponsors
## License
Nest is [MIT licensed](LICENSE).
<h4 align="center"> <a href="readme_zh.md">中文说明</a></h4>

View File

@@ -0,0 +1,3 @@
export declare const CACHE_MANAGER = "CACHE_MANAGER";
export declare const CACHE_MODULE_OPTIONS = "CACHE_MODULE_OPTIONS";
export declare const CACHE_KEY_METADATA = "cache_module:cache_key";

View File

@@ -0,0 +1,5 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.CACHE_MANAGER = 'CACHE_MANAGER';
exports.CACHE_MODULE_OPTIONS = 'CACHE_MODULE_OPTIONS';
exports.CACHE_KEY_METADATA = 'cache_module:cache_key';

8
bundle/common/cache/cache.module.d.ts vendored Normal file
View File

@@ -0,0 +1,8 @@
import { DynamicModule } from '../interfaces';
import { CacheModuleAsyncOptions, CacheModuleOptions } from './interfaces/cache-module.interface';
export declare class CacheModule {
static register(options?: CacheModuleOptions): DynamicModule;
static registerAsync(options: CacheModuleAsyncOptions): DynamicModule;
private static createAsyncProviders(options);
private static createAsyncOptionsProvider(options);
}

60
bundle/common/cache/cache.module.js vendored Normal file
View File

@@ -0,0 +1,60 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
Object.defineProperty(exports, "__esModule", { value: true });
const decorators_1 = require("../decorators");
const cache_constants_1 = require("./cache.constants");
const cache_providers_1 = require("./cache.providers");
let CacheModule = CacheModule_1 = class CacheModule {
static register(options = {}) {
return {
module: CacheModule_1,
providers: [{ provide: cache_constants_1.CACHE_MODULE_OPTIONS, useValue: options }],
};
}
static registerAsync(options) {
return {
module: CacheModule_1,
imports: options.imports,
providers: this.createAsyncProviders(options),
};
}
static createAsyncProviders(options) {
if (options.useExisting || options.useFactory) {
return [this.createAsyncOptionsProvider(options)];
}
return [
this.createAsyncOptionsProvider(options),
{
provide: options.useClass,
useClass: options.useClass,
},
];
}
static createAsyncOptionsProvider(options) {
if (options.useFactory) {
return {
provide: cache_constants_1.CACHE_MODULE_OPTIONS,
useFactory: options.useFactory,
inject: options.inject || [],
};
}
return {
provide: cache_constants_1.CACHE_MODULE_OPTIONS,
useFactory: async (optionsFactory) => await optionsFactory.createCacheOptions(),
inject: [options.useExisting || options.useClass],
};
}
};
CacheModule = CacheModule_1 = __decorate([
decorators_1.Module({
providers: [cache_providers_1.createCacheManager()],
exports: [cache_constants_1.CACHE_MANAGER],
})
], CacheModule);
exports.CacheModule = CacheModule;
var CacheModule_1;

View File

@@ -0,0 +1,2 @@
import { Provider } from '../interfaces';
export declare function createCacheManager(): Provider;

17
bundle/common/cache/cache.providers.js vendored Normal file
View File

@@ -0,0 +1,17 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const load_package_util_1 = require("../utils/load-package.util");
const cache_constants_1 = require("./cache.constants");
const default_options_1 = require("./default-options");
function createCacheManager() {
return {
provide: cache_constants_1.CACHE_MANAGER,
useFactory: (options) => {
const cacheManager = load_package_util_1.loadPackage('cache-manager', 'CacheModule');
const memoryCache = cacheManager.caching(Object.assign({}, default_options_1.defaultCacheOptions, (options || {})));
return memoryCache;
},
inject: [cache_constants_1.CACHE_MODULE_OPTIONS],
};
}
exports.createCacheManager = createCacheManager;

View File

@@ -0,0 +1 @@
export declare const CacheKey: (key: string) => (target: object, key?: any, descriptor?: any) => any;

View File

@@ -0,0 +1,5 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const decorators_1 = require("../../decorators");
const cache_constants_1 = require("../cache.constants");
exports.CacheKey = (key) => decorators_1.ReflectMetadata(cache_constants_1.CACHE_KEY_METADATA, key);

View File

@@ -0,0 +1 @@
export * from './cache-key.decorator';

View File

@@ -0,0 +1,6 @@
"use strict";
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./cache-key.decorator"));

View File

@@ -0,0 +1,5 @@
export declare const defaultCacheOptions: {
ttl: number;
max: number;
store: string;
};

View File

@@ -0,0 +1,7 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.defaultCacheOptions = {
ttl: 5,
max: 100,
store: 'memory',
};

5
bundle/common/cache/index.d.ts vendored Normal file
View File

@@ -0,0 +1,5 @@
export { CACHE_MANAGER } from './cache.constants';
export * from './cache.module';
export * from './decorators';
export * from './interceptors';
export * from './interfaces';

10
bundle/common/cache/index.js vendored Normal file
View File

@@ -0,0 +1,10 @@
"use strict";
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
var cache_constants_1 = require("./cache.constants");
exports.CACHE_MANAGER = cache_constants_1.CACHE_MANAGER;
__export(require("./cache.module"));
__export(require("./decorators"));
__export(require("./interceptors"));

View File

@@ -0,0 +1,11 @@
import { Observable } from 'rxjs';
import { ExecutionContext, HttpServer, NestInterceptor } from '../../interfaces';
export declare class CacheInterceptor implements NestInterceptor {
protected readonly httpServer: HttpServer;
protected readonly cacheManager: any;
protected readonly reflector: any;
protected readonly isHttpApp: boolean;
constructor(httpServer: HttpServer, cacheManager: any, reflector: any);
intercept(context: ExecutionContext, call$: Observable<any>): Promise<Observable<any>>;
trackBy(context: ExecutionContext): string | undefined;
}

View File

@@ -0,0 +1,68 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
const rxjs_1 = require("rxjs");
const operators_1 = require("rxjs/operators");
const decorators_1 = require("../../decorators");
const cache_constants_1 = require("../cache.constants");
// NOTE (external)
// We need to deduplicate them here due to the circular dependency
// between core and common packages
const HTTP_SERVER_REF = 'HTTP_SERVER_REF';
const REFLECTOR = 'Reflector';
let CacheInterceptor = class CacheInterceptor {
constructor(httpServer, cacheManager, reflector) {
this.httpServer = httpServer;
this.cacheManager = cacheManager;
this.reflector = reflector;
this.isHttpApp = httpServer && !!httpServer.getRequestMethod;
}
async intercept(context, call$) {
const key = this.trackBy(context);
if (!key) {
return call$;
}
try {
const value = await this.cacheManager.get(key);
if (value) {
return rxjs_1.of(value);
}
return call$.pipe(operators_1.tap(response => this.cacheManager.set(key, response)));
}
catch (_a) {
return call$;
}
}
trackBy(context) {
if (!this.isHttpApp) {
return this.reflector.get(cache_constants_1.CACHE_KEY_METADATA, context.getHandler());
}
const request = context.getArgByIndex(0);
const excludePaths = [];
if (this.httpServer.getRequestMethod(request) !== 'GET' ||
excludePaths.includes(this.httpServer.getRequestUrl)) {
return undefined;
}
return this.httpServer.getRequestUrl(context.getArgByIndex(0));
}
};
CacheInterceptor = __decorate([
decorators_1.Injectable(),
__param(0, decorators_1.Optional()),
__param(0, decorators_1.Inject(HTTP_SERVER_REF)),
__param(1, decorators_1.Inject(cache_constants_1.CACHE_MANAGER)),
__param(2, decorators_1.Inject(REFLECTOR)),
__metadata("design:paramtypes", [Object, Object, Object])
], CacheInterceptor);
exports.CacheInterceptor = CacheInterceptor;

View File

@@ -0,0 +1 @@
export * from './cache.interceptor';

View File

@@ -0,0 +1,6 @@
"use strict";
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./cache.interceptor"));

View File

@@ -0,0 +1,17 @@
export interface LiteralObject {
[key: string]: any;
}
export interface CacheStore {
set<T>(key: string, value: T): Promise<void> | void;
get<T>(key: string): Promise<void> | void;
del(key: string): void | Promise<void>;
}
export interface CacheStoreFactory {
create(args: LiteralObject): CacheStore;
}
export interface CacheManagerOptions {
store?: string | CacheStoreFactory;
ttl?: number;
max?: number;
isCacheableValue?: (value: any) => boolean;
}

View File

@@ -0,0 +1,2 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });

View File

@@ -0,0 +1,14 @@
import { ModuleMetadata, Type } from './../../interfaces';
import { CacheManagerOptions } from './cache-manager.interface';
export interface CacheModuleOptions extends CacheManagerOptions {
[key: string]: any;
}
export interface CacheOptionsFactory {
createCacheOptions(): Promise<CacheModuleOptions> | CacheModuleOptions;
}
export interface CacheModuleAsyncOptions extends Pick<ModuleMetadata, 'imports'> {
useExisting?: Type<CacheOptionsFactory>;
useClass?: Type<CacheOptionsFactory>;
useFactory?: (...args: any[]) => Promise<CacheModuleOptions> | CacheModuleOptions;
inject?: any[];
}

View File

@@ -0,0 +1,2 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });

View File

@@ -0,0 +1,2 @@
export * from './cache-manager.interface';
export * from './cache-module.interface';

View File

@@ -0,0 +1,2 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });

View File

@@ -11,6 +11,7 @@ export declare const GLOBAL_MODULE_METADATA = "__globalModule__";
export declare const PATH_METADATA = "path";
export declare const PARAMTYPES_METADATA = "design:paramtypes";
export declare const SELF_DECLARED_DEPS_METADATA = "self:paramtypes";
export declare const OPTIONAL_DEPS_METADATA = "optional:paramtypes";
export declare const METHOD_METADATA = "method";
export declare const ROUTE_ARGS_METADATA = "__routeArguments__";
export declare const CUSTOM_ROUTE_AGRS_METADATA = "__customRouteArgs__";

View File

@@ -13,6 +13,7 @@ exports.GLOBAL_MODULE_METADATA = '__globalModule__';
exports.PATH_METADATA = 'path';
exports.PARAMTYPES_METADATA = 'design:paramtypes';
exports.SELF_DECLARED_DEPS_METADATA = 'self:paramtypes';
exports.OPTIONAL_DEPS_METADATA = 'optional:paramtypes';
exports.METHOD_METADATA = 'method';
exports.ROUTE_ARGS_METADATA = '__routeArguments__';
exports.CUSTOM_ROUTE_AGRS_METADATA = '__customRouteArgs__';

View File

@@ -1,6 +1,7 @@
import 'reflect-metadata';
import { Type } from '../../interfaces';
/**
* Defines the Exceptions Filter. Takes set of exception types as an argument which has to be caught by this Filter.
* The class should implement the `ExceptionFilter` interface.
*/
export declare function Catch(...exceptions: any[]): ClassDecorator;
export declare function Catch(...exceptions: Type<any>[]): ClassDecorator;

View File

@@ -1,6 +1,7 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const deprecate = require("deprecate");
const uuid = require("uuid/v4");
/**
* Defines the injectable class. This class can inject dependencies through constructor.
* Those dependencies have to belong to the same module.
@@ -56,9 +57,8 @@ function Interceptor() {
}
exports.Interceptor = Interceptor;
function mixin(mixinClass) {
this.offset = this.offset ? ++this.offset : Math.random() * 100;
Object.defineProperty(mixinClass, 'name', {
value: JSON.stringify(this.offset),
value: uuid(),
});
Injectable()(mixinClass);
return mixinClass;

View File

@@ -1,11 +1,12 @@
export * from './controller.decorator';
export * from './component.decorator';
export * from './dependencies.decorator';
export * from './inject.decorator';
export * from './catch.decorator';
export * from './exception-filters.decorator';
export * from './use-pipes.decorator';
export * from './use-guards.decorator';
export * from './reflect-metadata.decorator';
export * from './use-interceptors.decorator';
export * from './bind.decorator';
export * from './catch.decorator';
export * from './component.decorator';
export * from './controller.decorator';
export * from './dependencies.decorator';
export * from './exception-filters.decorator';
export * from './inject.decorator';
export * from './optional.decorator';
export * from './reflect-metadata.decorator';
export * from './use-guards.decorator';
export * from './use-interceptors.decorator';
export * from './use-pipes.decorator';

View File

@@ -3,14 +3,15 @@ function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./controller.decorator"));
__export(require("./component.decorator"));
__export(require("./dependencies.decorator"));
__export(require("./inject.decorator"));
__export(require("./catch.decorator"));
__export(require("./exception-filters.decorator"));
__export(require("./use-pipes.decorator"));
__export(require("./use-guards.decorator"));
__export(require("./reflect-metadata.decorator"));
__export(require("./use-interceptors.decorator"));
__export(require("./bind.decorator"));
__export(require("./catch.decorator"));
__export(require("./component.decorator"));
__export(require("./controller.decorator"));
__export(require("./dependencies.decorator"));
__export(require("./exception-filters.decorator"));
__export(require("./inject.decorator"));
__export(require("./optional.decorator"));
__export(require("./reflect-metadata.decorator"));
__export(require("./use-guards.decorator"));
__export(require("./use-interceptors.decorator"));
__export(require("./use-pipes.decorator"));

View File

@@ -3,4 +3,4 @@ import 'reflect-metadata';
* Injects provider which has to be available in the current injector (module) scope.
* Providers are recognized by types or tokens.
*/
export declare function Inject(token: any): ParameterDecorator;
export declare function Inject<T = any>(token: T): ParameterDecorator;

View File

@@ -0,0 +1,5 @@
import 'reflect-metadata';
/**
* Sets dependency as an optional one.
*/
export declare function Optional(): ParameterDecorator;

View File

@@ -0,0 +1,14 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
require("reflect-metadata");
const constants_1 = require("../../constants");
/**
* Sets dependency as an optional one.
*/
function Optional() {
return (target, key, index) => {
const args = Reflect.getMetadata(constants_1.OPTIONAL_DEPS_METADATA, target) || [];
Reflect.defineMetadata(constants_1.OPTIONAL_DEPS_METADATA, [...args, index], target);
};
}
exports.Optional = Optional;

View File

@@ -1,5 +1,5 @@
/**
* Assigns the metadata to the class / function under specified `key`.
* Assigns the metadata to the class/function under specified `key`.
* This metadata can be reflected using `Reflector` class.
*/
export declare const ReflectMetadata: (metadataKey: any, metadataValue: any) => (target: object, key?: any, descriptor?: any) => any;
export declare const ReflectMetadata: <K = any, V = any>(metadataKey: K, metadataValue: V) => (target: object, key?: any, descriptor?: any) => any;

View File

@@ -1,7 +1,7 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* Assigns the metadata to the class / function under specified `key`.
* Assigns the metadata to the class/function under specified `key`.
* This metadata can be reflected using `Reflector` class.
*/
exports.ReflectMetadata = (metadataKey, metadataValue) => (target, key, descriptor) => {

View File

@@ -1,13 +1,15 @@
import { CustomParamFactory } from '../../interfaces/features/custom-route-param-factory.interface';
import { PipeTransform } from '../../index';
import { Type } from '../../interfaces';
import { CustomParamFactory } from '../../interfaces/features/custom-route-param-factory.interface';
export declare type ParamDecoratorEnhancer = ParameterDecorator;
/**
* Creates HTTP route param decorator
* Defines HTTP route param decorator
* @param factory
*/
export declare function createParamDecorator(factory: CustomParamFactory): (data?: any, ...pipes: PipeTransform<any>[]) => ParameterDecorator;
export declare function createParamDecorator(factory: CustomParamFactory, enhancers?: ParamDecoratorEnhancer[]): (...dataOrPipes: (Type<PipeTransform> | PipeTransform | any)[]) => ParameterDecorator;
/**
* Creates HTTP route param decorator
* Defines HTTP route param decorator
* @deprecated
* @param factory
*/
export declare function createRouteParamDecorator(factory: CustomParamFactory): (data?: any, ...pipes: PipeTransform<any>[]) => ParameterDecorator;
export declare function createRouteParamDecorator(factory: CustomParamFactory): (data?: any, ...pipes: (Type<PipeTransform> | PipeTransform)[]) => ParameterDecorator;

View File

@@ -1,30 +1,35 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const deprecate = require("deprecate");
const uuid = require("uuid/v4");
const constants_1 = require("../../constants");
const shared_utils_1 = require("../../utils/shared.utils");
const assignCustomMetadata = (args, paramtype, index, factory, data, ...pipes) => (Object.assign({}, args, { [`${paramtype}${constants_1.CUSTOM_ROUTE_AGRS_METADATA}:${index}`]: {
index,
factory,
data,
pipes,
} }));
const randomString = () => Math.random()
.toString(36)
.substring(2, 15);
/**
* Creates HTTP route param decorator
* Defines HTTP route param decorator
* @param factory
*/
function createParamDecorator(factory) {
const paramtype = randomString() + randomString();
function createParamDecorator(factory, enhancers = []) {
const paramtype = uuid();
return (data, ...pipes) => (target, key, index) => {
const args = Reflect.getMetadata(constants_1.ROUTE_ARGS_METADATA, target.constructor, key) || {};
Reflect.defineMetadata(constants_1.ROUTE_ARGS_METADATA, assignCustomMetadata(args, paramtype, index, factory, data, ...pipes), target.constructor, key);
const isPipe = pipe => pipe &&
((shared_utils_1.isFunction(pipe) && pipe.prototype) || shared_utils_1.isFunction(pipe.transform));
const hasParamData = shared_utils_1.isNil(data) || !isPipe(data);
const paramData = hasParamData ? data : undefined;
const paramPipes = hasParamData ? pipes : [data, ...pipes];
Reflect.defineMetadata(constants_1.ROUTE_ARGS_METADATA, assignCustomMetadata(args, paramtype, index, factory, paramData, ...paramPipes), target.constructor, key);
enhancers.forEach(fn => fn(target, key, index));
};
}
exports.createParamDecorator = createParamDecorator;
/**
* Creates HTTP route param decorator
* Defines HTTP route param decorator
* @deprecated
* @param factory
*/

View File

@@ -12,7 +12,7 @@ export declare const Request: () => ParameterDecorator;
export declare const Response: () => ParameterDecorator;
export declare const Next: () => ParameterDecorator;
export declare const Session: () => ParameterDecorator;
export declare const UploadedFile: () => ParameterDecorator;
export declare const UploadedFile: (fileKey?: string) => ParameterDecorator;
export declare const UploadedFiles: () => ParameterDecorator;
export declare const Headers: (property?: string) => ParameterDecorator;
export declare function Query(): any;

View File

@@ -0,0 +1,10 @@
import { HttpException } from './http.exception';
/**
* Any attempt to brew coffee with a teapot should result in the error code "418 I'm a teapot".
* The resulting entity body MAY be short and stout.
*
* http://save418.com/
*/
export declare class ImATeapotException extends HttpException {
constructor(message?: string | object | any, error?: string);
}

View File

@@ -0,0 +1,17 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const http_exception_1 = require("./http.exception");
const http_status_enum_1 = require("../enums/http-status.enum");
const http_exception_body_util_1 = require("../utils/http-exception-body.util");
/**
* Any attempt to brew coffee with a teapot should result in the error code "418 I'm a teapot".
* The resulting entity body MAY be short and stout.
*
* http://save418.com/
*/
class ImATeapotException extends http_exception_1.HttpException {
constructor(message, error = 'I\'m a teapot') {
super(http_exception_body_util_1.createHttpExceptionBody(message, error, http_status_enum_1.HttpStatus.I_AM_A_TEAPOT), http_status_enum_1.HttpStatus.I_AM_A_TEAPOT);
}
}
exports.ImATeapotException = ImATeapotException;

View File

@@ -16,3 +16,4 @@ export * from './not-implemented.exception';
export * from './bad-gateway.exception';
export * from './service-unavailable.exception';
export * from './gateway-timeout.exception';
export * from './im-a-teapot.exception';

View File

@@ -21,3 +21,4 @@ __export(require("./not-implemented.exception"));
__export(require("./bad-gateway.exception"));
__export(require("./service-unavailable.exception"));
__export(require("./gateway-timeout.exception"));
__export(require("./im-a-teapot.exception"));

View File

@@ -0,0 +1 @@
export declare const MULTER_MODULE_OPTIONS = "MULTER_MODULE_OPTIONS";

View File

@@ -0,0 +1,3 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.MULTER_MODULE_OPTIONS = 'MULTER_MODULE_OPTIONS';

3
bundle/common/files/index.d.ts vendored Normal file
View File

@@ -0,0 +1,3 @@
export * from './interceptors';
export * from './interfaces';
export * from './multer.module';

View File

@@ -0,0 +1,7 @@
"use strict";
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./interceptors"));
__export(require("./multer.module"));

View File

@@ -0,0 +1,2 @@
import { MulterField, MulterOptions } from '../../interfaces/external/multer-options.interface';
export declare function FileFieldsInterceptor(uploadFields: MulterField[], localOptions?: MulterOptions): any;

View File

@@ -0,0 +1,45 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
const multer = require("multer");
const decorators_1 = require("../../decorators");
const component_decorator_1 = require("../../decorators/core/component.decorator");
const files_constants_1 = require("./../files.constants");
const multer_utils_1 = require("./../multer/multer.utils");
function FileFieldsInterceptor(uploadFields, localOptions) {
let MixinInterceptor = class MixinInterceptor {
constructor(options = {}) {
this.upload = multer(Object.assign({}, options, localOptions));
}
async intercept(context, call$) {
const ctx = context.switchToHttp();
await new Promise((resolve, reject) => this.upload.fields(uploadFields)(ctx.getRequest(), ctx.getResponse(), err => {
if (err) {
const error = multer_utils_1.transformException(err);
return reject(error);
}
resolve();
}));
return call$;
}
};
MixinInterceptor = __decorate([
__param(0, decorators_1.Optional()),
__param(0, decorators_1.Inject(files_constants_1.MULTER_MODULE_OPTIONS)),
__metadata("design:paramtypes", [Object])
], MixinInterceptor);
const Interceptor = component_decorator_1.mixin(MixinInterceptor);
return Interceptor;
}
exports.FileFieldsInterceptor = FileFieldsInterceptor;

View File

@@ -0,0 +1,2 @@
import { MulterOptions } from '../../interfaces/external/multer-options.interface';
export declare function FileInterceptor(fieldName: string, localOptions?: MulterOptions): any;

View File

@@ -0,0 +1,45 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
const multer = require("multer");
const decorators_1 = require("../../decorators");
const component_decorator_1 = require("../../decorators/core/component.decorator");
const files_constants_1 = require("./../files.constants");
const multer_utils_1 = require("./../multer/multer.utils");
function FileInterceptor(fieldName, localOptions) {
let MixinInterceptor = class MixinInterceptor {
constructor(options = {}) {
this.upload = multer(Object.assign({}, options, localOptions));
}
async intercept(context, call$) {
const ctx = context.switchToHttp();
await new Promise((resolve, reject) => this.upload.single(fieldName)(ctx.getRequest(), ctx.getResponse(), err => {
if (err) {
const error = multer_utils_1.transformException(err);
return reject(error);
}
resolve();
}));
return call$;
}
};
MixinInterceptor = __decorate([
__param(0, decorators_1.Optional()),
__param(0, decorators_1.Inject(files_constants_1.MULTER_MODULE_OPTIONS)),
__metadata("design:paramtypes", [Object])
], MixinInterceptor);
const Interceptor = component_decorator_1.mixin(MixinInterceptor);
return Interceptor;
}
exports.FileInterceptor = FileInterceptor;

View File

@@ -0,0 +1,2 @@
import { MulterOptions } from '../../interfaces/external/multer-options.interface';
export declare function FilesInterceptor(fieldName: string, maxCount?: number, localOptions?: MulterOptions): any;

View File

@@ -0,0 +1,45 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
const multer = require("multer");
const decorators_1 = require("../../decorators");
const component_decorator_1 = require("../../decorators/core/component.decorator");
const files_constants_1 = require("./../files.constants");
const multer_utils_1 = require("./../multer/multer.utils");
function FilesInterceptor(fieldName, maxCount, localOptions) {
let MixinInterceptor = class MixinInterceptor {
constructor(options = {}) {
this.upload = multer(Object.assign({}, options, localOptions));
}
async intercept(context, call$) {
const ctx = context.switchToHttp();
await new Promise((resolve, reject) => this.upload.array(fieldName, maxCount)(ctx.getRequest(), ctx.getResponse(), err => {
if (err) {
const error = multer_utils_1.transformException(err);
return reject(error);
}
resolve();
}));
return call$;
}
};
MixinInterceptor = __decorate([
__param(0, decorators_1.Optional()),
__param(0, decorators_1.Inject(files_constants_1.MULTER_MODULE_OPTIONS)),
__metadata("design:paramtypes", [Object])
], MixinInterceptor);
const Interceptor = component_decorator_1.mixin(MixinInterceptor);
return Interceptor;
}
exports.FilesInterceptor = FilesInterceptor;

View File

@@ -0,0 +1,3 @@
export * from './file-fields.interceptor';
export * from './file.interceptor';
export * from './files.interceptor';

View File

@@ -0,0 +1,8 @@
"use strict";
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./file-fields.interceptor"));
__export(require("./file.interceptor"));
__export(require("./files.interceptor"));

View File

@@ -0,0 +1,13 @@
import { ModuleMetadata, Type } from '@nestjs/common/interfaces';
import { MulterOptions } from './../../interfaces/external/multer-options.interface';
export interface MulterModuleOptions extends MulterOptions {
}
export interface MulterOptionsFactory {
createMulterOptions(): Promise<MulterModuleOptions> | MulterModuleOptions;
}
export interface MulterModuleAsyncOptions extends Pick<ModuleMetadata, 'imports'> {
useExisting?: Type<MulterOptionsFactory>;
useClass?: Type<MulterOptionsFactory>;
useFactory?: (...args: any[]) => Promise<MulterModuleOptions> | MulterModuleOptions;
inject?: any[];
}

View File

@@ -0,0 +1,2 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });

View File

@@ -0,0 +1 @@
export * from './files-upload-module.interface';

View File

@@ -0,0 +1,2 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });

View File

@@ -0,0 +1,8 @@
import { DynamicModule } from '@nestjs/common';
import { MulterModuleAsyncOptions, MulterModuleOptions } from './interfaces/files-upload-module.interface';
export declare class MulterModule {
static register(options?: MulterModuleOptions): DynamicModule;
static registerAsync(options: MulterModuleAsyncOptions): DynamicModule;
private static createAsyncProviders(options);
private static createAsyncOptionsProvider(options);
}

View File

@@ -0,0 +1,58 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
Object.defineProperty(exports, "__esModule", { value: true });
const common_1 = require("@nestjs/common");
const files_constants_1 = require("./files.constants");
let MulterModule = MulterModule_1 = class MulterModule {
static register(options = {}) {
return {
module: MulterModule_1,
providers: [{ provide: files_constants_1.MULTER_MODULE_OPTIONS, useValue: options }],
exports: [files_constants_1.MULTER_MODULE_OPTIONS],
};
}
static registerAsync(options) {
return {
module: MulterModule_1,
imports: options.imports,
providers: this.createAsyncProviders(options),
exports: [files_constants_1.MULTER_MODULE_OPTIONS],
};
}
static createAsyncProviders(options) {
if (options.useExisting || options.useFactory) {
return [this.createAsyncOptionsProvider(options)];
}
return [
this.createAsyncOptionsProvider(options),
{
provide: options.useClass,
useClass: options.useClass,
},
];
}
static createAsyncOptionsProvider(options) {
if (options.useFactory) {
return {
provide: files_constants_1.MULTER_MODULE_OPTIONS,
useFactory: options.useFactory,
inject: options.inject || [],
};
}
return {
provide: files_constants_1.MULTER_MODULE_OPTIONS,
useFactory: async (optionsFactory) => await optionsFactory.createMulterOptions(),
inject: [options.useExisting || options.useClass],
};
}
};
MulterModule = MulterModule_1 = __decorate([
common_1.Module({})
], MulterModule);
exports.MulterModule = MulterModule;
var MulterModule_1;

View File

@@ -0,0 +1,9 @@
export declare const multerExceptions: {
LIMIT_PART_COUNT: string;
LIMIT_FILE_SIZE: string;
LIMIT_FILE_COUNT: string;
LIMIT_FIELD_KEY: string;
LIMIT_FIELD_VALUE: string;
LIMIT_FIELD_COUNT: string;
LIMIT_UNEXPECTED_FILE: string;
};

View File

@@ -0,0 +1,11 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.multerExceptions = {
LIMIT_PART_COUNT: 'Too many parts',
LIMIT_FILE_SIZE: 'File too large',
LIMIT_FILE_COUNT: 'Too many files',
LIMIT_FIELD_KEY: 'Field name too long',
LIMIT_FIELD_VALUE: 'Field value too long',
LIMIT_FIELD_COUNT: 'Too many fields',
LIMIT_UNEXPECTED_FILE: 'Unexpected field',
};

View File

@@ -0,0 +1,2 @@
import { BadRequestException, PayloadTooLargeException } from './../../exceptions';
export declare function transformException(error: Error | undefined): Error | BadRequestException | PayloadTooLargeException;

View File

@@ -0,0 +1,22 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const exceptions_1 = require("./../../exceptions");
const multer_constants_1 = require("./multer.constants");
function transformException(error) {
if (!error || error instanceof exceptions_1.HttpException) {
return error;
}
switch (error.message) {
case multer_constants_1.multerExceptions.LIMIT_FILE_SIZE:
return new exceptions_1.PayloadTooLargeException(error.message);
case multer_constants_1.multerExceptions.LIMIT_FILE_COUNT:
case multer_constants_1.multerExceptions.LIMIT_FIELD_KEY:
case multer_constants_1.multerExceptions.LIMIT_FIELD_VALUE:
case multer_constants_1.multerExceptions.LIMIT_FIELD_COUNT:
case multer_constants_1.multerExceptions.LIMIT_UNEXPECTED_FILE:
case multer_constants_1.multerExceptions.LIMIT_PART_COUNT:
return new exceptions_1.BadRequestException(error.message);
}
return error;
}
exports.transformException = transformException;

View File

@@ -0,0 +1 @@
export declare const AXIOS_INSTANCE_TOKEN = "AXIOS_INSTANCE_TOKEN";

View File

@@ -0,0 +1,3 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.AXIOS_INSTANCE_TOKEN = 'AXIOS_INSTANCE_TOKEN';

View File

@@ -1,2 +1,5 @@
import { AxiosRequestConfig } from 'axios';
import { DynamicModule } from '../interfaces';
export declare class HttpModule {
static register(config: AxiosRequestConfig): DynamicModule;
}

View File

@@ -6,14 +6,29 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
Object.defineProperty(exports, "__esModule", { value: true });
const axios_1 = require("axios");
const module_decorator_1 = require("../decorators/modules/module.decorator");
const http_constants_1 = require("./http.constants");
const http_service_1 = require("./http.service");
let HttpModule = class HttpModule {
let HttpModule = HttpModule_1 = class HttpModule {
static register(config) {
return {
module: HttpModule_1,
providers: [{
provide: http_constants_1.AXIOS_INSTANCE_TOKEN,
useValue: axios_1.default.create(config),
}],
};
}
};
HttpModule = __decorate([
HttpModule = HttpModule_1 = __decorate([
module_decorator_1.Module({
providers: [http_service_1.HttpService],
providers: [http_service_1.HttpService, {
provide: http_constants_1.AXIOS_INSTANCE_TOKEN,
useValue: axios_1.default,
}],
exports: [http_service_1.HttpService],
})
], HttpModule);
exports.HttpModule = HttpModule;
var HttpModule_1;

View File

@@ -1,6 +1,8 @@
import { AxiosRequestConfig, AxiosResponse } from 'axios';
import { AxiosInstance, AxiosRequestConfig, AxiosResponse } from 'axios';
import { Observable } from 'rxjs';
export declare class HttpService {
private readonly instance;
constructor(instance?: AxiosInstance);
request<T = any>(config: AxiosRequestConfig): Observable<AxiosResponse<T>>;
get<T = any>(url: string, config?: AxiosRequestConfig): Observable<AxiosResponse<T>>;
delete<T = any>(url: string, config?: AxiosRequestConfig): Observable<AxiosResponse<T>>;
@@ -8,4 +10,5 @@ export declare class HttpService {
post<T = any>(url: string, data?: any, config?: AxiosRequestConfig): Observable<AxiosResponse<T>>;
put<T = any>(url: string, data?: any, config?: AxiosRequestConfig): Observable<AxiosResponse<T>>;
patch<T = any>(url: string, data?: any, config?: AxiosRequestConfig): Observable<AxiosResponse<T>>;
readonly axiosRef: AxiosInstance;
}

View File

@@ -1,28 +1,52 @@
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
const axios_1 = require("axios");
const rxjs_1 = require("rxjs");
class HttpService {
const decorators_1 = require("../decorators");
const http_constants_1 = require("./http.constants");
let HttpService = class HttpService {
constructor(instance = axios_1.default) {
this.instance = instance;
}
request(config) {
return rxjs_1.from(axios_1.default.request(config));
return rxjs_1.defer(() => this.instance.request(config));
}
get(url, config) {
return rxjs_1.from(axios_1.default.get(url, config));
return rxjs_1.defer(() => this.instance.get(url, config));
}
delete(url, config) {
return rxjs_1.from(axios_1.default.delete(url, config));
return rxjs_1.defer(() => this.instance.delete(url, config));
}
head(url, config) {
return rxjs_1.from(axios_1.default.head(url, config));
return rxjs_1.defer(() => this.instance.head(url, config));
}
post(url, data, config) {
return rxjs_1.from(axios_1.default.post(url, data, config));
return rxjs_1.defer(() => this.instance.post(url, data, config));
}
put(url, data, config) {
return rxjs_1.from(axios_1.default.post(url, data, config));
return rxjs_1.defer(() => this.instance.put(url, data, config));
}
patch(url, data, config) {
return rxjs_1.from(axios_1.default.post(url, data, config));
return rxjs_1.defer(() => this.instance.patch(url, data, config));
}
}
get axiosRef() {
return this.instance;
}
};
HttpService = __decorate([
__param(0, decorators_1.Inject(http_constants_1.AXIOS_INSTANCE_TOKEN)),
__metadata("design:paramtypes", [Object])
], HttpService);
exports.HttpService = HttpService;

View File

@@ -1,9 +1,11 @@
export * from './cache';
export * from './decorators';
export * from './enums';
export { NestModule, INestApplication, INestMicroservice, NestMiddleware, MiddlewareFunction, MiddlewareConsumer, OnModuleInit, ExceptionFilter, WebSocketAdapter, PipeTransform, Paramtype, ArgumentMetadata, OnModuleDestroy, ExecutionContext, CanActivate, RpcExceptionFilter, WsExceptionFilter, NestInterceptor, DynamicModule, INestApplicationContext, HttpServer, Provider, Type, HttpServerFactory, ArgumentsHost, INestExpressApplication, INestFastifyApplication, ForwardReference } from './interfaces';
export * from './interceptors';
export * from './services/logger.service';
export * from './pipes';
export * from './utils';
export * from './exceptions';
export * from './files';
export * from './http';
export { ArgumentMetadata, ArgumentsHost, CanActivate, DynamicModule, ExceptionFilter, ExecutionContext, ForwardReference, HttpServer, HttpServerFactory, INestApplication, INestApplicationContext, INestExpressApplication, INestFastifyApplication, INestMicroservice, MiddlewareConsumer, MiddlewareFunction, NestInterceptor, NestMiddleware, NestModule, OnApplicationBootstrap, OnModuleDestroy, OnModuleInit, Paramtype, PipeTransform, Provider, RpcExceptionFilter, Type, WebSocketAdapter, WsExceptionFilter } from './interfaces';
export * from './pipes';
export * from './serializer';
export * from './services/logger.service';
export * from './utils';

View File

@@ -9,11 +9,13 @@ function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./cache"));
__export(require("./decorators"));
__export(require("./enums"));
__export(require("./interceptors"));
__export(require("./services/logger.service"));
__export(require("./pipes"));
__export(require("./utils"));
__export(require("./exceptions"));
__export(require("./files"));
__export(require("./http"));
__export(require("./pipes"));
__export(require("./serializer"));
__export(require("./services/logger.service"));
__export(require("./utils"));

View File

@@ -0,0 +1,2 @@
import { MulterField, MulterOptions } from '../interfaces/external/multer-options.interface';
export declare function FileFieldsInterceptor(uploadFields: MulterField[], options?: MulterOptions): any;

View File

@@ -0,0 +1,25 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const multer = require("multer");
const component_decorator_1 = require("../decorators/core/component.decorator");
const multer_utils_1 = require("./multer/multer.utils");
function FileFieldsInterceptor(uploadFields, options) {
const Interceptor = component_decorator_1.mixin(class {
constructor() {
this.upload = multer(options);
}
async intercept(context, call$) {
const ctx = context.switchToHttp();
await new Promise((resolve, reject) => this.upload.fields(uploadFields)(ctx.getRequest(), ctx.getResponse(), err => {
if (err) {
const error = multer_utils_1.transformException(err);
return reject(error);
}
resolve();
}));
return call$;
}
});
return Interceptor;
}
exports.FileFieldsInterceptor = FileFieldsInterceptor;

View File

@@ -1,9 +1,2 @@
import { Observable } from 'rxjs';
import { MulterOptions } from '../interfaces/external/multer-options.interface';
import { ExecutionContext } from '../interfaces';
export declare function FilesInterceptor(fieldName: string, maxCount?: number, options?: MulterOptions): {
new (): {
readonly upload: any;
intercept(context: ExecutionContext, call$: Observable<any>): Promise<Observable<any>>;
};
};
export declare function FilesInterceptor(fieldName: string, maxCount?: number, options?: MulterOptions): any;

View File

@@ -1,9 +1,10 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const multer = require("multer");
const component_decorator_1 = require("../decorators/core/component.decorator");
const multer_utils_1 = require("./multer/multer.utils");
function FilesInterceptor(fieldName, maxCount, options) {
const Interceptor = class {
const Interceptor = component_decorator_1.mixin(class {
constructor() {
this.upload = multer(options);
}
@@ -18,7 +19,7 @@ function FilesInterceptor(fieldName, maxCount, options) {
}));
return call$;
}
};
});
return Interceptor;
}
exports.FilesInterceptor = FilesInterceptor;

View File

@@ -1,2 +1,3 @@
export * from './file-fields.interceptor';
export * from './file.interceptor';
export * from './files.interceptor';

View File

@@ -3,5 +3,6 @@ function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./file-fields.interceptor"));
__export(require("./file.interceptor"));
__export(require("./files.interceptor"));

View File

@@ -1,2 +1,2 @@
import { PayloadTooLargeException, BadRequestException } from './../../exceptions';
import { BadRequestException, PayloadTooLargeException } from './../../exceptions';
export declare function transformException(error: Error | undefined): Error | BadRequestException | PayloadTooLargeException;

View File

@@ -0,0 +1,41 @@
/**
* Options to be passed during transformation.
* @see https://github.com/typestack/class-transformer
*/
export interface ClassTransformOptions {
/**
* Exclusion strategy. By default exposeAll is used, which means that it will expose all properties are transformed
* by default.
*/
strategy?: 'excludeAll' | 'exposeAll';
/**
* Only properties with given groups gonna be transformed.
*/
groups?: string[];
/**
* Only properties with "since" > version < "until" gonna be transformed.
*/
version?: number;
/**
* Excludes properties with the given prefixes. For example, if you mark your private properties with "_" and "__"
* you can set this option's value to ["_", "__"] and all private properties will be skipped.
* This works only for "exposeAll" strategy.
*/
excludePrefixes?: string[];
/**
* If set to true then class transformer will ignore all @Expose and @Exclude decorators and what inside them.
* This option is useful if you want to kinda clone your object but do not apply decorators affects.
*/
ignoreDecorators?: boolean;
/**
* Target maps allows to set a Types of the transforming object without using @Type decorator.
* This is useful when you are transforming external classes, or if you already have type metadata for
* objects and you don't want to set it up again.
*/
targetMaps?: any[];
/**
* If set to true then class transformer will perform a circular check. (circular check is turned off by default)
* This option is useful when you know for sure that your types might have a circular dependency.
*/
enableCircularCheck?: boolean;
}

View File

@@ -0,0 +1,2 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });

View File

@@ -49,3 +49,9 @@ export interface MulterOptions {
buffer: Buffer;
}, callback: (error: Error | null, acceptFile: boolean) => void): void;
}
export interface MulterField {
/** The field name. */
name: string;
/** Optional maximum number of files per field to accept. */
maxCount?: number;
}

View File

@@ -57,4 +57,8 @@ export interface ServeStaticOptions {
* stat the stat object of the file that is being sent
*/
setHeaders?: (res, path: string, stat: any) => any;
/**
* Creates a virtual path prefix
*/
prefix?: string;
}

View File

@@ -39,4 +39,8 @@ export interface ValidatorOptions {
*/
value?: boolean;
};
/**
* Setting true will cause fail validation of unknown objects.
*/
forbidUnknownValues?: boolean;
}

View File

@@ -1 +1 @@
export declare type CustomParamFactory = (data, req) => any;
export declare type CustomParamFactory<TData = any, TRequest = any, TResult = any> = (data: TData, req: TRequest) => TResult;

View File

@@ -1,5 +1,6 @@
/// <reference types="node" />
import { IncomingMessage, ServerResponse } from 'http';
import { RequestMethod } from '../../enums';
export declare type ErrorHandler = (error: any, req: Partial<IncomingMessage>, res: ServerResponse | any, next?: Function) => any;
export declare type RequestHandler = (req: Partial<IncomingMessage>, res: ServerResponse | any, next?: Function) => any;
export interface HttpServer {
@@ -29,8 +30,10 @@ export interface HttpServer {
useStaticAssets?(...args: any[]): this;
setBaseViewsDir?(path: string): this;
setViewEngine?(engineOrOptions: any): this;
createMiddlewareFactory(method: RequestMethod): (path: string, callback: Function) => any;
getRequestMethod?(request: any): string;
getRequestUrl?(request: any): string;
getInstance(): any;
getHttpServer(): any;
close(): any;
}

View File

@@ -1,33 +1,32 @@
export * from './request-mapping-metadata.interface';
export * from './modules/nest-module.interface';
export * from './modules/module-metadata.interface';
export * from './controllers/controller.interface';
export * from './injectable.interface';
export * from './controllers/controller-metadata.interface';
export * from './modules/module-metadata.interface';
export * from './type.interface';
export * from './nest-application.interface';
export * from './nest-microservice.interface';
export * from './nest-application-context.interface';
export * from './modules/on-init.interface';
export * from './modules/on-destroy.interface';
export * from './controllers/controller.interface';
export * from './exceptions/exception-filter.interface';
export * from './middleware';
export * from './websockets/web-socket-adapter.interface';
export * from './features/pipe-transform.interface';
export * from './features/paramtype.interface';
export * from './features/can-activate.interface';
export * from './exceptions/rpc-exception-filter.interface';
export * from './exceptions/ws-exception-filter.interface';
export * from './features/arguments-host.interface';
export * from './features/can-activate.interface';
export * from './features/custom-route-param-factory.interface';
export * from './features/execution-context.interface';
export * from './features/nest-interceptor.interface';
export * from './features/custom-route-param-factory.interface';
export * from './modules/dynamic-module.interface';
export * from './http/http-server.interface';
export * from './features/paramtype.interface';
export * from './features/pipe-transform.interface';
export * from './http/http-server-factory.interface';
export * from './features/arguments-host.interface';
export * from './http/http-server.interface';
export * from './injectable.interface';
export * from './middleware';
export * from './modules/dynamic-module.interface';
export * from './modules/forward-reference.interface';
export * from './modules/module-metadata.interface';
export * from './modules/nest-module.interface';
export * from './modules/on-destroy.interface';
export * from './modules/on-init.interface';
export * from './modules/provider.interface';
export * from './nest-application-context.interface';
export * from './nest-application.interface';
export * from './nest-express-application.interface';
export * from './nest-fastify-application.interface';
export * from './modules/provider.interface';
export * from './nest-microservice.interface';
export * from './on-application-bootstrap.interface';
export * from './request-mapping-metadata.interface';
export * from './type.interface';
export * from './modules/forward-reference.interface';
export * from './websockets/web-socket-adapter.interface';

View File

@@ -1,6 +1,6 @@
import { Transport } from '../../enums/transport.enum';
import { CustomTransportStrategy } from './custom-transport-strategy.interface';
import { MqttClientOptions } from '../external/mqtt-options.interface';
import { CustomTransportStrategy } from './custom-transport-strategy.interface';
export declare type MicroserviceOptions = GrpcOptions | TcpOptions | RedisOptions | NatsOptions | MqttOptions | CustomStrategy;
export interface CustomStrategy {
strategy?: CustomTransportStrategy;
@@ -13,6 +13,21 @@ export interface GrpcOptions {
credentials?: any;
protoPath: string;
package: string;
/** @deprecated */
root?: string;
loader?: {
keepCase?: boolean;
alternateCommentMode?: boolean;
longs?: Function;
enums?: Function;
bytes?: Function;
defaults?: boolean;
arrays?: boolean;
objects?: boolean;
oneofs?: boolean;
json?: boolean;
includeDirs?: string[];
};
};
}
export interface TcpOptions {

View File

@@ -1,19 +1,28 @@
import { MiddlewareConsumer } from './middleware-consumer.interface';
import { Type } from '../type.interface';
import { RouteInfo } from './middleware-configuration.interface';
import { MiddlewareConsumer } from './middleware-consumer.interface';
export interface MiddlewareConfigProxy {
/**
* Passes custom arguments to `resolve()` method of the middleware.
* Delegates custom arguments to the `resolve()` method of the middleware.
*
* @param {} ...data
* @returns {MiddlewareConfigProxy}
*/
with(...data: any[]): MiddlewareConfigProxy;
/**
* Attaches passed either routes (strings) or controllers to the processed middleware(s).
* When you pass Controller class Nest will attach middleware to every path defined within this controller.
* Excludes routes from the currently processed middleware.
* This excluded route has to use an exact same route path.
*
* @param {} ...routes
* @returns {MiddlewareConfigProxy}
*/
exclude(...routes: (string | RouteInfo)[]): MiddlewareConfigProxy;
/**
* Attaches passed either routes or controllers to the currently configured middleware.
* If you pass a class, Nest would attach middleware to every path defined within this controller.
*
* @param {} ...routes
* @returns {MiddlewareConsumer}
*/
forRoutes(...routes: (string | Type<any>)[]): MiddlewareConsumer;
forRoutes(...routes: (string | Type<any> | RouteInfo)[]): MiddlewareConsumer;
}

View File

@@ -1,5 +1,10 @@
import { RequestMethod } from '../../enums';
import { Type } from '../type.interface';
export interface MiddlewareConfiguration {
middleware: any;
forRoutes: (Type<any> | string)[];
export interface RouteInfo {
path: string;
method: RequestMethod;
}
export interface MiddlewareConfiguration<T = any> {
middleware: T;
forRoutes: (Type<any> | string | RouteInfo)[];
}

View File

@@ -1,11 +1,12 @@
import { Type } from '../type.interface';
import { MiddlewareConfigProxy } from './middleware-config-proxy.interface';
export interface MiddlewareConsumer {
/**
* Takes single middleware class or array of classes
* that subsequently could be attached to the passed either routes or controllers.
* Takes either middleware class/function or array of classes/functions
* that subsequently shall be attached to the passed routes.
*
* @param {any|any[]} middleware
* @returns {MiddlewareConfigProxy}
*/
apply(middleware: any | any[]): MiddlewareConfigProxy;
apply(...middleware: (Type<any> | Function)[]): MiddlewareConfigProxy;
}

View File

@@ -1 +1 @@
export declare type MiddlewareFunction = (req?, res?, next?) => any;
export declare type MiddlewareFunction<TRequest = any, TResponse = any, TResult = any> = (req?: TRequest, res?: TResponse, next?: Function) => TResult;

View File

@@ -1,14 +1,14 @@
import { DynamicModule } from './dynamic-module.interface';
import { Type } from '../type.interface';
import { Provider } from './provider.interface';
import { DynamicModule } from './dynamic-module.interface';
import { ForwardReference } from './forward-reference.interface';
import { Provider } from './provider.interface';
export interface ModuleMetadata {
imports?: Array<Type<any> | DynamicModule | ForwardReference>;
imports?: Array<Type<any> | DynamicModule | Promise<DynamicModule> | ForwardReference>;
controllers?: Type<any>[];
providers?: Provider[];
exports?: Array<DynamicModule | string | Provider | ForwardReference>;
exports?: Array<DynamicModule | Promise<DynamicModule> | string | Provider | ForwardReference>;
/** @deprecated */
modules?: Array<Type<any> | DynamicModule | ForwardReference>;
modules?: Array<Type<any> | DynamicModule | Promise<DynamicModule> | ForwardReference>;
/** @deprecated */
components?: Provider[];
}

View File

@@ -1,3 +1,4 @@
import { LoggerService } from './../services/logger.service';
import { Type } from './type.interface';
export interface INestApplicationContext {
/**
@@ -7,9 +8,19 @@ export interface INestApplicationContext {
select<T>(module: Type<T>): INestApplicationContext;
/**
* Retrieves an instance of either injectable or controller available anywhere, otherwise, throws exception.
* @returns {T}
* @returns {TResult}
*/
get<T>(typeOrToken: Type<T> | string | symbol, options?: {
get<TInput = any, TResult = TInput>(typeOrToken: Type<TInput> | string | symbol, options?: {
strict: boolean;
}): T;
}): TResult;
/**
* Terminates the application
* @returns {Promise<void>}
*/
close(): Promise<void>;
/**
* Sets custom logger service
* @returns {void}
*/
useLogger(logger: LoggerService): any;
}

Some files were not shown because too many files have changed in this diff Show More