154 Commits

Author SHA1 Message Date
9eedd5afbd chore: add semantic-release
close #153
2021-07-23 23:15:52 +02:00
dff86f7bda build(deps): bump jest from 26.6.3 to 27.0.6
close #128
2021-07-23 23:00:25 +02:00
a41881744a fix(types): onAuthorization can return a string 2021-07-23 22:54:07 +02:00
15f5c60b27 build(deps-dev): bump @types/node to 16.4.1 (#171) 2021-07-23 08:49:11 +02:00
56fb31edf6 build(deps-dev): bump markdownlint-cli from 0.27.1 to 0.28.1 (#172) 2021-07-23 08:34:29 +02:00
c08c431e6a build(deps): bump wagoid/commitlint-github-action to 4.1.1 (#167) 2021-07-22 08:07:00 +02:00
4ae9f519c5 build(deps): bump codecov/codecov-action from 1.5.2 to 2.0.1 (#168) 2021-07-22 08:06:17 +02:00
e4dcdf9928 build(deps): bump actions/setup-node from 2.2.0 to 2.3.0 (#169) 2021-07-22 08:05:56 +02:00
f08a6e4f62 build(deps-dev): bump socket.io-client from 4.1.2 to 4.1.3 (#161) 2021-07-18 00:33:11 +02:00
18df1dd19f build(deps-dev): bump socket.io from 4.1.2 to 4.1.3 (#162) 2021-07-16 23:25:29 +02:00
86cac11108 build(deps): bump wagoid/commitlint-github-action to 4.0.2 (#165) 2021-07-16 23:25:14 +02:00
170ad34da3 build(deps-dev): bump @types/jsonwebtoken from 8.5.3 to 8.5.4 (#155) 2021-07-07 21:40:27 +02:00
b5460b95ee build(deps-dev): bump @types/express from 4.17.12 to 4.17.13 (#156) 2021-07-07 21:40:16 +02:00
b1ab84e610 build(deps-dev): bump husky from 7.0.0 to 7.0.1 (#157) 2021-07-07 21:40:03 +02:00
b56248919e build(deps-dev): bump @types/jsonwebtoken to 8.5.3 (#152) 2021-07-02 10:19:49 +02:00
464381813f build(deps-dev): bump husky from 6.0.0 to 7.0.0 (#149) 2021-07-01 09:33:45 +02:00
6dc3696910 build(deps): bump actions/setup-node from 2.1.5 to 2.2.0 (#148) 2021-07-01 09:27:46 +02:00
e500fd3862 build(deps-dev): bump typescript to 4.3.5 (#150) 2021-07-01 09:03:53 +02:00
30aea8120a build(deps-dev): bump @types/jsonwebtoken to 8.5.2 (#142) 2021-06-23 13:30:42 +02:00
87d3af481e build(deps-dev): bump release-it to 14.10.0 (#144) 2021-06-23 13:30:25 +02:00
8867b9914e build(deps-dev): bump @release-it/conventional-changelog to 3.0.1 (#137) 2021-06-18 18:35:18 +02:00
8ae78c6732 build(deps-dev): bump typescript to 4.3.4 (#140) 2021-06-18 18:34:30 +02:00
def5b56184 build(deps-dev): bump release-it from 14.8.0 to 14.9.0 (#138)
Bumps [release-it](https://github.com/release-it/release-it) from 14.8.0 to 14.9.0.
- [Release notes](https://github.com/release-it/release-it/releases)
- [Changelog](https://github.com/release-it/release-it/blob/master/CHANGELOG.md)
- [Commits](https://github.com/release-it/release-it/compare/14.8.0...14.9.0)

---
updated-dependencies:
- dependency-name: release-it
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2021-06-15 23:34:11 +02:00
983d18ee09 build(deps): bump codecov/codecov-action from 1.5.0 to 1.5.2 (#136) 2021-06-12 22:03:42 +02:00
16f632d1b4 build(deps-dev): bump release-it from 14.7.0 to 14.8.0 (#134) 2021-06-12 22:03:31 +02:00
65bc3314cc chore: ci pass again (update jest later) 2021-05-28 10:13:00 +02:00
d6bd5e5cd7 build(deps-dev): bump typescript from 4.2.4 to 4.3.2 (#126) 2021-05-28 09:18:22 +02:00
96a41659bd build(deps): bump actions/cache from 2.1.5 to 2.1.6 (#127) 2021-05-28 09:18:03 +02:00
e5fca7e5ee build(deps-dev): bump jest from 26.6.3 to 27.0.1 (#123) 2021-05-26 18:45:48 +02:00
da40d6b1fd build(deps-dev): bump @types/express from 4.17.11 to 4.17.12 (#124) 2021-05-26 18:45:33 +02:00
219094da40 build(deps-dev): bump release-it from 14.6.2 to 14.7.0 (#122) 2021-05-25 18:07:56 +02:00
6361bd8782 build(deps-dev): bump @types/node from 15.6.0 to 15.6.1 (#121) 2021-05-25 18:07:33 +02:00
59efee7c37 build(deps-dev): bump @types/node from 15.3.1 to 15.6.0 (#120) 2021-05-24 11:29:11 +02:00
07c96e876b build(deps-dev): bump @types/node to 15.3.1 (#119) 2021-05-20 15:02:21 +02:00
ae08cc6e65 build(deps-dev): bump socket.io from 4.1.1 to 4.1.2 (#117) 2021-05-20 15:02:03 +02:00
3bae2e2bbf build(deps): bump wagoid/commitlint-github-action to 3.1.4 (#118) 2021-05-20 15:01:46 +02:00
47e69050e5 build(deps-dev): bump socket.io-client from 4.1.1 to 4.1.2 (#116) 2021-05-19 19:58:38 +02:00
9851fb319d build(deps-dev): bump @types/node from 15.0.3 to 15.3.0 (#115) 2021-05-17 16:29:51 +02:00
73fc64b9e5 build(deps-dev): bump @commitlint/cli from 12.1.1 to 12.1.4 (#112) 2021-05-15 15:59:19 +02:00
e300799e99 build(deps-dev): bump @commitlint/config-conventional (#114) 2021-05-13 13:37:14 +02:00
f6755c7d12 build(deps-dev): bump @types/node from 15.0.2 to 15.0.3 (#113) 2021-05-13 13:37:01 +02:00
5e16b06575 build(deps-dev): bump socket.io from 4.1.0 to 4.1.1 (#111) 2021-05-13 13:36:49 +02:00
a5468fdfae build(deps-dev): bump socket.io-client from 4.1.0 to 4.1.1 (#110) 2021-05-12 16:41:27 +02:00
4b86c778bf build(deps): bump codecov/codecov-action from 1 to 1.5.0 (#108) 2021-05-12 16:41:17 +02:00
a14e6e5ab1 build(deps): bump actions/checkout from 2 to 2.3.4 (#109) 2021-05-12 16:41:03 +02:00
927f021941 build(deps-dev): bump socket.io from 4.0.1 to 4.1.0 (#107) 2021-05-11 21:18:26 +02:00
344f71ced1 build(deps-dev): bump socket.io-client from 4.0.1 to 4.1.0 (#106) 2021-05-11 21:02:35 +02:00
3ce4b14d03 build(deps-dev): bump release-it from 14.6.1 to 14.6.2 (#103) 2021-05-11 18:29:05 +02:00
d11cbc3ffb build(deps): bump wagoid/commitlint-github-action from v3.1.0 to v3.1.3 (#105) 2021-05-11 18:28:53 +02:00
31ba9b48b5 build(deps-dev): bump ts-jest from 26.5.5 to 26.5.6 (#100) 2021-05-11 18:28:37 +02:00
88eba43f83 build(deps-dev): bump @types/node from 15.0.1 to 15.0.2 (#99) 2021-05-11 18:28:27 +02:00
9330edd3bc build(deps-dev): bump @types/node from 15.0.0 to 15.0.1 (#97) 2021-05-03 19:25:44 +02:00
2412e2e5fc build(deps-dev): bump @types/jest from 26.0.22 to 26.0.23 (#95) 2021-04-27 09:32:05 +02:00
7cfab50330 build(deps-dev): bump @types/node from 14.14.41 to 15.0.0 (#96) 2021-04-27 09:31:54 +02:00
644e3a52b7 build(deps-dev): bump ts-jest from 26.5.4 to 26.5.5 (#91) 2021-04-18 22:03:14 +02:00
1f912feda1 build(deps-dev): bump @types/node from 14.14.39 to 14.14.41 (#92) 2021-04-18 22:02:59 +02:00
6dcb8cbd49 build(deps-dev): bump @types/node from 14.14.37 to 14.14.39 (#90) 2021-04-15 18:17:33 +02:00
a93271bcec build(deps-dev): bump release-it from 14.5.1 to 14.6.1 (#88) 2021-04-14 14:10:38 +02:00
68e02a6ad5 build(deps): bump actions/cache from v2.1.4 to v2.1.5 (#89) 2021-04-14 14:10:26 +02:00
efb2b72572 build(deps-dev): bump typescript from 4.2.3 to 4.2.4 (#87) 2021-04-08 10:04:03 +02:00
4c869ba0ea build(deps): bump wagoid/commitlint-github-action from v3.0.8 to v3.1.0 (#86) 2021-04-07 19:36:16 +02:00
79c88b928b build(deps): bump wagoid/commitlint-github-action from v3.0.7 to v3.0.8 (#85) 2021-04-05 10:18:27 +02:00
f0f58630d9 build(deps-dev): bump @commitlint/config-conventional (#81) 2021-04-03 09:55:26 +02:00
cf81ca58fc build(deps-dev): bump @commitlint/cli from 12.0.1 to 12.1.1 (#82) 2021-04-03 09:53:19 +02:00
1255f7545e build(deps-dev): bump release-it from 14.5.0 to 14.5.1 (#83) 2021-04-03 09:53:08 +02:00
8570861d16 build(deps-dev): bump socket.io-client from 4.0.0 to 4.0.1 (#79) 2021-04-03 09:52:57 +02:00
f90cddc4a4 build(deps): bump wagoid/commitlint-github-action from v3.0.6 to v3.0.7 (#84) 2021-04-03 09:52:41 +02:00
f260bc793b build(deps-dev): bump socket.io from 4.0.0 to 4.0.1 (#78) 2021-04-01 13:24:20 +02:00
089ca1b67e build(deps-dev): bump editorconfig-checker from 4.0.1 to 4.0.2 (#80) 2021-04-01 13:24:04 +02:00
6696d1fa0a build(deps-dev): bump husky from 5.2.0 to 6.0.0 (#76) 2021-03-29 18:58:23 +02:00
d4d4adac31 build(deps-dev): bump @types/node from 14.14.36 to 14.14.37 (#77) 2021-03-29 18:58:10 +02:00
c8723a736e build(deps-dev): bump @types/node from 14.14.35 to 14.14.36 (#75) 2021-03-27 15:04:27 +01:00
38a5036623 build(deps-dev): bump @types/jest from 26.0.21 to 26.0.22 (#74) 2021-03-27 15:04:13 +01:00
f1866e290d build(deps-dev): bump release-it from 14.4.1 to 14.5.0 (#72) 2021-03-23 10:39:21 +01:00
47d74534ea build(deps-dev): bump husky from 5.1.3 to 5.2.0 (#73) 2021-03-23 10:39:04 +01:00
0d0109be52 chore: add editorconfig-checker 2021-03-19 14:07:21 +01:00
85953cdcce build(deps-dev): bump ts-jest from 26.5.3 to 26.5.4 (#70) 2021-03-18 16:31:12 +01:00
da2be10ed4 build(deps-dev): bump @types/jest from 26.0.20 to 26.0.21 (#71) 2021-03-18 16:30:58 +01:00
1bb3e0174f build(deps-dev): bump @types/jsonwebtoken from 8.5.0 to 8.5.1 (#69) 2021-03-17 18:26:01 +01:00
a20ead358c build(deps-dev): bump @types/node from 14.14.34 to 14.14.35 (#68) 2021-03-17 18:25:06 +01:00
215593c6d6 build(deps-dev): bump @types/node from 14.14.33 to 14.14.34 (#67) 2021-03-15 19:09:26 +01:00
7380635760 build(deps-dev): bump socket.io-client from 3.1.2 to 4.0.0 (#66) 2021-03-11 16:09:32 +01:00
7f7dda651b build(deps-dev): bump socket.io from 3.1.2 to 4.0.0 (#65) 2021-03-11 16:05:38 +01:00
2512c046d2 build(deps-dev): bump @types/node from 14.14.32 to 14.14.33 (#64) 2021-03-10 14:24:11 +01:00
88bfd46c33 chore(release): v2.1.0 2021-03-08 14:37:14 +01:00
4b95cd4293 chore: improve config files 2021-03-08 14:33:53 +01:00
c7f64a6312 feat: add optional onAuthentication option to add user property in socket object (#62) 2021-03-08 14:10:42 +01:00
89518a45d5 build(deps-dev): bump @types/node from 14.14.31 to 14.14.32 (#63) 2021-03-08 13:45:56 +01:00
a5da945bb5 build(deps-dev): bump typescript from 4.2.2 to 4.2.3 (#61) 2021-03-05 14:48:27 +01:00
ce798241e5 build(deps-dev): bump ts-jest from 26.5.2 to 26.5.3 (#59) 2021-03-04 12:32:10 +01:00
8dfddbd5b4 build(deps): bump wagoid/commitlint-github-action from v3.0.1 to v3.0.6 (#58) 2021-03-03 13:21:11 +01:00
e353d2a1fe build(deps-dev): bump markdownlint-cli from 0.27.0 to 0.27.1 (#57) 2021-03-03 13:20:58 +01:00
5a02e25f86 build(deps-dev): bump markdownlint-cli from 0.26.0 to 0.27.0 (#55) 2021-03-02 11:44:26 +01:00
f9678604cc build(deps-dev): bump husky from 5.1.2 to 5.1.3 (#56) 2021-03-02 11:41:42 +01:00
c5121fb008 build(deps-dev): bump @commitlint/config-conventional (#54) 2021-03-01 11:40:39 +01:00
95e461540a build(deps-dev): bump @commitlint/cli from 12.0.0 to 12.0.1 (#52) 2021-03-01 11:37:06 +01:00
7687ddfe83 build(deps-dev): bump husky from 5.1.1 to 5.1.2 (#53) 2021-03-01 11:36:53 +01:00
565f83db9d ci(commitlint): add configFile 2021-02-26 11:02:14 +01:00
6953d6952b build(deps-dev): bump socket.io from 3.1.1 to 3.1.2 (#51) 2021-02-26 10:56:11 +01:00
3d109f362f build(deps-dev): bump socket.io-client from 3.1.1 to 3.1.2 (#50) 2021-02-26 10:55:31 +01:00
ced2f5db1e build(deps): bump wagoid/commitlint-github-action from v2 to v3 (#49) 2021-02-25 07:55:53 +01:00
0971dcc1bb build(deps-dev): bump ts-jest from 26.5.1 to 26.5.2 (#47) 2021-02-24 12:57:00 +01:00
a710630ccf build(deps-dev): bump typescript from 4.1.5 to 4.2.2 (#48) 2021-02-24 12:56:37 +01:00
e50e7ea00e build(deps-dev): bump @release-it/conventional-changelog (#45) 2021-02-23 11:11:26 +01:00
cff7892c3d build(deps-dev): bump husky from 5.1.0 to 5.1.1 (#44) 2021-02-23 11:11:08 +01:00
17232c18e1 build(deps-dev): bump pinst from 2.1.4 to 2.1.6 (#46) 2021-02-23 11:10:52 +01:00
8f896eb93b build(deps-dev): bump @commitlint/cli from 11.0.0 to 12.0.0 (#43) 2021-02-23 11:09:59 +01:00
814fc781e3 build(deps-dev): bump @commitlint/config-conventional (#42) 2021-02-23 11:09:19 +01:00
4291da1417 build(deps): update actions/setup-node requirement to v2.1.5 (#41) 2021-02-23 11:09:02 +01:00
ad86800d8c chore(release): v2.0.0 2021-02-22 13:07:40 +01:00
a14d4e937b feat: usage of auth option to send credentials
BREAKING CHANGE: extraHeaders with Authorization doesn't work anymore

See: https://socket.io/docs/v3/middlewares/#Sending-credentials
2021-02-22 13:00:53 +01:00
4ba3e3bccb build(deps-dev): bump @types/node from 14.14.30 to 14.14.31 (#38) 2021-02-22 11:09:41 +01:00
907b82fca9 build(deps-dev): bump release-it from 14.4.0 to 14.4.1 (#40) 2021-02-22 11:09:26 +01:00
4c469169f4 build(deps-dev): bump husky from 5.0.9 to 5.1.0 (#39) 2021-02-22 11:09:01 +01:00
d5f402df86 build(deps-dev): bump @types/node from 14.14.28 to 14.14.30 (#36) 2021-02-19 09:24:50 +01:00
d01bcc29fa docs: add authorize options 2021-02-18 20:14:56 +01:00
55a5f71b6e build(deps-dev): bump @types/node from 14.14.27 to 14.14.28 (#35) 2021-02-15 14:00:04 +01:00
7ccdb8f9a0 chore: general improvements of config files 2021-02-14 19:28:15 +01:00
b61ddd1872 build(deps-dev): bump @types/node from 14.14.25 to 14.14.26 (#33) 2021-02-12 09:14:26 +01:00
ac3b5177e5 build(deps-dev): bump typescript from 4.1.4 to 4.1.5 (#32) 2021-02-11 09:58:40 +01:00
0e8630d145 build(deps-dev): bump ts-jest from 26.5.0 to 26.5.1 (#30) 2021-02-10 12:20:15 +01:00
bb1daa2e28 build(deps-dev): bump typescript from 4.1.3 to 4.1.4 (#31) 2021-02-10 12:19:50 +01:00
17d7f264a4 build(deps-dev): bump husky from 4.3.8 to 5.0.9 (#29) 2021-02-09 20:22:40 +01:00
7f1c25ed98 build(deps): bump actions/cache from v2 to v2.1.4 (#28) 2021-02-08 14:57:20 +01:00
d9fa92cb1c build(deps-dev): bump @types/node from 14.14.22 to 14.14.25 (#27) 2021-02-04 14:36:58 +01:00
b08354f2b2 build(deps-dev): bump socket.io from 3.1.0 to 3.1.1 (#26) 2021-02-04 13:37:42 +01:00
06141ec89d build(deps-dev): bump @types/node from 14.14.22 to 14.14.24 (#25) 2021-02-04 13:37:00 +01:00
113df6f8f7 build(deps-dev): bump release-it from 14.2.2 to 14.3.0 (#24) 2021-02-04 13:36:26 +01:00
a761725e6b build(deps-dev): bump socket.io-client from 3.1.0 to 3.1.1 (#23) 2021-02-04 13:36:00 +01:00
f5a13c01b0 build(deps-dev): bump ts-jest from 26.4.4 to 26.5.0 (#22) 2021-02-01 18:16:22 +01:00
5e3f5c1871 chore(release): v1.1.1 2021-01-28 19:16:53 +01:00
af7ff4e8d9 test: fix typings in fixture keySecret 2021-01-28 19:12:46 +01:00
959652b3d3 docs(readme): key.getPublicKey() with jwks-rsa 2021-01-28 18:53:56 +01:00
c1a9213a52 fix(types): decodedToken in secret callback
close #21
2021-01-28 18:47:38 +01:00
4d73584e4e build(deps-dev): bump @types/node from 14.14.21 to 14.14.22 (#20) 2021-01-20 10:47:39 +01:00
486aab1ded build(deps-dev): bump husky from 4.3.7 to 4.3.8 (#19) 2021-01-18 14:19:07 +01:00
6d593ff804 build(deps-dev): bump @types/node from 14.14.20 to 14.14.21 (#18) 2021-01-15 09:10:23 +01:00
5fc5d73752 build(deps-dev): bump socket.io-client from 3.0.5 to 3.1.0 (#17) 2021-01-15 09:10:03 +01:00
a38975ca49 build(deps-dev): bump socket.io from 3.0.5 to 3.1.0 (#16) 2021-01-15 09:09:20 +01:00
cb2cc8c074 build(deps-dev): bump @types/express from 4.17.10 to 4.17.11 (#15) 2021-01-13 11:26:07 +01:00
b7e1fcde6d build(deps-dev): bump @types/express from 4.17.9 to 4.17.10 (#13) 2021-01-12 08:37:56 +01:00
fd79d99235 chore(release): v1.1.0 2021-01-07 14:32:55 +01:00
261e8d66e2 feat: add support for jwks-rsa (#1) 2021-01-07 14:30:37 +01:00
ca83ad4ba2 build(deps-dev): bump husky from 4.3.6 to 4.3.7 (#11) 2021-01-07 11:47:55 +01:00
6d0f23ef31 chore: fix package.json syntax error 2021-01-07 05:45:46 +01:00
8c8d38fd69 build(deps-dev): bump socket.io-client from 3.0.4 to 3.0.5 (#9) 2021-01-06 19:07:15 +01:00
544801d8ba build(deps-dev): bump socket.io from 3.0.4 to 3.0.5 (#8) 2021-01-06 19:06:38 +01:00
0c68ada2b1 build(deps-dev): bump @types/node from 14.14.19 to 14.14.20 (#7) 2021-01-05 08:32:12 +01:00
b0c0cf6ee0 build(deps-dev): bump @types/node from 14.14.17 to 14.14.19 (#5) 2021-01-04 14:36:25 +01:00
84b523f434 feat: improve types by extending socket.io module (#6) 2021-01-04 14:35:59 +01:00
abc1225189 docs: update code of conduct link 2021-01-02 18:35:26 +01:00
e87a335064 chore: ts-standard linting in scripts 2021-01-01 04:42:06 +01:00
89bfd83cfc build(deps-dev): bump @types/node from 14.14.16 to 14.14.17 (#2) 2020-12-31 13:11:15 +01:00
abbabc588e feat: add algorithms option 2020-12-30 14:50:56 +01:00
35 changed files with 25532 additions and 291 deletions

1
.commitlintrc.json Normal file
View File

@ -0,0 +1 @@
{ "extends": ["@commitlint/config-conventional"] }

View File

@ -1,6 +1,7 @@
---
name: '🐛 Bug Report'
about: 'Report an unexpected problem or unintended behavior.'
title: '[Bug]'
labels: 'bug'
---

View File

@ -1,20 +1,18 @@
---
name: '📜 Documentation'
about: 'Correct spelling errors, improvements or additions to documentation files (README, CONTRIBUTING...).'
title: '[Documentation]'
labels: 'documentation'
---
<!--
Please make sure your issue has not already been fixed.
<!-- Please make sure your issue has not already been fixed. -->
Please place an x (no spaces - [x]) in all [ ] that apply.
-->
## Documentation
### Documentation :
<!-- Please uncomment the type of documentation problem this issue address -->
- [ ] Is Missing
- [ ] Is Confusing
- [ ] Has Typo errors
- [ ] Not Sure?
<!-- Documentation is Missing -->
<!-- Documentation is Confusing -->
<!-- Documentation has Typo errors -->
### Proposal
## Proposal

View File

@ -1,19 +1,20 @@
---
name: '✨ Feature Request'
about: 'Suggest a new feature idea.'
title: '[Feature]'
labels: 'feature request'
---
<!-- Please make sure your issue has not already been fixed. -->
### Description
## Description
<!-- A clear and concise description of the problem or missing capability... -->
### Describe the solution you'd like
## Describe the solution you'd like
<!-- If you have a solution in mind, please describe it. -->
### Describe alternatives you've considered
## Describe alternatives you've considered
<!-- Have you considered any alternative solutions or workarounds? -->

View File

@ -1,21 +1,20 @@
---
name: '🔧 Improvement'
about: 'Improve structure/format/performance/refactor/tests of the code.'
title: '[Improvement]'
labels: 'improvement'
---
<!--
Please make sure your issue has not already been fixed.
<!-- Please make sure your issue has not already been fixed. -->
Please place an x (no spaces - [x]) in all [ ] that apply.
-->
## Type of Improvement
### Type of Improvement :
<!-- Please uncomment the type of improvements this issue address -->
- [ ] Files and Folders Structure
- [ ] Performance
- [ ] Refactoring code
- [ ] Tests
- [ ] Not Sure?
<!-- Files and Folders Structure -->
<!-- Performance -->
<!-- Refactoring code -->
<!-- Tests -->
<!-- Not Sure? -->
### Proposal
## Proposal

View File

@ -1,6 +1,7 @@
---
name: '🙋 Question'
about: 'Further information is requested.'
title: '[Question]'
labels: 'question'
---

View File

@ -1,27 +1,7 @@
<!--
<!-- Please first discuss the change you wish to make via issue before making a change. It might avoid a waste of your time. -->
Please first discuss the change you wish to make via issue before making a change. It might avoid a waste of your time.
## What changes this PR introduce?
Before submitting your contribution, please take a moment to review this document:
https://github.com/Thream/socketio-jwt/blob/master/.github/CONTRIBUTING.md
## List any relevant issue numbers
Please place an x (no spaces - [x]) in all [ ] that apply.
-->
### What type of change does this PR introduce?
- [ ] Bugfix
- [ ] Feature
- [ ] Refactor
- [ ] Documentation
- [ ] Not Sure?
### Does this PR introduce breaking changes?
- [ ] Yes
- [ ] No
### List any relevant issue numbers:
### Description:
## Is there anything you'd like reviewers to focus on?

View File

@ -1,5 +1,3 @@
# For more information see: https://docs.github.com/en/github/administering-a-repository/configuration-options-for-dependency-updates
version: 2
updates:
- package-ecosystem: 'github-actions'

25
.github/workflows/build.yml vendored Normal file
View File

@ -0,0 +1,25 @@
name: 'Build'
on:
push:
branches: [master, develop]
pull_request:
branches: [master, develop]
jobs:
build:
runs-on: 'ubuntu-latest'
steps:
- uses: 'actions/checkout@v2'
- name: 'Use Node.js'
uses: 'actions/setup-node@v2.3.0'
with:
node-version: '16.x'
cache: 'npm'
- name: 'Install'
run: 'npm install'
- name: 'Build Package'
run: 'npm run build'

View File

@ -1,20 +0,0 @@
# For more information see: https://github.com/marketplace/actions/commit-linter
name: 'Lint Commit Messages'
on:
push:
branches: [master, develop]
pull_request_review:
branches: [master, develop]
types: [submitted]
jobs:
commitlint:
if: ${{ (github.event_name == 'push') || (github.event_name == 'pull_request_review' && github.event.review.state == 'approved' && (github.event.review.author_association == 'COLLABORATOR' || github.event.review.author_association == 'MEMBER' || github.event.review.author_association == 'OWNER') && !github.event.pull_request.draft && github.event.pull_request.state == 'open') }}
runs-on: ubuntu-latest
steps:
- uses: 'actions/checkout@v2'
with:
fetch-depth: 0
- uses: 'wagoid/commitlint-github-action@v2'

27
.github/workflows/lint.yml vendored Normal file
View File

@ -0,0 +1,27 @@
name: 'Lint'
on:
push:
branches: [master, develop]
pull_request:
branches: [master, develop]
jobs:
lint:
runs-on: 'ubuntu-latest'
steps:
- uses: 'actions/checkout@v2'
- name: 'Use Node.js'
uses: 'actions/setup-node@v2.3.0'
with:
node-version: '16.x'
cache: 'npm'
- name: 'Install'
run: 'npm install'
- run: 'npm run lint:commit -- --to "${{ github.sha }}"'
- run: 'npm run lint:editorconfig'
- run: 'npm run lint:markdown'
- run: 'npm run lint:typescript'

View File

@ -1,47 +0,0 @@
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
name: 'Node.js CI'
on:
push:
branches: [master, develop]
pull_request_review:
branches: [master, develop]
types: [submitted]
jobs:
ci_app:
if: ${{ (github.event_name == 'push') || (github.event_name == 'pull_request_review' && github.event.review.state == 'approved' && (github.event.review.author_association == 'COLLABORATOR' || github.event.review.author_association == 'MEMBER' || github.event.review.author_association == 'OWNER') && !github.event.pull_request.draft && github.event.pull_request.state == 'open') }}
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [14.x]
steps:
- uses: 'actions/checkout@v2'
- name: Use Node.js ${{ matrix.node-version }}
uses: 'actions/setup-node@v2.1.4'
with:
node-version: ${{ matrix.node-version }}
- name: 'Cache dependencies'
uses: 'actions/cache@v2'
with:
path: |
**/node_modules
key: ${{ runner.os }}-${{ hashFiles('**/package.json') }}
- name: 'Install dependencies'
run: 'npm install'
- name: 'Lint'
run: 'npm run lint'
- name: 'Build'
run: 'npm run build'
- name: 'Run the tests and generate coverage report'
run: 'npm test'
- name: 'Upload coverage to Codecov'
uses: 'codecov/codecov-action@v1'

View File

@ -1,30 +0,0 @@
# For more information see: https://help.github.com/actions/language-and-framework-guides/publishing-nodejs-packages
name: 'Node.js Package'
on:
release:
types: [created]
jobs:
publish-npm:
runs-on: 'ubuntu-latest'
steps:
- uses: 'actions/checkout@v2'
- name: 'Cache dependencies'
uses: 'actions/cache@v2'
with:
path: '**/node_modules'
key: ${{ runner.os }}-${{ hashFiles('**/package.json') }}
- uses: 'actions/setup-node@v2.1.2'
with:
node-version: 14
registry-url: 'https://registry.npmjs.org/'
- run: 'npm install'
- run: 'npm run build'
- run: 'npm publish --access public'
env:
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}}

29
.github/workflows/release.yml vendored Normal file
View File

@ -0,0 +1,29 @@
name: 'Release'
on:
push:
branches: [master]
jobs:
release:
runs-on: 'ubuntu-latest'
steps:
- uses: 'actions/checkout@v2'
- name: 'Use Node.js'
uses: 'actions/setup-node@v2.3.0'
with:
node-version: '16.x'
cache: 'npm'
- name: 'Install'
run: 'npm install'
- name: 'Build Package'
run: 'npm run build'
- name: 'Release'
run: 'npm run release'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}

28
.github/workflows/test.yml vendored Normal file
View File

@ -0,0 +1,28 @@
name: 'Test'
on:
push:
branches: [master, develop]
pull_request:
branches: [master, develop]
jobs:
test:
runs-on: 'ubuntu-latest'
steps:
- uses: 'actions/checkout@v2'
- name: 'Use Node.js'
uses: 'actions/setup-node@v2.3.0'
with:
node-version: '16.x'
cache: 'npm'
- name: 'Install'
run: 'npm install'
- name: 'Test'
run: 'npm run test'
- name: 'Upload Coverage'
uses: 'codecov/codecov-action@v2.0.1'

15
.gitignore vendored
View File

@ -2,9 +2,7 @@
# dependencies
node_modules
.pnp
.pnp.js
.yarn
.npm
# production
build
@ -12,19 +10,8 @@ build
# testing
coverage
# envs
.env
.env.production
# debug
npm-debug.log*
yarn-debug.log*
yarn-error.log*
# lockfiles
package-lock.json
yarn.lock
pnpm-lock.yaml
# editors
.vscode

4
.husky/commit-msg Executable file
View File

@ -0,0 +1,4 @@
#!/bin/sh
. "$(dirname "$0")/_/husky.sh"
npm run lint:commit -- --edit

7
.husky/pre-commit Executable file
View File

@ -0,0 +1,7 @@
#!/bin/sh
. "$(dirname "$0")/_/husky.sh"
npm run lint:editorconfig
npm run lint:markdown
npm run lint:typescript
npm run build

7
.markdownlint.json Normal file
View File

@ -0,0 +1,7 @@
{
"default": true,
"MD013": false,
"MD024": false,
"MD033": false,
"MD041": false
}

1
.npmrc
View File

@ -1,2 +1 @@
package-lock=false
save-exact=true

19
.releaserc.json Normal file
View File

@ -0,0 +1,19 @@
{
"branches": ["master"],
"plugins": [
[
"@semantic-release/commit-analyzer",
{
"preset": "conventionalcommits"
}
],
[
"@semantic-release/release-notes-generator",
{
"preset": "conventionalcommits"
}
],
"@semantic-release/npm",
"@semantic-release/github"
]
}

View File

@ -1,2 +0,0 @@
install.no-lockfile true
save-exact true

View File

@ -1,8 +1,70 @@
# Changelog
## [2.1.0](https://github.com/Thream/socketio-jwt/compare/v2.0.0...v2.1.0) (2021-03-08)
### Features
- add optional `onAuthentication` option to add `user` property in `socket` object ([#62](https://github.com/Thream/socketio-jwt/issues/62)) ([c7f64a6](https://github.com/Thream/socketio-jwt/commit/c7f64a6312a3e1f6f04918cb7cd415ddef7a11e5))
## [2.0.0](https://github.com/Thream/socketio-jwt/compare/v1.1.1...v2.0.0) (2021-02-22)
### Features
- usage of auth option to send credentials ([a14d4e9](https://github.com/Thream/socketio-jwt/commit/a14d4e937b764fdf4fb6b173c55b6f49688766dd))
See: <https://socket.io/docs/v3/middlewares/#Sending-credentials>
### BREAKING CHANGES
- `extraHeaders` with `Authorization` doesn't work anymore
### Migration
You need to change the way to connect client side.
Before :
```ts
import { io } from 'socket.io-client'
const socket = io('http://localhost:9000', {
extraHeaders: { Authorization: `Bearer ${yourJWT}` }
})
```
After :
```ts
import { io } from 'socket.io-client'
const socket = io('http://localhost:9000', {
auth: { token: `Bearer ${yourJWT}` }
})
```
## [1.1.1](https://github.com/Thream/socketio-jwt/compare/v1.1.0...v1.1.1) (2021-01-28)
### Bug Fixes
- **types:** decodedToken in secret callback ([c1a9213](https://github.com/Thream/socketio-jwt/commit/c1a9213a527e4c6188328221372e1f40191a790e)), closes [#21](https://github.com/Thream/socketio-jwt/issues/21)
### Documentation
- update server side usage with `jwks-rsa` : get the secret with `key.getPublicKey()` instead of `key.rsaPublicKey`
## [1.1.0](https://github.com/Thream/socketio-jwt/compare/v1.0.1...v1.1.0) (2021-01-07)
### Features
- add algorithms option ([abbabc5](https://github.com/Thream/socketio-jwt/commit/abbabc588e3ea8b906fa0a0dcc83c91a3b5b5ea8))
- add support for jwks-rsa ([#1](https://github.com/Thream/socketio-jwt/issues/1)) ([261e8d6](https://github.com/Thream/socketio-jwt/commit/261e8d66e2ec6fefb77429abcef8f846d996ecac))
- improve types by extending socket.io module ([#6](https://github.com/Thream/socketio-jwt/issues/6)) ([84b523f](https://github.com/Thream/socketio-jwt/commit/84b523f4348c81933887f0dc700f438c84bd779a))
## [1.0.1](https://github.com/Thream/socketio-jwt/compare/v1.0.0...v1.0.1) (2020-12-29)
- docs(readme): fix usage section by correctly importing `authorize`
### Documentation
- fix usage section by correctly importing `authorize`
## [1.0.0](https://github.com/Thream/socketio-jwt/compare/v4.6.2...v1.0.0) (2020-12-29)

View File

@ -1,25 +1,30 @@
<h1 align="center"><a href="https://www.npmjs.com/package/@thream/socketio-jwt">Thream/socketio-jwt</a></h1>
<h1 align="center">Thream/socketio-jwt</h1>
<p align="center">
<strong>Authenticate socket.io incoming connections with JWTs.</strong>
</p>
<p align="center">
<a href="https://github.com/Thream/socketio-jwt/actions?query=workflow%3A%22Node.js+CI%22"><img src="https://github.com/Thream/socketio-jwt/workflows/Node.js%20CI/badge.svg" alt="Node.js CI" /></a>
<a href="https://codecov.io/gh/Thream/socketio-jwt"><img src="https://codecov.io/gh/Thream/socketio-jwt/branch/develop/graph/badge.svg" alt="codecov" /></a>
<a href="https://dependabot.com/"><img src="https://badgen.net/github/dependabot/Thream/socketio-jwt?icon=dependabot" alt="Dependabot badge" /></a>
<a href="https://www.npmjs.com/package/@thream/socketio-jwt"><img src="https://img.shields.io/npm/v/@thream/socketio-jwt.svg" alt="npm version"></a>
<a href="https://www.npmjs.com/package/ts-standard"><img alt="TypeScript Standard Style" src="https://camo.githubusercontent.com/f87caadb70f384c0361ec72ccf07714ef69a5c0a/68747470733a2f2f62616467656e2e6e65742f62616467652f636f64652532307374796c652f74732d7374616e646172642f626c75653f69636f6e3d74797065736372697074"/></a>
<a href="./CONTRIBUTING.md"><img src="https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat" /></a>
<a href="./LICENSE"><img src="https://img.shields.io/badge/licence-MIT-blue.svg" alt="Licence MIT"/></a>
<a href="./CODE_OF_CONDUCT.md"><img src="https://img.shields.io/badge/Contributor%20Covenant-v2.0%20adopted-ff69b4.svg" alt="Contributor Covenant" /></a>
<a href="https://dependabot.com/"><img src="https://badgen.net/github/dependabot/Thream/socketio-jwt?icon=dependabot" alt="Dependabot badge" /></a>
<br/>
<a href="https://github.com/Thream/socketio-jwt/actions/workflows/build.yml"><img src="https://github.com/Thream/socketio-jwt/actions/workflows/build.yml/badge.svg?branch=develop" /></a>
<a href="https://github.com/Thream/socketio-jwt/actions/workflows/lint.yml"><img src="https://github.com/Thream/socketio-jwt/actions/workflows/lint.yml/badge.svg?branch=develop" /></a>
<a href="https://github.com/Thream/socketio-jwt/actions/workflows/test.yml"><img src="https://github.com/Thream/socketio-jwt/actions/workflows/test.yml/badge.svg?branch=develop" /></a>
<a href="https://codecov.io/gh/Thream/socketio-jwt"><img src="https://codecov.io/gh/Thream/socketio-jwt/branch/develop/graph/badge.svg" alt="codecov" /></a>
<br />
<a href="https://conventionalcommits.org"><img src="https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg" alt="Conventional Commits" /></a>
<a href="./.github/CODE_OF_CONDUCT.md"><img src="https://img.shields.io/badge/Contributor%20Covenant-v2.0%20adopted-ff69b4.svg" alt="Contributor Covenant" /></a>
<a href="https://github.com/semantic-release/semantic-release"><img src="https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg" alt="semantic-release" /></a>
<a href="https://www.npmjs.com/package/@thream/socketio-jwt"><img src="https://img.shields.io/npm/v/@thream/socketio-jwt.svg" alt="npm version"></a>
</p>
## 📜 About
Authenticate socket.io incoming connections with JWTs.
Compatible with `socket.io >= 3.0`.
Compatible with `socket.io >= 3.0.0`.
This repository was originally forked from [auth0-socketio-jwt](https://github.com/auth0-community/auth0-socketio-jwt) & it is not intended to take any credit but to improve the code from now on.
@ -44,25 +49,89 @@ io.use(
})
)
io.on('connection', async () => {
io.on('connection', async (socket) => {
// jwt payload of the connected client
console.log(socket.decodedToken)
const clients = await io.sockets.allSockets()
if (clients != null) {
for (const clientId of clients) {
const client = io.sockets.sockets.get(clientId)
client.emit('messages', { message: 'Success!' })
client?.emit('messages', { message: 'Success!' })
// we can access the jwt payload of each connected client
console.log(client.decodedToken)
console.log(client?.decodedToken)
}
}
})
```
### Server side with `jwks-rsa` (example)
```ts
import jwksClient from 'jwks-rsa'
import { Server } from 'socket.io'
import { authorize } from '@thream/socketio-jwt'
const client = jwksClient({
jwksUri: 'https://sandrino.auth0.com/.well-known/jwks.json'
})
const io = new Server(9000)
io.use(
authorize({
secret: async (decodedToken) => {
const key = await client.getSigningKeyAsync(decodedToken.header.kid)
return key.getPublicKey()
}
})
)
io.on('connection', async (socket) => {
// jwt payload of the connected client
console.log(socket.decodedToken)
// You can do the same things of the previous example there...
})
```
### Server side with `onAuthentication` (example)
```ts
import { Server } from 'socket.io'
import { authorize } from '@thream/socketio-jwt'
const io = new Server(9000)
io.use(
authorize({
secret: 'your secret or public key',
onAuthentication: async decodedToken => {
// return the object that you want to add to the user property
// or throw an error if the token is unauthorized
}
})
)
io.on('connection', async (socket) => {
// jwt payload of the connected client
console.log(socket.decodedToken)
// You can do the same things of the previous example there...
// user object returned in onAuthentication
console.log(socket.user)
})
```
### `authorize` options
- `secret` is a string containing the secret for HMAC algorithms, or a function that should fetch the secret or public key as shown in the example with `jwks-rsa`.
- `algorithms` (default: `HS256`)
- `onAuthentication` is a function that will be called with the `decodedToken` as a parameter after the token is authenticated. Return a value to add to the `user` property in the socket object.
### Client side
```ts
import { io } from 'socket.io-client'
// Require Bearer Tokens to be passed in as an Authorization Header
// Require Bearer Token
const socket = io('http://localhost:9000', {
extraHeaders: { Authorization: `Bearer ${yourJWT}` }
auth: { token: `Bearer ${yourJWT}` }
})
// Handling token expiration
@ -82,7 +151,7 @@ socket.on('messages', (data) => {
Anyone can help to improve the project, submit a Feature Request, a bug report or even correct a simple spelling mistake.
The steps to contribute can be found in the [CONTRIBUTING.md](./.github/CONTRIBUTING.md) file.
The steps to contribute can be found in the [CONTRIBUTING.md](./CONTRIBUTING.md) file.
## 📄 License

View File

@ -1 +0,0 @@
module.exports = { extends: ['@commitlint/config-conventional'] }

8
jest.config.js Normal file
View File

@ -0,0 +1,8 @@
module.exports = {
preset: 'ts-jest',
testEnvironment: 'node',
rootDir: './src',
setupFilesAfterEnv: ['<rootDir>/__test__/setup.ts'],
collectCoverage: true,
coverageDirectory: '../coverage/'
}

24870
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
{
"name": "@thream/socketio-jwt",
"version": "1.0.1",
"version": "0.0.0-development",
"description": "Authenticate socket.io incoming connections with JWTs.",
"license": "MIT",
"main": "build/index.js",
@ -9,7 +9,7 @@
"build"
],
"engines": {
"node": ">=12"
"node": ">=12.0.0"
},
"keywords": [
"socket",
@ -25,87 +25,58 @@
"url": "https://github.com/Thream/socketio-jwt/issues"
},
"homepage": "https://github.com/Thream/socketio-jwt#readme",
"husky": {
"hooks": {
"commit-msg": "commitlint -E HUSKY_GIT_PARAMS",
"pre-commit": "npm run lint"
}
},
"release-it": {
"git": {
"commitMessage": "chore(release): v${version}"
},
"github": {
"release": false
},
"npm": {
"publish": false
},
"hooks": {
"before:init": [
"npm run lint",
"npm run test"
]
},
"plugins": {
"@release-it/conventional-changelog": {
"preset": "angular",
"infile": "CHANGELOG.md"
}
}
},
"jest": {
"preset": "ts-jest",
"testEnvironment": "node",
"rootDir": "./src",
"collectCoverage": true,
"coverageDirectory": "../coverage/"
},
"ts-standard": {
"files": [
"./src/**/*.ts"
"ignore": [
"build",
"coverage",
"node_modules"
],
"envs": [
"node",
"jest"
]
],
"report": "stylish"
},
"scripts": {
"build": "rimraf ./build && tsc",
"lint": "exit 0",
"format": "ts-standard --fix | snazzy",
"release": "release-it",
"lint:commit": "commitlint",
"lint:editorconfig": "editorconfig-checker",
"lint:markdown": "markdownlint '**/*.md' --dot --ignore node_modules",
"lint:typescript": "ts-standard",
"release": "semantic-release",
"test": "jest",
"test:watchAll": "jest --watchAll",
"test:clearCache": "jest --clearCache"
"postinstall": "husky install",
"prepublishOnly": "pinst --disable",
"postpublish": "pinst --enable"
},
"peerDependencies": {
"socket.io": "*"
"socket.io": ">=3.0.0"
},
"dependencies": {
"jsonwebtoken": "8.5.1"
},
"devDependencies": {
"@commitlint/cli": "11.0.0",
"@commitlint/config-conventional": "11.0.0",
"@release-it/conventional-changelog": "2.0.0",
"@types/express": "4.17.9",
"@types/jest": "26.0.19",
"@types/jsonwebtoken": "8.5.0",
"@types/node": "14.14.16",
"@commitlint/cli": "12.1.4",
"@commitlint/config-conventional": "12.1.4",
"@types/express": "4.17.13",
"@types/jest": "26.0.24",
"@types/jsonwebtoken": "8.5.4",
"@types/node": "16.4.1",
"@types/server-destroy": "1.0.1",
"axios": "0.21.1",
"editorconfig-checker": "4.0.2",
"express": "4.17.1",
"husky": "4.3.6",
"jest": "26.6.3",
"release-it": "14.2.2",
"husky": "7.0.1",
"jest": "27.0.6",
"markdownlint-cli": "0.28.1",
"pinst": "2.1.6",
"rimraf": "3.0.2",
"semantic-release": "17.4.4",
"server-destroy": "1.0.1",
"snazzy": "9.0.0",
"socket.io": "3.0.4",
"socket.io-client": "3.0.4",
"ts-jest": "26.4.4",
"socket.io": "4.1.3",
"socket.io-client": "4.1.3",
"ts-jest": "27.0.4",
"ts-standard": "10.0.0",
"typescript": "4.1.3"
"typescript": "4.3.5"
}
}

View File

@ -1,17 +1,19 @@
import axios from 'axios'
import { io } from 'socket.io-client'
import { fixtureStart, fixtureStop } from './fixture'
import { fixtureStart, fixtureStop, getSocket, Profile } from './fixture'
describe('authorize', () => {
describe('authorize - with secret as string in options', () => {
let token: string = ''
beforeEach((done) => {
jest.setTimeout(15_000)
fixtureStart(async () => {
const response = await axios.post('http://localhost:9000/login')
token = response.data.token
done()
})
.then(done)
.catch((error) => {
done(error)
})
})
@ -31,7 +33,7 @@ describe('authorize', () => {
it('should emit error with bad token format', (done) => {
const socket = io('http://localhost:9000', {
extraHeaders: { Authorization: 'testing' }
auth: { token: 'testing' }
})
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual(
@ -45,7 +47,7 @@ describe('authorize', () => {
it('should emit error with unauthorized handshake', (done) => {
const socket = io('http://localhost:9000', {
extraHeaders: { Authorization: 'Bearer testing' }
auth: { token: 'Bearer testing' }
})
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual(
@ -59,11 +61,206 @@ describe('authorize', () => {
it('should connect the user', (done) => {
const socket = io('http://localhost:9000', {
extraHeaders: { Authorization: `Bearer ${token}` }
auth: { token: `Bearer ${token}` }
})
socket.on('connect', () => {
socket.close()
done()
})
socket.on('connect_error', (err: any) => {
done(err)
})
})
})
const secretCallback = async (): Promise<string> => {
return 'somesecret'
}
describe('authorize - with secret as callback in options', () => {
let token: string = ''
beforeEach((done) => {
fixtureStart(
async () => {
const response = await axios.post('http://localhost:9000/login')
token = response.data.token
},
{ secret: secretCallback }
)
.then(done)
.catch((error) => {
done(error)
})
})
afterEach((done) => {
fixtureStop(done)
})
it('should emit error with no token provided', (done) => {
const socket = io('http://localhost:9000')
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual('no token provided')
expect(err.data.code).toEqual('credentials_required')
socket.close()
done()
})
})
it('should emit error with bad token format', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: 'testing' }
})
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual(
'Format is Authorization: Bearer [token]'
)
expect(err.data.code).toEqual('credentials_bad_format')
socket.close()
done()
})
})
it('should emit error with unauthorized handshake', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: 'Bearer testing' }
})
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual(
'Unauthorized: Token is missing or invalid Bearer'
)
expect(err.data.code).toEqual('invalid_token')
socket.close()
done()
})
})
it('should connect the user', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: `Bearer ${token}` }
})
socket.on('connect', () => {
socket.close()
done()
})
socket.on('connect_error', (err: any) => {
done(err)
})
})
})
describe('authorize - with onAuthentication callback in options', () => {
let token: string = ''
let wrongToken: string = ''
beforeEach((done) => {
fixtureStart(
async () => {
const response = await axios.post('http://localhost:9000/login')
token = response.data.token
const responseWrong = await axios.post(
'http://localhost:9000/login-wrong'
)
wrongToken = responseWrong.data.token
},
{
secret: secretCallback,
onAuthentication: (decodedToken: Profile) => {
if (!decodedToken.checkField) {
throw new Error('Check Field validation failed')
}
return {
email: decodedToken.email
}
}
}
)
.then(done)
.catch((error) => {
done(error)
})
})
afterEach((done) => {
fixtureStop(done)
})
it('should emit error with no token provided', (done) => {
const socket = io('http://localhost:9000')
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual('no token provided')
expect(err.data.code).toEqual('credentials_required')
socket.close()
done()
})
})
it('should emit error with bad token format', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: 'testing' }
})
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual(
'Format is Authorization: Bearer [token]'
)
expect(err.data.code).toEqual('credentials_bad_format')
socket.close()
done()
})
})
it('should emit error with unauthorized handshake', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: 'Bearer testing' }
})
socket.on('connect_error', (err: any) => {
expect(err.data.message).toEqual(
'Unauthorized: Token is missing or invalid Bearer'
)
expect(err.data.code).toEqual('invalid_token')
socket.close()
done()
})
})
it('should connect the user', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: `Bearer ${token}` }
})
socket.on('connect', () => {
socket.close()
done()
})
})
it('should contain user property', (done) => {
const socketServer = getSocket()
socketServer?.on('connection', (client: any) => {
expect(client.user.email).toEqual('john@doe.com')
})
const socket = io('http://localhost:9000', {
auth: { token: `Bearer ${token}` }
})
socket.on('connect', () => {
socket.close()
done()
})
})
it('should emit error when user validation fails', (done) => {
const socket = io('http://localhost:9000', {
auth: { token: `Bearer ${wrongToken}` }
})
socket.on('connect_error', (err: any) => {
try {
expect(err.message).toEqual('Check Field validation failed')
} catch (err) {
socket.close()
done(err)
}
socket.close()
done()
})
})
})

View File

@ -5,7 +5,13 @@ import { Server as HttpsServer } from 'https'
import { Server as SocketIoServer } from 'socket.io'
import enableDestroy from 'server-destroy'
import { authorize } from '../../index'
import { authorize, AuthorizeOptions } from '../../index'
export interface Profile {
email: string
id: number
checkField: boolean
}
interface Socket {
io: null | SocketIoServer
@ -21,16 +27,34 @@ const socket: Socket = {
let server: HttpServer | null = null
export const fixtureStart = (done: any): void => {
const options = { secret: 'aaafoo super sercret' }
export const fixtureStart = async (
done: any,
options: AuthorizeOptions = { secret: 'super secret' }
): Promise<void> => {
const profile: Profile = {
email: 'john@doe.com',
id: 123,
checkField: true
}
let keySecret = ''
if (typeof options.secret === 'string') {
keySecret = options.secret
} else {
keySecret = await options.secret({ header: { alg: 'HS256' }, payload: profile })
}
const app = express()
app.use(express.json())
app.post('/login', (_req, res) => {
const profile = {
email: 'john@doe.com',
id: 123
}
const token = jwt.sign(profile, options.secret, { expiresIn: 60 * 60 * 5 })
const token = jwt.sign(profile, keySecret, {
expiresIn: 60 * 60 * 5
})
return res.json({ token })
})
app.post('/login-wrong', (_req, res) => {
profile.checkField = false
const token = jwt.sign(profile, keySecret, {
expiresIn: 60 * 60 * 5
})
return res.json({ token })
})
server = app.listen(9000, done)
@ -43,6 +67,10 @@ export const fixtureStop = (callback: Function): void => {
socket.io?.close()
try {
server?.destroy()
} catch (err) {}
} catch {}
callback()
}
export const getSocket = (): SocketIoServer | null => {
return socket.io
}

1
src/__test__/setup.ts Normal file
View File

@ -0,0 +1 @@
jest.setTimeout(15_000)

View File

@ -1,28 +1,50 @@
import jwt from 'jsonwebtoken'
import jwt, { Algorithm } from 'jsonwebtoken'
import { Socket } from 'socket.io'
import { UnauthorizedError } from './UnauthorizedError'
declare module 'socket.io' {
interface Socket extends ExtendedSocket {}
}
interface ExtendedError extends Error {
data?: any
}
interface ExtendedSocket {
encodedToken?: string
decodedToken?: any
user?: any
}
type SocketIOMiddleware = (
socket: Socket,
next: (err?: ExtendedError) => void
) => void
interface AuthorizeOptions {
secret: string
interface CompleteDecodedToken {
header: {
alg: Algorithm
[key: string]: any
}
payload: any
}
type SecretCallback = (decodedToken: CompleteDecodedToken) => Promise<string> | string
export interface AuthorizeOptions {
secret: string | SecretCallback
algorithms?: Algorithm[]
onAuthentication?: (decodedToken: any) => Promise<any> | any
}
export const authorize = (options: AuthorizeOptions): SocketIOMiddleware => {
const { secret } = options
return (socket, next) => {
let token: string | null = null
const authorizationHeader = socket.request.headers.authorization
if (authorizationHeader != null) {
const tokenSplitted = authorizationHeader.split(' ')
const { secret, algorithms = ['HS256'], onAuthentication } = options
return async (socket, next) => {
let encodedToken: string | null = null
const { token } = socket.handshake.auth
if (token != null) {
const tokenSplitted = token.split(' ')
if (tokenSplitted.length !== 2 || tokenSplitted[0] !== 'Bearer') {
return next(
new UnauthorizedError('credentials_bad_format', {
@ -30,20 +52,26 @@ export const authorize = (options: AuthorizeOptions): SocketIOMiddleware => {
})
)
}
token = tokenSplitted[1]
encodedToken = tokenSplitted[1]
}
if (token == null) {
if (encodedToken == null) {
return next(
new UnauthorizedError('credentials_required', {
message: 'no token provided'
})
)
}
// Store encoded JWT
socket = Object.assign(socket, { encodedToken: token })
let payload: any
socket.encodedToken = encodedToken
let keySecret: string | null = null
let decodedToken: any
if (typeof secret === 'string') {
keySecret = secret
} else {
const completeDecodedToken = jwt.decode(encodedToken, { complete: true })
keySecret = await secret(completeDecodedToken as CompleteDecodedToken)
}
try {
payload = jwt.verify(token, secret)
decodedToken = jwt.verify(encodedToken, keySecret, { algorithms })
} catch {
return next(
new UnauthorizedError('invalid_token', {
@ -51,8 +79,14 @@ export const authorize = (options: AuthorizeOptions): SocketIOMiddleware => {
})
)
}
// Store decoded JWT
socket = Object.assign(socket, { decodedToken: payload })
socket.decodedToken = decodedToken
if (onAuthentication != null) {
try {
socket.user = await onAuthentication(decodedToken)
} catch (err) {
return next(err)
}
}
return next()
}
}

View File

@ -1,23 +1,13 @@
{
"compilerOptions": {
"target": "ES2019",
"target": "ESNext",
"module": "commonjs",
"lib": ["ES2019"],
"lib": ["ESNext"],
"moduleResolution": "node",
"allowJs": false,
"checkJs": false,
"declaration": true,
"sourceMap": false,
"outDir": "./build",
"rootDir": "./src",
"removeComments": false,
"noEmitOnError": true,
"importHelpers": false,
"strict": true,
"esModuleInterop": true,
"experimentalDecorators": true,
"emitDecoratorMetadata": true,
"forceConsistentCasingInFileNames": true,
"incremental": false
"declaration": true,
}
}