@bleedingdev/modern-js-main-doc 3.5.0-ultramodern.3 → 3.5.0-ultramodern.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -197,11 +197,16 @@ The generated `api.client.*` API only exists for loader-materialized `@api/index
|
|
|
197
197
|
## Effect cohort
|
|
198
198
|
|
|
199
199
|
UltraModern-generated workspaces pin the framework-compatible Effect cohort
|
|
200
|
-
through `pnpm-workspace.yaml` overrides. For `3.5.0-ultramodern.
|
|
200
|
+
through `pnpm-workspace.yaml` overrides. For `3.5.0-ultramodern.5`, generated
|
|
201
201
|
apps use:
|
|
202
202
|
|
|
203
203
|
```yaml
|
|
204
|
+
minimumReleaseAgeExclude:
|
|
205
|
+
- 'effect@4.0.0-beta.91'
|
|
206
|
+
- '@effect/opentelemetry@4.0.0-beta.91'
|
|
207
|
+
|
|
204
208
|
trustPolicyExclude:
|
|
209
|
+
- 'effect@4.0.0-beta.91'
|
|
205
210
|
- '@effect/opentelemetry@4.0.0-beta.91'
|
|
206
211
|
|
|
207
212
|
overrides:
|
|
@@ -212,9 +217,10 @@ overrides:
|
|
|
212
217
|
Do not add a different direct `effect` version in an app package. A mismatched
|
|
213
218
|
Effect beta can fail while building layers or HTTP middleware because runtime
|
|
214
219
|
services come from different package instances. Keep the generated
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
220
|
+
policy exclusion entries with the same Effect cohort; they handle the
|
|
221
|
+
framework-selected Effect beta versions before the 24-hour maturity window and
|
|
222
|
+
the `effect`/`@effect/opentelemetry` trusted-publisher to provenance metadata
|
|
223
|
+
transition without weakening UltraModern API architecture checks.
|
|
218
224
|
|
|
219
225
|
## Contract tests
|
|
220
226
|
|
|
@@ -78,20 +78,20 @@ mise exec -- pnpm check
|
|
|
78
78
|
mise exec -- pnpm build
|
|
79
79
|
```
|
|
80
80
|
|
|
81
|
-
Strict generated API migration requires `3.5.0-ultramodern.
|
|
81
|
+
Strict generated API migration requires `3.5.0-ultramodern.5` or newer.
|
|
82
82
|
`3.4.0-ultramodern.20` and earlier cohorts do not include this full direct
|
|
83
83
|
`api/index.ts` generator, generated `.mts` checks, strict Oxlint boundary rule
|
|
84
84
|
set, Effect cohort overrides, and strict Effect migration command. Agents that
|
|
85
85
|
cannot install that BleedingDev cohort yet should use the local Modern.js
|
|
86
|
-
workspace for migration validation; otherwise pin `3.5.0-ultramodern.
|
|
86
|
+
workspace for migration validation; otherwise pin `3.5.0-ultramodern.5` or
|
|
87
87
|
newer with `--ultramodern-package-version`.
|
|
88
88
|
|
|
89
89
|
Before hand-editing package aliases or generated metadata, run the framework
|
|
90
90
|
migration command from the target workspace:
|
|
91
91
|
|
|
92
92
|
```bash
|
|
93
|
-
pnpm dlx @bleedingdev/modern-js-create@3.5.0-ultramodern.
|
|
94
|
-
migrate-strict-effect --version 3.5.0-ultramodern.
|
|
93
|
+
pnpm dlx @bleedingdev/modern-js-create@3.5.0-ultramodern.5 ultramodern \
|
|
94
|
+
migrate-strict-effect --version 3.5.0-ultramodern.5
|
|
95
95
|
pnpm api:check
|
|
96
96
|
pnpm contract:check
|
|
97
97
|
```
|
|
@@ -107,9 +107,10 @@ and `src/effect`.
|
|
|
107
107
|
Generated strict Effect workspaces pin the compatible Effect cohort with pnpm
|
|
108
108
|
overrides: `effect@4.0.0-beta.91` and `@effect/vitest@4.0.0-beta.91`. Do not
|
|
109
109
|
add app-local direct Effect versions that disagree with those overrides. They
|
|
110
|
-
also carry
|
|
111
|
-
`@effect/opentelemetry@4.0.0-beta.91` so
|
|
112
|
-
the
|
|
110
|
+
also carry generated pnpm policy exclusions for `effect@4.0.0-beta.91` and
|
|
111
|
+
`@effect/opentelemetry@4.0.0-beta.91` so the framework-selected Effect beta
|
|
112
|
+
cohort is not blocked by the 24-hour age gate or trusted-publisher to
|
|
113
|
+
provenance metadata transition.
|
|
113
114
|
|
|
114
115
|
Gradual migration means old, unmigrated Modern.js apps can keep their existing
|
|
115
116
|
runtime until they are converted. Once a surface is generated or migrated as
|
|
@@ -195,10 +195,15 @@ export default defineConfig({
|
|
|
195
195
|
## Effect 版本组
|
|
196
196
|
|
|
197
197
|
UltraModern 生成的 workspace 会通过 `pnpm-workspace.yaml` overrides 锁定与框架兼容的
|
|
198
|
-
Effect 版本组。`3.5.0-ultramodern.
|
|
198
|
+
Effect 版本组。`3.5.0-ultramodern.5` 使用:
|
|
199
199
|
|
|
200
200
|
```yaml
|
|
201
|
+
minimumReleaseAgeExclude:
|
|
202
|
+
- 'effect@4.0.0-beta.91'
|
|
203
|
+
- '@effect/opentelemetry@4.0.0-beta.91'
|
|
204
|
+
|
|
201
205
|
trustPolicyExclude:
|
|
206
|
+
- 'effect@4.0.0-beta.91'
|
|
202
207
|
- '@effect/opentelemetry@4.0.0-beta.91'
|
|
203
208
|
|
|
204
209
|
overrides:
|
|
@@ -207,10 +212,10 @@ overrides:
|
|
|
207
212
|
```
|
|
208
213
|
|
|
209
214
|
不要在应用包里添加不同版本的直接 `effect` 依赖。Effect beta 不一致时,Layer 或 HTTP
|
|
210
|
-
middleware 构建可能因为运行时 service 来自不同包实例而失败。保留生成的
|
|
211
|
-
|
|
212
|
-
`@effect/opentelemetry` 从 trusted-publisher
|
|
213
|
-
时的 pnpm no-downgrade 检查。
|
|
215
|
+
middleware 构建可能因为运行时 service 来自不同包实例而失败。保留生成的 policy
|
|
216
|
+
exclusion 条目并让它跟随同一个 Effect 版本组;它用于处理框架选定 Effect beta 版本在
|
|
217
|
+
24 小时成熟期内的安装,以及 `effect` 和 `@effect/opentelemetry` 从 trusted-publisher
|
|
218
|
+
metadata 迁移到 provenance attestation 时的 pnpm no-downgrade 检查。
|
|
214
219
|
|
|
215
220
|
## 契约测试
|
|
216
221
|
|
|
@@ -71,18 +71,18 @@ mise exec -- pnpm check
|
|
|
71
71
|
mise exec -- pnpm build
|
|
72
72
|
```
|
|
73
73
|
|
|
74
|
-
严格生成 API 迁移要求 `3.5.0-ultramodern.
|
|
74
|
+
严格生成 API 迁移要求 `3.5.0-ultramodern.5` 或更新版本。
|
|
75
75
|
`3.4.0-ultramodern.20` 及更早 cohort 还没有这套完整的直接
|
|
76
76
|
`api/index.ts` 生成器、生成的 `.mts` 检查、严格 Oxlint 边界规则、Effect 版本组
|
|
77
77
|
overrides 和严格 Effect 迁移命令。还不能安装该 BleedingDev cohort 的 agent 应使用本地
|
|
78
78
|
Modern.js workspace 做迁移校验;否则用 `--ultramodern-package-version` 固定
|
|
79
|
-
`3.5.0-ultramodern.
|
|
79
|
+
`3.5.0-ultramodern.5` 或更新版本。
|
|
80
80
|
|
|
81
81
|
手写 package alias 或生成 metadata 之前,先在目标 workspace 运行框架迁移命令:
|
|
82
82
|
|
|
83
83
|
```bash
|
|
84
|
-
pnpm dlx @bleedingdev/modern-js-create@3.5.0-ultramodern.
|
|
85
|
-
migrate-strict-effect --version 3.5.0-ultramodern.
|
|
84
|
+
pnpm dlx @bleedingdev/modern-js-create@3.5.0-ultramodern.5 ultramodern \
|
|
85
|
+
migrate-strict-effect --version 3.5.0-ultramodern.5
|
|
86
86
|
pnpm api:check
|
|
87
87
|
pnpm contract:check
|
|
88
88
|
```
|
|
@@ -96,9 +96,9 @@ pnpm overrides/trust policy 和 pnpm lockfile。剩余失败就是源码迁移
|
|
|
96
96
|
严格 Effect 生成 workspace 会通过 pnpm overrides 固定兼容版本组:
|
|
97
97
|
`effect@4.0.0-beta.91` 和 `@effect/vitest@4.0.0-beta.91`。不要添加与这些
|
|
98
98
|
overrides 冲突的 app 本地直接 Effect 版本。生成的 pnpm policy 还会为
|
|
99
|
-
`@effect/opentelemetry@4.0.0-beta.91`
|
|
100
|
-
|
|
101
|
-
no-downgrade 检查误拦截。
|
|
99
|
+
`effect@4.0.0-beta.91` 和 `@effect/opentelemetry@4.0.0-beta.91` 添加例外,避免框架选定的
|
|
100
|
+
Effect beta 版本组被 24 小时成熟期检查,或从 trusted-publisher metadata 迁移到
|
|
101
|
+
provenance attestation 时被 no-downgrade 检查误拦截。
|
|
102
102
|
|
|
103
103
|
渐进迁移意味着尚未迁移的旧 Modern.js app 可以保留现有 runtime,直到被转换为
|
|
104
104
|
UltraModern。一个 surface 一旦生成为或迁移为 UltraModern HTTP API,就只能使用
|
package/package.json
CHANGED
|
@@ -19,14 +19,14 @@
|
|
|
19
19
|
"modern.js",
|
|
20
20
|
"ultramodern.js"
|
|
21
21
|
],
|
|
22
|
-
"version": "3.5.0-ultramodern.
|
|
22
|
+
"version": "3.5.0-ultramodern.5",
|
|
23
23
|
"publishConfig": {
|
|
24
24
|
"registry": "https://registry.npmjs.org/",
|
|
25
25
|
"access": "public"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
28
|
"mermaid": "^11.16.0",
|
|
29
|
-
"@modern-js/sandpack-react": "npm:@bleedingdev/modern-js-sandpack-react@3.5.0-ultramodern.
|
|
29
|
+
"@modern-js/sandpack-react": "npm:@bleedingdev/modern-js-sandpack-react@3.5.0-ultramodern.5"
|
|
30
30
|
},
|
|
31
31
|
"devDependencies": {
|
|
32
32
|
"@rsbuild/plugin-sass": "2.0.0",
|