@aws-cdk/cloud-assembly-schema 39.1.39 → 39.1.41

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/.jsii CHANGED
@@ -8,7 +8,7 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "bundled": {
11
- "jsonschema": "^1.5.0",
11
+ "jsonschema": "~1.4.1",
12
12
  "semver": "^7.6.3"
13
13
  },
14
14
  "description": "Cloud Assembly Schema",
@@ -303,7 +303,7 @@
303
303
  "kind": "enum",
304
304
  "locationInModule": {
305
305
  "filename": "lib/cloud-assembly/metadata-schema.ts",
306
- "line": 275
306
+ "line": 285
307
307
  },
308
308
  "members": [
309
309
  {
@@ -4644,7 +4644,7 @@
4644
4644
  "kind": "interface",
4645
4645
  "locationInModule": {
4646
4646
  "filename": "lib/cloud-assembly/metadata-schema.ts",
4647
- "line": 310
4647
+ "line": 320
4648
4648
  },
4649
4649
  "name": "MetadataEntry",
4650
4650
  "properties": [
@@ -4657,7 +4657,7 @@
4657
4657
  "immutable": true,
4658
4658
  "locationInModule": {
4659
4659
  "filename": "lib/cloud-assembly/metadata-schema.ts",
4660
- "line": 314
4660
+ "line": 324
4661
4661
  },
4662
4662
  "name": "type",
4663
4663
  "type": {
@@ -4674,7 +4674,7 @@
4674
4674
  "immutable": true,
4675
4675
  "locationInModule": {
4676
4676
  "filename": "lib/cloud-assembly/metadata-schema.ts",
4677
- "line": 321
4677
+ "line": 331
4678
4678
  },
4679
4679
  "name": "data",
4680
4680
  "optional": true,
@@ -4684,6 +4684,12 @@
4684
4684
  {
4685
4685
  "primitive": "string"
4686
4686
  },
4687
+ {
4688
+ "primitive": "number"
4689
+ },
4690
+ {
4691
+ "primitive": "boolean"
4692
+ },
4687
4693
  {
4688
4694
  "fqn": "@aws-cdk/cloud-assembly-schema.FileAssetMetadataEntry"
4689
4695
  },
@@ -4712,7 +4718,7 @@
4712
4718
  "immutable": true,
4713
4719
  "locationInModule": {
4714
4720
  "filename": "lib/cloud-assembly/metadata-schema.ts",
4715
- "line": 328
4721
+ "line": 338
4716
4722
  },
4717
4723
  "name": "trace",
4718
4724
  "optional": true,
@@ -5511,6 +5517,6 @@
5511
5517
  "symbolId": "lib/cloud-assembly/context-queries:VpcContextQuery"
5512
5518
  }
5513
5519
  },
5514
- "version": "39.1.39",
5515
- "fingerprint": "1EGrfgAm+uyb/RyQdI/wfTO2vJkSbh2RfjcoyfWwk1Y="
5520
+ "version": "39.1.41",
5521
+ "fingerprint": "yeWUnuoY8GfA2PSsi1sPHXVBSvc2pSLyTixGC4FIP48="
5516
5522
  }
@@ -233,10 +233,18 @@ export type LogicalIdMetadataEntry = string;
233
233
  * @see ArtifactMetadataEntryType.STACK_TAGS
234
234
  */
235
235
  export type StackTagsMetadataEntry = Tag[];
236
+ /**
237
+ * Any other type of metadata entry
238
+ *
239
+ * This could probably be changed to `any`, but it's safer not
240
+ * to do so right now.
241
+ * See https://github.com/cdklabs/cloud-assembly-schema/pull/121.
242
+ */
243
+ export type PrimitiveType = boolean | number | string;
236
244
  /**
237
245
  * Union type for all metadata entries that might exist in the manifest.
238
246
  */
239
- export type MetadataEntryData = AssetMetadataEntry | LogMessageMetadataEntry | LogicalIdMetadataEntry | StackTagsMetadataEntry;
247
+ export type MetadataEntryData = AssetMetadataEntry | LogMessageMetadataEntry | LogicalIdMetadataEntry | StackTagsMetadataEntry | PrimitiveType;
240
248
  /**
241
249
  * Type of artifact metadata entry.
242
250
  */
@@ -31,4 +31,4 @@ var ArtifactMetadataEntryType;
31
31
  */
32
32
  ArtifactMetadataEntryType["STACK_TAGS"] = "aws:cdk:stack-tags";
33
33
  })(ArtifactMetadataEntryType || (exports.ArtifactMetadataEntryType = ArtifactMetadataEntryType = {}));
34
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata-schema.js","sourceRoot":"","sources":["metadata-schema.ts"],"names":[],"mappings":";;;AA+QA;;GAEG;AACH,IAAY,yBA8BX;AA9BD,WAAY,yBAAyB;IACnC;;OAEG;IACH,oDAAuB,CAAA;IAEvB;;OAEG;IACH,kDAAqB,CAAA;IAErB;;OAEG;IACH,qDAAwB,CAAA;IAExB;;OAEG;IACH,oDAAuB,CAAA;IAEvB;;OAEG;IACH,6DAAgC,CAAA;IAEhC;;OAEG;IACH,8DAAiC,CAAA;AACnC,CAAC,EA9BW,yBAAyB,yCAAzB,yBAAyB,QA8BpC","sourcesContent":["/**\n * Common properties for asset metadata.\n */\ninterface BaseAssetMetadataEntry {\n  /**\n   * Requested packaging style\n   */\n  readonly packaging: string;\n\n  /**\n   * Logical identifier for the asset\n   */\n  readonly id: string;\n\n  /**\n   * The hash of the asset source.\n   */\n  readonly sourceHash: string;\n\n  /**\n   * Path on disk to the asset\n   */\n  readonly path: string;\n}\n\n/**\n * Metadata Entry spec for files.\n *\n * @example\n * const entry = {\n *   packaging: 'file',\n *   s3BucketParameter: 'bucket-parameter',\n *   s3KeyParamenter: 'key-parameter',\n *   artifactHashParameter: 'hash-parameter',\n * }\n */\nexport interface FileAssetMetadataEntry extends BaseAssetMetadataEntry {\n  /**\n   * Requested packaging style\n   */\n  readonly packaging: 'zip' | 'file';\n\n  /**\n   * Name of parameter where S3 bucket should be passed in\n   */\n  readonly s3BucketParameter: string;\n\n  /**\n   * Name of parameter where S3 key should be passed in\n   */\n  readonly s3KeyParameter: string;\n\n  /**\n   * The name of the parameter where the hash of the bundled asset should be passed in.\n   */\n  readonly artifactHashParameter: string;\n}\n\n/**\n * Metadata Entry spec for stack tag.\n */\nexport interface Tag {\n  /**\n   * Tag key.\n   *\n   * (In the actual file on disk this will be cased as \"Key\", and the structure is\n   * patched to match this structure upon loading:\n   * https://github.com/aws/aws-cdk/blob/4aadaa779b48f35838cccd4e25107b2338f05547/packages/%40aws-cdk/cloud-assembly-schema/lib/manifest.ts#L137)\n   */\n  readonly key: string;\n\n  /**\n   * Tag value.\n   *\n   * (In the actual file on disk this will be cased as \"Value\", and the structure is\n   * patched to match this structure upon loading:\n   * https://github.com/aws/aws-cdk/blob/4aadaa779b48f35838cccd4e25107b2338f05547/packages/%40aws-cdk/cloud-assembly-schema/lib/manifest.ts#L137)\n   */\n  readonly value: string;\n}\n\n/**\n * Options for configuring the Docker cache backend\n */\nexport interface ContainerImageAssetCacheOption {\n  /**\n   * The type of cache to use.\n   * Refer to https://docs.docker.com/build/cache/backends/ for full list of backends.\n   * @default - unspecified\n   *\n   * @example 'registry'\n   */\n  readonly type: string;\n  /**\n   * Any parameters to pass into the docker cache backend configuration.\n   * Refer to https://docs.docker.com/build/cache/backends/ for cache backend configuration.\n   * @default {} No options provided\n   *\n   * @example\n   * declare const branch: string;\n   *\n   * const params = {\n   *   ref: `12345678.dkr.ecr.us-west-2.amazonaws.com/cache:${branch}`,\n   *   mode: \"max\",\n   * };\n   */\n  readonly params?: { [key: string]: string };\n}\n\n/**\n * Metadata Entry spec for container images.\n *\n * @example\n * const entry = {\n *   packaging: 'container-image',\n *   repositoryName: 'repository-name',\n *   imageTag: 'tag',\n * }\n */\nexport interface ContainerImageAssetMetadataEntry extends BaseAssetMetadataEntry {\n  /**\n   * Type of asset\n   */\n  readonly packaging: 'container-image';\n\n  /**\n   * ECR Repository name and repo digest (separated by \"@sha256:\") where this\n   * image is stored.\n   *\n   * @default undefined If not specified, `repositoryName` and `imageTag` are\n   * required because otherwise how will the stack know where to find the asset,\n   * ha?\n   * @deprecated specify `repositoryName` and `imageTag` instead, and then you\n   * know where the image will go.\n   */\n  readonly imageNameParameter?: string;\n\n  /**\n   * ECR repository name, if omitted a default name based on the asset's ID is\n   * used instead. Specify this property if you need to statically address the\n   * image, e.g. from a Kubernetes Pod. Note, this is only the repository name,\n   * without the registry and the tag parts.\n   *\n   * @default - this parameter is REQUIRED after 1.21.0\n   */\n  readonly repositoryName?: string;\n\n  /**\n   * The docker image tag to use for tagging pushed images. This field is\n   * required if `imageParameterName` is ommited (otherwise, the app won't be\n   * able to find the image).\n   *\n   * @default - this parameter is REQUIRED after 1.21.0\n   */\n  readonly imageTag?: string;\n\n  /**\n   * Build args to pass to the `docker build` command\n   *\n   * @default no build args are passed\n   */\n  readonly buildArgs?: { [key: string]: string };\n\n  /**\n   * SSH agent socket or keys to pass to the `docker build` command\n   *\n   * @default no ssh arg is passed\n   */\n  readonly buildSsh?: string;\n\n  /**\n   * Build secrets to pass to the `docker build` command\n   *\n   * @default no build secrets are passed\n   */\n  readonly buildSecrets?: { [key: string]: string };\n\n  /**\n   * Docker target to build to\n   *\n   * @default no build target\n   */\n  readonly target?: string;\n\n  /**\n   * Path to the Dockerfile (relative to the directory).\n   *\n   * @default - no file is passed\n   */\n  readonly file?: string;\n\n  /**\n   * Networking mode for the RUN commands during build.\n   *\n   * @default - no networking mode specified\n   */\n  readonly networkMode?: string;\n\n  /**\n   * Platform to build for. _Requires Docker Buildx_.\n   *\n   * @default - current machine platform\n   */\n  readonly platform?: string;\n\n  /**\n   * Outputs to pass to the `docker build` command.\n   *\n   * @default - no outputs are passed to the build command (default outputs are used)\n   * @see https://docs.docker.com/engine/reference/commandline/build/#custom-build-outputs\n   */\n  readonly outputs?: string[];\n\n  /**\n   * Cache from options to pass to the `docker build` command.\n   *\n   * @default - no cache from options are passed to the build command\n   * @see https://docs.docker.com/build/cache/backends/\n   */\n  readonly cacheFrom?: ContainerImageAssetCacheOption[];\n\n  /**\n   * Cache to options to pass to the `docker build` command.\n   *\n   * @default - no cache to options are passed to the build command\n   * @see https://docs.docker.com/build/cache/backends/\n   */\n  readonly cacheTo?: ContainerImageAssetCacheOption;\n\n  /**\n   * Disable the cache and pass `--no-cache` to the `docker build` command.\n   *\n   * @default - cache is used\n   */\n  readonly cacheDisabled?: boolean;\n}\n\n/**\n * @see ArtifactMetadataEntryType.ASSET\n */\nexport type AssetMetadataEntry = FileAssetMetadataEntry | ContainerImageAssetMetadataEntry;\n\n// Type aliases for metadata entries.\n// Used simply to assign names to data types for more clarity.\n\n/**\n * @see ArtifactMetadataEntryType.INFO\n * @see ArtifactMetadataEntryType.WARN\n * @see ArtifactMetadataEntryType.ERROR\n */\nexport type LogMessageMetadataEntry = string;\n\n/**\n * @see ArtifactMetadataEntryType.LOGICAL_ID\n */\nexport type LogicalIdMetadataEntry = string;\n\n/**\n * @see ArtifactMetadataEntryType.STACK_TAGS\n */\nexport type StackTagsMetadataEntry = Tag[];\n\n/**\n * Union type for all metadata entries that might exist in the manifest.\n */\nexport type MetadataEntryData =\n  | AssetMetadataEntry\n  | LogMessageMetadataEntry\n  | LogicalIdMetadataEntry\n  | StackTagsMetadataEntry;\n\n/**\n * Type of artifact metadata entry.\n */\nexport enum ArtifactMetadataEntryType {\n  /**\n   * Asset in metadata.\n   */\n  ASSET = 'aws:cdk:asset',\n\n  /**\n   * Metadata key used to print INFO-level messages by the toolkit when an app is syntheized.\n   */\n  INFO = 'aws:cdk:info',\n\n  /**\n   * Metadata key used to print WARNING-level messages by the toolkit when an app is syntheized.\n   */\n  WARN = 'aws:cdk:warning',\n\n  /**\n   * Metadata key used to print ERROR-level messages by the toolkit when an app is syntheized.\n   */\n  ERROR = 'aws:cdk:error',\n\n  /**\n   * Represents the CloudFormation logical ID of a resource at a certain path.\n   */\n  LOGICAL_ID = 'aws:cdk:logicalId',\n\n  /**\n   * Represents tags of a stack.\n   */\n  STACK_TAGS = 'aws:cdk:stack-tags',\n}\n\n/**\n * A metadata entry in a cloud assembly artifact.\n */\nexport interface MetadataEntry {\n  /**\n   * The type of the metadata entry.\n   */\n  readonly type: string;\n\n  /**\n   * The data.\n   *\n   * @default - no data.\n   */\n  readonly data?: MetadataEntryData;\n\n  /**\n   * A stack trace for when the entry was created.\n   *\n   * @default - no trace.\n   */\n  readonly trace?: string[];\n}\n"]}
34
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata-schema.js","sourceRoot":"","sources":["metadata-schema.ts"],"names":[],"mappings":";;;AAyRA;;GAEG;AACH,IAAY,yBA8BX;AA9BD,WAAY,yBAAyB;IACnC;;OAEG;IACH,oDAAuB,CAAA;IAEvB;;OAEG;IACH,kDAAqB,CAAA;IAErB;;OAEG;IACH,qDAAwB,CAAA;IAExB;;OAEG;IACH,oDAAuB,CAAA;IAEvB;;OAEG;IACH,6DAAgC,CAAA;IAEhC;;OAEG;IACH,8DAAiC,CAAA;AACnC,CAAC,EA9BW,yBAAyB,yCAAzB,yBAAyB,QA8BpC","sourcesContent":["/**\n * Common properties for asset metadata.\n */\ninterface BaseAssetMetadataEntry {\n  /**\n   * Requested packaging style\n   */\n  readonly packaging: string;\n\n  /**\n   * Logical identifier for the asset\n   */\n  readonly id: string;\n\n  /**\n   * The hash of the asset source.\n   */\n  readonly sourceHash: string;\n\n  /**\n   * Path on disk to the asset\n   */\n  readonly path: string;\n}\n\n/**\n * Metadata Entry spec for files.\n *\n * @example\n * const entry = {\n *   packaging: 'file',\n *   s3BucketParameter: 'bucket-parameter',\n *   s3KeyParamenter: 'key-parameter',\n *   artifactHashParameter: 'hash-parameter',\n * }\n */\nexport interface FileAssetMetadataEntry extends BaseAssetMetadataEntry {\n  /**\n   * Requested packaging style\n   */\n  readonly packaging: 'zip' | 'file';\n\n  /**\n   * Name of parameter where S3 bucket should be passed in\n   */\n  readonly s3BucketParameter: string;\n\n  /**\n   * Name of parameter where S3 key should be passed in\n   */\n  readonly s3KeyParameter: string;\n\n  /**\n   * The name of the parameter where the hash of the bundled asset should be passed in.\n   */\n  readonly artifactHashParameter: string;\n}\n\n/**\n * Metadata Entry spec for stack tag.\n */\nexport interface Tag {\n  /**\n   * Tag key.\n   *\n   * (In the actual file on disk this will be cased as \"Key\", and the structure is\n   * patched to match this structure upon loading:\n   * https://github.com/aws/aws-cdk/blob/4aadaa779b48f35838cccd4e25107b2338f05547/packages/%40aws-cdk/cloud-assembly-schema/lib/manifest.ts#L137)\n   */\n  readonly key: string;\n\n  /**\n   * Tag value.\n   *\n   * (In the actual file on disk this will be cased as \"Value\", and the structure is\n   * patched to match this structure upon loading:\n   * https://github.com/aws/aws-cdk/blob/4aadaa779b48f35838cccd4e25107b2338f05547/packages/%40aws-cdk/cloud-assembly-schema/lib/manifest.ts#L137)\n   */\n  readonly value: string;\n}\n\n/**\n * Options for configuring the Docker cache backend\n */\nexport interface ContainerImageAssetCacheOption {\n  /**\n   * The type of cache to use.\n   * Refer to https://docs.docker.com/build/cache/backends/ for full list of backends.\n   * @default - unspecified\n   *\n   * @example 'registry'\n   */\n  readonly type: string;\n  /**\n   * Any parameters to pass into the docker cache backend configuration.\n   * Refer to https://docs.docker.com/build/cache/backends/ for cache backend configuration.\n   * @default {} No options provided\n   *\n   * @example\n   * declare const branch: string;\n   *\n   * const params = {\n   *   ref: `12345678.dkr.ecr.us-west-2.amazonaws.com/cache:${branch}`,\n   *   mode: \"max\",\n   * };\n   */\n  readonly params?: { [key: string]: string };\n}\n\n/**\n * Metadata Entry spec for container images.\n *\n * @example\n * const entry = {\n *   packaging: 'container-image',\n *   repositoryName: 'repository-name',\n *   imageTag: 'tag',\n * }\n */\nexport interface ContainerImageAssetMetadataEntry extends BaseAssetMetadataEntry {\n  /**\n   * Type of asset\n   */\n  readonly packaging: 'container-image';\n\n  /**\n   * ECR Repository name and repo digest (separated by \"@sha256:\") where this\n   * image is stored.\n   *\n   * @default undefined If not specified, `repositoryName` and `imageTag` are\n   * required because otherwise how will the stack know where to find the asset,\n   * ha?\n   * @deprecated specify `repositoryName` and `imageTag` instead, and then you\n   * know where the image will go.\n   */\n  readonly imageNameParameter?: string;\n\n  /**\n   * ECR repository name, if omitted a default name based on the asset's ID is\n   * used instead. Specify this property if you need to statically address the\n   * image, e.g. from a Kubernetes Pod. Note, this is only the repository name,\n   * without the registry and the tag parts.\n   *\n   * @default - this parameter is REQUIRED after 1.21.0\n   */\n  readonly repositoryName?: string;\n\n  /**\n   * The docker image tag to use for tagging pushed images. This field is\n   * required if `imageParameterName` is ommited (otherwise, the app won't be\n   * able to find the image).\n   *\n   * @default - this parameter is REQUIRED after 1.21.0\n   */\n  readonly imageTag?: string;\n\n  /**\n   * Build args to pass to the `docker build` command\n   *\n   * @default no build args are passed\n   */\n  readonly buildArgs?: { [key: string]: string };\n\n  /**\n   * SSH agent socket or keys to pass to the `docker build` command\n   *\n   * @default no ssh arg is passed\n   */\n  readonly buildSsh?: string;\n\n  /**\n   * Build secrets to pass to the `docker build` command\n   *\n   * @default no build secrets are passed\n   */\n  readonly buildSecrets?: { [key: string]: string };\n\n  /**\n   * Docker target to build to\n   *\n   * @default no build target\n   */\n  readonly target?: string;\n\n  /**\n   * Path to the Dockerfile (relative to the directory).\n   *\n   * @default - no file is passed\n   */\n  readonly file?: string;\n\n  /**\n   * Networking mode for the RUN commands during build.\n   *\n   * @default - no networking mode specified\n   */\n  readonly networkMode?: string;\n\n  /**\n   * Platform to build for. _Requires Docker Buildx_.\n   *\n   * @default - current machine platform\n   */\n  readonly platform?: string;\n\n  /**\n   * Outputs to pass to the `docker build` command.\n   *\n   * @default - no outputs are passed to the build command (default outputs are used)\n   * @see https://docs.docker.com/engine/reference/commandline/build/#custom-build-outputs\n   */\n  readonly outputs?: string[];\n\n  /**\n   * Cache from options to pass to the `docker build` command.\n   *\n   * @default - no cache from options are passed to the build command\n   * @see https://docs.docker.com/build/cache/backends/\n   */\n  readonly cacheFrom?: ContainerImageAssetCacheOption[];\n\n  /**\n   * Cache to options to pass to the `docker build` command.\n   *\n   * @default - no cache to options are passed to the build command\n   * @see https://docs.docker.com/build/cache/backends/\n   */\n  readonly cacheTo?: ContainerImageAssetCacheOption;\n\n  /**\n   * Disable the cache and pass `--no-cache` to the `docker build` command.\n   *\n   * @default - cache is used\n   */\n  readonly cacheDisabled?: boolean;\n}\n\n/**\n * @see ArtifactMetadataEntryType.ASSET\n */\nexport type AssetMetadataEntry = FileAssetMetadataEntry | ContainerImageAssetMetadataEntry;\n\n// Type aliases for metadata entries.\n// Used simply to assign names to data types for more clarity.\n\n/**\n * @see ArtifactMetadataEntryType.INFO\n * @see ArtifactMetadataEntryType.WARN\n * @see ArtifactMetadataEntryType.ERROR\n */\nexport type LogMessageMetadataEntry = string;\n\n/**\n * @see ArtifactMetadataEntryType.LOGICAL_ID\n */\nexport type LogicalIdMetadataEntry = string;\n\n/**\n * @see ArtifactMetadataEntryType.STACK_TAGS\n */\nexport type StackTagsMetadataEntry = Tag[];\n\n/**\n * Any other type of metadata entry\n *\n * This could probably be changed to `any`, but it's safer not\n * to do so right now.\n * See https://github.com/cdklabs/cloud-assembly-schema/pull/121.\n */\nexport type PrimitiveType = boolean | number | string;\n\n/**\n * Union type for all metadata entries that might exist in the manifest.\n */\nexport type MetadataEntryData =\n  | AssetMetadataEntry\n  | LogMessageMetadataEntry\n  | LogicalIdMetadataEntry\n  | StackTagsMetadataEntry\n  | PrimitiveType;\n\n/**\n * Type of artifact metadata entry.\n */\nexport enum ArtifactMetadataEntryType {\n  /**\n   * Asset in metadata.\n   */\n  ASSET = 'aws:cdk:asset',\n\n  /**\n   * Metadata key used to print INFO-level messages by the toolkit when an app is syntheized.\n   */\n  INFO = 'aws:cdk:info',\n\n  /**\n   * Metadata key used to print WARNING-level messages by the toolkit when an app is syntheized.\n   */\n  WARN = 'aws:cdk:warning',\n\n  /**\n   * Metadata key used to print ERROR-level messages by the toolkit when an app is syntheized.\n   */\n  ERROR = 'aws:cdk:error',\n\n  /**\n   * Represents the CloudFormation logical ID of a resource at a certain path.\n   */\n  LOGICAL_ID = 'aws:cdk:logicalId',\n\n  /**\n   * Represents tags of a stack.\n   */\n  STACK_TAGS = 'aws:cdk:stack-tags',\n}\n\n/**\n * A metadata entry in a cloud assembly artifact.\n */\nexport interface MetadataEntry {\n  /**\n   * The type of the metadata entry.\n   */\n  readonly type: string;\n\n  /**\n   * The data.\n   *\n   * @default - no data.\n   */\n  readonly data?: MetadataEntryData;\n\n  /**\n   * A stack trace for when the entry was created.\n   *\n   * @default - no trace.\n   */\n  readonly trace?: string[];\n}\n"]}
package/lib/manifest.js CHANGED
@@ -249,7 +249,7 @@ class Manifest {
249
249
  }
250
250
  exports.Manifest = Manifest;
251
251
  _a = JSII_RTTI_SYMBOL_1;
252
- Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "39.1.39" };
252
+ Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "39.1.41" };
253
253
  function mapValues(xs, fn) {
254
254
  if (!xs) {
255
255
  return undefined;
@@ -80,8 +80,6 @@ var p = {
80
80
  v.addSchema(addressSchema, '/SimpleAddress');
81
81
  console.log(v.validate(p, schema));
82
82
  ```
83
- Returned ValidatorResult object, will show this example is NOT valid since: `"votes": "lots"` is not an integer.
84
-
85
83
  ### Example for Array schema
86
84
 
87
85
  ```json
@@ -270,34 +268,6 @@ function importNextSchema(){
270
268
  }
271
269
  importNextSchema();
272
270
  ```
273
- ### Disallowing unknown attributes
274
-
275
- Sometimes you may want to disallow unknown attributes passed in the body of the request, in order to disallow those unknown attributes before the validation of the body, you need to set additionalProperties to false.
276
-
277
- ```javascript
278
- {
279
- "$schema": "http://json-schema.org/draft-04/schema#",
280
- "title": "Accounting Resource - Add Item",
281
- "type": "object",
282
- "additionalProperties": false,
283
- "properties": {
284
- "itemNumber": {
285
- "type":"string"
286
- },
287
- "title": {
288
- "type":"string"
289
- },
290
- "description": {
291
- "type":"string"
292
- }
293
- },
294
- "required": [
295
- "itemNumber",
296
- "title",
297
- "description"
298
- ]
299
- }
300
- ```
301
271
 
302
272
  ### Default base URI
303
273
 
@@ -1,5 +1,7 @@
1
1
  'use strict';
2
2
 
3
+ var uri = require('url');
4
+
3
5
  var ValidationError = exports.ValidationError = function ValidationError (message, instance, schema, path, name, argument) {
4
6
  if(Array.isArray(path)){
5
7
  this.path = path;
@@ -82,7 +84,7 @@ Object.defineProperty(ValidatorResult.prototype, "valid", { get: function() {
82
84
 
83
85
  module.exports.ValidatorResultError = ValidatorResultError;
84
86
  function ValidatorResultError(result) {
85
- if(typeof Error.captureStackTrace === 'function'){
87
+ if(Error.captureStackTrace){
86
88
  Error.captureStackTrace(this, ValidatorResultError);
87
89
  }
88
90
  this.instance = result.instance;
@@ -103,9 +105,7 @@ var SchemaError = exports.SchemaError = function SchemaError (msg, schema) {
103
105
  this.message = msg;
104
106
  this.schema = schema;
105
107
  Error.call(this, msg);
106
- if(typeof Error.captureStackTrace === 'function'){
107
- Error.captureStackTrace(this, SchemaError);
108
- }
108
+ Error.captureStackTrace(this, SchemaError);
109
109
  };
110
110
  SchemaError.prototype = Object.create(Error.prototype,
111
111
  {
@@ -129,13 +129,13 @@ var SchemaContext = exports.SchemaContext = function SchemaContext (schema, opti
129
129
  };
130
130
 
131
131
  SchemaContext.prototype.resolve = function resolve (target) {
132
- return (() => resolveUrl(this.base,target))();
132
+ return uri.resolve(this.base, target);
133
133
  };
134
134
 
135
135
  SchemaContext.prototype.makeChild = function makeChild(schema, propertyName){
136
136
  var path = (propertyName===undefined) ? this.path : this.path.concat([propertyName]);
137
137
  var id = schema.$id || schema.id;
138
- let base = (() => resolveUrl(this.base,id||''))();
138
+ var base = uri.resolve(this.base, id||'');
139
139
  var ctx = new SchemaContext(schema, this.options, path, base, Object.create(this.schemas));
140
140
  if(id && !ctx.schemas[base]){
141
141
  ctx.schemas[base] = schema;
@@ -388,19 +388,3 @@ exports.isSchema = function isSchema(val){
388
388
  return (typeof val === 'object' && val) || (typeof val === 'boolean');
389
389
  };
390
390
 
391
- /**
392
- * Resolve target URL from a base and relative URL.
393
- * Similar to Node's URL Lib's legacy resolve function.
394
- * Code from example in deprecation note in said library.
395
- * @param string
396
- * @param string
397
- * @returns {string}
398
- */
399
- var resolveUrl = exports.resolveUrl = function resolveUrl(from, to) {
400
- const resolvedUrl = new URL(to, new URL(from, 'resolve://'));
401
- if (resolvedUrl.protocol === 'resolve:') {
402
- const { pathname, search, hash } = resolvedUrl;
403
- return pathname + search + hash;
404
- }
405
- return resolvedUrl.toString();
406
- }
@@ -27,13 +27,6 @@ export declare class ValidatorResult {
27
27
  toString(): string;
28
28
  }
29
29
 
30
- export declare class ValidatorResultError extends Error {
31
- instance: any;
32
- schema: Schema;
33
- options: Options;
34
- errors: ValidationError;
35
- }
36
-
37
30
  export declare class ValidationError {
38
31
  constructor(message?: string, instance?: any, schema?: Schema, propertyPath?: any, name?: string, argument?: any);
39
32
  path: (string|number)[];
@@ -72,14 +65,12 @@ export interface Schema {
72
65
  pattern?: string | RegExp
73
66
  additionalItems?: boolean | Schema
74
67
  items?: Schema | Schema[]
75
- contains?: Schema
76
68
  maxItems?: number
77
69
  minItems?: number
78
70
  uniqueItems?: boolean
79
71
  maxProperties?: number
80
72
  minProperties?: number
81
73
  required?: string[] | boolean
82
- propertyNames?: boolean | Schema
83
74
  additionalProperties?: boolean | Schema
84
75
  definitions?: {
85
76
  [name: string]: Schema
@@ -104,8 +95,6 @@ export interface Schema {
104
95
  if?: Schema
105
96
  then?: Schema
106
97
  else?: Schema
107
- default?: any
108
- examples?: any[]
109
98
  }
110
99
 
111
100
  export interface Options {
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
 
3
+ var urilib = require('url');
3
4
  var helpers = require('./helpers');
4
5
 
5
6
  module.exports.SchemaScanResult = SchemaScanResult;
@@ -19,13 +20,12 @@ module.exports.scan = function scan(base, schema){
19
20
  if(!schema || typeof schema!='object') return;
20
21
  // Mark all referenced schemas so we can tell later which schemas are referred to, but never defined
21
22
  if(schema.$ref){
22
- let resolvedUri = helpers.resolveUrl(baseuri,schema.$ref);
23
+ var resolvedUri = urilib.resolve(baseuri, schema.$ref);
23
24
  ref[resolvedUri] = ref[resolvedUri] ? ref[resolvedUri]+1 : 0;
24
25
  return;
25
26
  }
26
27
  var id = schema.$id || schema.id;
27
- let resolvedBase = helpers.resolveUrl(baseuri,id);
28
- var ourBase = id ? resolvedBase : baseuri;
28
+ var ourBase = id ? urilib.resolve(baseuri, id) : baseuri;
29
29
  if (ourBase) {
30
30
  // If there's no fragment, append an empty one
31
31
  if(ourBase.indexOf('#')<0) ourBase += '#';
@@ -1,5 +1,7 @@
1
1
  'use strict';
2
2
 
3
+ var urilib = require('url');
4
+
3
5
  var attribute = require('./attribute');
4
6
  var helpers = require('./helpers');
5
7
  var scanSchema = require('./scan').scan;
@@ -113,7 +115,7 @@ Validator.prototype.validate = function validate (instance, schema, options, ctx
113
115
  // This section indexes subschemas in the provided schema, so they don't need to be added with Validator#addSchema
114
116
  // This will work so long as the function at uri.resolve() will resolve a relative URI to a relative URI
115
117
  var id = schema.$id || schema.id;
116
- let base = helpers.resolveUrl(options.base,id||'');
118
+ var base = urilib.resolve(options.base||anonymousBase, id||'');
117
119
  if(!ctx){
118
120
  ctx = new SchemaContext(schema, options, [], base, Object.create(this.schemas));
119
121
  if (!ctx.schemas[base]) {
@@ -260,8 +262,8 @@ Validator.prototype.resolve = function resolve (schema, switchSchema, ctx) {
260
262
  return {subschema: ctx.schemas[switchSchema], switchSchema: switchSchema};
261
263
  }
262
264
  // Else try walking the property pointer
263
- let parsed = new URL(switchSchema,'thismessage::/');
264
- let fragment = parsed.hash;
265
+ var parsed = urilib.parse(switchSchema);
266
+ var fragment = parsed && parsed.hash;
265
267
  var document = fragment && fragment.length && switchSchema.substr(0, switchSchema.length - fragment.length);
266
268
  if (!document || !ctx.schemas[document]) {
267
269
  throw new SchemaError("no such schema <" + switchSchema + ">", schema);
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "author": "Tom de Grunt <tom@degrunt.nl>",
3
3
  "name": "jsonschema",
4
- "version": "1.5.0",
4
+ "version": "1.4.1",
5
5
  "license": "MIT",
6
6
  "dependencies": {},
7
7
  "contributors": [
@@ -39,4 +39,4 @@
39
39
  "stryker": "stryker run",
40
40
  "test": "./node_modules/.bin/mocha -R spec"
41
41
  }
42
- }
42
+ }
package/package.json CHANGED
@@ -66,7 +66,7 @@
66
66
  "typescript-json-schema": "^0.65.1"
67
67
  },
68
68
  "dependencies": {
69
- "jsonschema": "^1.5.0",
69
+ "jsonschema": "~1.4.1",
70
70
  "semver": "^7.6.3"
71
71
  },
72
72
  "bundledDependencies": [
@@ -80,7 +80,7 @@
80
80
  "main": "lib/index.js",
81
81
  "license": "Apache-2.0",
82
82
  "homepage": "https://github.com/cdklabs/cloud-assembly-schema",
83
- "version": "39.1.39",
83
+ "version": "39.1.41",
84
84
  "types": "lib/index.d.ts",
85
85
  "stability": "stable",
86
86
  "jsii": {
@@ -126,7 +126,11 @@
126
126
  }
127
127
  },
128
128
  {
129
- "type": "string"
129
+ "type": [
130
+ "string",
131
+ "number",
132
+ "boolean"
133
+ ]
130
134
  },
131
135
  {
132
136
  "description": "Free form data."
@@ -1,4 +1,4 @@
1
1
  {
2
- "schemaHash": "f0ccc3212331af8a1c75830878d218fd667e5957063831be3b5bfd803b25f0cc",
2
+ "schemaHash": "bf762e5da559c685e06892ef65fdfc33d1c4bd53d4eb07d4a326d476ac58ae25",
3
3
  "revision": 39
4
4
  }