mirror of https://github.com/pulumi/pulumi.git
130 lines
5.4 KiB
Go
130 lines
5.4 KiB
Go
// Copyright 2016-2020, Pulumi Corporation.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package nodejs
|
|
|
|
import (
|
|
"encoding/json"
|
|
|
|
"github.com/pulumi/pulumi/pkg/v3/codegen/schema"
|
|
)
|
|
|
|
// Compatibility mode for Kubernetes 2.0 SDK
|
|
const kubernetes20 = "kubernetes20"
|
|
|
|
// Compatibility mode for tfbridge 2.x SDKs
|
|
const tfbridge20 = "tfbridge20"
|
|
|
|
// NodePackageInfo contains NodeJS-specific information for a package.
|
|
type NodePackageInfo struct {
|
|
// Custom name for the NPM package.
|
|
PackageName string `json:"packageName,omitempty"`
|
|
// Description for the NPM package.
|
|
PackageDescription string `json:"packageDescription,omitempty"`
|
|
// Readme contains the text for the package's README.md files.
|
|
Readme string `json:"readme,omitempty"`
|
|
// NPM dependencies to add to package.json.
|
|
Dependencies map[string]string `json:"dependencies,omitempty"`
|
|
// NPM dev-dependencies to add to package.json.
|
|
DevDependencies map[string]string `json:"devDependencies,omitempty"`
|
|
// NPM peer-dependencies to add to package.json.
|
|
PeerDependencies map[string]string `json:"peerDependencies,omitempty"`
|
|
// NPM resolutions to add to package.json
|
|
Resolutions map[string]string `json:"resolutions,omitempty"`
|
|
// A specific version of TypeScript to include in package.json.
|
|
TypeScriptVersion string `json:"typescriptVersion,omitempty"`
|
|
// A map containing overrides for module names to package names.
|
|
ModuleToPackage map[string]string `json:"moduleToPackage,omitempty"`
|
|
// Toggle compatibility mode for a specified target.
|
|
Compatibility string `json:"compatibility,omitempty"`
|
|
// Disable support for unions in output types.
|
|
DisableUnionOutputTypes bool `json:"disableUnionOutputTypes,omitempty"`
|
|
// An indicator for whether the package contains enums.
|
|
ContainsEnums bool `json:"containsEnums,omitempty"`
|
|
// A map allowing you to map the name of a provider to the name of the module encapsulating the provider.
|
|
ProviderNameToModuleName map[string]string `json:"providerNameToModuleName,omitempty"`
|
|
// Additional files to include in TypeScript compilation.
|
|
// These paths are added to the `files` section of the
|
|
// generated `tsconfig.json`. A typical use case for this is
|
|
// compiling hand-authored unit test files that check the
|
|
// generated code.
|
|
ExtraTypeScriptFiles []string `json:"extraTypeScriptFiles,omitempty"`
|
|
// Determines whether to make single-return-value methods return an output object or the single value.
|
|
LiftSingleValueMethodReturns bool `json:"liftSingleValueMethodReturns,omitempty"`
|
|
|
|
// Respect the Pkg.Version field in the schema
|
|
RespectSchemaVersion bool `json:"respectSchemaVersion,omitempty"`
|
|
|
|
// Experimental flag that permits `import type *` style code
|
|
// to be generated to optimize startup time of programs
|
|
// consuming the provider by minimizing the set of Node
|
|
// modules loaded at startup. Turning this on may currently
|
|
// generate non-compiling code for some providers; but if the
|
|
// code compiles it is safe to use. Also, turning this on
|
|
// requires TypeScript 3.8 or higher to compile the generated
|
|
// code.
|
|
UseTypeOnlyReferences bool `json:"useTypeOnlyReferences,omitempty"`
|
|
}
|
|
|
|
// NodeObjectInfo contains NodeJS-specific information for an object.
|
|
type NodeObjectInfo struct {
|
|
// List of properties that are required on the input side of a type.
|
|
RequiredInputs []string `json:"requiredInputs"`
|
|
// List of properties that are required on the output side of a type.
|
|
RequiredOutputs []string `json:"requiredOutputs"`
|
|
}
|
|
|
|
// Importer implements schema.Language for NodeJS.
|
|
var Importer schema.Language = importer(0)
|
|
|
|
type importer int
|
|
|
|
// ImportDefaultSpec decodes language-specific metadata associated with a DefaultValue.
|
|
func (importer) ImportDefaultSpec(def *schema.DefaultValue, raw json.RawMessage) (interface{}, error) {
|
|
return raw, nil
|
|
}
|
|
|
|
// ImportPropertySpec decodes language-specific metadata associated with a Property.
|
|
func (importer) ImportPropertySpec(property *schema.Property, raw json.RawMessage) (interface{}, error) {
|
|
return raw, nil
|
|
}
|
|
|
|
// ImportObjectTypeSpec decodes language-specific metadata associated with a ObjectType.
|
|
func (importer) ImportObjectTypeSpec(object *schema.ObjectType, raw json.RawMessage) (interface{}, error) {
|
|
var info NodeObjectInfo
|
|
if err := json.Unmarshal([]byte(raw), &info); err != nil {
|
|
return nil, err
|
|
}
|
|
return info, nil
|
|
}
|
|
|
|
// ImportResourceSpec decodes language-specific metadata associated with a Resource.
|
|
func (importer) ImportResourceSpec(resource *schema.Resource, raw json.RawMessage) (interface{}, error) {
|
|
return raw, nil
|
|
}
|
|
|
|
// ImportFunctionSpec decodes language-specific metadata associated with a Function.
|
|
func (importer) ImportFunctionSpec(function *schema.Function, raw json.RawMessage) (interface{}, error) {
|
|
return raw, nil
|
|
}
|
|
|
|
// ImportPackageSpec decodes language-specific metadata associated with a Package.
|
|
func (importer) ImportPackageSpec(pkg *schema.Package, raw json.RawMessage) (interface{}, error) {
|
|
var info NodePackageInfo
|
|
if err := json.Unmarshal([]byte(raw), &info); err != nil {
|
|
return nil, err
|
|
}
|
|
return info, nil
|
|
}
|