Compare commits
16 Commits
blitz@2.0.
...
v2.0.0-alp
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0bc107fd7f | ||
|
|
cb55ed266d | ||
|
|
271c58ac62 | ||
|
|
06427f67f2 | ||
|
|
f120f6723a | ||
|
|
bac5e740ba | ||
|
|
630c718129 | ||
|
|
078fe47419 | ||
|
|
8dfaad088d | ||
|
|
dd299ae89f | ||
|
|
41608c4c34 | ||
|
|
70b334a2f7 | ||
|
|
f0ca738d56 | ||
|
|
1010858446 | ||
|
|
ebd74b4e97 | ||
|
|
8870580710 |
@@ -3660,6 +3660,16 @@
|
||||
"doc",
|
||||
"code"
|
||||
]
|
||||
},
|
||||
{
|
||||
"login": "oltdaniel",
|
||||
"name": "Daniel Oltmanns",
|
||||
"avatar_url": "https://avatars.githubusercontent.com/u/53529846?v=4",
|
||||
"profile": "oltdaniel.eu",
|
||||
"contributions": [
|
||||
"doc",
|
||||
"code"
|
||||
]
|
||||
}
|
||||
],
|
||||
"contributorsPerLine": 7,
|
||||
|
||||
5
.changeset/blue-pigs-tan.md
Normal file
5
.changeset/blue-pigs-tan.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/codemod": patch
|
||||
---
|
||||
|
||||
Throw error if cookiePrefix is undefined when running codemod
|
||||
5
.changeset/clever-radios-lie.md
Normal file
5
.changeset/clever-radios-lie.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/codemod": patch
|
||||
---
|
||||
Add DocumentProps & DocumentContext to the codemod import map
|
||||
|
||||
5
.changeset/curly-rules-speak.md
Normal file
5
.changeset/curly-rules-speak.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Comment out generate command import until we add the full support back
|
||||
6
.changeset/great-candles-stare.md
Normal file
6
.changeset/great-candles-stare.md
Normal file
@@ -0,0 +1,6 @@
|
||||
---
|
||||
"@blitzjs/rpc": patch
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Use internal branded blitz logger for @blitzjs/rpc
|
||||
5
.changeset/kind-walls-suffer.md
Normal file
5
.changeset/kind-walls-suffer.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Run codegen tasks on blitz dev command
|
||||
@@ -22,6 +22,7 @@
|
||||
},
|
||||
"changesets": [
|
||||
"big-phones-bow",
|
||||
"blue-pigs-tan",
|
||||
"breezy-cameras-double",
|
||||
"breezy-moose-behave",
|
||||
"bright-mangos-run",
|
||||
@@ -29,8 +30,10 @@
|
||||
"calm-nails-wait",
|
||||
"calm-tomatoes-drive",
|
||||
"clean-walls-wink",
|
||||
"clever-radios-lie",
|
||||
"cool-doors-invent",
|
||||
"cool-horses-check",
|
||||
"curly-rules-speak",
|
||||
"curly-seas-serve",
|
||||
"dirty-monkeys-greet",
|
||||
"dirty-planets-chew",
|
||||
@@ -52,6 +55,7 @@
|
||||
"good-insects-wink",
|
||||
"gorgeous-buses-scream",
|
||||
"gorgeous-games-obey",
|
||||
"great-candles-stare",
|
||||
"great-months-train",
|
||||
"great-terms-rescue",
|
||||
"green-papayas-do",
|
||||
@@ -62,6 +66,7 @@
|
||||
"hot-cups-rhyme",
|
||||
"hot-drinks-approve",
|
||||
"hungry-baboons-swim",
|
||||
"kind-walls-suffer",
|
||||
"late-steaks-give",
|
||||
"lemon-games-press",
|
||||
"lemon-seas-push",
|
||||
@@ -102,20 +107,25 @@
|
||||
"red-badgers-retire",
|
||||
"rich-chairs-invent",
|
||||
"rich-queens-travel",
|
||||
"rotten-rocks-remember",
|
||||
"shaggy-carpets-brake",
|
||||
"sharp-falcons-begin",
|
||||
"shy-olives-hang",
|
||||
"shy-pumpkins-try",
|
||||
"silent-colts-reply",
|
||||
"silly-apricots-share",
|
||||
"six-apricots-kick",
|
||||
"slimy-humans-impress",
|
||||
"slimy-needles-taste",
|
||||
"slow-walls-poke",
|
||||
"small-socks-confess",
|
||||
"smooth-planets-admire",
|
||||
"smooth-stingrays-drum",
|
||||
"smooth-tools-train",
|
||||
"soft-adults-smell",
|
||||
"sour-lemons-hunt",
|
||||
"spicy-beds-float",
|
||||
"stale-jobs-drum",
|
||||
"strong-apes-reply",
|
||||
"stupid-walls-sell",
|
||||
"sweet-kiwis-cross",
|
||||
@@ -132,12 +142,14 @@
|
||||
"three-lies-pull",
|
||||
"tidy-clouds-smoke",
|
||||
"tough-toes-pull",
|
||||
"twelve-hornets-sip",
|
||||
"twelve-lemons-smile",
|
||||
"twenty-beans-pump",
|
||||
"two-carpets-rhyme",
|
||||
"two-eyes-knock",
|
||||
"two-kiwis-help",
|
||||
"two-tigers-type",
|
||||
"unlucky-avocados-fix",
|
||||
"unlucky-papayas-sleep",
|
||||
"violet-bags-leave",
|
||||
"violet-lions-help",
|
||||
|
||||
5
.changeset/rotten-rocks-remember.md
Normal file
5
.changeset/rotten-rocks-remember.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"blitz": patch
|
||||
---
|
||||
|
||||
Run codegen tasks after creating a new app if user chose yarn as a package manager
|
||||
5
.changeset/shaggy-carpets-brake.md
Normal file
5
.changeset/shaggy-carpets-brake.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Fix template path for the generator
|
||||
5
.changeset/slimy-humans-impress.md
Normal file
5
.changeset/slimy-humans-impress.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Remove trailing comma from tsconfig.json file in the new app template"
|
||||
5
.changeset/smooth-tools-train.md
Normal file
5
.changeset/smooth-tools-train.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Add ts-jest to dependencies in new app templates
|
||||
5
.changeset/stale-jobs-drum.md
Normal file
5
.changeset/stale-jobs-drum.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/codemod": patch
|
||||
---
|
||||
|
||||
Set correct packages versions in package.json with upgrade-legacy codemod
|
||||
5
.changeset/twelve-hornets-sip.md
Normal file
5
.changeset/twelve-hornets-sip.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/codemod": patch
|
||||
---
|
||||
|
||||
Fix codemod to accept a self closing `DocumentHead` in the `_document` page
|
||||
5
.changeset/unlucky-avocados-fix.md
Normal file
5
.changeset/unlucky-avocados-fix.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"@blitzjs/generator": patch
|
||||
---
|
||||
|
||||
Add `@testing-library/jest-dom` to new app dependecies
|
||||
@@ -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-388-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-389-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">
|
||||
@@ -708,6 +708,7 @@ Thanks to these wonderful people ([emoji key](https://allcontributors.org/docs/e
|
||||
<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>
|
||||
<td align="center"><a href="oltdaniel.eu"><img src="https://avatars.githubusercontent.com/u/53529846?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Daniel Oltmanns</b></sub></a><br /><a href="https://github.com/blitz-js/blitz/commits?author=oltdaniel" title="Documentation">📖</a> <a href="https://github.com/blitz-js/blitz/commits?author=oltdaniel" 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.66",
|
||||
"blitz": "workspace:2.0.0-alpha.68",
|
||||
"next": "12.2.0",
|
||||
"prisma": "4.0.0",
|
||||
"react": "18.0.0",
|
||||
|
||||
@@ -33,7 +33,7 @@
|
||||
"prettier": "^2.5.1",
|
||||
"prettier-plugin-prisma": "3.8.0",
|
||||
"pretty-quick": "3.1.3",
|
||||
"turbo": "1.1.5",
|
||||
"turbo": "1.4.2",
|
||||
"vitest": "0.8.2",
|
||||
"wait-on": "6.0.1"
|
||||
},
|
||||
|
||||
@@ -1,5 +1,21 @@
|
||||
# @blitzjs/auth
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [271c58ac]
|
||||
- Updated dependencies [630c7181]
|
||||
- Updated dependencies [f0ca738d]
|
||||
- Updated dependencies [41608c4c]
|
||||
- blitz@2.0.0-alpha.68
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- blitz@2.0.0-alpha.67
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/auth",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"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.66",
|
||||
"blitz": "2.0.0-alpha.68",
|
||||
"cookie": "0.4.1",
|
||||
"cookie-session": "2.0.0",
|
||||
"debug": "4.3.3",
|
||||
@@ -40,7 +40,7 @@
|
||||
"url": "0.11.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.68",
|
||||
"@testing-library/react": "13.0.0",
|
||||
"@testing-library/react-hooks": "7.0.2",
|
||||
"@types/cookie": "0.4.1",
|
||||
|
||||
@@ -1,5 +1,18 @@
|
||||
# @blitzjs/next
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [630c7181]
|
||||
- @blitzjs/rpc@2.0.0-alpha.68
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- @blitzjs/rpc@2.0.0-alpha.67
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/next",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"dev": "pnpm predev && pnpm watch unbuild src --wait=0.2",
|
||||
@@ -24,7 +24,7 @@
|
||||
"eslint.js"
|
||||
],
|
||||
"dependencies": {
|
||||
"@blitzjs/rpc": "2.0.0-alpha.66",
|
||||
"@blitzjs/rpc": "2.0.0-alpha.68",
|
||||
"@tanstack/react-query": "4.0.10",
|
||||
"@types/hoist-non-react-statics": "3.3.1",
|
||||
"debug": "4.3.3",
|
||||
@@ -34,7 +34,7 @@
|
||||
"supports-color": "8.1.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.68",
|
||||
"@testing-library/dom": "8.13.0",
|
||||
"@testing-library/jest-dom": "5.16.3",
|
||||
"@testing-library/react": "13.0.0",
|
||||
@@ -44,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.66",
|
||||
"blitz": "2.0.0-alpha.68",
|
||||
"cross-spawn": "7.0.3",
|
||||
"find-up": "4.1.0",
|
||||
"next": "12.2.0",
|
||||
|
||||
@@ -1,5 +1,18 @@
|
||||
# @blitzjs/rpc
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 630c7181: Use internal branded blitz logger for @blitzjs/rpc
|
||||
- @blitzjs/auth@2.0.0-alpha.68
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- @blitzjs/auth@2.0.0-alpha.67
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/rpc",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"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,7 +20,7 @@
|
||||
"dist/**"
|
||||
],
|
||||
"dependencies": {
|
||||
"@blitzjs/auth": "2.0.0-alpha.66",
|
||||
"@blitzjs/auth": "2.0.0-alpha.68",
|
||||
"@tanstack/react-query": "4.0.10",
|
||||
"b64-lite": "1.4.0",
|
||||
"bad-behavior": "1.0.1",
|
||||
@@ -30,11 +30,11 @@
|
||||
"supports-color": "8.1.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.68",
|
||||
"@types/debug": "4.1.7",
|
||||
"@types/react": "18.0.1",
|
||||
"@types/react-dom": "17.0.14",
|
||||
"blitz": "2.0.0-alpha.66",
|
||||
"blitz": "2.0.0-alpha.68",
|
||||
"next": "12.2.0",
|
||||
"react": "18.0.0",
|
||||
"react-dom": "18.0.0",
|
||||
|
||||
@@ -1,7 +1,8 @@
|
||||
import {assert, Ctx, prettyMs} from "blitz"
|
||||
import {assert, baseLogger, Ctx, newLine, prettyMs} from "blitz"
|
||||
import {NextApiRequest, NextApiResponse} from "next"
|
||||
import {deserialize, serialize as superjsonSerialize} from "superjson"
|
||||
import {resolve} from "path"
|
||||
import chalk from "chalk"
|
||||
|
||||
// TODO - optimize end user server bundles by not exporting all client stuff here
|
||||
export * from "./index-browser"
|
||||
@@ -156,6 +157,13 @@ export function rpcHandler(config: RpcConfig) {
|
||||
const relativeRoutePath = (req.query.blitz as string[])?.join("/")
|
||||
const routePath = "/" + relativeRoutePath
|
||||
|
||||
const log = baseLogger().getChildLogger({
|
||||
prefix: [routePath.replace("/api/rpc/", "") + "()"],
|
||||
})
|
||||
const customChalk = new chalk.Instance({
|
||||
level: log.settings.type === "json" ? 0 : chalk.level,
|
||||
})
|
||||
|
||||
const loadableResolver = resolverMap?.[routePath]
|
||||
if (!loadableResolver) {
|
||||
throw new Error("No resolver for path: " + routePath)
|
||||
@@ -175,7 +183,7 @@ export function rpcHandler(config: RpcConfig) {
|
||||
|
||||
if (typeof req.body.params === "undefined") {
|
||||
const error = {message: "Request body is missing the `params` key"}
|
||||
console.error(error.message)
|
||||
log.error(error.message)
|
||||
res.status(400).json({
|
||||
result: null,
|
||||
error,
|
||||
@@ -189,11 +197,11 @@ export function rpcHandler(config: RpcConfig) {
|
||||
meta: req.body.meta?.params,
|
||||
})
|
||||
|
||||
console.info("Starting with input:", data ? data : JSON.stringify(data))
|
||||
log.info(customChalk.dim("Starting with input:"), data ? data : JSON.stringify(data))
|
||||
const startTime = Date.now()
|
||||
const result = await resolver(data, (res as any).blitzCtx)
|
||||
const resolverDuration = Date.now() - startTime
|
||||
console.debug("Result:", result ? result : JSON.stringify(result))
|
||||
log.debug(customChalk.dim("Result:"), result ? result : JSON.stringify(result))
|
||||
|
||||
const serializerStartTime = Date.now()
|
||||
const serializedResult = superjsonSerialize(result)
|
||||
@@ -207,16 +215,22 @@ export function rpcHandler(config: RpcConfig) {
|
||||
result: serializedResult.meta,
|
||||
},
|
||||
})
|
||||
console.debug(`Next.js serialization:${prettyMs(Date.now() - nextSerializerStartTime)}`)
|
||||
log.debug(
|
||||
customChalk.dim(
|
||||
`Next.js serialization:${prettyMs(Date.now() - nextSerializerStartTime)}`,
|
||||
),
|
||||
)
|
||||
const serializerDuration = Date.now() - serializerStartTime
|
||||
const duration = Date.now() - startTime
|
||||
|
||||
console.info(
|
||||
`Finished: resolver:${prettyMs(resolverDuration)} serializer:${prettyMs(
|
||||
serializerDuration,
|
||||
)} total:${prettyMs(duration)}`,
|
||||
log.info(
|
||||
customChalk.dim(
|
||||
`Finished: resolver:${prettyMs(resolverDuration)} serializer:${prettyMs(
|
||||
serializerDuration,
|
||||
)} total:${prettyMs(duration)}`,
|
||||
),
|
||||
)
|
||||
console.log("\n")
|
||||
newLine()
|
||||
|
||||
return
|
||||
} catch (error: any) {
|
||||
@@ -226,8 +240,8 @@ export function rpcHandler(config: RpcConfig) {
|
||||
|
||||
config.onError?.(error)
|
||||
|
||||
console.error(error)
|
||||
console.log("\n")
|
||||
log.error(error)
|
||||
newLine()
|
||||
|
||||
if (!error.statusCode) {
|
||||
error.statusCode = 500
|
||||
@@ -246,7 +260,7 @@ export function rpcHandler(config: RpcConfig) {
|
||||
}
|
||||
} else {
|
||||
// Everything else is error
|
||||
console.warn(`${req.method} method not supported`)
|
||||
log.warn(`${req.method} method not supported`)
|
||||
res.status(404).end()
|
||||
return
|
||||
}
|
||||
|
||||
@@ -1,5 +1,25 @@
|
||||
# blitz
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 271c58ac: Comment out generate command import until we add the full support back
|
||||
- 630c7181: Use internal branded blitz logger for @blitzjs/rpc
|
||||
- f0ca738d: Run codegen tasks on blitz dev command
|
||||
- 41608c4c: Run codegen tasks after creating a new app if user chose yarn as a package manager
|
||||
- Updated dependencies [70b334a2]
|
||||
- Updated dependencies [dd299ae8]
|
||||
- Updated dependencies [078fe474]
|
||||
- @blitzjs/generator@2.0.0-alpha.68
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [ebd74b4e]
|
||||
- @blitzjs/generator@2.0.0-alpha.67
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "blitz",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"scripts": {
|
||||
"build": "unbuild",
|
||||
"dev": "watch unbuild src --wait=0.2",
|
||||
@@ -23,7 +23,7 @@
|
||||
"blitz": "bin/blitz"
|
||||
},
|
||||
"dependencies": {
|
||||
"@blitzjs/generator": "2.0.0-alpha.66",
|
||||
"@blitzjs/generator": "2.0.0-alpha.68",
|
||||
"arg": "5.0.1",
|
||||
"boxen": "7.0.0",
|
||||
"chalk": "^4.1.0",
|
||||
@@ -55,7 +55,7 @@
|
||||
"watchpack": "2.1.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.66",
|
||||
"@blitzjs/config": "workspace:2.0.0-alpha.68",
|
||||
"@types/cookie": "0.4.1",
|
||||
"@types/cross-spawn": "6.0.2",
|
||||
"@types/debug": "4.1.7",
|
||||
|
||||
@@ -1,22 +1,14 @@
|
||||
import arg from "arg"
|
||||
import {CliCommand} from "../index"
|
||||
import prompts from "prompts"
|
||||
import {
|
||||
capitalize,
|
||||
FormGenerator,
|
||||
ModelGenerator,
|
||||
MutationGenerator,
|
||||
MutationsGenerator,
|
||||
PageGenerator,
|
||||
pluralCamel,
|
||||
pluralPascal,
|
||||
QueriesGenerator,
|
||||
QueryGenerator,
|
||||
singleCamel,
|
||||
singlePascal,
|
||||
uncapitalize,
|
||||
} from "@blitzjs/generator"
|
||||
import arg from "arg"
|
||||
import {CliCommand} from "../index"
|
||||
import prompts from "prompts"
|
||||
import chalk from "chalk"
|
||||
|
||||
const getIsTypeScript = async () =>
|
||||
require("fs").existsSync(require("path").join(process.cwd(), "tsconfig.json"))
|
||||
@@ -47,21 +39,21 @@ function ModelNames(input: string = "") {
|
||||
}
|
||||
|
||||
const generatorMap = {
|
||||
[ResourceType.All]: [
|
||||
PageGenerator,
|
||||
FormGenerator,
|
||||
QueriesGenerator,
|
||||
MutationsGenerator,
|
||||
ModelGenerator,
|
||||
],
|
||||
[ResourceType.Crud]: [MutationsGenerator, QueriesGenerator],
|
||||
[ResourceType.Model]: [ModelGenerator],
|
||||
[ResourceType.Pages]: [PageGenerator, FormGenerator],
|
||||
[ResourceType.Queries]: [QueriesGenerator],
|
||||
[ResourceType.Query]: [QueryGenerator],
|
||||
[ResourceType.Mutations]: [MutationsGenerator],
|
||||
[ResourceType.Mutation]: [MutationGenerator],
|
||||
[ResourceType.Resource]: [QueriesGenerator, MutationsGenerator, ModelGenerator],
|
||||
// [ResourceType.All]: [
|
||||
// PageGenerator,
|
||||
// FormGenerator,
|
||||
// QueriesGenerator,
|
||||
// MutationsGenerator,
|
||||
// ModelGenerator,
|
||||
// ],
|
||||
// [ResourceType.Crud]: [MutationsGenerator, QueriesGenerator],
|
||||
// [ResourceType.Model]: [ModelGenerator],
|
||||
// [ResourceType.Pages]: [PageGenerator, FormGenerator],
|
||||
// [ResourceType.Queries]: [QueriesGenerator],
|
||||
// [ResourceType.Query]: [QueryGenerator],
|
||||
// [ResourceType.Mutations]: [MutationsGenerator],
|
||||
// [ResourceType.Mutation]: [MutationGenerator],
|
||||
// [ResourceType.Resource]: [QueriesGenerator, MutationsGenerator, ModelGenerator],
|
||||
}
|
||||
|
||||
const args = arg(
|
||||
@@ -196,30 +188,30 @@ const getHelp = async () => {
|
||||
if (args["--help"]) {
|
||||
console.log(`
|
||||
# The 'crud' type will generate all queries & mutations for a model
|
||||
|
||||
|
||||
> blitz generate --type crud --name productVariant
|
||||
|
||||
# The 'all' generator will scaffold out everything possible for a model
|
||||
|
||||
|
||||
> blitz generate --type all --name products
|
||||
|
||||
# The '--context' flag will allow you to generate files in a nested folder
|
||||
|
||||
|
||||
> blitz generate --type pages --name projects --context admin
|
||||
|
||||
# Context can also be supplied in the model name directly
|
||||
|
||||
|
||||
> blitz generate --type pages --name admin/projects
|
||||
|
||||
# To generate nested routes for dependent models (e.g. Projects that contain Tasks), specify a parent model.
|
||||
# To generate nested routes for dependent models (e.g. Projects that contain Tasks), specify a parent model.
|
||||
For example, this command generates pages under app/tasks/pages/projects/[projectId]/tasks/
|
||||
|
||||
|
||||
> blitz generate --type all --name tasks --parent=projects
|
||||
|
||||
# Database models can also be generated directly from the CLI.
|
||||
Model fields can be specified with any generator that generates a database model ("all", "model", "resource").
|
||||
Model fields can be specified with any generator that generates a database model ("all", "model", "resource").
|
||||
Both of the commands below will generate the proper database model for a Task.
|
||||
|
||||
|
||||
> blitz generate --type model --name task name:string completed:boolean:default=false belongsTo:project?
|
||||
|
||||
> blitz generate --type all --name tasks name:string completed:boolean:default=false belongsTo:project?
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
import {loadEnvConfig} from "../../env-utils"
|
||||
import prompts from "prompts"
|
||||
import path from "path"
|
||||
import chalk from "chalk"
|
||||
@@ -6,8 +5,10 @@ import hasbin from "hasbin"
|
||||
import {CliCommand} from "../index"
|
||||
import arg from "arg"
|
||||
import {AppGenerator, AppGeneratorOptions, getLatestVersion} from "@blitzjs/generator"
|
||||
import {loadEnvConfig} from "../../utils/env"
|
||||
import {runPrisma} from "../../utils/run-prisma"
|
||||
import {checkLatestVersion} from "../utils/check-latest-version"
|
||||
import {runPrisma} from "../../run-prisma"
|
||||
import {codegenTasks} from "../utils/codegen-tasks"
|
||||
|
||||
const forms: Record<AppGeneratorOptions["form"], string> = {
|
||||
finalform: "React Final Form (recommended)",
|
||||
@@ -269,6 +270,10 @@ const newApp: CliCommand = async (argv) => {
|
||||
)
|
||||
const result = await runPrisma(["migrate", "dev", "--name", "Initial migration"], true)
|
||||
if (!result.success) throw new Error()
|
||||
|
||||
if (projectPkgManger === "yarn") {
|
||||
await codegenTasks()
|
||||
}
|
||||
} catch (error) {
|
||||
postInstallSteps.push(
|
||||
"blitz prisma migrate dev (when asked, you can name the migration anything)",
|
||||
|
||||
@@ -1,38 +1,6 @@
|
||||
import {Readable} from "stream"
|
||||
import {getCommandBin} from "../utils/config"
|
||||
import {CliCommand} from "../index"
|
||||
import arg from "arg"
|
||||
|
||||
let prismaBin: string
|
||||
|
||||
export const runPrisma = async (args: string[], silent = false) => {
|
||||
if (!prismaBin) {
|
||||
try {
|
||||
prismaBin = await getCommandBin("prisma")
|
||||
} catch (err) {
|
||||
throw err
|
||||
}
|
||||
}
|
||||
|
||||
const cp = require("cross-spawn").spawn(prismaBin, args, {
|
||||
stdio: silent ? "pipe" : "inherit",
|
||||
env: process.env,
|
||||
})
|
||||
|
||||
const cp_stderr: string[] = []
|
||||
if (silent) {
|
||||
cp.stderr.on("data", (chunk: Readable) => {
|
||||
cp_stderr.push(chunk.toString())
|
||||
})
|
||||
}
|
||||
|
||||
const code = await require("p-event")(cp, "exit", {rejectionEvents: []})
|
||||
|
||||
return {
|
||||
success: code === 0,
|
||||
stderr: silent ? cp_stderr.join("") : undefined,
|
||||
}
|
||||
}
|
||||
import {runPrisma} from "../../utils/run-prisma"
|
||||
|
||||
export const runPrismaExitOnError = async (...args: Parameters<typeof runPrisma>) => {
|
||||
const result = await runPrisma(...args)
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import arg from "arg"
|
||||
import spawn from "cross-spawn"
|
||||
|
||||
import {loadEnvConfig} from "../env-utils"
|
||||
import {loadEnvConfig} from "../utils/env"
|
||||
import {NON_STANDARD_NODE_ENV} from "./utils/constants"
|
||||
import {getCommandBin} from "./utils/config"
|
||||
import {readVersions} from "./utils/read-versions"
|
||||
@@ -31,7 +31,7 @@ const commands = {
|
||||
build: () => import("./commands/next/build").then((i) => i.build),
|
||||
start: () => import("./commands/next/start").then((i) => i.start),
|
||||
new: () => import("./commands/new").then((i) => i.newApp),
|
||||
generate: () => import("./commands/generate").then((i) => i.generate),
|
||||
// generate: () => import("./commands/generate").then((i) => i.generate),
|
||||
codegen: () => import("./commands/codegen").then((i) => i.codegen),
|
||||
db: () => import("./commands/db").then((i) => i.db),
|
||||
}
|
||||
@@ -41,7 +41,7 @@ const aliases: Record<string, keyof typeof commands> = {
|
||||
b: "build",
|
||||
s: "start",
|
||||
n: "new",
|
||||
g: "generate",
|
||||
// g: "generate",
|
||||
}
|
||||
|
||||
type Command = keyof typeof commands
|
||||
|
||||
@@ -4,7 +4,7 @@ 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"
|
||||
import {runPrisma} from "../../utils/run-prisma"
|
||||
|
||||
export const codegenTasks = async () => {
|
||||
try {
|
||||
@@ -41,7 +41,7 @@ export const codegenTasks = async () => {
|
||||
let prismaSpinner = log.spinner(`Generating Prisma client`).start()
|
||||
const result = await runPrisma(["generate"], true)
|
||||
if (result.success) {
|
||||
prismaSpinner.succeed()
|
||||
prismaSpinner.succeed(log.greenText("Generated Prisma client"))
|
||||
} else {
|
||||
prismaSpinner.fail()
|
||||
console.log("\n" + result.stderr)
|
||||
|
||||
@@ -8,7 +8,7 @@ import {
|
||||
buildCustomServer,
|
||||
} from "./next-utils"
|
||||
import {checkLatestVersion} from "./check-latest-version"
|
||||
import {readBlitzConfig} from "../../server-utils"
|
||||
import {readBlitzConfig} from "../../utils/server"
|
||||
import {codegenTasks} from "./codegen-tasks"
|
||||
|
||||
export async function build(config: ServerConfig) {
|
||||
@@ -20,6 +20,7 @@ export async function build(config: ServerConfig) {
|
||||
|
||||
export async function dev(config: ServerConfig) {
|
||||
const {rootFolder, nextBin} = await normalize({...config, env: "dev"})
|
||||
await codegenTasks()
|
||||
// void checkLatestVersion()
|
||||
if (customServerExists()) {
|
||||
console.log("Using your custom server")
|
||||
|
||||
@@ -58,17 +58,19 @@ export function readVersions() {
|
||||
return versions
|
||||
}
|
||||
|
||||
export function resolveVersionType(version: string) {
|
||||
export function resolveVersionType(
|
||||
version: string,
|
||||
): "alpha" | "beta" | "canary" | "stable" | "danger" | "latest" {
|
||||
if (version.includes("alpha")) {
|
||||
return "alpha" as const
|
||||
return "alpha"
|
||||
}
|
||||
|
||||
if (version.includes("beta")) {
|
||||
return "beta" as const
|
||||
return "beta"
|
||||
}
|
||||
|
||||
if (version.includes("danger")) {
|
||||
return "danger" as const
|
||||
return "danger"
|
||||
}
|
||||
|
||||
if (version.includes("canary")) {
|
||||
|
||||
@@ -79,8 +79,7 @@ if (typeof window !== "undefined" && process.env.NODE_ENV === "development") {
|
||||
}
|
||||
|
||||
export * from "./utils"
|
||||
export * from "./ts-utils"
|
||||
export * from "./types"
|
||||
export * from "./errors"
|
||||
export * from "./zod-utils"
|
||||
export * from "./prisma-utils"
|
||||
export * from "./utils/zod"
|
||||
export * from "./utils/prisma"
|
||||
|
||||
@@ -1,20 +1,14 @@
|
||||
import "./global"
|
||||
import {IncomingMessage, ServerResponse} from "http"
|
||||
import {Ctx} from "./types"
|
||||
// import {findBlitzConfigDirectory} from "./cli/utils/routes-manifest"
|
||||
// import {readFileSync} from "fs-extra"
|
||||
|
||||
export * from "./index-browser"
|
||||
export * from "./types"
|
||||
export * from "./prisma-utils"
|
||||
export * from "./run-prisma"
|
||||
export * from "./utils/run-prisma"
|
||||
export * from "./middleware"
|
||||
export * from "./paginate"
|
||||
export {baseLogger, newLine, log} from "./logging"
|
||||
export {startWatcher, stopWatcher} from "./cli/utils/routes-manifest"
|
||||
// const blitzConfig = findBlitzConfigDirectory() as string
|
||||
// const file = readFileSync(blitzConfig)
|
||||
// export const Routes = eval(file.toString())
|
||||
|
||||
export interface MiddlewareResponse<C extends Ctx = Ctx> extends ServerResponse {
|
||||
blitzCtx: C
|
||||
|
||||
@@ -92,6 +92,10 @@ const withProgress = (str: string) => {
|
||||
return withCaret(str)
|
||||
}
|
||||
|
||||
const greenText = (str: string) => {
|
||||
return `${c.green(str)}`
|
||||
}
|
||||
|
||||
/**
|
||||
* Logs a branded purple message to stdout.
|
||||
*
|
||||
@@ -182,6 +186,7 @@ export const log = {
|
||||
progress,
|
||||
spinner,
|
||||
success,
|
||||
greenText,
|
||||
error,
|
||||
variable,
|
||||
debug,
|
||||
|
||||
@@ -1,38 +0,0 @@
|
||||
export type AsyncFunc = (...args: any) => Promise<any>
|
||||
|
||||
/**
|
||||
* Infer the type of the parameter from function that takes a single argument
|
||||
*/
|
||||
export type FirstParam<F extends (...args: any) => Promise<any>> = Parameters<F>[0]
|
||||
|
||||
/**
|
||||
* If type has a Promise, unwrap it. Otherwise return the original type
|
||||
*/
|
||||
export type Await<T> = T extends PromiseLike<infer U> ? U : T
|
||||
|
||||
/**
|
||||
* Ensure the type is a promise
|
||||
*/
|
||||
export type EnsurePromise<T> = T extends PromiseLike<unknown> ? T : Promise<T>
|
||||
|
||||
/**
|
||||
* Get the return type of a function which returns a Promise.
|
||||
*/
|
||||
export type PromiseReturnType<T extends (...args: any) => Promise<any>> = Await<ReturnType<T>>
|
||||
|
||||
export interface CancellablePromise<T> extends Promise<T> {
|
||||
cancel?: Function
|
||||
}
|
||||
|
||||
export type UnionToIntersection<U> = (U extends any ? (k: U) => void : never) extends (
|
||||
k: infer I,
|
||||
) => void
|
||||
? I
|
||||
: never
|
||||
|
||||
export type Simplify<T> = {[P in keyof T]: T[P]}
|
||||
|
||||
export type AddParameters<
|
||||
TFunction extends (...args: any) => any,
|
||||
TParameters extends [...args: any],
|
||||
> = (...args: [...Parameters<TFunction>, ...TParameters]) => ReturnType<TFunction>
|
||||
@@ -5,3 +5,42 @@ export interface Ctx {}
|
||||
export interface RouteUrlObject extends Pick<UrlObject, "pathname" | "query"> {
|
||||
pathname: string
|
||||
}
|
||||
|
||||
export type AsyncFunc = (...args: any) => Promise<any>
|
||||
|
||||
/**
|
||||
* Infer the type of the parameter from function that takes a single argument
|
||||
*/
|
||||
export type FirstParam<F extends (...args: any) => Promise<any>> = Parameters<F>[0]
|
||||
|
||||
/**
|
||||
* If type has a Promise, unwrap it. Otherwise return the original type
|
||||
*/
|
||||
export type Await<T> = T extends PromiseLike<infer U> ? U : T
|
||||
|
||||
/**
|
||||
* Ensure the type is a promise
|
||||
*/
|
||||
export type EnsurePromise<T> = T extends PromiseLike<unknown> ? T : Promise<T>
|
||||
|
||||
/**
|
||||
* Get the return type of a function which returns a Promise.
|
||||
*/
|
||||
export type PromiseReturnType<T extends (...args: any) => Promise<any>> = Await<ReturnType<T>>
|
||||
|
||||
export interface CancellablePromise<T> extends Promise<T> {
|
||||
cancel?: Function
|
||||
}
|
||||
|
||||
export type UnionToIntersection<U> = (U extends any ? (k: U) => void : never) extends (
|
||||
k: infer I,
|
||||
) => void
|
||||
? I
|
||||
: never
|
||||
|
||||
export type Simplify<T> = {[P in keyof T]: T[P]}
|
||||
|
||||
export type AddParameters<
|
||||
TFunction extends (...args: any) => any,
|
||||
TParameters extends [...args: any],
|
||||
> = (...args: [...Parameters<TFunction>, ...TParameters]) => ReturnType<TFunction>
|
||||
|
||||
@@ -1,6 +1,4 @@
|
||||
import {RequestMiddleware} from "./index-server"
|
||||
import * as path from "path"
|
||||
import * as fs from "fs"
|
||||
import {RequestMiddleware} from "../index-server"
|
||||
|
||||
export function assert(condition: any, message: string): asserts condition {
|
||||
if (!condition) throw new Error(message)
|
||||
@@ -3,8 +3,8 @@ import {createServer, IncomingMessage, ServerResponse} from "http"
|
||||
import fetch from "node-fetch"
|
||||
import listen from "test-listen"
|
||||
import {Stream} from "stream"
|
||||
import {Middleware} from "./index-server"
|
||||
import {handleRequestWithMiddleware} from "./middleware"
|
||||
import {Middleware} from "../src/index-server"
|
||||
import {handleRequestWithMiddleware} from "../src/middleware"
|
||||
|
||||
export function sendData(res: ServerResponse, body: any): void {
|
||||
if (body === null || body === undefined) {
|
||||
@@ -1,5 +1,5 @@
|
||||
import {describe, it, expect} from "vitest"
|
||||
import {paginate} from "./paginate"
|
||||
import {paginate} from "../src/paginate"
|
||||
|
||||
describe("paginate", () => {
|
||||
const dummyPaginationPromises = {
|
||||
@@ -1,6 +1,6 @@
|
||||
import {describe, it, expect} from "vitest"
|
||||
import {z} from "zod"
|
||||
import {formatZodError, validateZodSchema} from "./zod-utils"
|
||||
import {formatZodError, validateZodSchema} from "../src/utils/zod"
|
||||
|
||||
const validateSchema = (schema: any, input: any) => {
|
||||
const result = schema.safeParse(input)
|
||||
@@ -1,5 +1,31 @@
|
||||
# @blitzjs/codemod
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 06427f67: Throw error if cookiePrefix is undefined when running codemod
|
||||
- f120f672: Add DocumentProps & DocumentContext to the codemod import map
|
||||
- 8dfaad08: Set correct packages versions in package.json with upgrade-legacy codemod
|
||||
- cb55ed26: Fix codemod to accept a self closing `DocumentHead` in the `_document` page
|
||||
- Updated dependencies [271c58ac]
|
||||
- Updated dependencies [630c7181]
|
||||
- Updated dependencies [f0ca738d]
|
||||
- Updated dependencies [41608c4c]
|
||||
- Updated dependencies [70b334a2]
|
||||
- Updated dependencies [dd299ae8]
|
||||
- Updated dependencies [078fe474]
|
||||
- blitz@2.0.0-alpha.68
|
||||
- @blitzjs/generator@2.0.0-alpha.68
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [ebd74b4e]
|
||||
- @blitzjs/generator@2.0.0-alpha.67
|
||||
- blitz@2.0.0-alpha.67
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/codemod",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"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.66",
|
||||
"@blitzjs/generator": "2.0.0-alpha.68",
|
||||
"arg": "5.0.1",
|
||||
"blitz": "2.0.0-alpha.66",
|
||||
"blitz": "2.0.0-alpha.68",
|
||||
"chalk": "^4.1.0",
|
||||
"cross-spawn": "7.0.3",
|
||||
"debug": "4.3.3",
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import j, {ImportDeclaration} from "jscodeshift"
|
||||
import j, {ImportDeclaration, ImportDefaultSpecifier, ImportSpecifier} from "jscodeshift"
|
||||
import * as fs from "fs-extra"
|
||||
import path from "path"
|
||||
import {
|
||||
@@ -11,13 +11,22 @@ import {
|
||||
getAllFiles,
|
||||
getCollectionFromSource,
|
||||
wrapDeclaration,
|
||||
findIdentifier,
|
||||
removeImport,
|
||||
replaceImport,
|
||||
replaceIdentifiers,
|
||||
replaceBlitzPkgsVersions,
|
||||
} from "./utils"
|
||||
import {log} from "blitz"
|
||||
|
||||
const CURRENT_BLITZ_TAG = "alpha"
|
||||
|
||||
class ExpectedError extends Error {
|
||||
constructor(message: string) {
|
||||
super(message)
|
||||
this.name = "Expected Error"
|
||||
}
|
||||
}
|
||||
|
||||
const isInternalBlitzMonorepoDevelopment = fs.existsSync(
|
||||
path.join(__dirname, "../../../blitz-next"),
|
||||
)
|
||||
@@ -81,19 +90,11 @@ const upgradeLegacy = async () => {
|
||||
steps.push({
|
||||
name: "update dependencies in package.json",
|
||||
action: async () => {
|
||||
let packageJsonPath = require(path.resolve("package.json"))
|
||||
packageJsonPath.dependencies["react"] = "latest"
|
||||
packageJsonPath.dependencies["react-dom"] = "latest"
|
||||
packageJsonPath.dependencies["@blitzjs/next"] = "alpha"
|
||||
packageJsonPath.dependencies["@blitzjs/rpc"] = "alpha"
|
||||
packageJsonPath.dependencies["@blitzjs/auth"] = "alpha"
|
||||
packageJsonPath.dependencies["blitz"] = "alpha"
|
||||
packageJsonPath.dependencies["next"] = "latest"
|
||||
packageJsonPath.dependencies["prisma"] = "latest"
|
||||
packageJsonPath.dependencies["@prisma/client"] = "latest"
|
||||
packageJsonPath.devDependencies["typescript"] = isTypescript && "latest"
|
||||
const packageJson = require(path.resolve("package.json"))
|
||||
|
||||
fs.writeFileSync(path.resolve("package.json"), JSON.stringify(packageJsonPath, null, " "))
|
||||
const newPackageJson = await replaceBlitzPkgsVersions(packageJson, CURRENT_BLITZ_TAG)
|
||||
|
||||
fs.writeFileSync(path.resolve("package.json"), JSON.stringify(newPackageJson, null, " "))
|
||||
},
|
||||
})
|
||||
|
||||
@@ -111,6 +112,8 @@ const upgradeLegacy = async () => {
|
||||
|
||||
Document: "next/document",
|
||||
DocumentHead: "next/document",
|
||||
DocumentProps: "next/document",
|
||||
DocumentContext: "next/document",
|
||||
Html: "next/document",
|
||||
Main: "next/document",
|
||||
BlitzScript: "next/document",
|
||||
@@ -401,7 +404,7 @@ const upgradeLegacy = async () => {
|
||||
replaceTemplateValues(blitzClient),
|
||||
)
|
||||
} else {
|
||||
throw new Error("App directory doesn't exit")
|
||||
throw new ExpectedError("App directory doesn't exit")
|
||||
}
|
||||
},
|
||||
})
|
||||
@@ -416,19 +419,25 @@ const upgradeLegacy = async () => {
|
||||
)
|
||||
if (cookieIdentifier.length) {
|
||||
const cookiePrefix = cookieIdentifier.get().parentPath.value.value.value
|
||||
const blitzClientProgram = getCollectionFromSource(
|
||||
path.join(appDir, `blitz-client.${isTypescript ? "ts" : "js"}`),
|
||||
)
|
||||
const cookieIdentifierBlitzClient = blitzClientProgram.find(
|
||||
j.Identifier,
|
||||
(node) => node.name === "cookiePrefix",
|
||||
)
|
||||
cookieIdentifierBlitzClient.get().parentPath.value.value.value = cookiePrefix
|
||||
if (cookiePrefix) {
|
||||
const blitzClientProgram = getCollectionFromSource(
|
||||
path.join(appDir, `blitz-client.${isTypescript ? "ts" : "js"}`),
|
||||
)
|
||||
const cookieIdentifierBlitzClient = blitzClientProgram.find(
|
||||
j.Identifier,
|
||||
(node) => node.name === "cookiePrefix",
|
||||
)
|
||||
cookieIdentifierBlitzClient.get().parentPath.value.value.value = cookiePrefix
|
||||
|
||||
fs.writeFileSync(
|
||||
`${appDir}/blitz-client.${isTypescript ? "ts" : "js"}`,
|
||||
blitzClientProgram.toSource(),
|
||||
)
|
||||
fs.writeFileSync(
|
||||
`${appDir}/blitz-client.${isTypescript ? "ts" : "js"}`,
|
||||
blitzClientProgram.toSource(),
|
||||
)
|
||||
} else {
|
||||
throw new ExpectedError(
|
||||
"Cookie Prefix is undefined & not a string. Please set your cookie prefix manually in app/blitz-client",
|
||||
)
|
||||
}
|
||||
} else {
|
||||
log.error("Cookie Prefix not found in blitz config file")
|
||||
}
|
||||
@@ -921,28 +930,58 @@ const upgradeLegacy = async () => {
|
||||
)
|
||||
|
||||
const importStatements = findImport(program, "next/document")
|
||||
importStatements?.remove()
|
||||
|
||||
let nextDocumentImportPaths: (ImportSpecifier | ImportDefaultSpecifier)[] = []
|
||||
importStatements?.forEach((path) => {
|
||||
path.value.specifiers?.forEach((s) => {
|
||||
if (s.type === "ImportSpecifier") {
|
||||
// Go through the typical imports required for Next.js and build the correct import specifier
|
||||
switch (s.imported.name) {
|
||||
case "Document":
|
||||
nextDocumentImportPaths.unshift(
|
||||
j.importDefaultSpecifier(j.identifier("Document")),
|
||||
)
|
||||
break
|
||||
case "BlitzScript":
|
||||
nextDocumentImportPaths.push(j.importSpecifier(j.identifier("NextScript")))
|
||||
break
|
||||
case "Html":
|
||||
nextDocumentImportPaths.push(j.importSpecifier(j.identifier("Html")))
|
||||
break
|
||||
case "Main":
|
||||
nextDocumentImportPaths.push(j.importSpecifier(j.identifier("Main")))
|
||||
break
|
||||
case "DocumentHead":
|
||||
nextDocumentImportPaths.push(j.importSpecifier(j.identifier("Head")))
|
||||
break
|
||||
case "DocumentProps":
|
||||
nextDocumentImportPaths.push(j.importSpecifier(j.identifier("DocumentProps")))
|
||||
break
|
||||
case "DocumentContext":
|
||||
nextDocumentImportPaths.push(j.importSpecifier(j.identifier("DocumentContext")))
|
||||
break
|
||||
}
|
||||
}
|
||||
})
|
||||
})
|
||||
|
||||
// Add new import statement to the top of the _document page
|
||||
program
|
||||
.get()
|
||||
.value.program.body.unshift(
|
||||
j.importDeclaration(
|
||||
[
|
||||
j.importDefaultSpecifier(j.identifier("Document")),
|
||||
j.importSpecifier(j.identifier("Html")),
|
||||
j.importSpecifier(j.identifier("Head")),
|
||||
j.importSpecifier(j.identifier("Main")),
|
||||
j.importSpecifier(j.identifier("NextScript")),
|
||||
],
|
||||
j.stringLiteral("next/document"),
|
||||
),
|
||||
j.importDeclaration([...nextDocumentImportPaths], j.stringLiteral("next/document")),
|
||||
)
|
||||
// Remove the old import statements
|
||||
importStatements?.remove()
|
||||
|
||||
const documentHead = program
|
||||
.find(j.JSXElement, (node) => node.openingElement.name.name === "DocumentHead")
|
||||
.get()
|
||||
|
||||
documentHead.value.openingElement.name.name = "Head"
|
||||
documentHead.value.closingElement.name.name = "Head"
|
||||
if (documentHead.value.closingElement) {
|
||||
documentHead.value.closingElement.name.name = "Head"
|
||||
}
|
||||
|
||||
const blitzScript = program.find(j.Identifier, (node) => node.name === "BlitzScript").get()
|
||||
blitzScript.value.name = "NextScript"
|
||||
@@ -1026,7 +1065,7 @@ const upgradeLegacy = async () => {
|
||||
})
|
||||
|
||||
if (errors > 0) {
|
||||
throw new Error("Local middleware is not supported")
|
||||
throw new ExpectedError("Local middleware is not supported")
|
||||
}
|
||||
},
|
||||
})
|
||||
@@ -1093,7 +1132,7 @@ const upgradeLegacy = async () => {
|
||||
})
|
||||
|
||||
if (errors > 0) {
|
||||
throw new Error(
|
||||
throw new ExpectedError(
|
||||
"\n invokeWithMiddleware is not supported. \n Use invokeWithCtx instead: https://canary.blitzjs.com/docs/resolver-server-utilities#invoke-with-ctx \n Fix the files above, then run the codemod again.",
|
||||
)
|
||||
}
|
||||
@@ -1166,7 +1205,7 @@ const upgradeLegacy = async () => {
|
||||
"Don't panic, go to the file with the error & manually fix it. Then run the codemod again. It will continue where it left off.",
|
||||
),
|
||||
)
|
||||
} else {
|
||||
} else if (!(err instanceof ExpectedError)) {
|
||||
log.error(
|
||||
log.withBrand(
|
||||
"This is an unexpected error. Please ask for help in the discord #general-help channel. https://discord.blitzjs.com",
|
||||
|
||||
@@ -12,6 +12,8 @@ import j, {
|
||||
Identifier,
|
||||
} from "jscodeshift"
|
||||
import {parseSync} from "@babel/core"
|
||||
import {fetchDistTags} from "@blitzjs/generator"
|
||||
import {PromiseReturnType} from "blitz"
|
||||
|
||||
export function findIdentifier(program: Collection<any>, name: string): Collection<Identifier> {
|
||||
return program.find(j.Identifier, (node) => node.name === name)
|
||||
@@ -326,3 +328,30 @@ export function replaceIdentifiers(
|
||||
path.value.name = "NextApiRequest"
|
||||
})
|
||||
}
|
||||
|
||||
export const replaceBlitzPkgsVersions = async (
|
||||
packageJson: {dependencies?: Record<string, any>},
|
||||
npmTag: string,
|
||||
) => {
|
||||
let blitzPkgVersion = npmTag
|
||||
const result = await fetchDistTags("blitz")
|
||||
if (npmTag in result) {
|
||||
blitzPkgVersion = result[npmTag]
|
||||
}
|
||||
|
||||
if (!packageJson.dependencies) {
|
||||
packageJson.dependencies = {}
|
||||
}
|
||||
|
||||
packageJson.dependencies["@blitzjs/next"] = blitzPkgVersion
|
||||
packageJson.dependencies["@blitzjs/rpc"] = blitzPkgVersion
|
||||
packageJson.dependencies["@blitzjs/auth"] = blitzPkgVersion
|
||||
packageJson.dependencies["blitz"] = blitzPkgVersion
|
||||
packageJson.dependencies["next"] = "12.2.0"
|
||||
|
||||
// for zod, we want to use the latest version
|
||||
const zodResult = await fetchDistTags("zod")
|
||||
packageJson.dependencies["zod"] = zodResult["latest"] || "latest"
|
||||
|
||||
return packageJson
|
||||
}
|
||||
|
||||
90
packages/codemod/tests/codemod.unit.test.ts
Normal file
90
packages/codemod/tests/codemod.unit.test.ts
Normal file
@@ -0,0 +1,90 @@
|
||||
import {describe, it, expect, vi, afterAll} from "vitest"
|
||||
import {replaceBlitzPkgsVersions} from "../src/utils"
|
||||
|
||||
describe("replaceBlitzPkgsVersions", () => {
|
||||
afterAll(() => {
|
||||
vi.clearAllMocks()
|
||||
})
|
||||
|
||||
vi.mock("@blitzjs/generator", async () => {
|
||||
return {
|
||||
fetchDistTags: vi.fn((pkg: string) => {
|
||||
if (pkg === "blitz") {
|
||||
return {alpha: "1.0.0", beta: "2.0.0", danger: "3.0.0"}
|
||||
}
|
||||
if (pkg === "zod") {
|
||||
return {latest: "1.2.3"}
|
||||
}
|
||||
}),
|
||||
}
|
||||
})
|
||||
|
||||
const pkgJson = {
|
||||
dependencies: {},
|
||||
}
|
||||
|
||||
it("correctly updates versions with the alpha tag", async () => {
|
||||
expect(await replaceBlitzPkgsVersions(pkgJson, "alpha")).toEqual({
|
||||
dependencies: {
|
||||
blitz: "1.0.0",
|
||||
"@blitzjs/rpc": "1.0.0",
|
||||
"@blitzjs/auth": "1.0.0",
|
||||
"@blitzjs/next": "1.0.0",
|
||||
next: "12.2.0",
|
||||
zod: "1.2.3",
|
||||
},
|
||||
})
|
||||
})
|
||||
|
||||
it("correctly updates versions with the beta tag", async () => {
|
||||
expect(await replaceBlitzPkgsVersions(pkgJson, "beta")).toEqual({
|
||||
dependencies: {
|
||||
blitz: "2.0.0",
|
||||
"@blitzjs/rpc": "2.0.0",
|
||||
"@blitzjs/auth": "2.0.0",
|
||||
"@blitzjs/next": "2.0.0",
|
||||
next: "12.2.0",
|
||||
zod: "1.2.3",
|
||||
},
|
||||
})
|
||||
})
|
||||
|
||||
it("correctly updates versions with the danger tag", async () => {
|
||||
expect(await replaceBlitzPkgsVersions(pkgJson, "danger")).toEqual({
|
||||
dependencies: {
|
||||
blitz: "3.0.0",
|
||||
"@blitzjs/rpc": "3.0.0",
|
||||
"@blitzjs/auth": "3.0.0",
|
||||
"@blitzjs/next": "3.0.0",
|
||||
next: "12.2.0",
|
||||
zod: "1.2.3",
|
||||
},
|
||||
})
|
||||
})
|
||||
|
||||
it("sets version as a provided tag if it wasn't found with fetchDistTag function", async () => {
|
||||
expect(await replaceBlitzPkgsVersions(pkgJson, "custom")).toEqual({
|
||||
dependencies: {
|
||||
blitz: "custom",
|
||||
"@blitzjs/rpc": "custom",
|
||||
"@blitzjs/auth": "custom",
|
||||
"@blitzjs/next": "custom",
|
||||
next: "12.2.0",
|
||||
zod: "1.2.3",
|
||||
},
|
||||
})
|
||||
})
|
||||
|
||||
it("handles package.json without dependecies key", async () => {
|
||||
expect(await replaceBlitzPkgsVersions({}, "custom")).toEqual({
|
||||
dependencies: {
|
||||
blitz: "custom",
|
||||
"@blitzjs/rpc": "custom",
|
||||
"@blitzjs/auth": "custom",
|
||||
"@blitzjs/next": "custom",
|
||||
next: "12.2.0",
|
||||
zod: "1.2.3",
|
||||
},
|
||||
})
|
||||
})
|
||||
})
|
||||
@@ -1,5 +1,9 @@
|
||||
# @blitzjs/config
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
## 2.0.0-alpha.65
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
{
|
||||
"name": "@blitzjs/config",
|
||||
"private": true,
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@typescript-eslint/eslint-plugin": "5.9.1",
|
||||
|
||||
@@ -1,5 +1,19 @@
|
||||
# @blitzjs/generator
|
||||
|
||||
## 2.0.0-alpha.68
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- 70b334a2: Remove trailing comma from tsconfig.json file in the new app template"
|
||||
- dd299ae8: Add ts-jest to dependencies in new app templates
|
||||
- 078fe474: Add `@testing-library/jest-dom` to new app dependecies
|
||||
|
||||
## 2.0.0-alpha.67
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- ebd74b4e: Fix template path for the generator
|
||||
|
||||
## 2.0.0-alpha.66
|
||||
|
||||
### Patch Changes
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@blitzjs/generator",
|
||||
"version": "2.0.0-alpha.66",
|
||||
"version": "2.0.0-alpha.68",
|
||||
"scripts": {
|
||||
"dev": "watch unbuild src --wait=0.2",
|
||||
"build": "unbuild && pnpm build:templates",
|
||||
@@ -46,7 +46,7 @@
|
||||
"vinyl": "2.2.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "2.0.0-alpha.66",
|
||||
"@blitzjs/config": "2.0.0-alpha.68",
|
||||
"@juanm04/cpx": "2.0.1",
|
||||
"@types/babel__core": "7.1.19",
|
||||
"@types/diff": "5.0.2",
|
||||
|
||||
@@ -302,7 +302,7 @@ export abstract class Generator<
|
||||
return path.join(
|
||||
__dirname,
|
||||
"..",
|
||||
process.env.NODE_ENV === "test" ? "./templates" : "./templates",
|
||||
process.env.NODE_ENV === "test" ? "./templates" : "./dist/templates",
|
||||
this.sourceRoot.path,
|
||||
...paths,
|
||||
)
|
||||
|
||||
@@ -4,9 +4,9 @@ import {readJSONSync, writeJson} from "fs-extra"
|
||||
import {join} from "path"
|
||||
import username from "username"
|
||||
import {Generator, GeneratorOptions, SourceRootType} from "../generator"
|
||||
import {baseLogger, log} from "../utils/log"
|
||||
import {fetchLatestVersionsFor} from "../utils/fetch-latest-version-for"
|
||||
import {getBlitzDependencyVersion} from "../utils/get-blitz-dependency-version"
|
||||
import {baseLogger, log} from "../utils/log"
|
||||
|
||||
function assert(condition: any, message: string): asserts condition {
|
||||
if (!condition) throw new Error(message)
|
||||
@@ -27,7 +27,7 @@ export interface AppGeneratorOptions extends GeneratorOptions {
|
||||
version: string
|
||||
skipInstall: boolean
|
||||
skipGit: boolean
|
||||
form?: "finalform" | "hookform" | "formik"
|
||||
form: "finalform" | "hookform" | "formik"
|
||||
onPostInstall?: () => Promise<void>
|
||||
}
|
||||
|
||||
@@ -120,7 +120,7 @@ export class AppGenerator extends Generator<AppGeneratorOptions> {
|
||||
] = await Promise.all([
|
||||
fetchLatestVersionsFor(pkg.dependencies),
|
||||
fetchLatestVersionsFor(pkg.devDependencies),
|
||||
getBlitzDependencyVersion(this.options.version),
|
||||
getBlitzDependencyVersion(),
|
||||
])
|
||||
|
||||
pkg.dependencies = newDependencies
|
||||
|
||||
@@ -9,6 +9,8 @@ export * from "./generators/form-generator"
|
||||
export * from "./generator"
|
||||
export * from "./conflict-checker"
|
||||
export {getLatestVersion} from "./utils/get-latest-version"
|
||||
export * from "./utils/npm-fetch"
|
||||
export * from "./utils/get-blitz-dependency-version"
|
||||
export {
|
||||
singleCamel,
|
||||
singlePascal,
|
||||
|
||||
@@ -1,16 +1,14 @@
|
||||
import {Fallbackable} from "./fallbackable"
|
||||
import {logFailedVersionFetch} from "./get-latest-version"
|
||||
import {fetchDistTags} from "./npm-fetch"
|
||||
|
||||
export const getBlitzDependencyVersion = async (
|
||||
cliVersion: string,
|
||||
): Promise<Fallbackable<string>> => {
|
||||
try {
|
||||
// TODO: Need to update this to handle alpha, beta and major
|
||||
const {alpha} = await fetchDistTags("blitz")
|
||||
const CURRENT_BLITZ_TAG = "alpha"
|
||||
|
||||
if (alpha) {
|
||||
return {value: alpha}
|
||||
export const getBlitzDependencyVersion = async () => {
|
||||
try {
|
||||
const result = await fetchDistTags("blitz")
|
||||
|
||||
if (CURRENT_BLITZ_TAG in result) {
|
||||
return {value: result}
|
||||
}
|
||||
|
||||
logFailedVersionFetch("blitz")
|
||||
|
||||
@@ -1,25 +1,23 @@
|
||||
import got from "got"
|
||||
|
||||
type PackageInformation = any
|
||||
type NpmDepResponse = {versions: Record<string, PackageInformation>}
|
||||
export type NpmDepResponse = {versions: Record<string, PackageInformation>}
|
||||
|
||||
export const fetchAllVersions = async (dependency: string) => {
|
||||
const res = await got(`https://registry.npmjs.org/${dependency}`, {
|
||||
const res = (await got(`https://registry.npmjs.org/${dependency}`, {
|
||||
retry: {limit: 3},
|
||||
timeout: 3000,
|
||||
responseType: "json",
|
||||
}).json<NpmDepResponse>()
|
||||
}).json<NpmDepResponse>()) as unknown as NpmDepResponse
|
||||
return Object.keys(res.versions)
|
||||
}
|
||||
|
||||
type NpmDistTagsResponse = {latest: string; canary: string; alpha: string}
|
||||
|
||||
export const fetchDistTags = async (dependency: string) => {
|
||||
const res = await got(`https://registry.npmjs.org/-/package/${dependency}/dist-tags`, {
|
||||
const res = (await got(`https://registry.npmjs.org/-/package/${dependency}/dist-tags`, {
|
||||
retry: {limit: 3},
|
||||
timeout: 3000,
|
||||
responseType: "json",
|
||||
}).json<NpmDistTagsResponse>()
|
||||
}).json()) as unknown as Record<string, any>
|
||||
return res
|
||||
}
|
||||
|
||||
|
||||
@@ -35,6 +35,7 @@
|
||||
},
|
||||
"devDependencies": {
|
||||
"@next/bundle-analyzer": "12.0.8",
|
||||
"@testing-library/jest-dom": "5.16.3",
|
||||
"@types/jest": "27.4.1",
|
||||
"@types/node": "17.0.16",
|
||||
"@types/preview-email": "2.0.1",
|
||||
|
||||
@@ -35,6 +35,7 @@
|
||||
},
|
||||
"devDependencies": {
|
||||
"@next/bundle-analyzer": "12.0.8",
|
||||
"@testing-library/jest-dom": "5.16.3",
|
||||
"@types/jest": "27.4.1",
|
||||
"@types/node": "17.0.16",
|
||||
"@types/preview-email": "2.0.1",
|
||||
@@ -50,6 +51,7 @@
|
||||
"prettier-plugin-prisma": "3.8.0",
|
||||
"pretty-quick": "3.1.3",
|
||||
"preview-email": "3.x",
|
||||
"ts-jest": "28.0.7",
|
||||
"typescript": "^4.5.3"
|
||||
},
|
||||
"private": true
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
"isolatedModules": true,
|
||||
"jsx": "preserve",
|
||||
"incremental": true,
|
||||
"tsBuildInfoFile": ".tsbuildinfo",
|
||||
"tsBuildInfoFile": ".tsbuildinfo"
|
||||
},
|
||||
"exclude": ["node_modules", "**/*.e2e.ts", "cypress"],
|
||||
"include": ["blitz-env.d.ts", "**/*.ts", "**/*.tsx", "types"]
|
||||
|
||||
@@ -27,6 +27,7 @@
|
||||
},
|
||||
"devDependencies": {
|
||||
"@next/bundle-analyzer": "12.0.8",
|
||||
"@testing-library/jest-dom": "5.16.3",
|
||||
"@types/jest": "27.4.1",
|
||||
"@types/node": "17.0.16",
|
||||
"@types/react": "18.0.1",
|
||||
|
||||
@@ -29,6 +29,7 @@
|
||||
},
|
||||
"devDependencies": {
|
||||
"@next/bundle-analyzer": "12.0.8",
|
||||
"@testing-library/jest-dom": "5.16.3",
|
||||
"@types/jest": "27.4.1",
|
||||
"@types/node": "17.0.16",
|
||||
"@types/react": "18.0.1",
|
||||
@@ -41,6 +42,7 @@
|
||||
"lint-staged": "12.1.7",
|
||||
"prettier": "^2.5.1",
|
||||
"pretty-quick": "3.1.3",
|
||||
"ts-jest": "28.0.7",
|
||||
"typescript": "^4.5.3"
|
||||
},
|
||||
"private": true
|
||||
|
||||
@@ -25,7 +25,7 @@
|
||||
"@typescript-eslint/parser": "5.9.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blitzjs/config": "2.0.0-alpha.66",
|
||||
"@blitzjs/config": "2.0.0-alpha.68",
|
||||
"@types/react": "18.0.1",
|
||||
"@types/react-dom": "17.0.14",
|
||||
"react": "18.0.0",
|
||||
|
||||
164
pnpm-lock.yaml
generated
164
pnpm-lock.yaml
generated
@@ -14,7 +14,7 @@ importers:
|
||||
prettier: ^2.5.1
|
||||
prettier-plugin-prisma: 3.8.0
|
||||
pretty-quick: 3.1.3
|
||||
turbo: 1.1.5
|
||||
turbo: 1.4.2
|
||||
vitest: 0.8.2
|
||||
wait-on: 6.0.1
|
||||
dependencies:
|
||||
@@ -29,7 +29,7 @@ importers:
|
||||
prettier: 2.6.2
|
||||
prettier-plugin-prisma: 3.8.0_prettier@2.6.2
|
||||
pretty-quick: 3.1.3_prettier@2.6.2
|
||||
turbo: 1.1.5
|
||||
turbo: 1.4.2
|
||||
vitest: 0.8.2_jsdom@19.0.0
|
||||
wait-on: 6.0.1
|
||||
|
||||
@@ -49,7 +49,7 @@ importers:
|
||||
"@types/preview-email": 2.0.1
|
||||
"@types/react": 18.0.1
|
||||
"@typescript-eslint/eslint-plugin": 5.9.1
|
||||
blitz: workspace:2.0.0-alpha.65
|
||||
blitz: workspace:2.0.0-alpha.67
|
||||
eslint: 7.32.0
|
||||
eslint-config-next: 12.2.0
|
||||
eslint-config-prettier: 8.5.0
|
||||
@@ -324,7 +324,7 @@ importers:
|
||||
"@vitejs/plugin-react": 1.3.0
|
||||
delay: 5.0.0
|
||||
eslint: 7.32.0
|
||||
eslint-config-next: 12.2.3_hrkuebk64jiu2ut2d2sm4oylnu
|
||||
eslint-config-next: 12.2.4_hrkuebk64jiu2ut2d2sm4oylnu
|
||||
eslint-plugin-testing-library: 5.0.1_hrkuebk64jiu2ut2d2sm4oylnu
|
||||
jsdom: 19.0.0
|
||||
typescript: 4.6.3
|
||||
@@ -475,8 +475,8 @@ importers:
|
||||
|
||||
packages/blitz:
|
||||
specifiers:
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.65
|
||||
"@blitzjs/generator": 2.0.0-alpha.65
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.67
|
||||
"@blitzjs/generator": 2.0.0-alpha.67
|
||||
"@types/cookie": 0.4.1
|
||||
"@types/cross-spawn": 6.0.2
|
||||
"@types/debug": 4.1.7
|
||||
@@ -586,7 +586,7 @@ importers:
|
||||
|
||||
packages/blitz-auth:
|
||||
specifiers:
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.65
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.67
|
||||
"@testing-library/react": 13.0.0
|
||||
"@testing-library/react-hooks": 7.0.2
|
||||
"@types/b64-lite": 1.3.0
|
||||
@@ -600,7 +600,7 @@ importers:
|
||||
"@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.67
|
||||
cookie: 0.4.1
|
||||
cookie-session: 2.0.0
|
||||
debug: 4.3.3
|
||||
@@ -653,8 +653,8 @@ importers:
|
||||
|
||||
packages/blitz-next:
|
||||
specifiers:
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.65
|
||||
"@blitzjs/rpc": 2.0.0-alpha.65
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.67
|
||||
"@blitzjs/rpc": 2.0.0-alpha.67
|
||||
"@tanstack/react-query": 4.0.10
|
||||
"@testing-library/dom": 8.13.0
|
||||
"@testing-library/jest-dom": 5.16.3
|
||||
@@ -666,7 +666,7 @@ importers:
|
||||
"@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.67
|
||||
cross-spawn: 7.0.3
|
||||
debug: 4.3.3
|
||||
find-up: 4.1.0
|
||||
@@ -716,15 +716,15 @@ importers:
|
||||
|
||||
packages/blitz-rpc:
|
||||
specifiers:
|
||||
"@blitzjs/auth": 2.0.0-alpha.65
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.65
|
||||
"@blitzjs/auth": 2.0.0-alpha.67
|
||||
"@blitzjs/config": workspace:2.0.0-alpha.67
|
||||
"@tanstack/react-query": 4.0.10
|
||||
"@types/debug": 4.1.7
|
||||
"@types/react": 18.0.1
|
||||
"@types/react-dom": 17.0.14
|
||||
b64-lite: 1.4.0
|
||||
bad-behavior: 1.0.1
|
||||
blitz: 2.0.0-alpha.65
|
||||
blitz: 2.0.0-alpha.67
|
||||
chalk: ^4.1.0
|
||||
debug: 4.3.3
|
||||
next: 12.2.0
|
||||
@@ -767,12 +767,12 @@ importers:
|
||||
"@babel/plugin-syntax-typescript": 7.17.12
|
||||
"@babel/preset-env": 7.12.10
|
||||
"@blitzjs/config": workspace:*
|
||||
"@blitzjs/generator": 2.0.0-alpha.65
|
||||
"@blitzjs/generator": 2.0.0-alpha.67
|
||||
"@types/jscodeshift": 0.11.2
|
||||
"@types/node": 17.0.16
|
||||
arg: 5.0.1
|
||||
ast-types: 0.14.2
|
||||
blitz: 2.0.0-alpha.65
|
||||
blitz: 2.0.0-alpha.67
|
||||
chalk: ^4.1.0
|
||||
cross-spawn: 7.0.3
|
||||
debug: 4.3.3
|
||||
@@ -827,7 +827,7 @@ importers:
|
||||
"@babel/plugin-transform-typescript": 7.12.1
|
||||
"@babel/preset-env": 7.12.10
|
||||
"@babel/types": 7.12.10
|
||||
"@blitzjs/config": 2.0.0-alpha.65
|
||||
"@blitzjs/config": 2.0.0-alpha.67
|
||||
"@juanm04/cpx": 2.0.1
|
||||
"@mrleebo/prisma-ast": 0.2.6
|
||||
"@types/babel__core": 7.1.19
|
||||
@@ -881,7 +881,7 @@ importers:
|
||||
diff: 5.0.0
|
||||
enquirer: 2.3.6
|
||||
fs-extra: 10.0.1
|
||||
got: 11.8.5
|
||||
got: 11.8.1
|
||||
jscodeshift: 0.13.0_slgjdbbopna4ebnpdn2nkn3v2a
|
||||
mem-fs: 1.2.0
|
||||
mem-fs-editor: 8.0.0
|
||||
@@ -920,7 +920,7 @@ importers:
|
||||
|
||||
packages/pkg-template:
|
||||
specifiers:
|
||||
"@blitzjs/config": 2.0.0-alpha.65
|
||||
"@blitzjs/config": 2.0.0-alpha.67
|
||||
"@types/react": 18.0.1
|
||||
"@types/react-dom": 17.0.14
|
||||
"@typescript-eslint/eslint-plugin": 5.9.1
|
||||
@@ -2182,7 +2182,7 @@ packages:
|
||||
peerDependencies:
|
||||
"@babel/core": ^7.0.0-0
|
||||
dependencies:
|
||||
"@babel/core": 7.12.10_supports-color@8.1.1
|
||||
"@babel/core": 7.12.10
|
||||
"@babel/helper-plugin-utils": 7.17.12
|
||||
dev: false
|
||||
|
||||
@@ -3060,7 +3060,6 @@ packages:
|
||||
semver: 5.7.1
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
dev: false
|
||||
|
||||
/@babel/preset-flow/7.17.12_@babel+core@7.18.2:
|
||||
resolution:
|
||||
@@ -4033,10 +4032,10 @@ packages:
|
||||
dependencies:
|
||||
glob: 7.1.7
|
||||
|
||||
/@next/eslint-plugin-next/12.2.3:
|
||||
/@next/eslint-plugin-next/12.2.4:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-B2e8Yg1MpuLsGxhCx4rU8/Tcnr5wFmCx1O2eyLXBPnaCcsFXfGCo067ujagtDLtWASL3GNgzg78U1SB0dbc38A==,
|
||||
integrity: sha512-ChDkUIkJeYWKRx+FdF+EhUgvKtK1wF+Xew4Os7ef3iAjMch5GGBiezw2zGXTa/C0E6potz4j11EpX89mngffug==,
|
||||
}
|
||||
dependencies:
|
||||
glob: 7.1.7
|
||||
@@ -5491,7 +5490,6 @@ packages:
|
||||
typescript: 4.6.3
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
dev: false
|
||||
|
||||
/@typescript-eslint/experimental-utils/5.28.0_hrkuebk64jiu2ut2d2sm4oylnu:
|
||||
resolution:
|
||||
@@ -9315,12 +9313,11 @@ packages:
|
||||
transitivePeerDependencies:
|
||||
- eslint-import-resolver-webpack
|
||||
- supports-color
|
||||
dev: false
|
||||
|
||||
/eslint-config-next/12.2.3_hrkuebk64jiu2ut2d2sm4oylnu:
|
||||
/eslint-config-next/12.2.4_hrkuebk64jiu2ut2d2sm4oylnu:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-xAQqAqwa2bu9ZMRypz58ym4tNCo22Wc6LuoLpbpf3yW5c4ZkVib9934AgGDDvh2zKrP56Z6X0Pp6gNnuuZzcRw==,
|
||||
integrity: sha512-r3keSLY1Z+rN+ASN8nmWwZ+AsMl6IrPGRWgbQhKHcop4/fk1hJGxE9Xf/mYMkV07+1Q/catchw25lu525HFy5Q==,
|
||||
}
|
||||
peerDependencies:
|
||||
eslint: ^7.23.0 || ^8.0.0
|
||||
@@ -9329,7 +9326,7 @@ packages:
|
||||
typescript:
|
||||
optional: true
|
||||
dependencies:
|
||||
"@next/eslint-plugin-next": 12.2.3
|
||||
"@next/eslint-plugin-next": 12.2.4
|
||||
"@rushstack/eslint-patch": 1.1.3
|
||||
"@typescript-eslint/parser": 5.28.0_hrkuebk64jiu2ut2d2sm4oylnu
|
||||
eslint: 7.32.0
|
||||
@@ -9353,7 +9350,6 @@ packages:
|
||||
hasBin: true
|
||||
peerDependencies:
|
||||
eslint: ">=7.0.0"
|
||||
dev: false
|
||||
|
||||
/eslint-config-prettier/8.5.0_eslint@7.32.0:
|
||||
resolution:
|
||||
@@ -10836,10 +10832,10 @@ packages:
|
||||
- supports-color
|
||||
dev: false
|
||||
|
||||
/got/11.8.5:
|
||||
/got/11.8.1:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-o0Je4NvQObAuZPHLFoRSkdG2lTgtcynqymzg2Vupdx6PorhaT5MCbIyXG6d4D94kk8ZG57QeosgdiqfJWhEhlQ==,
|
||||
integrity: sha512-9aYdZL+6nHmvJwHALLwKSUZ0hMwGaJGYv3hoPLPgnT8BoBXm1SjnZeky+91tfwJaDzun2s4RsBRy48IEYv2q2Q==,
|
||||
}
|
||||
engines: {node: ">=10.19.0"}
|
||||
dependencies:
|
||||
@@ -12018,7 +12014,7 @@ packages:
|
||||
pretty-format: 27.5.1
|
||||
slash: 3.0.0
|
||||
strip-json-comments: 3.1.1
|
||||
ts-node: 10.7.0_fxg3r7oju3tntkxsvleuiot4fa
|
||||
ts-node: 10.7.0_typescript@4.6.3
|
||||
transitivePeerDependencies:
|
||||
- bufferutil
|
||||
- canvas
|
||||
@@ -17304,6 +17300,7 @@ packages:
|
||||
typescript: 4.6.3
|
||||
v8-compile-cache-lib: 3.0.1
|
||||
yn: 3.1.1
|
||||
dev: false
|
||||
|
||||
/ts-node/10.7.0_typescript@4.6.3:
|
||||
resolution:
|
||||
@@ -17336,7 +17333,6 @@ packages:
|
||||
typescript: 4.6.3
|
||||
v8-compile-cache-lib: 3.0.1
|
||||
yn: 3.1.1
|
||||
dev: false
|
||||
|
||||
/tsconfig-paths/3.14.1:
|
||||
resolution:
|
||||
@@ -17418,10 +17414,21 @@ packages:
|
||||
yargs: 15.4.1
|
||||
dev: false
|
||||
|
||||
/turbo-darwin-64/1.1.5:
|
||||
/turbo-android-arm64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-qdGMylQ408NmYhzuMmx+25W0iHFyFMRPO4579tDEv+WBiVDfAEYEzjajE4c+CQOLhd1aVEaPdSa+YhngQUgoDQ==,
|
||||
integrity: sha512-h6PorJ+muKDQE3wETwrkx3NpqypAxjIFLP3b8RQaAoNvxYa1JTSC71VMtYxMbwuDk58A1KGbXLDteR4by8Lqew==,
|
||||
}
|
||||
cpu: [arm64]
|
||||
os: [android]
|
||||
requiresBuild: true
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-darwin-64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-HrXRwx+5FuKeR4r2ea2mWO5dImzxG7z987t4xZWytEWJ0gEujln1z1cjwotYU1l2pq8slJS8W3q9Qv3JRMrSkQ==,
|
||||
}
|
||||
cpu: [x64]
|
||||
os: [darwin]
|
||||
@@ -17429,10 +17436,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-darwin-arm64/1.1.5:
|
||||
/turbo-darwin-arm64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-mXU324d3vYzxRT9FSSkW9yG2BvFosd0f4DUvqy4qms8wzM6Yv9Aeo4zZTL86rF88UYGUkbiRaPQUeceb/QARVg==,
|
||||
integrity: sha512-/qkMqq1hdbM/I0gchx08/ZZucgnQVp6gd03tHHYnyG20z8a39f38MbX7+I5aLRpa3pQzBk8RgNx0o7G1T+KvzA==,
|
||||
}
|
||||
cpu: [arm64]
|
||||
os: [darwin]
|
||||
@@ -17440,10 +17447,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-freebsd-64/1.1.5:
|
||||
/turbo-freebsd-64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-qjjPTnZKOxw2x1Ito3yZAYDcwsCEg/5kYJwbPVvDn1jyXoxr3pUxTHUohroxQ6EmyxQ28qL7QpCVWDoQpDwrOQ==,
|
||||
integrity: sha512-bZcjR7GxpuE/0qz/aKg4gWDa+6eiuoV0cRnqCJ/rae14/iSmBt0MsMa+lUH5gZUFj581Dj8fQRoBeE+EOau5CA==,
|
||||
}
|
||||
cpu: [x64]
|
||||
os: [freebsd]
|
||||
@@ -17451,10 +17458,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-freebsd-arm64/1.1.5:
|
||||
/turbo-freebsd-arm64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-jYW+Th9Y6yEYevaFe7v3lFQoxyrpd8wX5KuuvqLazMRbNxvKgqTDmT7AbCOGJY5ejzqGnMlTGkQr8c3g3B8ndA==,
|
||||
integrity: sha512-dDx++7AELGAHuaMQjzNiKjSPu/xdDelUtRjWOzJWmwXzrgJlwNgQ93p+LYEA7LBWVZ8a32fpBE/VDait0alIJw==,
|
||||
}
|
||||
cpu: [arm64]
|
||||
os: [freebsd]
|
||||
@@ -17462,10 +17469,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-linux-32/1.1.5:
|
||||
/turbo-linux-32/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-c5I8tdR1jD8L8pJWk+rlO734bpWI1gwGdvNOaA/IGZxzOfDSn4CGoUErnUPgOadT8azi7lT9UPQf/pLfEvjCOw==,
|
||||
integrity: sha512-AAxsEYhgv6x4UXwCoiRe+iL2pd+ArsJQDMgJGsJn+Tb09ca6+i1rTgdOTgcCSyvRwbXt0LYzqXN9zp6FwG6VHQ==,
|
||||
}
|
||||
cpu: [ia32]
|
||||
os: [linux]
|
||||
@@ -17473,10 +17480,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-linux-64/1.1.5:
|
||||
/turbo-linux-64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-BZAxLfIkEtQa7u+VPYpdeVVJH6ab4WwXv4oCrUDaZf2BseDUxr57y2ASAWNFsg40T3oXXt4Kcbdc5LibjWQdtQ==,
|
||||
integrity: sha512-t7gGxp1ILmGwzymcf72Lw4Ca916Bi9j2C4xPnJ2CAqxMWQOJKCRvyOuUHC/uy1kFDjR2yszxMb+ZJL6P3nccfA==,
|
||||
}
|
||||
cpu: [x64]
|
||||
os: [linux]
|
||||
@@ -17484,10 +17491,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-linux-arm/1.1.5:
|
||||
/turbo-linux-arm/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-X6J05gQSWTc2c/TCkOQdFLhr35pUjEExY6K8yanYs2QKgd4GvDHmxYaBZ+6f90qcIUHYpe++adDPJcuAUv+8ug==,
|
||||
integrity: sha512-6Rri//bX3wPMa8D0sSie05Xuze+6jTUDt4qsKp+JoQVanUKkKmRaVDpyV4WuFfjDbC5iP4ocN20FeaXenMFxTA==,
|
||||
}
|
||||
cpu: [arm]
|
||||
os: [linux]
|
||||
@@ -17495,10 +17502,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-linux-arm64/1.1.5:
|
||||
/turbo-linux-arm64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-8/yz5L0B6Jb0pNcvx/08LcPswizqggxQ0zlFEw+Oh9RAC+ZM5+X2YiMyKolvLCpkoRqrlKku0lmXH7mx6DWbig==,
|
||||
integrity: sha512-V7eBFUOrIvLvjrc81UE8C+NfqBRKADyKrrbKD9hMG5beE/piZZNGoHUwuEgLgsykCSfHjn1sQCidocVztuTMAw==,
|
||||
}
|
||||
cpu: [arm64]
|
||||
os: [linux]
|
||||
@@ -17506,21 +17513,21 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-linux-mips64le/1.1.5:
|
||||
/turbo-linux-mips64le/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-K26bEFcLDGPkcaW7Eq4CMSxUbJf/x58aE92+0tONhrxXzamaBqTrSxPYlk/T8OoH7HxOvja2ctkpeI/NRAoIyw==,
|
||||
integrity: sha512-C0JpzpwyvhW5ChWr6S7ulUd8a+1SBLe2mLBepTWaXTh/5+sFDU/AMwPNkhpfV5o0gEtz03UPm7Y4G6dqU3UCAQ==,
|
||||
}
|
||||
cpu: [mips64el]
|
||||
cpu: [mipsel]
|
||||
os: [linux]
|
||||
requiresBuild: true
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-linux-ppc64le/1.1.5:
|
||||
/turbo-linux-ppc64le/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-fr1/5yf8fe1BJiW/6Y9lmV+kxZZC3u3xvSBC5AXDSl9u3aJFZl96CRE9tOJbTZMaOVGxhplKD+EiHbjIxUnTrA==,
|
||||
integrity: sha512-ipxyQCj3NXq/2V6a4lKoNDt8CjcufICgHAvOhAUmoAxz4kIEKRvA/75xsPpt2Ih/a4fWGxsbWFK6oA+ac0l3jQ==,
|
||||
}
|
||||
cpu: [ppc64]
|
||||
os: [linux]
|
||||
@@ -17528,10 +17535,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-windows-32/1.1.5:
|
||||
/turbo-windows-32/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-K9LdIgQXJ7jL0aLJS0l2asJAH/vYBFP7qFzODiAcJ1EeKBjYqAVnIxFQrUN07lzNDtL9WK/aN5q0bJCDnhwTQw==,
|
||||
integrity: sha512-pCvsh8mPSw6ZFABQqeJzfercnsOwCj1LpbWTPW1QftDij6zw1OWU4jWU529Ub1f+GMBej+xm/ufJhT+8A3NhwA==,
|
||||
}
|
||||
cpu: [ia32]
|
||||
os: [win32]
|
||||
@@ -17539,10 +17546,10 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo-windows-64/1.1.5:
|
||||
/turbo-windows-64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-c2Jkmw8yGZVz4opzEvB5HAf9XkA8CZBnorie46s44ec0FaNbcP9SCuUNvgAHxqDIHTGWC4A5PoPn0owkD3ss6A==,
|
||||
integrity: sha512-GnvM8uGOA6idUloDDxiEgUpIx5o5ZJL0ARL7f+6r/vfwA+qlSe/F+4hDCmT3+Xkg7/7zDZix5ViKVoTDMBP/Ig==,
|
||||
}
|
||||
cpu: [x64]
|
||||
os: [win32]
|
||||
@@ -17550,26 +17557,39 @@ packages:
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo/1.1.5:
|
||||
/turbo-windows-arm64/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-jXW8G4lr01/E/jS/66LYpEjwWFQAksC8TxR8gi3VGea7OeNj28l8zmXoY3IgT5H22MBnhmtOKV/GhsbPjI2Jrg==,
|
||||
integrity: sha512-2mCPiDnMLY924+M07mMo464cjOr0EITuIkK67IBm3EeEwSlunOmQk+LRc/Jq/Zx6Zuzp5XPZ2fZVvmmSFfogpQ==,
|
||||
}
|
||||
cpu: [arm64]
|
||||
os: [win32]
|
||||
requiresBuild: true
|
||||
dev: false
|
||||
optional: true
|
||||
|
||||
/turbo/1.4.2:
|
||||
resolution:
|
||||
{
|
||||
integrity: sha512-ry1vUs5oHCIM+Sef8HED2XsbL28YAeclCrOtDp9zbZZMUX1r5s01COqOJjFJZfDiv2zSlUge9IIQXprM8BfrtA==,
|
||||
}
|
||||
hasBin: true
|
||||
requiresBuild: true
|
||||
optionalDependencies:
|
||||
turbo-darwin-64: 1.1.5
|
||||
turbo-darwin-arm64: 1.1.5
|
||||
turbo-freebsd-64: 1.1.5
|
||||
turbo-freebsd-arm64: 1.1.5
|
||||
turbo-linux-32: 1.1.5
|
||||
turbo-linux-64: 1.1.5
|
||||
turbo-linux-arm: 1.1.5
|
||||
turbo-linux-arm64: 1.1.5
|
||||
turbo-linux-mips64le: 1.1.5
|
||||
turbo-linux-ppc64le: 1.1.5
|
||||
turbo-windows-32: 1.1.5
|
||||
turbo-windows-64: 1.1.5
|
||||
turbo-android-arm64: 1.4.2
|
||||
turbo-darwin-64: 1.4.2
|
||||
turbo-darwin-arm64: 1.4.2
|
||||
turbo-freebsd-64: 1.4.2
|
||||
turbo-freebsd-arm64: 1.4.2
|
||||
turbo-linux-32: 1.4.2
|
||||
turbo-linux-64: 1.4.2
|
||||
turbo-linux-arm: 1.4.2
|
||||
turbo-linux-arm64: 1.4.2
|
||||
turbo-linux-mips64le: 1.4.2
|
||||
turbo-linux-ppc64le: 1.4.2
|
||||
turbo-windows-32: 1.4.2
|
||||
turbo-windows-64: 1.4.2
|
||||
turbo-windows-arm64: 1.4.2
|
||||
dev: false
|
||||
|
||||
/type-check/0.3.2:
|
||||
|
||||
Reference in New Issue
Block a user