@takeshape/schema 11.144.1 → 11.154.2
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.
- package/examples/latest/all-fields-shapes-inline.json +1 -1
- package/examples/latest/all-fields-shapes.json +1 -1
- package/examples/latest/betzino.json +1 -1
- package/examples/latest/blog-schema.json +1 -1
- package/examples/latest/brewery-schema.json +1 -1
- package/examples/latest/chat-agent-schema.json +1 -1
- package/examples/latest/clear-cache-schema.json +1 -1
- package/examples/latest/complex-project-schema.json +1 -1
- package/examples/latest/complex-schema.json +1 -1
- package/examples/latest/edit-schema.json +1 -1
- package/examples/latest/frank-and-fred-schema.json +1 -1
- package/examples/latest/generate-agent-schema.json +1 -1
- package/examples/latest/klirr-schema.json +1 -1
- package/examples/latest/layers/rick-and-morty-layer.json +1 -1
- package/examples/latest/layers/shopify-layer-2023-01.json +1 -1
- package/examples/latest/layers/shopify-storefront-2023-04.json +1 -1
- package/examples/latest/layers/wordpress-2024-01.json +1 -1
- package/examples/latest/massive-schema.json +1 -1
- package/examples/latest/mill-components-schema.json +1 -1
- package/examples/latest/nested-shape-arrays.json +1 -1
- package/examples/latest/one-earth.json +1 -1
- package/examples/latest/pet-oneof-array.json +1 -1
- package/examples/latest/post-schema.json +1 -1
- package/examples/latest/pruned-shopify-product-schema.json +1 -1
- package/examples/latest/rag-example.json +1 -1
- package/examples/latest/real-world-schema.json +1 -1
- package/examples/latest/recursive-repeater-schema.json +1 -1
- package/examples/latest/recursive-schema.json +1 -1
- package/examples/latest/rick-and-morty-ast.json +1 -1
- package/examples/latest/rick-and-morty-graphql.json +1 -1
- package/examples/latest/rick-and-morty-rest.json +1 -1
- package/examples/latest/rick-and-morty-user-schema.json +1 -1
- package/examples/latest/rick-and-morty-with-indexing.json +1 -1
- package/examples/latest/schema-where-filter.json +1 -1
- package/examples/latest/schema-with-repeater-draftjs.json +1 -1
- package/examples/latest/schema-with-rick-and-morty.json +1 -1
- package/examples/latest/shape-books-v3_2_0.json +1 -1
- package/examples/latest/shape-books.json +1 -1
- package/examples/latest/shape-editor-schema-edited.json +1 -1
- package/examples/latest/shape-editor-schema-initial.json +1 -1
- package/examples/latest/shapedb-crud-every-prop-type.json +1 -1
- package/examples/latest/shopify-lookbook.json +1 -1
- package/examples/latest/shopify-product-2022-07.json +1 -1
- package/examples/latest/shopify-product-2023-04.json +1 -1
- package/examples/latest/shopify-store-with-widget.json +1 -1
- package/examples/latest/stripe-product-runtime-schema.json +1 -1
- package/examples/latest/stripe-starter-resolved.json +1 -1
- package/examples/latest/user-schema-no-required.json +1 -1
- package/examples/latest/user-schema-with-defaults.json +1 -1
- package/examples/latest/valvoline-ai-demo.json +1461 -1421
- package/examples/latest/vector-search-schema.json +1 -1
- package/package.json +10 -9
- package/dist/agents.d.ts +0 -62
- package/dist/agents.js +0 -338
- package/dist/api-version.d.ts +0 -5
- package/dist/api-version.js +0 -17
- package/dist/auth-schemas.d.ts +0 -128
- package/dist/auth-schemas.js +0 -7
- package/dist/auth-utils.d.ts +0 -5
- package/dist/auth-utils.js +0 -6
- package/dist/builtin-schema.d.ts +0 -18
- package/dist/builtin-schema.js +0 -683
- package/dist/constants.d.ts +0 -1
- package/dist/constants.js +0 -1
- package/dist/content-schema-transform.d.ts +0 -35
- package/dist/content-schema-transform.js +0 -162
- package/dist/create-input-schema.d.ts +0 -9
- package/dist/create-input-schema.js +0 -68
- package/dist/enum.d.ts +0 -2
- package/dist/enum.js +0 -9
- package/dist/flatten-templates.d.ts +0 -2
- package/dist/flatten-templates.js +0 -20
- package/dist/get-is-leaf.d.ts +0 -3
- package/dist/get-is-leaf.js +0 -56
- package/dist/index.d.ts +0 -62
- package/dist/index.js +0 -59
- package/dist/interfaces.d.ts +0 -14
- package/dist/interfaces.js +0 -86
- package/dist/layers/layers.d.ts +0 -26
- package/dist/layers/layers.js +0 -301
- package/dist/layers/refs.d.ts +0 -102
- package/dist/layers/refs.js +0 -220
- package/dist/layers/type-utils.d.ts +0 -59
- package/dist/layers/type-utils.js +0 -118
- package/dist/layers/visitor.d.ts +0 -5
- package/dist/layers/visitor.js +0 -38
- package/dist/migration/index.d.ts +0 -73
- package/dist/migration/index.js +0 -103
- package/dist/migration/to/v3.0.0.d.ts +0 -4
- package/dist/migration/to/v3.0.0.js +0 -212
- package/dist/migration/to/v3.1.0.d.ts +0 -4
- package/dist/migration/to/v3.1.0.js +0 -194
- package/dist/migration/to/v3.10.0.d.ts +0 -4
- package/dist/migration/to/v3.10.0.js +0 -67
- package/dist/migration/to/v3.11.0.d.ts +0 -4
- package/dist/migration/to/v3.11.0.js +0 -85
- package/dist/migration/to/v3.12.3.d.ts +0 -4
- package/dist/migration/to/v3.12.3.js +0 -87
- package/dist/migration/to/v3.13.0.d.ts +0 -4
- package/dist/migration/to/v3.13.0.js +0 -17
- package/dist/migration/to/v3.17.0.d.ts +0 -4
- package/dist/migration/to/v3.17.0.js +0 -22
- package/dist/migration/to/v3.18.0.d.ts +0 -4
- package/dist/migration/to/v3.18.0.js +0 -64
- package/dist/migration/to/v3.18.1.d.ts +0 -4
- package/dist/migration/to/v3.18.1.js +0 -12
- package/dist/migration/to/v3.18.2.d.ts +0 -4
- package/dist/migration/to/v3.18.2.js +0 -19
- package/dist/migration/to/v3.20.0.d.ts +0 -4
- package/dist/migration/to/v3.20.0.js +0 -24
- package/dist/migration/to/v3.22.0.d.ts +0 -4
- package/dist/migration/to/v3.22.0.js +0 -25
- package/dist/migration/to/v3.24.0.d.ts +0 -4
- package/dist/migration/to/v3.24.0.js +0 -11
- package/dist/migration/to/v3.25.0.d.ts +0 -4
- package/dist/migration/to/v3.25.0.js +0 -11
- package/dist/migration/to/v3.3.0.d.ts +0 -4
- package/dist/migration/to/v3.3.0.js +0 -13
- package/dist/migration/to/v3.31.0.d.ts +0 -4
- package/dist/migration/to/v3.31.0.js +0 -38
- package/dist/migration/to/v3.32.0.d.ts +0 -4
- package/dist/migration/to/v3.32.0.js +0 -59
- package/dist/migration/to/v3.34.0.d.ts +0 -6
- package/dist/migration/to/v3.34.0.js +0 -111
- package/dist/migration/to/v3.36.0.d.ts +0 -4
- package/dist/migration/to/v3.36.0.js +0 -22
- package/dist/migration/to/v3.39.0.d.ts +0 -4
- package/dist/migration/to/v3.39.0.js +0 -45
- package/dist/migration/to/v3.40.0.d.ts +0 -4
- package/dist/migration/to/v3.40.0.js +0 -26
- package/dist/migration/to/v3.46.0.d.ts +0 -4
- package/dist/migration/to/v3.46.0.js +0 -35
- package/dist/migration/to/v3.57.0.d.ts +0 -4
- package/dist/migration/to/v3.57.0.js +0 -18
- package/dist/migration/to/v3.9.0.d.ts +0 -4
- package/dist/migration/to/v3.9.0.js +0 -79
- package/dist/migration/types.d.ts +0 -26
- package/dist/migration/types.js +0 -3
- package/dist/migration/utils.d.ts +0 -2
- package/dist/migration/utils.js +0 -6
- package/dist/mocks.d.ts +0 -14
- package/dist/mocks.js +0 -58
- package/dist/models/agent.d.ts +0 -3
- package/dist/models/agent.js +0 -29
- package/dist/models/project-schema.d.ts +0 -18
- package/dist/models/project-schema.js +0 -119
- package/dist/models/query.d.ts +0 -3
- package/dist/models/query.js +0 -38
- package/dist/models/runtime-schema.d.ts +0 -9
- package/dist/models/runtime-schema.js +0 -20
- package/dist/models/shape.d.ts +0 -4
- package/dist/models/shape.js +0 -36
- package/dist/models/types.d.ts +0 -36
- package/dist/models/types.js +0 -1
- package/dist/models/user-schema.d.ts +0 -7
- package/dist/models/user-schema.js +0 -9
- package/dist/patterns.d.ts +0 -12
- package/dist/patterns.js +0 -1
- package/dist/project-schema/index.d.ts +0 -211
- package/dist/project-schema/index.js +0 -83
- package/dist/project-schema/latest.d.ts +0 -2619
- package/dist/project-schema/latest.js +0 -7
- package/dist/project-schema/migrate.d.ts +0 -4
- package/dist/project-schema/migrate.js +0 -218
- package/dist/project-schema/v1.0.0.d.ts +0 -299
- package/dist/project-schema/v1.0.0.js +0 -7
- package/dist/project-schema/v3.0.0.d.ts +0 -478
- package/dist/project-schema/v3.0.0.js +0 -7
- package/dist/project-schema/v3.1.0.d.ts +0 -621
- package/dist/project-schema/v3.1.0.js +0 -7
- package/dist/project-schema/v3.10.0.d.ts +0 -1201
- package/dist/project-schema/v3.10.0.js +0 -7
- package/dist/project-schema/v3.11.0.d.ts +0 -1210
- package/dist/project-schema/v3.11.0.js +0 -7
- package/dist/project-schema/v3.12.0.d.ts +0 -1214
- package/dist/project-schema/v3.12.0.js +0 -7
- package/dist/project-schema/v3.12.1.d.ts +0 -1273
- package/dist/project-schema/v3.12.1.js +0 -7
- package/dist/project-schema/v3.12.2.d.ts +0 -1283
- package/dist/project-schema/v3.12.2.js +0 -7
- package/dist/project-schema/v3.12.3.d.ts +0 -1306
- package/dist/project-schema/v3.12.3.js +0 -7
- package/dist/project-schema/v3.13.0.d.ts +0 -1317
- package/dist/project-schema/v3.13.0.js +0 -7
- package/dist/project-schema/v3.13.1.d.ts +0 -1412
- package/dist/project-schema/v3.13.1.js +0 -7
- package/dist/project-schema/v3.14.0.d.ts +0 -1436
- package/dist/project-schema/v3.14.0.js +0 -7
- package/dist/project-schema/v3.15.0.d.ts +0 -1458
- package/dist/project-schema/v3.15.0.js +0 -7
- package/dist/project-schema/v3.16.0.d.ts +0 -1470
- package/dist/project-schema/v3.16.0.js +0 -7
- package/dist/project-schema/v3.17.0.d.ts +0 -1467
- package/dist/project-schema/v3.17.0.js +0 -7
- package/dist/project-schema/v3.17.1.d.ts +0 -1468
- package/dist/project-schema/v3.17.1.js +0 -7
- package/dist/project-schema/v3.18.0.d.ts +0 -1333
- package/dist/project-schema/v3.18.0.js +0 -7
- package/dist/project-schema/v3.18.1.d.ts +0 -1332
- package/dist/project-schema/v3.18.1.js +0 -7
- package/dist/project-schema/v3.18.2.d.ts +0 -1332
- package/dist/project-schema/v3.18.2.js +0 -7
- package/dist/project-schema/v3.19.0.d.ts +0 -1336
- package/dist/project-schema/v3.19.0.js +0 -7
- package/dist/project-schema/v3.2.0.d.ts +0 -632
- package/dist/project-schema/v3.2.0.js +0 -7
- package/dist/project-schema/v3.20.0.d.ts +0 -1336
- package/dist/project-schema/v3.20.0.js +0 -7
- package/dist/project-schema/v3.21.0.d.ts +0 -1338
- package/dist/project-schema/v3.21.0.js +0 -7
- package/dist/project-schema/v3.22.0.d.ts +0 -1344
- package/dist/project-schema/v3.22.0.js +0 -7
- package/dist/project-schema/v3.23.0.d.ts +0 -1376
- package/dist/project-schema/v3.23.0.js +0 -7
- package/dist/project-schema/v3.24.0.d.ts +0 -1364
- package/dist/project-schema/v3.24.0.js +0 -7
- package/dist/project-schema/v3.25.0.d.ts +0 -1363
- package/dist/project-schema/v3.25.0.js +0 -7
- package/dist/project-schema/v3.26.0.d.ts +0 -1388
- package/dist/project-schema/v3.26.0.js +0 -7
- package/dist/project-schema/v3.27.0.d.ts +0 -1397
- package/dist/project-schema/v3.27.0.js +0 -7
- package/dist/project-schema/v3.28.0.d.ts +0 -1416
- package/dist/project-schema/v3.28.0.js +0 -7
- package/dist/project-schema/v3.29.0.d.ts +0 -1423
- package/dist/project-schema/v3.29.0.js +0 -7
- package/dist/project-schema/v3.3.0.d.ts +0 -632
- package/dist/project-schema/v3.3.0.js +0 -7
- package/dist/project-schema/v3.30.0.d.ts +0 -1416
- package/dist/project-schema/v3.30.0.js +0 -7
- package/dist/project-schema/v3.31.0.d.ts +0 -1448
- package/dist/project-schema/v3.31.0.js +0 -7
- package/dist/project-schema/v3.32.0.d.ts +0 -1439
- package/dist/project-schema/v3.32.0.js +0 -7
- package/dist/project-schema/v3.33.0.d.ts +0 -1445
- package/dist/project-schema/v3.33.0.js +0 -7
- package/dist/project-schema/v3.34.0.d.ts +0 -1445
- package/dist/project-schema/v3.34.0.js +0 -7
- package/dist/project-schema/v3.35.0.d.ts +0 -1464
- package/dist/project-schema/v3.35.0.js +0 -7
- package/dist/project-schema/v3.36.0.d.ts +0 -1470
- package/dist/project-schema/v3.36.0.js +0 -7
- package/dist/project-schema/v3.37.0.d.ts +0 -1522
- package/dist/project-schema/v3.37.0.js +0 -7
- package/dist/project-schema/v3.38.0.d.ts +0 -1522
- package/dist/project-schema/v3.38.0.js +0 -7
- package/dist/project-schema/v3.39.0.d.ts +0 -1529
- package/dist/project-schema/v3.39.0.js +0 -7
- package/dist/project-schema/v3.4.0.d.ts +0 -624
- package/dist/project-schema/v3.4.0.js +0 -7
- package/dist/project-schema/v3.40.0.d.ts +0 -1530
- package/dist/project-schema/v3.40.0.js +0 -7
- package/dist/project-schema/v3.41.0.d.ts +0 -1530
- package/dist/project-schema/v3.41.0.js +0 -7
- package/dist/project-schema/v3.42.0.d.ts +0 -1534
- package/dist/project-schema/v3.42.0.js +0 -7
- package/dist/project-schema/v3.43.0.d.ts +0 -1536
- package/dist/project-schema/v3.43.0.js +0 -7
- package/dist/project-schema/v3.44.0.d.ts +0 -1621
- package/dist/project-schema/v3.44.0.js +0 -7
- package/dist/project-schema/v3.45.0.d.ts +0 -1650
- package/dist/project-schema/v3.45.0.js +0 -7
- package/dist/project-schema/v3.46.0.d.ts +0 -1703
- package/dist/project-schema/v3.46.0.js +0 -7
- package/dist/project-schema/v3.47.0.d.ts +0 -1736
- package/dist/project-schema/v3.47.0.js +0 -7
- package/dist/project-schema/v3.48.0.d.ts +0 -2208
- package/dist/project-schema/v3.48.0.js +0 -7
- package/dist/project-schema/v3.49.0.d.ts +0 -2217
- package/dist/project-schema/v3.49.0.js +0 -7
- package/dist/project-schema/v3.5.0.d.ts +0 -649
- package/dist/project-schema/v3.5.0.js +0 -7
- package/dist/project-schema/v3.5.1.d.ts +0 -649
- package/dist/project-schema/v3.5.1.js +0 -7
- package/dist/project-schema/v3.50.0.d.ts +0 -2269
- package/dist/project-schema/v3.50.0.js +0 -7
- package/dist/project-schema/v3.51.0.d.ts +0 -2269
- package/dist/project-schema/v3.51.0.js +0 -7
- package/dist/project-schema/v3.52.0.d.ts +0 -2269
- package/dist/project-schema/v3.52.0.js +0 -7
- package/dist/project-schema/v3.53.0.d.ts +0 -2350
- package/dist/project-schema/v3.53.0.js +0 -7
- package/dist/project-schema/v3.54.0.d.ts +0 -2369
- package/dist/project-schema/v3.54.0.js +0 -7
- package/dist/project-schema/v3.55.0.d.ts +0 -2369
- package/dist/project-schema/v3.55.0.js +0 -7
- package/dist/project-schema/v3.56.0.d.ts +0 -2405
- package/dist/project-schema/v3.56.0.js +0 -7
- package/dist/project-schema/v3.57.0.d.ts +0 -2601
- package/dist/project-schema/v3.57.0.js +0 -7
- package/dist/project-schema/v3.58.0.d.ts +0 -2601
- package/dist/project-schema/v3.58.0.js +0 -7
- package/dist/project-schema/v3.59.0.d.ts +0 -2619
- package/dist/project-schema/v3.59.0.js +0 -7
- package/dist/project-schema/v3.6.0.d.ts +0 -658
- package/dist/project-schema/v3.6.0.js +0 -7
- package/dist/project-schema/v3.7.0.d.ts +0 -961
- package/dist/project-schema/v3.7.0.js +0 -7
- package/dist/project-schema/v3.8.0.d.ts +0 -979
- package/dist/project-schema/v3.8.0.js +0 -7
- package/dist/project-schema/v3.9.0.d.ts +0 -1178
- package/dist/project-schema/v3.9.0.js +0 -7
- package/dist/project-schema/v4.0.0.d.ts +0 -1328
- package/dist/project-schema/v4.0.0.js +0 -7
- package/dist/refs.d.ts +0 -218
- package/dist/refs.js +0 -616
- package/dist/relationships.d.ts +0 -40
- package/dist/relationships.js +0 -302
- package/dist/resolvers/ai/abort-agent-message-args.d.ts +0 -16
- package/dist/resolvers/ai/abort-agent-message-args.js +0 -13
- package/dist/resolvers/ai/abort-agent-message-response.d.ts +0 -39
- package/dist/resolvers/ai/abort-agent-message-response.js +0 -19
- package/dist/resolvers/ai/agent-chat-args.d.ts +0 -17
- package/dist/resolvers/ai/agent-chat-args.js +0 -14
- package/dist/resolvers/ai/agent-chat-payload.d.ts +0 -35
- package/dist/resolvers/ai/agent-chat-payload.js +0 -26
- package/dist/resolvers/ai/agent-chat-response.d.ts +0 -289
- package/dist/resolvers/ai/agent-chat-response.js +0 -21
- package/dist/resolvers/ai/agent-generate-args.d.ts +0 -17
- package/dist/resolvers/ai/agent-generate-args.js +0 -14
- package/dist/resolvers/ai/agent-message-input.d.ts +0 -73
- package/dist/resolvers/ai/agent-message-input.js +0 -39
- package/dist/resolvers/ai/agent-message-output.d.ts +0 -169
- package/dist/resolvers/ai/agent-message-output.js +0 -77
- package/dist/resolvers/ai/agent-message-payload.d.ts +0 -507
- package/dist/resolvers/ai/agent-message-payload.js +0 -156
- package/dist/resolvers/ai/agent-run-mode.d.ts +0 -7
- package/dist/resolvers/ai/agent-run-mode.js +0 -9
- package/dist/resolvers/ai/agent-session-payload.d.ts +0 -515
- package/dist/resolvers/ai/agent-session-payload.js +0 -175
- package/dist/resolvers/ai/create-agent-session-response.d.ts +0 -199
- package/dist/resolvers/ai/create-agent-session-response.js +0 -9
- package/dist/resolvers/ai/embedding-search.d.ts +0 -54
- package/dist/resolvers/ai/embedding-search.js +0 -46
- package/dist/resolvers/ai/get-agent-message-args.d.ts +0 -16
- package/dist/resolvers/ai/get-agent-message-args.js +0 -13
- package/dist/resolvers/ai/get-agent-message-response.d.ts +0 -805
- package/dist/resolvers/ai/get-agent-message-response.js +0 -63
- package/dist/resolvers/ai/inspect-agent-args.d.ts +0 -16
- package/dist/resolvers/ai/inspect-agent-args.js +0 -13
- package/dist/resolvers/ai/inspect-agent-response.d.ts +0 -504
- package/dist/resolvers/ai/inspect-agent-response.js +0 -48
- package/dist/resolvers/ai/send-agent-feedback-args.d.ts +0 -52
- package/dist/resolvers/ai/send-agent-feedback-args.js +0 -16
- package/dist/resolvers/ai/send-agent-message-args.d.ts +0 -48
- package/dist/resolvers/ai/send-agent-message-args.js +0 -36
- package/dist/resolvers/ai/send-agent-message-response.d.ts +0 -353
- package/dist/resolvers/ai/send-agent-message-response.js +0 -51
- package/dist/resolvers/ai/types.d.ts +0 -6
- package/dist/resolvers/ai/types.js +0 -1
- package/dist/resolvers/takeshape/assets/asset-image-meta.d.ts +0 -79
- package/dist/resolvers/takeshape/assets/asset-image-meta.js +0 -98
- package/dist/resolvers/takeshape/assets/asset-image-params.d.ts +0 -901
- package/dist/resolvers/takeshape/assets/asset-image-params.js +0 -726
- package/dist/resolvers/takeshape/assets/asset-image.d.ts +0 -17
- package/dist/resolvers/takeshape/assets/asset-image.js +0 -15
- package/dist/resolvers/takeshape/assets/asset.d.ts +0 -125
- package/dist/resolvers/takeshape/assets/asset.js +0 -107
- package/dist/resolvers/takeshape/assets/constants.d.ts +0 -11
- package/dist/resolvers/takeshape/assets/constants.js +0 -11
- package/dist/resolvers/takeshape/builtins/constants.d.ts +0 -1
- package/dist/resolvers/takeshape/builtins/constants.js +0 -1
- package/dist/runtime-schema.d.ts +0 -6
- package/dist/runtime-schema.js +0 -85
- package/dist/scalars.d.ts +0 -2
- package/dist/scalars.js +0 -4
- package/dist/schema-transform.d.ts +0 -19
- package/dist/schema-transform.js +0 -74
- package/dist/schema-util.d.ts +0 -266
- package/dist/schema-util.js +0 -1127
- package/dist/schemas/auth-schemas.json +0 -374
- package/dist/schemas/index.d.ts +0 -4
- package/dist/schemas/index.js +0 -170
- package/dist/schemas/project-schema/experimental-2025-07.json +0 -1297
- package/dist/schemas/project-schema/latest.d.ts +0 -180
- package/dist/schemas/project-schema/latest.js +0 -11
- package/dist/schemas/project-schema/latest.json +0 -4846
- package/dist/schemas/project-schema/meta-schema-v1.0.0.json +0 -193
- package/dist/schemas/project-schema/meta-schema-v3.0.0.json +0 -608
- package/dist/schemas/project-schema/meta-schema-v3.1.0.json +0 -608
- package/dist/schemas/project-schema/meta-schema-v3.2.0.json +0 -612
- package/dist/schemas/project-schema/meta-schema-v3.3.0.json +0 -612
- package/dist/schemas/project-schema/meta-schema-v3.4.0.json +0 -637
- package/dist/schemas/project-schema/meta-schema-v3.5.0.json +0 -626
- package/dist/schemas/project-schema/meta-schema-v3.5.1.json +0 -626
- package/dist/schemas/project-schema/meta-schema-v3.6.0.json +0 -629
- package/dist/schemas/project-schema/meta-schema-v3.7.0.json +0 -1137
- package/dist/schemas/project-schema/meta-schema-v3.8.0.json +0 -1137
- package/dist/schemas/project-schema/meta-schema-v3.9.0.json +0 -1477
- package/dist/schemas/project-schema/v1.0.0.json +0 -321
- package/dist/schemas/project-schema/v3.0.0.json +0 -414
- package/dist/schemas/project-schema/v3.1.0.json +0 -572
- package/dist/schemas/project-schema/v3.10.0.json +0 -2097
- package/dist/schemas/project-schema/v3.11.0.json +0 -2141
- package/dist/schemas/project-schema/v3.12.0.json +0 -2144
- package/dist/schemas/project-schema/v3.12.1.json +0 -2282
- package/dist/schemas/project-schema/v3.12.2.json +0 -2304
- package/dist/schemas/project-schema/v3.12.3.json +0 -2357
- package/dist/schemas/project-schema/v3.13.0.json +0 -2377
- package/dist/schemas/project-schema/v3.14.0.json +0 -2385
- package/dist/schemas/project-schema/v3.15.0.json +0 -2365
- package/dist/schemas/project-schema/v3.16.0.json +0 -2373
- package/dist/schemas/project-schema/v3.17.0.json +0 -2378
- package/dist/schemas/project-schema/v3.17.1.json +0 -2380
- package/dist/schemas/project-schema/v3.18.0.json +0 -2356
- package/dist/schemas/project-schema/v3.18.1.json +0 -2357
- package/dist/schemas/project-schema/v3.18.2.json +0 -2357
- package/dist/schemas/project-schema/v3.19.0.json +0 -2369
- package/dist/schemas/project-schema/v3.2.0.json +0 -580
- package/dist/schemas/project-schema/v3.20.0.json +0 -2369
- package/dist/schemas/project-schema/v3.21.0.json +0 -2376
- package/dist/schemas/project-schema/v3.22.0.json +0 -2381
- package/dist/schemas/project-schema/v3.23.0.json +0 -2456
- package/dist/schemas/project-schema/v3.24.0.json +0 -2556
- package/dist/schemas/project-schema/v3.25.0.json +0 -2552
- package/dist/schemas/project-schema/v3.26.0.json +0 -2599
- package/dist/schemas/project-schema/v3.27.0.json +0 -2611
- package/dist/schemas/project-schema/v3.28.0.json +0 -2656
- package/dist/schemas/project-schema/v3.29.0.json +0 -2670
- package/dist/schemas/project-schema/v3.3.0.json +0 -581
- package/dist/schemas/project-schema/v3.30.0.json +0 -2656
- package/dist/schemas/project-schema/v3.31.0.json +0 -2714
- package/dist/schemas/project-schema/v3.32.0.json +0 -2708
- package/dist/schemas/project-schema/v3.33.0.json +0 -2715
- package/dist/schemas/project-schema/v3.34.0.json +0 -2715
- package/dist/schemas/project-schema/v3.35.0.json +0 -2748
- package/dist/schemas/project-schema/v3.36.0.json +0 -2756
- package/dist/schemas/project-schema/v3.37.0.json +0 -2821
- package/dist/schemas/project-schema/v3.38.0.json +0 -2819
- package/dist/schemas/project-schema/v3.39.0.json +0 -2827
- package/dist/schemas/project-schema/v3.4.0.json +0 -571
- package/dist/schemas/project-schema/v3.40.0.json +0 -2830
- package/dist/schemas/project-schema/v3.41.0.json +0 -2830
- package/dist/schemas/project-schema/v3.42.0.json +0 -2835
- package/dist/schemas/project-schema/v3.43.0.json +0 -2841
- package/dist/schemas/project-schema/v3.44.0.json +0 -3013
- package/dist/schemas/project-schema/v3.45.0.json +0 -3064
- package/dist/schemas/project-schema/v3.46.0.json +0 -3136
- package/dist/schemas/project-schema/v3.47.0.json +0 -3189
- package/dist/schemas/project-schema/v3.48.0.json +0 -3196
- package/dist/schemas/project-schema/v3.49.0.json +0 -3239
- package/dist/schemas/project-schema/v3.5.0.json +0 -571
- package/dist/schemas/project-schema/v3.5.1.json +0 -571
- package/dist/schemas/project-schema/v3.50.0.json +0 -3320
- package/dist/schemas/project-schema/v3.51.0.json +0 -3326
- package/dist/schemas/project-schema/v3.52.0.json +0 -3326
- package/dist/schemas/project-schema/v3.53.0.json +0 -3476
- package/dist/schemas/project-schema/v3.54.0.json +0 -3512
- package/dist/schemas/project-schema/v3.55.0.json +0 -3515
- package/dist/schemas/project-schema/v3.56.0.json +0 -3530
- package/dist/schemas/project-schema/v3.57.0.json +0 -4815
- package/dist/schemas/project-schema/v3.58.0.json +0 -4815
- package/dist/schemas/project-schema/v3.59.0.json +0 -4846
- package/dist/schemas/project-schema/v3.6.0.json +0 -587
- package/dist/schemas/project-schema/v3.7.0.json +0 -587
- package/dist/schemas/project-schema/v3.8.0.json +0 -604
- package/dist/schemas/project-schema/v3.9.0.json +0 -604
- package/dist/schemas/project-schema/v4.0.0.json +0 -2316
- package/dist/schemas/project-schema.json +0 -214
- package/dist/service-dependencies.d.ts +0 -13
- package/dist/service-dependencies.js +0 -165
- package/dist/services/services.d.ts +0 -31
- package/dist/services/services.js +0 -145
- package/dist/services/types.d.ts +0 -11
- package/dist/services/types.js +0 -1
- package/dist/services/util.d.ts +0 -16
- package/dist/services/util.js +0 -36
- package/dist/shape-paths.d.ts +0 -7
- package/dist/shape-paths.js +0 -28
- package/dist/taxonomies.d.ts +0 -15
- package/dist/taxonomies.js +0 -24
- package/dist/template-shapes/index.d.ts +0 -7
- package/dist/template-shapes/index.js +0 -33
- package/dist/template-shapes/names.d.ts +0 -10
- package/dist/template-shapes/names.js +0 -21
- package/dist/template-shapes/templates.d.ts +0 -32
- package/dist/template-shapes/templates.js +0 -316
- package/dist/template-shapes/types.d.ts +0 -15
- package/dist/template-shapes/types.js +0 -7
- package/dist/template-shapes/where.d.ts +0 -37
- package/dist/template-shapes/where.js +0 -400
- package/dist/types/index.d.ts +0 -3
- package/dist/types/index.js +0 -2
- package/dist/types/transforms.d.ts +0 -15
- package/dist/types/transforms.js +0 -1
- package/dist/types/types.d.ts +0 -200
- package/dist/types/types.js +0 -10
- package/dist/types/utils.d.ts +0 -112
- package/dist/types/utils.js +0 -269
- package/dist/unions.d.ts +0 -14
- package/dist/unions.js +0 -77
- package/dist/util/ai-tools.d.ts +0 -2
- package/dist/util/ai-tools.js +0 -14
- package/dist/util/api-indexing.d.ts +0 -9
- package/dist/util/api-indexing.js +0 -57
- package/dist/util/coerce-value.d.ts +0 -9
- package/dist/util/coerce-value.js +0 -32
- package/dist/util/detect-cycles.d.ts +0 -7
- package/dist/util/detect-cycles.js +0 -45
- package/dist/util/expressions.d.ts +0 -34
- package/dist/util/expressions.js +0 -350
- package/dist/util/find-shape-at-path.d.ts +0 -21
- package/dist/util/find-shape-at-path.js +0 -53
- package/dist/util/form-config.d.ts +0 -11
- package/dist/util/form-config.js +0 -62
- package/dist/util/get-conflicting-properties.d.ts +0 -6
- package/dist/util/get-conflicting-properties.js +0 -55
- package/dist/util/get-return-shape.d.ts +0 -4
- package/dist/util/get-return-shape.js +0 -30
- package/dist/util/has-arg.d.ts +0 -6
- package/dist/util/has-arg.js +0 -25
- package/dist/util/is-asset-property.d.ts +0 -3
- package/dist/util/is-asset-property.js +0 -11
- package/dist/util/mcp.d.ts +0 -8
- package/dist/util/mcp.js +0 -21
- package/dist/util/merge.d.ts +0 -15
- package/dist/util/merge.js +0 -254
- package/dist/util/patch-schema.d.ts +0 -8
- package/dist/util/patch-schema.js +0 -51
- package/dist/util/query-field-path.d.ts +0 -9
- package/dist/util/query-field-path.js +0 -23
- package/dist/util/shapes.d.ts +0 -5
- package/dist/util/shapes.js +0 -22
- package/dist/validate/ai.d.ts +0 -6
- package/dist/validate/ai.js +0 -183
- package/dist/validate/errors.d.ts +0 -3
- package/dist/validate/errors.js +0 -20
- package/dist/validate/types.d.ts +0 -1
- package/dist/validate/types.js +0 -1
- package/dist/validate/util.d.ts +0 -3
- package/dist/validate/util.js +0 -28
- package/dist/validate/validate.d.ts +0 -80
- package/dist/validate/validate.js +0 -1058
- package/dist/versions.d.ts +0 -4
- package/dist/versions.js +0 -4
- package/dist/workflows.d.ts +0 -14
- package/dist/workflows.js +0 -66
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import jsep, { type Expression } from 'jsep';
|
|
2
|
-
export interface ObjectExpression extends Expression {
|
|
3
|
-
type: 'ObjectExpression';
|
|
4
|
-
properties: PropertyExpression[];
|
|
5
|
-
}
|
|
6
|
-
export interface PropertyExpression extends Expression {
|
|
7
|
-
type: 'Property';
|
|
8
|
-
computed: boolean;
|
|
9
|
-
key: AnyExpression;
|
|
10
|
-
value: AnyExpression;
|
|
11
|
-
shorthand: boolean;
|
|
12
|
-
}
|
|
13
|
-
type AnyExpression = jsep.ArrayExpression | jsep.BinaryExpression | jsep.MemberExpression | jsep.CallExpression | jsep.ConditionalExpression | jsep.Identifier | jsep.Literal | jsep.ThisExpression | jsep.UnaryExpression | ObjectExpression | PropertyExpression;
|
|
14
|
-
export declare const METHODS_NOT_SUPPORTED = "Methods are not supported in expressions";
|
|
15
|
-
export declare const THIS_NOT_SUPPORTED = "This is not supported in expressions";
|
|
16
|
-
export declare function parseExpression(expression: string): AnyExpression;
|
|
17
|
-
export type ExpressionContext = {
|
|
18
|
-
currentStateId: string;
|
|
19
|
-
previousStateId?: string;
|
|
20
|
-
currentStateOutput?: unknown;
|
|
21
|
-
sessionMemory: Record<string, unknown>;
|
|
22
|
-
claims: Record<string, unknown>;
|
|
23
|
-
args: Record<string, unknown>;
|
|
24
|
-
vars: Record<string, unknown>;
|
|
25
|
-
};
|
|
26
|
-
export declare function validateExpression(expression: string): {
|
|
27
|
-
valid: true;
|
|
28
|
-
} | {
|
|
29
|
-
valid: false;
|
|
30
|
-
errors: string[];
|
|
31
|
-
};
|
|
32
|
-
export declare function compileExpression(expression: string): (context: Record<string, unknown>) => unknown;
|
|
33
|
-
export declare function expressionToString(_node: jsep.Expression | null, parent?: AnyExpression): string;
|
|
34
|
-
export {};
|
package/dist/util/expressions.js
DELETED
|
@@ -1,350 +0,0 @@
|
|
|
1
|
-
import object from '@jsep-plugin/object';
|
|
2
|
-
import jsep from 'jsep';
|
|
3
|
-
jsep.plugins.register(object);
|
|
4
|
-
// Default operator precedence from https://github.com/EricSmekens/jsep/blob/master/src/jsep.js#L55
|
|
5
|
-
const DEFAULT_PRECEDENCE = {
|
|
6
|
-
'||': 1,
|
|
7
|
-
'&&': 2,
|
|
8
|
-
'|': 3,
|
|
9
|
-
'^': 4,
|
|
10
|
-
'&': 5,
|
|
11
|
-
'==': 6,
|
|
12
|
-
'!=': 6,
|
|
13
|
-
'===': 6,
|
|
14
|
-
'!==': 6,
|
|
15
|
-
'<': 7,
|
|
16
|
-
'>': 7,
|
|
17
|
-
'<=': 7,
|
|
18
|
-
'>=': 7,
|
|
19
|
-
'<<': 8,
|
|
20
|
-
'>>': 8,
|
|
21
|
-
'>>>': 8,
|
|
22
|
-
'+': 9,
|
|
23
|
-
'-': 9,
|
|
24
|
-
'*': 10,
|
|
25
|
-
'/': 10,
|
|
26
|
-
'%': 10
|
|
27
|
-
};
|
|
28
|
-
/**
|
|
29
|
-
* Evaluation code from JSEP project, under MIT License.
|
|
30
|
-
* Copyright (c) 2013 Stephen Oney, http://jsep.from.so/
|
|
31
|
-
*/
|
|
32
|
-
const binops = {
|
|
33
|
-
// '|'(a, b) {
|
|
34
|
-
// return a | b;
|
|
35
|
-
// },
|
|
36
|
-
// '^'(a, b) {
|
|
37
|
-
// return a ^ b;
|
|
38
|
-
// },
|
|
39
|
-
// '&'(a, b) {
|
|
40
|
-
// return a & b;
|
|
41
|
-
// },
|
|
42
|
-
'=='(a, b) {
|
|
43
|
-
// biome-ignore lint/suspicious/noDoubleEquals: ignore
|
|
44
|
-
return a == b;
|
|
45
|
-
},
|
|
46
|
-
'!='(a, b) {
|
|
47
|
-
// biome-ignore lint/suspicious/noDoubleEquals: ignore
|
|
48
|
-
return a != b;
|
|
49
|
-
},
|
|
50
|
-
'==='(a, b) {
|
|
51
|
-
return a === b;
|
|
52
|
-
},
|
|
53
|
-
'!=='(a, b) {
|
|
54
|
-
return a !== b;
|
|
55
|
-
},
|
|
56
|
-
'<'(a, b) {
|
|
57
|
-
return a < b;
|
|
58
|
-
},
|
|
59
|
-
'>'(a, b) {
|
|
60
|
-
return a > b;
|
|
61
|
-
},
|
|
62
|
-
'<='(a, b) {
|
|
63
|
-
return a <= b;
|
|
64
|
-
},
|
|
65
|
-
'>='(a, b) {
|
|
66
|
-
return a >= b;
|
|
67
|
-
},
|
|
68
|
-
// '<<'(a, b) {
|
|
69
|
-
// return a << b;
|
|
70
|
-
// },
|
|
71
|
-
// '>>'(a, b) {
|
|
72
|
-
// return a >> b;
|
|
73
|
-
// },
|
|
74
|
-
// '>>>'(a, b) {
|
|
75
|
-
// return a >>> b;
|
|
76
|
-
// },
|
|
77
|
-
'+'(a, b) {
|
|
78
|
-
return a + b;
|
|
79
|
-
},
|
|
80
|
-
'-'(a, b) {
|
|
81
|
-
return a - b;
|
|
82
|
-
},
|
|
83
|
-
'*'(a, b) {
|
|
84
|
-
return a * b;
|
|
85
|
-
},
|
|
86
|
-
'/'(a, b) {
|
|
87
|
-
return a / b;
|
|
88
|
-
},
|
|
89
|
-
'%'(a, b) {
|
|
90
|
-
return a % b;
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
const unops = {
|
|
94
|
-
'-'(a) {
|
|
95
|
-
return -a;
|
|
96
|
-
},
|
|
97
|
-
'+'(a) {
|
|
98
|
-
return Number(a);
|
|
99
|
-
},
|
|
100
|
-
// '~'(a) {
|
|
101
|
-
// return ~a;
|
|
102
|
-
// },
|
|
103
|
-
'!'(a) {
|
|
104
|
-
return !a;
|
|
105
|
-
}
|
|
106
|
-
};
|
|
107
|
-
function evaluateArray(list, context) {
|
|
108
|
-
return list.map((v) => (v ? evaluate(v, context) : undefined));
|
|
109
|
-
}
|
|
110
|
-
function evaluateObject(properties, context) {
|
|
111
|
-
const obj = {};
|
|
112
|
-
for (const node of properties) {
|
|
113
|
-
const key = !node.computed && node.key.type === 'Identifier' ? node.key.name : evaluate(node.key, context);
|
|
114
|
-
obj[key] = evaluate(node.value, context);
|
|
115
|
-
}
|
|
116
|
-
return obj;
|
|
117
|
-
}
|
|
118
|
-
function isObject(x) {
|
|
119
|
-
return Boolean(x) && typeof x === 'object';
|
|
120
|
-
}
|
|
121
|
-
export const METHODS_NOT_SUPPORTED = 'Methods are not supported in expressions';
|
|
122
|
-
export const THIS_NOT_SUPPORTED = 'This is not supported in expressions';
|
|
123
|
-
function evaluateMember(node, context) {
|
|
124
|
-
const object = evaluate(node.object, context);
|
|
125
|
-
let key;
|
|
126
|
-
if (node.computed) {
|
|
127
|
-
key = evaluate(node.property, context);
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
key = node.property.name;
|
|
131
|
-
}
|
|
132
|
-
if (typeof key === 'string' && /^__proto__|prototype|constructor$/.test(key)) {
|
|
133
|
-
throw Error(`Access to member "${key}" disallowed.`);
|
|
134
|
-
}
|
|
135
|
-
if (isObject(object) && Object.hasOwn(object, key)) {
|
|
136
|
-
return [object, object[key]];
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
function evaluate(_node, context) {
|
|
140
|
-
const node = _node;
|
|
141
|
-
switch (node.type) {
|
|
142
|
-
case 'ArrayExpression':
|
|
143
|
-
return evaluateArray(node.elements, context);
|
|
144
|
-
case 'ObjectExpression':
|
|
145
|
-
return evaluateObject(node.properties, context);
|
|
146
|
-
case 'CallExpression': {
|
|
147
|
-
if (node.callee.type === 'MemberExpression') {
|
|
148
|
-
throw Error(METHODS_NOT_SUPPORTED);
|
|
149
|
-
}
|
|
150
|
-
const fn = evaluate(node.callee, context);
|
|
151
|
-
if (typeof fn !== 'function') {
|
|
152
|
-
return undefined;
|
|
153
|
-
}
|
|
154
|
-
return fn.apply(null, evaluateArray(node.arguments, context));
|
|
155
|
-
}
|
|
156
|
-
case 'ConditionalExpression':
|
|
157
|
-
return evaluate(node.test, context) ? evaluate(node.consequent, context) : evaluate(node.alternate, context);
|
|
158
|
-
case 'Identifier':
|
|
159
|
-
return context[node.name];
|
|
160
|
-
case 'Literal':
|
|
161
|
-
return node.value;
|
|
162
|
-
case 'BinaryExpression': {
|
|
163
|
-
if (node.operator === '||') {
|
|
164
|
-
return evaluate(node.left, context) || evaluate(node.right, context);
|
|
165
|
-
}
|
|
166
|
-
if (node.operator === '&&') {
|
|
167
|
-
return evaluate(node.left, context) && evaluate(node.right, context);
|
|
168
|
-
}
|
|
169
|
-
const op = binops[node.operator];
|
|
170
|
-
if (!op) {
|
|
171
|
-
throw new Error(`Unsupported operator ${node.operator}`);
|
|
172
|
-
}
|
|
173
|
-
return op(evaluate(node.left, context), evaluate(node.right, context));
|
|
174
|
-
}
|
|
175
|
-
case 'UnaryExpression': {
|
|
176
|
-
const op = unops[node.operator];
|
|
177
|
-
if (!op) {
|
|
178
|
-
throw new Error(`Unsupported operator ${node.operator}`);
|
|
179
|
-
}
|
|
180
|
-
return op(evaluate(node.argument, context));
|
|
181
|
-
}
|
|
182
|
-
case 'MemberExpression':
|
|
183
|
-
return evaluateMember(node, context)?.[1];
|
|
184
|
-
case 'ThisExpression':
|
|
185
|
-
return context;
|
|
186
|
-
default:
|
|
187
|
-
return undefined;
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
export function parseExpression(expression) {
|
|
191
|
-
return jsep(expression);
|
|
192
|
-
}
|
|
193
|
-
function validateAST(options, rootNode) {
|
|
194
|
-
const validate = (_node, parent, parentKey) => {
|
|
195
|
-
const node = _node;
|
|
196
|
-
switch (node.type) {
|
|
197
|
-
case 'ArrayExpression':
|
|
198
|
-
return node.elements.flatMap((v) => (v ? validate(v, node, 'elements') : []));
|
|
199
|
-
case 'ObjectExpression':
|
|
200
|
-
return node.properties.flatMap((v) => validate(v, node, 'properties'));
|
|
201
|
-
case 'Property': {
|
|
202
|
-
{
|
|
203
|
-
const keyErrors = !node.computed && node.key.type === 'Identifier' ? undefined : validate(node.key, node, 'key');
|
|
204
|
-
const valueErrors = validate(node.value, node, 'value');
|
|
205
|
-
return keyErrors ? [...keyErrors, ...valueErrors] : valueErrors;
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
case 'CallExpression': {
|
|
209
|
-
if (node.callee.type === 'MemberExpression') {
|
|
210
|
-
return [{ message: METHODS_NOT_SUPPORTED }];
|
|
211
|
-
}
|
|
212
|
-
return [
|
|
213
|
-
...validate(node.callee, node, 'callee'),
|
|
214
|
-
...node.arguments.flatMap((v) => (v ? validate(v, node, 'arguments') : []))
|
|
215
|
-
];
|
|
216
|
-
}
|
|
217
|
-
case 'ConditionalExpression':
|
|
218
|
-
return [
|
|
219
|
-
...validate(node.test, node, 'test'),
|
|
220
|
-
...validate(node.consequent, node, 'consequent'),
|
|
221
|
-
...validate(node.alternate, node, 'alternate')
|
|
222
|
-
];
|
|
223
|
-
case 'Identifier': {
|
|
224
|
-
const errors = [];
|
|
225
|
-
if (parent?.type === 'CallExpression' && parentKey === 'callee' && options.allowedFunctions) {
|
|
226
|
-
if (!options.allowedFunctions.includes(node.name)) {
|
|
227
|
-
errors.push({ message: `Unknown function "${node.name}"` });
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
else {
|
|
231
|
-
if (parent?.type === 'MemberExpression' && !parent.computed && parentKey === 'property') {
|
|
232
|
-
return errors;
|
|
233
|
-
}
|
|
234
|
-
if (options.allowedVars && !options.allowedVars.includes(node.name)) {
|
|
235
|
-
errors.push({ message: `Unknown variable "${node.name}"` });
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
return errors;
|
|
239
|
-
}
|
|
240
|
-
case 'Literal':
|
|
241
|
-
return [];
|
|
242
|
-
case 'BinaryExpression': {
|
|
243
|
-
const op = binops[node.operator];
|
|
244
|
-
if (!op) {
|
|
245
|
-
throw new Error(`Unsupported operator ${node.operator}`);
|
|
246
|
-
}
|
|
247
|
-
return [...validate(node.left, node, 'left'), ...validate(node.right, node, 'right')];
|
|
248
|
-
}
|
|
249
|
-
case 'UnaryExpression': {
|
|
250
|
-
const op = unops[node.operator];
|
|
251
|
-
if (!op) {
|
|
252
|
-
return [{ message: `Unsupported operator ${node.operator}` }];
|
|
253
|
-
}
|
|
254
|
-
return validate(node.argument, node, 'argument');
|
|
255
|
-
}
|
|
256
|
-
case 'MemberExpression':
|
|
257
|
-
return [
|
|
258
|
-
...validate(node.object, node, 'object'),
|
|
259
|
-
...(node.computed ? validate(node.property, node, 'property') : [])
|
|
260
|
-
];
|
|
261
|
-
case 'ThisExpression':
|
|
262
|
-
return [{ message: THIS_NOT_SUPPORTED }];
|
|
263
|
-
}
|
|
264
|
-
};
|
|
265
|
-
return validate(rootNode, undefined, undefined);
|
|
266
|
-
}
|
|
267
|
-
const contextKeys = [
|
|
268
|
-
'currentStateId',
|
|
269
|
-
'previousStateId',
|
|
270
|
-
'currentStateOutput',
|
|
271
|
-
'sessionMemory',
|
|
272
|
-
'claims',
|
|
273
|
-
'args',
|
|
274
|
-
'vars'
|
|
275
|
-
];
|
|
276
|
-
export function validateExpression(expression) {
|
|
277
|
-
try {
|
|
278
|
-
const ast = parseExpression(expression);
|
|
279
|
-
const errors = validateAST({
|
|
280
|
-
allowedVars: contextKeys,
|
|
281
|
-
allowedFunctions: ['contains']
|
|
282
|
-
}, ast);
|
|
283
|
-
if (errors.length) {
|
|
284
|
-
return {
|
|
285
|
-
valid: false,
|
|
286
|
-
errors: errors.map((e) => e.message)
|
|
287
|
-
};
|
|
288
|
-
}
|
|
289
|
-
return { valid: true };
|
|
290
|
-
}
|
|
291
|
-
catch (e) {
|
|
292
|
-
return { valid: false, errors: [e.message] };
|
|
293
|
-
}
|
|
294
|
-
}
|
|
295
|
-
export function compileExpression(expression) {
|
|
296
|
-
const ast = parseExpression(expression);
|
|
297
|
-
return (context) => evaluate(ast, context);
|
|
298
|
-
}
|
|
299
|
-
export function expressionToString(_node, parent) {
|
|
300
|
-
if (!_node) {
|
|
301
|
-
return '';
|
|
302
|
-
}
|
|
303
|
-
const node = _node;
|
|
304
|
-
if (node.type === 'BinaryExpression') {
|
|
305
|
-
const wrap = parent?.type === 'BinaryExpression' && DEFAULT_PRECEDENCE[parent.operator] > DEFAULT_PRECEDENCE[node.operator];
|
|
306
|
-
const str = `${expressionToString(node.left, node)} ${node.operator} ${expressionToString(node.right, node)}`;
|
|
307
|
-
return wrap ? `(${str})` : str;
|
|
308
|
-
}
|
|
309
|
-
if (node.type === 'CallExpression') {
|
|
310
|
-
const args = node.arguments.map((arg) => expressionToString(arg, node));
|
|
311
|
-
return `${expressionToString(node.callee, node)}(${args.join(', ')})`;
|
|
312
|
-
}
|
|
313
|
-
if (node.type === 'UnaryExpression') {
|
|
314
|
-
return node.operator + expressionToString(node.argument, node);
|
|
315
|
-
}
|
|
316
|
-
if (node.type === 'MemberExpression') {
|
|
317
|
-
if (node.computed) {
|
|
318
|
-
return `${expressionToString(node.object, node)}[${expressionToString(node.property, node)}]`;
|
|
319
|
-
}
|
|
320
|
-
return `${expressionToString(node.object, node)}.${expressionToString(node.property, node)}`;
|
|
321
|
-
}
|
|
322
|
-
if (node.type === 'ArrayExpression') {
|
|
323
|
-
const arr = node.elements.map((element) => expressionToString(element, node)).join(',');
|
|
324
|
-
return `[${arr}]`;
|
|
325
|
-
}
|
|
326
|
-
if (node.type === 'Property') {
|
|
327
|
-
const keyStr = expressionToString(node.key, node);
|
|
328
|
-
if (node.shorthand) {
|
|
329
|
-
return keyStr;
|
|
330
|
-
}
|
|
331
|
-
return `${node.computed ? `[${keyStr}]` : keyStr}: ${expressionToString(node.value, node)}`;
|
|
332
|
-
}
|
|
333
|
-
if (node.type === 'ObjectExpression') {
|
|
334
|
-
const props = node.properties.map((element) => expressionToString(element, node)).join(',');
|
|
335
|
-
return `{ ${props} }`;
|
|
336
|
-
}
|
|
337
|
-
if (node.type === 'Literal') {
|
|
338
|
-
return node.raw;
|
|
339
|
-
}
|
|
340
|
-
if (node.type === 'Identifier') {
|
|
341
|
-
return node.name;
|
|
342
|
-
}
|
|
343
|
-
if (node.type === 'ConditionalExpression') {
|
|
344
|
-
return `${expressionToString(node.test, node)} ? ${expressionToString(node.consequent, node)} : ${expressionToString(node.alternate, node)}`;
|
|
345
|
-
}
|
|
346
|
-
if (node.type === 'ThisExpression') {
|
|
347
|
-
return 'this';
|
|
348
|
-
}
|
|
349
|
-
return '';
|
|
350
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import type { ProjectSchemaJSON, PropertySchema, ShapeJSON } from '../project-schema/index.ts';
|
|
2
|
-
/**
|
|
3
|
-
*
|
|
4
|
-
* @param projectSchema
|
|
5
|
-
* @param schema
|
|
6
|
-
* @param queryPath
|
|
7
|
-
*
|
|
8
|
-
* @example
|
|
9
|
-
* findShapeAtPath(projectSchema, projectSchema.shapes.Shopify_ProductConnection.shape, ['edges', 'node']) // finds {'@ref': Shopify_Product}
|
|
10
|
-
*/
|
|
11
|
-
export declare function findSchemaAtPath(projectSchema: Pick<ProjectSchemaJSON, 'services' | 'shapes'>, schema: PropertySchema, queryPath: string[]): PropertySchema | undefined;
|
|
12
|
-
/**
|
|
13
|
-
*
|
|
14
|
-
* @param projectSchema
|
|
15
|
-
* @param propSchema
|
|
16
|
-
* @param queryPath
|
|
17
|
-
*
|
|
18
|
-
* @example
|
|
19
|
-
* findShapeAtPath(projectSchema, projectSchema.shapes.Shopify_ProductConnection.shape, ['edges', 'node']) // finds Shopify_Product
|
|
20
|
-
*/
|
|
21
|
-
export declare function findShapeAtPath(projectSchema: Pick<ProjectSchemaJSON, 'services' | 'shapes'>, propSchema: PropertySchema, queryPath: string[]): ShapeJSON | undefined;
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { getRef, refItemToShape, refItemToShapeSchema } from "../refs.js";
|
|
2
|
-
import { isArraySchema, isObjectSchema, isRefSchema } from "../types/index.js";
|
|
3
|
-
/**
|
|
4
|
-
*
|
|
5
|
-
* @param projectSchema
|
|
6
|
-
* @param schema
|
|
7
|
-
* @param queryPath
|
|
8
|
-
*
|
|
9
|
-
* @example
|
|
10
|
-
* findShapeAtPath(projectSchema, projectSchema.shapes.Shopify_ProductConnection.shape, ['edges', 'node']) // finds {'@ref': Shopify_Product}
|
|
11
|
-
*/
|
|
12
|
-
export function findSchemaAtPath(projectSchema, schema, queryPath) {
|
|
13
|
-
if (queryPath.length === 0) {
|
|
14
|
-
return schema;
|
|
15
|
-
}
|
|
16
|
-
const [prop, ...rest] = queryPath;
|
|
17
|
-
if (isRefSchema(schema)) {
|
|
18
|
-
const ref = getRef(projectSchema, schema);
|
|
19
|
-
if (ref) {
|
|
20
|
-
const shapeSchema = refItemToShapeSchema(projectSchema, ref);
|
|
21
|
-
if (shapeSchema) {
|
|
22
|
-
return findSchemaAtPath(projectSchema, shapeSchema, queryPath);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
return undefined;
|
|
26
|
-
}
|
|
27
|
-
if (isArraySchema(schema)) {
|
|
28
|
-
return findSchemaAtPath(projectSchema, schema.items, queryPath);
|
|
29
|
-
}
|
|
30
|
-
if (isObjectSchema(schema)) {
|
|
31
|
-
const propSchema = schema.properties[prop];
|
|
32
|
-
if (propSchema) {
|
|
33
|
-
return findSchemaAtPath(projectSchema, propSchema, rest);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
return undefined;
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
*
|
|
40
|
-
* @param projectSchema
|
|
41
|
-
* @param propSchema
|
|
42
|
-
* @param queryPath
|
|
43
|
-
*
|
|
44
|
-
* @example
|
|
45
|
-
* findShapeAtPath(projectSchema, projectSchema.shapes.Shopify_ProductConnection.shape, ['edges', 'node']) // finds Shopify_Product
|
|
46
|
-
*/
|
|
47
|
-
export function findShapeAtPath(projectSchema, propSchema, queryPath) {
|
|
48
|
-
const result = findSchemaAtPath(projectSchema, propSchema, queryPath);
|
|
49
|
-
if (result) {
|
|
50
|
-
const refItem = getRef(projectSchema, result.items ?? result);
|
|
51
|
-
return refItem && refItemToShape(projectSchema, refItem);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { type Maybe } from '@takeshape/util';
|
|
2
|
-
import type { FormConfig, FormMap, ProjectSchemaJSON } from '../project-schema/index.ts';
|
|
3
|
-
/**
|
|
4
|
-
* If there any non-normal (nested) forms in the schema, create forms for referenced shapes.
|
|
5
|
-
* The original forms are left intact.
|
|
6
|
-
*/
|
|
7
|
-
export declare function normalizeForms(projectSchema: ProjectSchemaJSON): FormMap;
|
|
8
|
-
/**
|
|
9
|
-
* Find the form config for a given shape name and the form key.
|
|
10
|
-
*/
|
|
11
|
-
export declare function findShapeFormConfig(projectSchema: ProjectSchemaJSON, shapeName: string, formName: string): Maybe<FormConfig>;
|
package/dist/util/form-config.js
DELETED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { deepClone } from '@takeshape/util';
|
|
2
|
-
import { getRefOrItemsRef, refItemToNamespacedShapeName } from "../refs.js";
|
|
3
|
-
import { createSchemaPropertyAccessor } from "../schema-util.js";
|
|
4
|
-
/**
|
|
5
|
-
* If there any non-normal (nested) forms in the schema, create forms for referenced shapes.
|
|
6
|
-
* The original forms are left intact.
|
|
7
|
-
*/
|
|
8
|
-
export function normalizeForms(projectSchema) {
|
|
9
|
-
const normalizedForms = {};
|
|
10
|
-
const { forms = {} } = projectSchema;
|
|
11
|
-
const storeSourceForm = (shapeName, formConfig, propName) => {
|
|
12
|
-
// Leave original forms intact for backwards compatibility
|
|
13
|
-
if (!forms[shapeName]) {
|
|
14
|
-
normalizedForms[shapeName] ||= { default: deepClone(formConfig) };
|
|
15
|
-
// Remove prop now that it has been normalized
|
|
16
|
-
delete normalizedForms[shapeName].default.properties[propName];
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
const normalizeNested = (shapeName, formConfig) => {
|
|
20
|
-
const shape = projectSchema.shapes[shapeName];
|
|
21
|
-
if (!shape || !formConfig.properties) {
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
const propertyAccessor = createSchemaPropertyAccessor(projectSchema, shape);
|
|
25
|
-
for (const propName of Object.keys(formConfig.properties)) {
|
|
26
|
-
const propConfig = formConfig.properties[propName];
|
|
27
|
-
const propSchema = propertyAccessor.getValue(propName);
|
|
28
|
-
if (propSchema) {
|
|
29
|
-
const ref = getRefOrItemsRef(projectSchema, propSchema);
|
|
30
|
-
if (ref && propConfig.properties) {
|
|
31
|
-
const nestedShapeName = refItemToNamespacedShapeName(projectSchema, ref);
|
|
32
|
-
normalizedForms[nestedShapeName] = { default: deepClone(propConfig) };
|
|
33
|
-
storeSourceForm(shapeName, formConfig, propName);
|
|
34
|
-
normalizeNested(nestedShapeName, propConfig);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
};
|
|
39
|
-
if (forms) {
|
|
40
|
-
for (const shapeName of Object.keys(forms)) {
|
|
41
|
-
normalizeNested(shapeName, forms[shapeName].default);
|
|
42
|
-
// copy forms with no changes
|
|
43
|
-
normalizedForms[shapeName] ||= forms[shapeName];
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
return normalizedForms;
|
|
47
|
-
}
|
|
48
|
-
const cache = new WeakMap();
|
|
49
|
-
/**
|
|
50
|
-
* Find the form config for a given shape name and the form key.
|
|
51
|
-
*/
|
|
52
|
-
export function findShapeFormConfig(projectSchema, shapeName, formName) {
|
|
53
|
-
if (!projectSchema.forms) {
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
let normalizedForms = cache.get(projectSchema);
|
|
57
|
-
if (!normalizedForms) {
|
|
58
|
-
normalizedForms = normalizeForms(projectSchema);
|
|
59
|
-
cache.set(projectSchema, normalizedForms);
|
|
60
|
-
}
|
|
61
|
-
return normalizedForms[shapeName]?.[formName];
|
|
62
|
-
}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import type { ShapeJSON } from '../project-schema/index.ts';
|
|
2
|
-
import { type ServicesShapesContext } from '../refs.ts';
|
|
3
|
-
/**
|
|
4
|
-
* Given a list of shapes find the conflicting props
|
|
5
|
-
*/
|
|
6
|
-
export declare function getConflictingProperties(context: ServicesShapesContext, shapes: ShapeJSON[]): Set<string>;
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { isDefined, setIsEqual } from '@takeshape/util';
|
|
2
|
-
import { dereferenceSchema, getRef, serializeRef } from "../refs.js";
|
|
3
|
-
import { isObjectSchema } from "../types/index.js";
|
|
4
|
-
/**
|
|
5
|
-
* Normalize ref, oneOf and array schemas and get a list of @ref expressions
|
|
6
|
-
*/
|
|
7
|
-
function getRefStrings(context, propertySchema) {
|
|
8
|
-
const schema = propertySchema.items ?? propertySchema;
|
|
9
|
-
const schemas = schema.oneOf ? schema.oneOf : [schema];
|
|
10
|
-
return schemas
|
|
11
|
-
.map((propertySchema) => {
|
|
12
|
-
const ref = getRef(context, propertySchema);
|
|
13
|
-
return ref ? serializeRef(ref) : undefined;
|
|
14
|
-
})
|
|
15
|
-
.filter(isDefined);
|
|
16
|
-
}
|
|
17
|
-
function isRefEqual(context, a, b) {
|
|
18
|
-
return setIsEqual(getRefStrings(context, a), getRefStrings(context, b));
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Given a list of shapes find the conflicting props
|
|
22
|
-
*/
|
|
23
|
-
export function getConflictingProperties(context, shapes) {
|
|
24
|
-
const conflicts = new Set();
|
|
25
|
-
const allProps = {};
|
|
26
|
-
for (const shape of Object.values(shapes)) {
|
|
27
|
-
const schema = dereferenceSchema(context, shape.schema, ['shapes', shape.name]);
|
|
28
|
-
if (!isObjectSchema(schema)) {
|
|
29
|
-
continue;
|
|
30
|
-
}
|
|
31
|
-
const required = new Set(schema.required ?? []);
|
|
32
|
-
for (const [name, prop] of Object.entries(schema.properties)) {
|
|
33
|
-
// skip props that we know already have conflict
|
|
34
|
-
if (conflicts.has(name)) {
|
|
35
|
-
continue;
|
|
36
|
-
}
|
|
37
|
-
const isRequired = required.has(name);
|
|
38
|
-
if (allProps[name]) {
|
|
39
|
-
if (
|
|
40
|
-
// same type
|
|
41
|
-
allProps[name][0].type !== prop.type ||
|
|
42
|
-
// same refs
|
|
43
|
-
!isRefEqual(context, allProps[name][0], prop) ||
|
|
44
|
-
// same nullability
|
|
45
|
-
isRequired !== allProps[name][1]) {
|
|
46
|
-
conflicts.add(name);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
else {
|
|
50
|
-
allProps[name] = [prop, isRequired];
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
return conflicts;
|
|
55
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { ProjectSchemaJSON, PropertySchema, QueryJSON, ShapeJSON } from '../project-schema/index.ts';
|
|
2
|
-
import { type ServicesShapesContext } from '../refs.ts';
|
|
3
|
-
export declare function getReturnShapeRef(context: ServicesShapesContext, propOrQuery: PropertySchema | QueryJSON): import("@takeshape/util").Maybe<import("../refs.ts").RefItem>;
|
|
4
|
-
export declare function getReturnShape(projectSchema: Pick<ProjectSchemaJSON, 'services' | 'shapes'>, propOrQuery: PropertySchema | QueryJSON): ShapeJSON | undefined;
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { getRef, parseReturnShape, refItemToShape } from "../refs.js";
|
|
2
|
-
function isQuery(propOrQuery) {
|
|
3
|
-
return 'shape' in propOrQuery && 'resolver' in propOrQuery;
|
|
4
|
-
}
|
|
5
|
-
function getReturnShapeHelper(projectSchema, propOrQuery) {
|
|
6
|
-
let shape;
|
|
7
|
-
if (isQuery(propOrQuery)) {
|
|
8
|
-
const { shapeName } = parseReturnShape(projectSchema, propOrQuery.shape);
|
|
9
|
-
shape = projectSchema.shapes[shapeName];
|
|
10
|
-
}
|
|
11
|
-
else {
|
|
12
|
-
const ref = getRef(projectSchema, propOrQuery);
|
|
13
|
-
if (ref) {
|
|
14
|
-
shape = refItemToShape(projectSchema, ref);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
return shape;
|
|
18
|
-
}
|
|
19
|
-
export function getReturnShapeRef(context, propOrQuery) {
|
|
20
|
-
return isQuery(propOrQuery) ? parseReturnShape(context, propOrQuery.shape).ref : getRef(context, propOrQuery);
|
|
21
|
-
}
|
|
22
|
-
const cache = new WeakMap();
|
|
23
|
-
export function getReturnShape(projectSchema, propOrQuery) {
|
|
24
|
-
let result = cache.get(propOrQuery);
|
|
25
|
-
if (result === undefined) {
|
|
26
|
-
result = getReturnShapeHelper(projectSchema, propOrQuery);
|
|
27
|
-
cache.set(propOrQuery, result ?? null);
|
|
28
|
-
}
|
|
29
|
-
return result ?? undefined;
|
|
30
|
-
}
|
package/dist/util/has-arg.d.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import type { Args, ObjectSchema, ProjectSchemaJSON } from '../project-schema/index.ts';
|
|
2
|
-
import { type ServicesShapesContext } from '../refs.ts';
|
|
3
|
-
import { type SchemaWithArgs } from '../types/index.ts';
|
|
4
|
-
export declare function getArgs(prop: SchemaWithArgs): Args | undefined;
|
|
5
|
-
export declare function getArgsSchema(projectSchema: ServicesShapesContext, args: Args): ObjectSchema | undefined;
|
|
6
|
-
export declare function hasArg(projectSchema: ProjectSchemaJSON, prop: SchemaWithArgs, argPath: string | string[]): boolean;
|
package/dist/util/has-arg.js
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { dereferenceObjectSchema, parseRef, refItemToShape } from "../refs.js";
|
|
2
|
-
import { isObjectSchema } from "../types/index.js";
|
|
3
|
-
import { findSchemaAtPath } from "./find-shape-at-path.js";
|
|
4
|
-
export function getArgs(prop) {
|
|
5
|
-
return '@args' in prop ? prop['@args'] : 'args' in prop ? prop.args : undefined;
|
|
6
|
-
}
|
|
7
|
-
export function getArgsSchema(projectSchema, args) {
|
|
8
|
-
if (typeof args === 'object') {
|
|
9
|
-
return dereferenceObjectSchema(projectSchema, args);
|
|
10
|
-
}
|
|
11
|
-
const ref = parseRef(projectSchema, args);
|
|
12
|
-
const shapeSchema = refItemToShape(projectSchema, ref)?.schema;
|
|
13
|
-
if (shapeSchema && isObjectSchema(shapeSchema)) {
|
|
14
|
-
return shapeSchema;
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
export function hasArg(projectSchema, prop, argPath) {
|
|
18
|
-
const args = getArgs(prop);
|
|
19
|
-
if (!args) {
|
|
20
|
-
return false;
|
|
21
|
-
}
|
|
22
|
-
const schema = getArgsSchema(projectSchema, args);
|
|
23
|
-
const pathArray = Array.isArray(argPath) ? argPath : argPath.split('.');
|
|
24
|
-
return Boolean(schema && findSchemaAtPath(projectSchema, schema, pathArray));
|
|
25
|
-
}
|