13 KiB
Pulumi Package Metaschema
A description of the schema for a Pulumi Package
object
Properties
attribution
Freeform text attribution of derived work, if required.
string
config
The package's configuration variables.
object
Properties
required
A list of the names of the package's required configuration variables.
array
Items: string
variables
A map from variable name to propertySpec that describes a package's configuration variables.
object
Additional properties: Property Definition
description
The description of the package. Descriptions are interpreted as Markdown.
string
displayName
The human-friendly name of the package.
string
functions
A map from token to functionSpec that describes the set of functions defined by this package.
object
Property names: Token
Additional properties: Function Definition
homepage
The package's homepage.
string
keywords
The list of keywords that are associated with the package, if any.
array
Items: string
language
Additional language-specific data about the package.
object
license
The name of the license used for the package's contents.
string
logoUrl
The URL of the package's logo, if any.
string
meta
Format metadata about this package.
object
Properties
moduleFormat
(required)
A regex that is used by the importer to extract a module name from the module portion of a type token. Packages that use the module format "namespace1/namespace2/.../namespaceN" do not need to specify a format. The regex must define one capturing group that contains the module name, which must be formatted as "namespace1/namespace2/...namespaceN".
string
Format: regex
name
(required)
The unqualified name of the package (e.g. "aws", "azure", "gcp", "kubernetes", "random")
string
Pattern: ^[a-zA-Z][-a-zA-Z0-9_]*$
pluginDownloadUrl
The URL to use when downloading the provider plugin binary.
string
provider
The provider type for this package.
publisher
The name of the person or organization that authored and published the package.
string
repository
The URL at which the package's sources can be found.
string
resources
A map from type token to resourceSpec that describes the set of resources and components defined by this package.
object
Property names: Token
Additional properties: Resource Definition
types
A map from type token to complexTypeSpec that describes the set of complex types (i.e. object, enum) defined by this package.
object
Property names: Token
Additional properties: Type Definition
version
The version of the package. The version must be valid semver.
string
Pattern: ^v?(?P<major>0|[1-9]\d*)\.(?P<minor>0|[1-9]\d*)\.(?P<patch>0|[1-9]\d*)(?:-(?P<prerelease>(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+(?P<buildmetadata>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$
Alias Definition
object
Properties
name
The name portion of the alias, if any
string
project
The project portion of the alias, if any
string
type
The type portion of the alias, if any
string
Array Type
A reference to an array type. The "type" property must be set to "array" and the "items" property must be present. No other properties may be present.
object
Properties
items
(required)
The element type of the array
type
(required)
Constant: "array"
Enum Type Definition
Describes an enum type
object
Properties
enum
(required)
The list of possible values for the enum
array
Items: Enum Value Definition
type
(required)
The underlying primitive type of the enum
string
Enum: "boolean"
| "integer"
| "number"
| "string"
Enum Value Definition
object
Properties
deprecationMessage
Indicates whether the value is deprecated.
string
description
The description of the enum value, if any. Interpreted as Markdown.
string
name
If present, overrides the name of the enum value that would usually be derived from the value.
string
value
(required)
The enum value itself
boolean
| integer
| number
| string
Function Definition
Describes a function.
object
Properties
deprecationMessage
Indicates whether the function is deprecated
string
description
The description of the function, if any. Interpreted as Markdown.
string
inputs
The bag of input values for the function, if any.
isOverlay
Indicates that the implementation of the function should not be generated from the schema, and is instead provided out-of-band by the package author
boolean
language
Additional language-specific data about the function.
object
outputs
The bag of output values for the function, if any.
Map Type
A reference to a map type. The "type" property must be set to "object" and the "additionalProperties" property may be present. No other properties may be present.
object
Properties
additionalProperties
The element type of the map. Defaults to "string" when omitted.
type
(required)
Constant: "object"
Named Type
A reference to a type in this or another document. The "$ref" property must be present. The "type" property is ignored if it is present. No other properties may be present.
object
Properties
$ref
(required)
The URI of the referenced type. For example, the built-in Archive, Asset, and Any types are referenced as "pulumi.json#/Archive", "pulumi.json#/Asset", and "pulumi.json#/Any", respectively. A type from this document is referenced as "#/types/pulumi:type:token". A type from another document is referenced as "path#/types/pulumi:type:token", where path is of the form: "/provider/vX.Y.Z/schema.json" or "pulumi.json" or "http[s]://example.com/provider/vX.Y.Z/schema.json" A resource from this document is referenced as "#/resources/pulumi:type:token". A resource from another document is referenced as "path#/resources/pulumi:type:token", where path is of the form: "/provider/vX.Y.Z/schema.json" or "pulumi.json" or "http[s]://example.com/provider/vX.Y.Z/schema.json"
string
Format: uri-reference
type
ignored; present for compatibility with existing schemas
string
Object Type Definition
object
All of:
Properties
type
Constant: "object"
Object Type Details
Describes an object type
object
Properties
properties
A map from property name to propertySpec that describes the object's properties.
object
Additional properties: Property Definition
required
A list of the names of an object type's required properties. These properties must be set for inputs and will always be set for outputs.
array
Items: string
Primitive Type
A reference to a primitive type. A primitive type must have only the "type" property set.
object
Properties
type
(required)
The primitive type, if any
string
Enum: "boolean"
| "integer"
| "number"
| "string"
Property Definition
Describes an object or resource property
object
All of:
Properties
const
The constant value for the property, if any. The type of the value must be assignable to the type of the property.
boolean
| number
| string
default
The default value for the property, if any. The type of the value must be assignable to the type of the property.
boolean
| number
| string
defaultInfo
Additional information about the property's default value, if any.
object
Properties
environment
(required)
A set of environment variables to probe for a default value.
array
Items: string
language
Additional language-specific data about the default value.
object
deprecationMessage
Indicates whether the property is deprecated
string
description
The description of the property, if any. Interpreted as Markdown.
string
language
Additional language-specific data about the property.
object
replaceOnChanges
Specifies whether a change to the property causes its containing resource to be replaced instead of updated (default false).
boolean
willReplaceOnChanges
Indicates that the provider will replace the resource when this property is changed.
boolean
secret
Specifies whether the property is secret (default false).
boolean
Resource Definition
Describes a resource or component.
object
All of:
Properties
aliases
The list of aliases for the resource.
array
Items: Alias Definition
deprecationMessage
Indicates whether the resource is deprecated
string
description
The description of the resource, if any. Interpreted as Markdown.
string
inputProperties
A map from property name to propertySpec that describes the resource's input properties.
object
Additional properties: Property Definition
isComponent
Indicates whether the resource is a component.
boolean
isOverlay
Indicates that the implementation of the resource should not be generated from the schema, and is instead provided out-of-band by the package author
boolean
overlaySupportedLanguages
Indicates what languages the overlay supports. This only has an effect if the Resource is an Overlay (IsOverlay == true). Supported values are "nodejs", "python", "go", "csharp", "java", "yaml".
array
Items: string
methods
A map from method name to function token that describes the resource's method set.
object
Additional properties: string
requiredInputs
A list of the names of the resource's required input properties.
array
Items: string
stateInputs
An optional objectTypeSpec that describes additional inputs that mau be necessary to get an existing resource. If this is unset, only an ID is necessary.
Token
string
Pattern: ^[a-zA-Z][-a-zA-Z0-9_]*:([^0-9][a-zA-Z0-9._/-]*)?:[^0-9][a-zA-Z0-9._/]*$
Type Definition
Describes an object or enum type.
object
One of:
Properties
description
The description of the type, if any. Interpreted as Markdown.
string
isOverlay
Indicates that the implementation of the type should not be generated from the schema, and is instead provided out-of-band by the package author
boolean
language
Additional language-specific data about the type.
object
Type Reference
A reference to a type. The particular kind of type referenced is determined based on the contents of the "type" property and the presence or absence of the "additionalProperties", "items", "oneOf", and "$ref" properties.
object
One of:
Properties
plain
Indicates that when used as an input, this type does not accept eventual values.
boolean
Union Type
A reference to a union type. The "oneOf" property must be present. The union may additional specify an underlying primitive type via the "type" property and a discriminator via the "discriminator" property. No other properties may be present.
object
Properties
discriminator
Informs the consumer of an alternative schema based on the value associated with it
object
Properties
mapping
an optional object to hold mappings between payload values and schema names or references
object
Additional properties: string
propertyName
(required)
PropertyName is the name of the property in the payload that will hold the discriminator value
string
oneOf
(required)
If present, indicates that values of the type may be one of any of the listed types
array
Items: Type Reference
type
The underlying primitive type of the union, if any
string
Enum: "boolean"
| "integer"
| "number"
| "string"