Compare commits
15 Commits
@blitzjs/a
...
@blitzjs/c
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
414d758fe8 | ||
|
|
fce0f3135a | ||
|
|
9620ef6b1e | ||
|
|
240f3f3471 | ||
|
|
91aa535632 | ||
|
|
ccb1af8d08 | ||
|
|
807a2b5645 | ||
|
|
a3e6c49c4d | ||
|
|
4d7d126d9c | ||
|
|
890b0c0c9d | ||
|
|
928e840b59 | ||
|
|
55b1cb2044 | ||
|
|
3a6677b307 | ||
|
|
f202aac183 | ||
|
|
065db256d7 |
@@ -971,7 +971,8 @@
|
||||
"profile": "https://twitter.com/dillonraphael",
|
||||
"contributions": [
|
||||
"code",
|
||||
"doc"
|
||||
"doc",
|
||||
"test"
|
||||
]
|
||||
},
|
||||
{
|
||||
@@ -3649,6 +3650,16 @@
|
||||
"doc",
|
||||
"code"
|
||||
]
|
||||
},
|
||||
{
|
||||
"login": "chaiwattsw",
|
||||
"name": "Chaiwat Trisuwan",
|
||||
"avatar_url": "https://avatars.githubusercontent.com/u/30198386?v=4",
|
||||
"profile": "https://chaiwattsw.com/",
|
||||
"contributions": [
|
||||
"doc",
|
||||
"code"
|
||||
]
|
||||
}
|
||||
],
|
||||
"contributorsPerLine": 7,
|
||||
|
||||
5
.changeset/calm-tomatoes-drive.md
Normal file
5
.changeset/calm-tomatoes-drive.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Include `.env.test` file to the generator templates
|
||||
5
.changeset/fair-carrots-guess.md
Normal file
5
.changeset/fair-carrots-guess.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Fixes loading production env variables by default for blitz build command
|
||||
5
.changeset/gorgeous-games-obey.md
Normal file
5
.changeset/gorgeous-games-obey.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/next": patch
|
||||
---
|
||||
|
||||
Avoid `invalid config detected` warnings by deleting `"blitz"` key from next config object
|
||||
5
.changeset/great-terms-rescue.md
Normal file
5
.changeset/great-terms-rescue.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Add BlitzServerMiddleware utility function to wrap middleware in blitz server file
|
||||
5
.changeset/green-pillows-hammer.md
Normal file
5
.changeset/green-pillows-hammer.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Runs the codegen on the blitz build command
|
||||
5
.changeset/light-donkeys-double.md
Normal file
5
.changeset/light-donkeys-double.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Run `prisma generate` as a `blitz codegen` step if "prisma" is found in project's dependencies
|
||||
6
.changeset/ninety-rice-tickle.md
Normal file
6
.changeset/ninety-rice-tickle.md
Normal file
@@ -0,0 +1,6 @@
|
||||
---
|
||||
"blitz": patch
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Improve `blitz new` messaging and fix minor issues
|
||||
@@ -27,6 +27,7 @@
|
||||
"bright-mangos-run",
|
||||
"calm-carpets-deny",
|
||||
"calm-nails-wait",
|
||||
"calm-tomatoes-drive",
|
||||
"clean-walls-wink",
|
||||
"cool-doors-invent",
|
||||
"cool-horses-check",
|
||||
@@ -36,6 +37,7 @@
|
||||
"eleven-humans-sort",
|
||||
"empty-berries-rule",
|
||||
"empty-turkeys-wave",
|
||||
"fair-carrots-guess",
|
||||
"fair-wombats-sneeze",
|
||||
"famous-kings-explain",
|
||||
"fast-trainers-kneel",
|
||||
@@ -49,8 +51,11 @@
|
||||
"good-apes-drum",
|
||||
"good-insects-wink",
|
||||
"gorgeous-buses-scream",
|
||||
"gorgeous-games-obey",
|
||||
"great-months-train",
|
||||
"great-terms-rescue",
|
||||
"green-papayas-do",
|
||||
"green-pillows-hammer",
|
||||
"happy-hotels-visit",
|
||||
"healthy-rice-shout",
|
||||
"heavy-apes-judge",
|
||||
@@ -60,6 +65,7 @@
|
||||
"late-steaks-give",
|
||||
"lemon-games-press",
|
||||
"lemon-seas-push",
|
||||
"light-donkeys-double",
|
||||
"lovely-colts-share",
|
||||
"lucky-cows-try",
|
||||
"mean-gorillas-reply",
|
||||
@@ -76,6 +82,7 @@
|
||||
"nine-onions-admire",
|
||||
"ninety-lies-press",
|
||||
"ninety-pets-heal",
|
||||
"ninety-rice-tickle",
|
||||
"olive-bees-buy",
|
||||
"olive-feet-rhyme",
|
||||
"olive-sheep-rhyme",
|
||||
@@ -92,6 +99,7 @@
|
||||
"quiet-feet-travel",
|
||||
"quiet-pans-hunt",
|
||||
"quiet-sloths-rule",
|
||||
"red-badgers-retire",
|
||||
"rich-chairs-invent",
|
||||
"rich-queens-travel",
|
||||
"sharp-falcons-begin",
|
||||
@@ -107,6 +115,7 @@
|
||||
"smooth-stingrays-drum",
|
||||
"soft-adults-smell",
|
||||
"sour-lemons-hunt",
|
||||
"spicy-beds-float",
|
||||
"strong-apes-reply",
|
||||
"stupid-walls-sell",
|
||||
"sweet-kiwis-cross",
|
||||
@@ -120,11 +129,13 @@
|
||||
"tender-pianos-check",
|
||||
"thick-parrots-float",
|
||||
"thirty-countries-build",
|
||||
"three-lies-pull",
|
||||
"tidy-clouds-smoke",
|
||||
"tough-toes-pull",
|
||||
"twelve-lemons-smile",
|
||||
"twenty-beans-pump",
|
||||
"two-carpets-rhyme",
|
||||
"two-eyes-knock",
|
||||
"two-kiwis-help",
|
||||
"two-tigers-type",
|
||||
"unlucky-papayas-sleep",
|
||||
@@ -133,6 +144,7 @@
|
||||
"weak-suns-shave",
|
||||
"wicked-ghosts-cough",
|
||||
"wicked-rings-walk",
|
||||
"wise-frogs-give"
|
||||
"wise-frogs-give",
|
||||
"wise-rabbits-complain"
|
||||
]
|
||||
}
|
||||
|
||||
8
.changeset/red-badgers-retire.md
Normal file
8
.changeset/red-badgers-retire.md
Normal file
@@ -0,0 +1,8 @@
|
||||
---
|
||||
"blitz": patch
|
||||
"@blitzjs/next": patch
|
||||
"@blitzjs/rpc": patch
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Fixes peer dependency warnings
|
||||
8
.changeset/spicy-beds-float.md
Normal file
8
.changeset/spicy-beds-float.md
Normal file
@@ -0,0 +1,8 @@
|
||||
---
|
||||
"@blitzjs/auth": patch
|
||||
"@blitzjs/next": patch
|
||||
"@blitzjs/rpc": patch
|
||||
"blitz": patch
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
Fixes the supports-color warning for pnpm
|
||||
5
.changeset/three-lies-pull.md
Normal file
5
.changeset/three-lies-pull.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/rpc": patch
|
||||
---
|
||||
|
||||
moves zod to devDependencies
|
||||
5
.changeset/two-eyes-knock.md
Normal file
5
.changeset/two-eyes-knock.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Update new app templates to use blitz-rpc's resolver function
|
||||
5
.changeset/wise-rabbits-complain.md
Normal file
5
.changeset/wise-rabbits-complain.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Mocks @blitzjs/auth instead of blitz inside the forgotPassword mutation test & hardcodes blitz package version types instead of just using the alpha tag.
|
||||
@@ -6,7 +6,7 @@
|
||||
<img alt="" src="https://img.shields.io/badge/Join%20our%20community-6700EB.svg?style=for-the-badge&labelColor=000000&logoWidth=20&logo=">
|
||||
</a>
|
||||
<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->
|
||||
<a aria-label="All Contributors" href="#contributors-"><img alt="" src="https://img.shields.io/badge/all_contributors-387-17BB8A.svg?style=for-the-badge&labelColor=000000"></a>
|
||||
<a aria-label="All Contributors" href="#contributors-"><img alt="" src="https://img.shields.io/badge/all_contributors-388-17BB8A.svg?style=for-the-badge&labelColor=000000"></a>
|
||||
<!-- ALL-CONTRIBUTORS-BADGE:END -->
|
||||
<a aria-label="License" href="https://github.com/blitz-js/blitz/blob/canary/LICENSE">
|
||||
<img alt="" src="https://img.shields.io/npm/l/blitz.svg?style=for-the-badge&labelColor=000000&color=blue">
|
||||
@@ -337,7 +337,7 @@ Thanks to these wonderful people ([emoji key](https://allcontributors.org/docs/e
|
||||
</tr>
|
||||
<tr>
|
||||
<td align="center"><a href="https://github.com/jschepmans"><img src="https://avatars2.githubusercontent.com/u/5782977?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Johan Schepmans</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=jschepmans" title="Code">💻</a></td>
|
||||
<td align="center"><a href="https://twitter.com/dillonraphael"><img src="https://avatars0.githubusercontent.com/u/3496193?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Dillon Raphael</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=dillonraphael" title="Code">💻</a> <a href="https://github.com/blitz-js/blitz/commits?author=dillonraphael" title="Documentation">📖</a></td>
|
||||
<td align="center"><a href="https://twitter.com/dillonraphael"><img src="https://avatars0.githubusercontent.com/u/3496193?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Dillon Raphael</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=dillonraphael" title="Code">💻</a> <a href="https://github.com/blitz-js/blitz/commits?author=dillonraphael" title="Documentation">📖</a> <a href="https://github.com/blitz-js/blitz/commits?author=dillonraphael" title="Tests">⚠️</a></td>
|
||||
<td align="center"><a href="https://github.com/clgeoio"><img src="https://avatars2.githubusercontent.com/u/37571416?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Cody G</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=clgeoio" title="Code">💻</a> <a href="https://github.com/blitz-js/blitz/commits?author=clgeoio" title="Tests">⚠️</a></td>
|
||||
<td align="center"><a href="https://github.com/madflow"><img src="https://avatars0.githubusercontent.com/u/183248?v=4?s=100" width="100px;" alt=""/><br /><sub><b>madflow</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=madflow" title="Documentation">📖</a></td>
|
||||
<td align="center"><a href="https://twitter.com/nitaking_"><img src="https://avatars2.githubusercontent.com/u/10850034?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Satoshi Nitawaki</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=nitaking" title="Code">💻</a> <a href="#maintenance-nitaking" title="Maintenance">🚧</a> <a href="#question-nitaking" title="Answering Questions">💬</a> <a href="https://github.com/blitz-js/blitz/commits?author=nitaking" title="Documentation">📖</a></td>
|
||||
@@ -707,6 +707,7 @@ Thanks to these wonderful people ([emoji key](https://allcontributors.org/docs/e
|
||||
<tr>
|
||||
<td align="center"><a href="https://github.com/tommywong-dev"><img src="https://avatars.githubusercontent.com/u/79971095?v=4?s=100" width="100px;" alt=""/><br /><sub><b>tommywong-dev</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=tommywong-dev" title="Documentation">📖</a></td>
|
||||
<td align="center"><a href="https://github.com/datner"><img src="https://avatars.githubusercontent.com/u/22598347?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Datner</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=datner" title="Documentation">📖</a> <a href="https://github.com/blitz-js/blitz/commits?author=datner" title="Code">💻</a></td>
|
||||
<td align="center"><a href="https://chaiwattsw.com/"><img src="https://avatars.githubusercontent.com/u/30198386?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Chaiwat Trisuwan</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=chaiwattsw" title="Documentation">📖</a> <a href="https://github.com/blitz-js/blitz/commits?author=chaiwattsw" title="Code">💻</a></td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
|
||||
@@ -29,7 +29,7 @@
|
||||
"@blitzjs/rpc": "workspace:*",
|
||||
"@hookform/resolvers": "2.8.8",
|
||||
"@prisma/client": "4.0.0",
|
||||
"blitz": "workspace:2.0.0-alpha.65",
|
||||
"blitz": "workspace:2.0.0-alpha.66",
|
||||
"next": "12.2.0",
|
||||
"prisma": "4.0.0",
|
||||
"react": "18.0.0",
|
||||
|
||||
@@ -1,5 +1,19 @@
|
||||
# @blitzjs/auth
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- a3e6c49c: Fixes the supports-color warning for pnpm
|
||||
- Updated dependencies [928e840b]
|
||||
- Updated dependencies [240f3f34]
|
||||
- Updated dependencies [55b1cb20]
|
||||
- Updated dependencies [4d7d126d]
|
||||
- Updated dependencies [890b0c0c]
|
||||
- Updated dependencies [807a2b56]
|
||||
- Updated dependencies [a3e6c49c]
|
||||
- blitz@2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/auth",
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"predev": "wait-on -d 250 ../blitz/dist/index-server.d.ts",
|
||||
@@ -26,7 +26,7 @@
|
||||
"@types/secure-password": "3.1.1",
|
||||
"b64-lite": "1.4.0",
|
||||
"bad-behavior": "1.0.1",
|
||||
"blitz": "2.0.0-alpha.65",
|
||||
"blitz": "2.0.0-alpha.66",
|
||||
"cookie": "0.4.1",
|
||||
"cookie-session": "2.0.0",
|
||||
"debug": "4.3.3",
|
||||
@@ -36,10 +36,11 @@
|
||||
"passport": "0.5.2",
|
||||
"path": "0.12.7",
|
||||
"secure-password": "4.0.0",
|
||||
"supports-color": "8.1.1",
|
||||
"url": "0.11.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.65",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@testing-library/react": "13.0.0",
|
||||
"@testing-library/react-hooks": "7.0.2",
|
||||
"@types/cookie": "0.4.1",
|
||||
|
||||
@@ -1,5 +1,17 @@
|
||||
# @blitzjs/next
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- ccb1af8d: Avoid `invalid config detected` warnings by deleting `"blitz"` key from next config object
|
||||
- 807a2b56: Fixes peer dependency warnings
|
||||
- a3e6c49c: Fixes the supports-color warning for pnpm
|
||||
- Updated dependencies [807a2b56]
|
||||
- Updated dependencies [a3e6c49c]
|
||||
- Updated dependencies [9620ef6b]
|
||||
- @blitzjs/rpc@2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -2,7 +2,7 @@ import {BuildConfig} from "unbuild"
|
||||
|
||||
const config: BuildConfig = {
|
||||
entries: ["./src/index-browser", "./src/index-server"],
|
||||
externals: ["index-browser.cjs", "index-browser.mjs", "blitz", ".blitz"],
|
||||
externals: ["index-browser.cjs", "index-browser.mjs", "blitz", ".blitz", "next", "react"],
|
||||
declaration: true,
|
||||
rollup: {
|
||||
emitCJS: true,
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/next",
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"dev": "pnpm predev && pnpm watch unbuild src --wait=0.2",
|
||||
@@ -24,16 +24,17 @@
|
||||
"eslint.js"
|
||||
],
|
||||
"dependencies": {
|
||||
"@blitzjs/rpc": "2.0.0-alpha.65",
|
||||
"@blitzjs/rpc": "2.0.0-alpha.66",
|
||||
"@tanstack/react-query": "4.0.10",
|
||||
"@types/hoist-non-react-statics": "3.3.1",
|
||||
"debug": "4.3.3",
|
||||
"fs-extra": "10.0.1",
|
||||
"hoist-non-react-statics": "3.3.2",
|
||||
"superjson": "1.8.0"
|
||||
"superjson": "1.8.0",
|
||||
"supports-color": "8.1.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.65",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@testing-library/dom": "8.13.0",
|
||||
"@testing-library/jest-dom": "5.16.3",
|
||||
"@testing-library/react": "13.0.0",
|
||||
@@ -43,7 +44,7 @@
|
||||
"@types/react": "18.0.1",
|
||||
"@types/react-dom": "17.0.14",
|
||||
"@types/testing-library__react-hooks": "4.0.0",
|
||||
"blitz": "2.0.0-alpha.65",
|
||||
"blitz": "2.0.0-alpha.66",
|
||||
"cross-spawn": "7.0.3",
|
||||
"find-up": "4.1.0",
|
||||
"next": "12.2.0",
|
||||
@@ -57,9 +58,5 @@
|
||||
},
|
||||
"publishConfig": {
|
||||
"access": "public"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"next": ">=12.2.0",
|
||||
"react": "*"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -209,7 +209,8 @@ export function withBlitz(nextConfig: BlitzConfig = {}) {
|
||||
},
|
||||
})
|
||||
|
||||
return config
|
||||
const {blitz, ...rest} = config
|
||||
return rest
|
||||
}
|
||||
|
||||
export type PrefetchQueryFn = <T extends AsyncFunc, TInput = FirstParam<T>>(
|
||||
|
||||
@@ -1,5 +1,15 @@
|
||||
# @blitzjs/rpc
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 807a2b56: Fixes peer dependency warnings
|
||||
- a3e6c49c: Fixes the supports-color warning for pnpm
|
||||
- 9620ef6b: moves zod to devDependencies
|
||||
- Updated dependencies [a3e6c49c]
|
||||
- @blitzjs/auth@2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -14,6 +14,9 @@ const config: BuildConfig = {
|
||||
"index-server.cjs",
|
||||
"index-server.mjs",
|
||||
"react",
|
||||
"blitz",
|
||||
"next",
|
||||
"zod",
|
||||
],
|
||||
declaration: true,
|
||||
rollup: {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/rpc",
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"predev": "wait-on -d 250 ../blitz/dist/index-server.d.ts && wait-on -d 250 ../blitz-auth/dist/index-browser.d.ts",
|
||||
@@ -20,31 +20,28 @@
|
||||
"dist/**"
|
||||
],
|
||||
"dependencies": {
|
||||
"@blitzjs/auth": "2.0.0-alpha.65",
|
||||
"@blitzjs/auth": "2.0.0-alpha.66",
|
||||
"@tanstack/react-query": "4.0.10",
|
||||
"b64-lite": "1.4.0",
|
||||
"bad-behavior": "1.0.1",
|
||||
"chalk": "^4.1.0",
|
||||
"debug": "4.3.3",
|
||||
"superjson": "1.8.0",
|
||||
"zod": "3.17.3"
|
||||
"supports-color": "8.1.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.65",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@types/debug": "4.1.7",
|
||||
"@types/react": "18.0.1",
|
||||
"@types/react-dom": "17.0.14",
|
||||
"blitz": "2.0.0-alpha.65",
|
||||
"blitz": "2.0.0-alpha.66",
|
||||
"next": "12.2.0",
|
||||
"react": "18.0.0",
|
||||
"react-dom": "18.0.0",
|
||||
"typescript": "^4.5.3",
|
||||
"unbuild": "0.7.6",
|
||||
"watch": "1.0.2"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"blitz": "2.0.0-alpha.65",
|
||||
"next": ">=12.2.0"
|
||||
"watch": "1.0.2",
|
||||
"zod": "3.17.3"
|
||||
},
|
||||
"publishConfig": {
|
||||
"access": "public"
|
||||
|
||||
@@ -1,5 +1,24 @@
|
||||
# blitz
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 928e840b: Fixes loading production env variables by default for blitz build command
|
||||
- 240f3f34: Add BlitzServerMiddleware utility function to wrap middleware in blitz server file
|
||||
- 55b1cb20: Runs the codegen on the blitz build command
|
||||
- 4d7d126d: Run `prisma generate` as a `blitz codegen` step if "prisma" is found in project's dependencies
|
||||
- 890b0c0c: Improve `blitz new` messaging and fix minor issues
|
||||
- 807a2b56: Fixes peer dependency warnings
|
||||
- a3e6c49c: Fixes the supports-color warning for pnpm
|
||||
- Updated dependencies [91aa5356]
|
||||
- Updated dependencies [890b0c0c]
|
||||
- Updated dependencies [807a2b56]
|
||||
- Updated dependencies [a3e6c49c]
|
||||
- Updated dependencies [065db256]
|
||||
- Updated dependencies [f202aac1]
|
||||
- @blitzjs/generator@2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -2,7 +2,7 @@ import {BuildConfig} from "unbuild"
|
||||
|
||||
const config: BuildConfig = {
|
||||
entries: ["./src/index-browser", "./src/index-server", "./src/cli/index"],
|
||||
externals: ["index-browser.cjs", "index-browser.mjs", "index.cjs", "zod"],
|
||||
externals: ["index-browser.cjs", "index-browser.mjs", "index.cjs", "zod", "react"],
|
||||
declaration: true,
|
||||
rollup: {
|
||||
emitCJS: true,
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "blitz",
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"dev": "watch unbuild src --wait=0.2",
|
||||
@@ -23,7 +23,7 @@
|
||||
"blitz": "bin/blitz"
|
||||
},
|
||||
"dependencies": {
|
||||
"@blitzjs/generator": "2.0.0-alpha.65",
|
||||
"@blitzjs/generator": "2.0.0-alpha.66",
|
||||
"arg": "5.0.1",
|
||||
"boxen": "7.0.0",
|
||||
"chalk": "^4.1.0",
|
||||
@@ -48,13 +48,14 @@
|
||||
"resolve-cwd": "3.0.0",
|
||||
"resolve-from": "5.0.0",
|
||||
"superjson": "1.8.0",
|
||||
"supports-color": "8.1.1",
|
||||
"ts-node": "10.7.0",
|
||||
"tsconfig-paths": "4.0.0",
|
||||
"tslog": "3.3.1",
|
||||
"watchpack": "2.1.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.65",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@types/cookie": "0.4.1",
|
||||
"@types/cross-spawn": "6.0.2",
|
||||
"@types/debug": "4.1.7",
|
||||
@@ -78,9 +79,6 @@
|
||||
"watch": "1.0.2",
|
||||
"zod": "3.17.3"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"react": "*"
|
||||
},
|
||||
"publishConfig": {
|
||||
"access": "public"
|
||||
}
|
||||
|
||||
@@ -1,37 +1,14 @@
|
||||
import {CliCommand} from "../index"
|
||||
/* @ts-ignore */
|
||||
import {generateManifest} from "../utils/routes-manifest"
|
||||
import resolveCwd from "resolve-cwd"
|
||||
import {join} from "path"
|
||||
import fs from "fs-extra"
|
||||
import {codegenTasks} from "../utils/codegen-tasks"
|
||||
|
||||
const codegen: CliCommand = async () => {
|
||||
try {
|
||||
/*
|
||||
Updates the user's nextjs file and adds onRecoverableError to the hydrateRoot 3rd parameter object.
|
||||
We can remove this when https://github.com/vercel/next.js/pull/38207 is merged into next.js
|
||||
*/
|
||||
const nextDir = await resolveCwd("next")
|
||||
const nextClientIndex = join(nextDir, "../..", "client", "index.js")
|
||||
const readFile = await fs.readFile(nextClientIndex)
|
||||
const updatedFile = readFile
|
||||
.toString()
|
||||
.replace(
|
||||
/ReactDOM\.hydrateRoot\(.*?\);/,
|
||||
`ReactDOM.hydrateRoot(domEl, reactEl, process.env.NODE_ENV === 'development' ? {onRecoverableError: (err) => err.toString().includes("could not finish this Suspense boundary") ? null : console.error(err)} : undefined);`,
|
||||
)
|
||||
await fs.writeFile(nextClientIndex, updatedFile)
|
||||
await codegenTasks()
|
||||
process.exit(0)
|
||||
} catch (err) {
|
||||
console.log(err)
|
||||
process.exit(1)
|
||||
}
|
||||
|
||||
try {
|
||||
await generateManifest()
|
||||
} catch (err) {
|
||||
console.log(err)
|
||||
}
|
||||
|
||||
process.exit(0)
|
||||
}
|
||||
|
||||
export {codegen}
|
||||
|
||||
@@ -9,17 +9,15 @@ import {AppGenerator, AppGeneratorOptions, getLatestVersion} from "@blitzjs/gene
|
||||
import {checkLatestVersion} from "../utils/check-latest-version"
|
||||
import {runPrisma} from "../../run-prisma"
|
||||
|
||||
const forms = {
|
||||
"react-final-form": "React Final Form" as const,
|
||||
"react-hook-form": "React Hook Form" as const,
|
||||
formik: "Formik" as const,
|
||||
const forms: Record<AppGeneratorOptions["form"], string> = {
|
||||
finalform: "React Final Form (recommended)",
|
||||
hookform: "React Hook Form",
|
||||
formik: "Formik",
|
||||
}
|
||||
|
||||
type TForms = keyof typeof forms
|
||||
|
||||
const language = {
|
||||
typescript: "TypeScript",
|
||||
javascript: "Javascript",
|
||||
javascript: "JavaScript",
|
||||
}
|
||||
|
||||
type TLanguage = keyof typeof language
|
||||
@@ -75,7 +73,7 @@ const args = arg(
|
||||
let projectName: string = ""
|
||||
let projectPath: string = ""
|
||||
let projectLanguage: string | TLanguage = ""
|
||||
let projectFormLib: AppGeneratorOptions["form"] = undefined
|
||||
let projectFormLib: AppGeneratorOptions["form"] = "finalform"
|
||||
let projectTemplate: AppGeneratorOptions["template"] = templates.full
|
||||
let projectPkgManger: TPkgManager = PREFERABLE_PKG_MANAGER
|
||||
let shouldInstallDeps: boolean = true
|
||||
@@ -110,7 +108,7 @@ const determineLanguage = async () => {
|
||||
const res = await prompts({
|
||||
type: "select",
|
||||
name: "language",
|
||||
message: "Pick which language you'd like to use for your new blitz project",
|
||||
message: "Pick a new project's language",
|
||||
initial: 0,
|
||||
choices: Object.entries(language).map((c) => {
|
||||
return {title: c[1], value: c[1]}
|
||||
@@ -129,16 +127,16 @@ const determineFormLib = async () => {
|
||||
const res = await prompts({
|
||||
type: "select",
|
||||
name: "form",
|
||||
message: "Pick which form you'd like to use for your new blitz project",
|
||||
message: "Pick a form library (you can switch to something else later if you want)",
|
||||
initial: 0,
|
||||
choices: Object.entries(forms).map((c) => {
|
||||
return {title: c[1], value: c[1]}
|
||||
return {value: c[0], title: c[1]}
|
||||
}),
|
||||
})
|
||||
|
||||
projectFormLib = res.form
|
||||
} else {
|
||||
projectFormLib = forms[args["--form"] as TForms]
|
||||
projectFormLib = args["--form"] as AppGeneratorOptions["form"]
|
||||
}
|
||||
}
|
||||
|
||||
@@ -148,14 +146,17 @@ const determineTemplate = async () => {
|
||||
!args["--template"] ||
|
||||
(args["--template"] && !Object.keys(templates).includes(args["--template"].toLowerCase()))
|
||||
) {
|
||||
const choices: Array<{value: keyof typeof templates; title: string}> = [
|
||||
{value: "full", title: "Full - includes DB and auth (Recommended)"},
|
||||
{value: "minimal", title: "Minimal — no DB, no auth"},
|
||||
]
|
||||
|
||||
const res = await prompts({
|
||||
type: "select",
|
||||
name: "template",
|
||||
message: "Pick which template you'd like to use for your new blitz project",
|
||||
message: "Pick your new app template",
|
||||
initial: 0,
|
||||
choices: Object.entries(templates).map((c) => {
|
||||
return {title: c[0], value: c[0]}
|
||||
}),
|
||||
choices,
|
||||
})
|
||||
|
||||
projectTemplate = templates[res.template as TTemplate]
|
||||
@@ -203,7 +204,11 @@ const determinePkgManagerToInstallDeps = async () => {
|
||||
],
|
||||
})
|
||||
|
||||
projectPkgManger = res.pkgManager
|
||||
if (res.pkgManager === "skip") {
|
||||
projectPkgManger = PREFERABLE_PKG_MANAGER
|
||||
} else {
|
||||
projectPkgManger = res.pkgManager
|
||||
}
|
||||
|
||||
shouldInstallDeps = res.pkgManager !== "skip"
|
||||
} else {
|
||||
|
||||
@@ -15,7 +15,7 @@ const build: CliCommand = async () => {
|
||||
const config: ServerConfig = {
|
||||
rootFolder: process.cwd(),
|
||||
inspect: nextArgs["--inspect"],
|
||||
env: process.env.NODE_ENV === "production" ? "prod" : "dev",
|
||||
env: "prod",
|
||||
}
|
||||
|
||||
await import("../../utils/next-commands").then((i) => i.build(config))
|
||||
|
||||
@@ -124,7 +124,6 @@ async function main() {
|
||||
if (args["--env"]) {
|
||||
process.env.APP_ENV = args["--env"]
|
||||
}
|
||||
loadEnvConfig(process.cwd(), undefined, {error: console.error, info: console.info})
|
||||
|
||||
// Version is inlined into the file using taskr build pipeline
|
||||
if (args["_"].length === 0 && args["--version"]) {
|
||||
@@ -145,7 +144,7 @@ async function main() {
|
||||
}
|
||||
|
||||
process.env.NODE_ENV = process.env.NODE_ENV || defaultEnv
|
||||
|
||||
loadEnvConfig(process.cwd(), undefined, {error: console.error, info: console.info})
|
||||
// Make sure commands gracefully respect termination signals (e.g. from Docker)
|
||||
process.on("SIGTERM", () => process.exit(0))
|
||||
process.on("SIGINT", () => process.exit(0))
|
||||
|
||||
54
packages/blitz/src/cli/utils/codegen-tasks.ts
Normal file
54
packages/blitz/src/cli/utils/codegen-tasks.ts
Normal file
@@ -0,0 +1,54 @@
|
||||
import {generateManifest} from "./routes-manifest"
|
||||
import {log} from "../../logging"
|
||||
import resolveCwd from "resolve-cwd"
|
||||
import {join} from "path"
|
||||
import fs from "fs-extra"
|
||||
import {getPackageJson} from "./get-package-json"
|
||||
import {runPrisma} from "../../run-prisma"
|
||||
|
||||
export const codegenTasks = async () => {
|
||||
try {
|
||||
/*
|
||||
Updates the user's nextjs file and adds onRecoverableError to the hydrateRoot 3rd parameter object.
|
||||
We can remove this when https://github.com/vercel/next.js/pull/38207 is merged into next.js
|
||||
*/
|
||||
const nextDir = await resolveCwd("next")
|
||||
const nextClientIndex = join(nextDir, "../..", "client", "index.js")
|
||||
const readFile = await fs.readFile(nextClientIndex)
|
||||
const updatedFile = readFile
|
||||
.toString()
|
||||
.replace(
|
||||
/ReactDOM\.hydrateRoot\(.*?\);/,
|
||||
`ReactDOM.hydrateRoot(domEl, reactEl, process.env.NODE_ENV === 'development' ? {onRecoverableError: (err) => err.toString().includes("could not finish this Suspense boundary") ? null : console.error(err)} : undefined);`,
|
||||
)
|
||||
await fs.writeFile(nextClientIndex, updatedFile)
|
||||
log.success("Next.js was successfully patched with a React Suspense fix")
|
||||
} catch (err) {
|
||||
log.error(JSON.stringify(err, null, 2))
|
||||
}
|
||||
|
||||
try {
|
||||
await generateManifest()
|
||||
log.success("Routes manifest was successfully generated")
|
||||
|
||||
const {dependencies, devDependencies} = await getPackageJson()
|
||||
|
||||
const hasPrisma = Object.keys({...dependencies, ...devDependencies}).some(
|
||||
(name) => name === "prisma",
|
||||
)
|
||||
|
||||
if (hasPrisma) {
|
||||
let prismaSpinner = log.spinner(`Generating Prisma client`).start()
|
||||
const result = await runPrisma(["generate"], true)
|
||||
if (result.success) {
|
||||
prismaSpinner.succeed()
|
||||
} else {
|
||||
prismaSpinner.fail()
|
||||
console.log("\n" + result.stderr)
|
||||
process.exit(1)
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
log.error(JSON.stringify(err, null, 2))
|
||||
}
|
||||
}
|
||||
11
packages/blitz/src/cli/utils/get-package-json.ts
Normal file
11
packages/blitz/src/cli/utils/get-package-json.ts
Normal file
@@ -0,0 +1,11 @@
|
||||
import {existsSync} from "fs"
|
||||
import {readJSON} from "fs-extra"
|
||||
import {join} from "path"
|
||||
|
||||
export const getPackageJson = async () => {
|
||||
const pkgJsonPath = join(process.cwd(), "package.json")
|
||||
if (existsSync(pkgJsonPath)) {
|
||||
return readJSON(pkgJsonPath)
|
||||
}
|
||||
return {}
|
||||
}
|
||||
@@ -9,10 +9,11 @@ import {
|
||||
} from "./next-utils"
|
||||
import {checkLatestVersion} from "./check-latest-version"
|
||||
import {readBlitzConfig} from "../../server-utils"
|
||||
import {codegenTasks} from "./codegen-tasks"
|
||||
|
||||
export async function build(config: ServerConfig) {
|
||||
const {rootFolder, nextBin, watch} = await normalize(config)
|
||||
|
||||
await codegenTasks()
|
||||
await nextBuild(nextBin, rootFolder, {} as any, config)
|
||||
if (customServerExists()) await buildCustomServer({watch})
|
||||
}
|
||||
|
||||
@@ -590,7 +590,7 @@ export async function stopWatcher(): Promise<void> {
|
||||
if (!webpackWatcher) {
|
||||
return
|
||||
}
|
||||
console.log("stopWatcher")
|
||||
|
||||
webpackWatcher.close()
|
||||
webpackWatcher = null
|
||||
}
|
||||
|
||||
@@ -60,3 +60,11 @@ export function createSetupServer<TMiddleware extends RequestMiddleware, TExport
|
||||
) {
|
||||
return setupServerConstructor
|
||||
}
|
||||
|
||||
export const BlitzServerMiddleware = <
|
||||
TMiddleware extends RequestMiddleware<any, any> = RequestMiddleware,
|
||||
>(
|
||||
middleware: TMiddleware,
|
||||
): BlitzServerPlugin => ({
|
||||
requestMiddlewares: [middleware],
|
||||
})
|
||||
|
||||
@@ -1,5 +1,22 @@
|
||||
# @blitzjs/codemod
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [91aa5356]
|
||||
- Updated dependencies [928e840b]
|
||||
- Updated dependencies [240f3f34]
|
||||
- Updated dependencies [55b1cb20]
|
||||
- Updated dependencies [4d7d126d]
|
||||
- Updated dependencies [890b0c0c]
|
||||
- Updated dependencies [807a2b56]
|
||||
- Updated dependencies [a3e6c49c]
|
||||
- Updated dependencies [065db256]
|
||||
- Updated dependencies [f202aac1]
|
||||
- @blitzjs/generator@2.0.0-alpha.66
|
||||
- blitz@2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/codemod",
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"dev": "watch unbuild src --wait=0.2",
|
||||
@@ -25,9 +25,9 @@
|
||||
"@babel/plugin-proposal-class-properties": "7.17.12",
|
||||
"@babel/plugin-syntax-jsx": "7.17.12",
|
||||
"@babel/plugin-syntax-typescript": "7.17.12",
|
||||
"@blitzjs/generator": "2.0.0-alpha.65",
|
||||
"@blitzjs/generator": "2.0.0-alpha.66",
|
||||
"arg": "5.0.1",
|
||||
"blitz": "2.0.0-alpha.65",
|
||||
"blitz": "2.0.0-alpha.66",
|
||||
"chalk": "^4.1.0",
|
||||
"cross-spawn": "7.0.3",
|
||||
"debug": "4.3.3",
|
||||
|
||||
@@ -1,5 +1,7 @@
|
||||
# @blitzjs/config
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
## 2.0.0-alpha.64
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
{
|
||||
"name": "@blitzjs/config",
|
||||
"private": true,
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@typescript-eslint/eslint-plugin": "5.9.1",
|
||||
|
||||
@@ -1,5 +1,16 @@
|
||||
# @blitzjs/generator
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 91aa5356: Include `.env.test` file to the generator templates
|
||||
- 890b0c0c: Improve `blitz new` messaging and fix minor issues
|
||||
- 807a2b56: Fixes peer dependency warnings
|
||||
- a3e6c49c: Fixes the supports-color warning for pnpm
|
||||
- 065db256: Update new app templates to use blitz-rpc's resolver function
|
||||
- f202aac1: Mocks @blitzjs/auth instead of blitz inside the forgotPassword mutation test & hardcodes blitz package version types instead of just using the alpha tag.
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
## 2.0.0-alpha.64
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/generator",
|
||||
"version": "2.0.0-alpha.65",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"scripts": {
|
||||
"dev": "watch unbuild src --wait=0.2",
|
||||
"build": "unbuild && pnpm build:templates",
|
||||
@@ -40,12 +40,13 @@
|
||||
"pluralize": "8.0.0",
|
||||
"prettier": "^2.5.1",
|
||||
"recast": "0.20.5",
|
||||
"supports-color": "8.1.1",
|
||||
"tslog": "3.3.1",
|
||||
"username": "5.1.0",
|
||||
"vinyl": "2.2.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "2.0.0-alpha.65",
|
||||
"@blitzjs/config": "2.0.0-alpha.66",
|
||||
"@juanm04/cpx": "2.0.1",
|
||||
"@types/babel__core": "7.1.19",
|
||||
"@types/diff": "5.0.2",
|
||||
@@ -70,8 +71,5 @@
|
||||
},
|
||||
"publishConfig": {
|
||||
"access": "public"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"react": "*"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -302,7 +302,7 @@ export abstract class Generator<
|
||||
return path.join(
|
||||
__dirname,
|
||||
"..",
|
||||
process.env.NODE_ENV === "test" ? "./templates" : "./dist/templates",
|
||||
process.env.NODE_ENV === "test" ? "./templates" : "./templates",
|
||||
this.sourceRoot.path,
|
||||
...paths,
|
||||
)
|
||||
|
||||
@@ -27,7 +27,7 @@ export interface AppGeneratorOptions extends GeneratorOptions {
|
||||
version: string
|
||||
skipInstall: boolean
|
||||
skipGit: boolean
|
||||
form?: "React Final Form" | "React Hook Form" | "Formik"
|
||||
form?: "finalform" | "hookform" | "formik"
|
||||
onPostInstall?: () => Promise<void>
|
||||
}
|
||||
|
||||
@@ -126,6 +126,9 @@ export class AppGenerator extends Generator<AppGeneratorOptions> {
|
||||
pkg.dependencies = newDependencies
|
||||
pkg.devDependencies = newDevDependencies
|
||||
pkg.dependencies.blitz = blitzDependencyVersion
|
||||
pkg.dependencies["@blitzjs/next"] = blitzDependencyVersion
|
||||
pkg.dependencies["@blitzjs/rpc"] = blitzDependencyVersion
|
||||
pkg.dependencies["@blitzjs/auth"] = blitzDependencyVersion
|
||||
|
||||
const fallbackUsed = dependenciesUsedFallback || devDependenciesUsedFallback
|
||||
|
||||
@@ -299,21 +302,18 @@ export class AppGenerator extends Generator<AppGeneratorOptions> {
|
||||
assert(pkg, "couldn't find package.json")
|
||||
|
||||
const ext = this.options.useTs ? "tsx" : "js"
|
||||
let type: string = ""
|
||||
|
||||
switch (this.options.form) {
|
||||
case "React Final Form":
|
||||
type = "finalform"
|
||||
const type = this.options.form
|
||||
switch (type) {
|
||||
case "finalform":
|
||||
pkg.dependencies["final-form"] = "4.x"
|
||||
pkg.dependencies["react-final-form"] = "6.x"
|
||||
break
|
||||
case "React Hook Form":
|
||||
type = "hookform"
|
||||
case "hookform":
|
||||
pkg.dependencies["react-hook-form"] = "7.x"
|
||||
pkg.dependencies["@hookform/resolvers"] = "2.x"
|
||||
break
|
||||
case "Formik":
|
||||
type = "formik"
|
||||
case "formik":
|
||||
pkg.dependencies["formik"] = "2.x"
|
||||
break
|
||||
}
|
||||
|
||||
5
packages/generator/templates/app/.env.test
Normal file
5
packages/generator/templates/app/.env.test
Normal file
@@ -0,0 +1,5 @@
|
||||
# SQLite is ready to go out of the box, but you can switch to Postgres
|
||||
# by first changing the provider from "sqlite" to "postgres" in the Prisma
|
||||
# schema file and by second swapping the DATABASE_URL below.
|
||||
DATABASE_URL="file:./db_test.sqlite"
|
||||
# DATABASE_URL=postgresql://__username__@localhost:5432/__name___test
|
||||
@@ -1,9 +1,9 @@
|
||||
import { NotFoundError, AuthenticationError } from "blitz"
|
||||
import { resolver } from "@blitzjs/rpc"
|
||||
import { SecurePassword } from "@blitzjs/auth"
|
||||
import db from "db"
|
||||
import { authenticateUser } from "./login"
|
||||
import { ChangePassword } from "../validations"
|
||||
import { resolver } from "@blitzjs/rpc"
|
||||
import { SecurePassword } from "@blitzjs/auth"
|
||||
|
||||
export default resolver.pipe(
|
||||
resolver.zod(ChangePassword),
|
||||
|
||||
@@ -9,8 +9,8 @@ beforeEach(async () => {
|
||||
})
|
||||
|
||||
const generatedToken = "plain-token"
|
||||
jest.mock("blitz", () => ({
|
||||
...jest.requireActual<Record<string, unknown>>("blitz")!,
|
||||
jest.mock("@blitzjs/auth", () => ({
|
||||
...jest.requireActual<Record<string, unknown>>("@blitzjs/auth")!,
|
||||
generateToken: () => generatedToken,
|
||||
}))
|
||||
jest.mock("preview-email", () => jest.fn())
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import { SecurePassword, hash256 } from "@blitzjs/auth"
|
||||
import { resolver } from "@blitzjs/rpc"
|
||||
import db from "db"
|
||||
import { ResetPassword } from "../validations"
|
||||
import login from "./login"
|
||||
@@ -8,10 +9,9 @@ export class ResetPasswordError extends Error {
|
||||
message = "Reset password link is invalid or it has expired."
|
||||
}
|
||||
|
||||
export default async function resetPassword(input, ctx) {
|
||||
ResetPassword.parse(input)
|
||||
export default resolver.pipe(resolver.zod(ResetPassword), async ({ password, token }, ctx) => {
|
||||
// 1. Try to find this token in the database
|
||||
const hashedToken = hash256(input.token)
|
||||
const hashedToken = hash256(token)
|
||||
const possibleToken = await db.token.findFirst({
|
||||
where: { hashedToken, type: "RESET_PASSWORD" },
|
||||
include: { user: true },
|
||||
@@ -32,7 +32,7 @@ export default async function resetPassword(input, ctx) {
|
||||
}
|
||||
|
||||
// 5. Since token is valid, now we can update the user's password
|
||||
const hashedPassword = await SecurePassword.hash(input.password.trim())
|
||||
const hashedPassword = await SecurePassword.hash(password.trim())
|
||||
const user = await db.user.update({
|
||||
where: { id: savedToken.userId },
|
||||
data: { hashedPassword },
|
||||
@@ -42,7 +42,7 @@ export default async function resetPassword(input, ctx) {
|
||||
await db.session.deleteMany({ where: { userId: user.id } })
|
||||
|
||||
// 7. Now log the user in with the new credentials
|
||||
await login({ email: user.email, password: input.password }, ctx)
|
||||
await login({ email: user.email, password }, ctx)
|
||||
|
||||
return true
|
||||
}
|
||||
})
|
||||
|
||||
@@ -1,21 +1,16 @@
|
||||
import db from "db"
|
||||
import { SecurePassword } from "@blitzjs/auth"
|
||||
import { resolver } from "@blitzjs/rpc"
|
||||
import db from "db"
|
||||
import { Role } from "types"
|
||||
import { Signup } from "../validations"
|
||||
|
||||
export default async function signup(input, ctx) {
|
||||
const blitzContext = ctx
|
||||
|
||||
const hashedPassword = await SecurePassword.hash((input.password as string) || "test-password")
|
||||
const email = (input.email as string) || "test" + Math.random() + "@test.com"
|
||||
export default resolver.pipe(resolver.zod(Signup), async ({ email, password }, ctx) => {
|
||||
const hashedPassword = await SecurePassword.hash(password.trim())
|
||||
const user = await db.user.create({
|
||||
data: { email, hashedPassword, role: "user" },
|
||||
data: { email: email.toLowerCase().trim(), hashedPassword, role: "USER" },
|
||||
select: { id: true, name: true, email: true, role: true },
|
||||
})
|
||||
|
||||
await blitzContext.session.$create({
|
||||
userId: user.id,
|
||||
role: user.role as Role,
|
||||
})
|
||||
|
||||
return { userId: blitzContext.session.userId, ...user, email: input.email }
|
||||
}
|
||||
await ctx.session.$create({ userId: user.id, role: user.role as Role })
|
||||
return user
|
||||
})
|
||||
|
||||
5
packages/generator/templates/minimalapp/.env.test
Normal file
5
packages/generator/templates/minimalapp/.env.test
Normal file
@@ -0,0 +1,5 @@
|
||||
# SQLite is ready to go out of the box, but you can switch to Postgres
|
||||
# by first changing the provider from "sqlite" to "postgres" in the Prisma
|
||||
# schema file and by second swapping the DATABASE_URL below.
|
||||
DATABASE_URL="file:./db_test.sqlite"
|
||||
# DATABASE_URL=postgresql://__username__@localhost:5432/__name___test
|
||||
@@ -25,7 +25,7 @@
|
||||
"@typescript-eslint/parser": "5.9.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "2.0.0-alpha.65",
|
||||
"@blitzjs/config": "2.0.0-alpha.66",
|
||||
"@types/react": "18.0.1",
|
||||
"@types/react-dom": "17.0.14",
|
||||
"react": "18.0.0",
|
||||
|
||||
1413
pnpm-lock.yaml
generated
1413
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user