mirror of https://github.com/pulumi/pulumi.git
145 lines
5.4 KiB
Go
145 lines
5.4 KiB
Go
// Copyright 2016-2018, 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 deploy
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
|
|
"github.com/pulumi/pulumi/pkg/v3/resource/deploy/providers"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource/plugin"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/tokens"
|
|
pulumirpc "github.com/pulumi/pulumi/sdk/v3/proto/go"
|
|
"google.golang.org/protobuf/types/known/emptypb"
|
|
)
|
|
|
|
type ResultState int
|
|
|
|
const (
|
|
ResultStateSuccess ResultState = iota
|
|
ResultStateFailed
|
|
ResultStateSkipped
|
|
)
|
|
|
|
// A ProviderSource allows a Source to lookup provider plugins.
|
|
type ProviderSource interface {
|
|
// GetProvider fetches the provider plugin for the given reference.
|
|
GetProvider(ref providers.Reference) (plugin.Provider, bool)
|
|
}
|
|
|
|
// A Source can generate a new set of resources that the planner will process accordingly.
|
|
type Source interface {
|
|
io.Closer
|
|
|
|
// Project returns the package name of the Pulumi project we are obtaining resources from.
|
|
Project() tokens.PackageName
|
|
// Info returns a serializable payload that can be used to stamp snapshots for future reconciliation.
|
|
Info() interface{}
|
|
|
|
// Iterate begins iterating the source. Error is non-nil upon failure; otherwise, a valid iterator is returned.
|
|
Iterate(ctx context.Context, providers ProviderSource) (SourceIterator, error)
|
|
}
|
|
|
|
// A SourceIterator enumerates the list of resources that a source has to offer and tracks associated state.
|
|
type SourceIterator interface {
|
|
io.Closer
|
|
|
|
// Next returns the next event from the source.
|
|
Next() (SourceEvent, error)
|
|
}
|
|
|
|
// SourceResourceMonitor directs resource operations from the `Source` to various resource
|
|
// providers.
|
|
type SourceResourceMonitor interface {
|
|
// NOTE: This interface does not implement pulumirpc.ResourceMonitorClient because the eval and
|
|
// query implementations of `Source` do not implement precisely the same signatures.
|
|
|
|
Address() string
|
|
Cancel() error
|
|
AbortChan() <-chan bool
|
|
Invoke(ctx context.Context, req *pulumirpc.ResourceInvokeRequest) (*pulumirpc.InvokeResponse, error)
|
|
Call(ctx context.Context, req *pulumirpc.ResourceCallRequest) (*pulumirpc.CallResponse, error)
|
|
ReadResource(ctx context.Context,
|
|
req *pulumirpc.ReadResourceRequest) (*pulumirpc.ReadResourceResponse, error)
|
|
RegisterResource(ctx context.Context,
|
|
req *pulumirpc.RegisterResourceRequest) (*pulumirpc.RegisterResourceResponse, error)
|
|
RegisterResourceOutputs(ctx context.Context,
|
|
req *pulumirpc.RegisterResourceOutputsRequest) (*emptypb.Empty, error)
|
|
}
|
|
|
|
// SourceEvent is an event associated with the enumeration of a plan. It is an intent expressed by the source
|
|
// program, and it is the responsibility of the engine to make it so.
|
|
type SourceEvent interface {
|
|
event()
|
|
}
|
|
|
|
// RegisterResourceEvent is a step that asks the engine to provision a resource.
|
|
type RegisterResourceEvent interface {
|
|
SourceEvent
|
|
// Goal returns the goal state for the resource object that was allocated by the program.
|
|
Goal() *resource.Goal
|
|
// Done indicates that we are done with this step. It must be called to perform cleanup associated with the step.
|
|
Done(result *RegisterResult)
|
|
}
|
|
|
|
// RegisterResult is the state of the resource after it has been registered.
|
|
type RegisterResult struct {
|
|
State *resource.State // the resource state.
|
|
Result ResultState // the result of the registration.
|
|
}
|
|
|
|
// RegisterResourceOutputsEvent is an event that asks the engine to complete the provisioning of a resource.
|
|
type RegisterResourceOutputsEvent interface {
|
|
SourceEvent
|
|
// URN is the resource URN that this completion applies to.
|
|
URN() resource.URN
|
|
// Outputs returns a property map of output properties to add to a resource before completing.
|
|
Outputs() resource.PropertyMap
|
|
// Done indicates that we are done with this step. It must be called to perform cleanup associated with the step.
|
|
Done()
|
|
}
|
|
|
|
// ReadResourceEvent is an event that asks the engine to read the state of an existing resource.
|
|
type ReadResourceEvent interface {
|
|
SourceEvent
|
|
|
|
// ID is the requested ID of this read.
|
|
ID() resource.ID
|
|
// Name is the requested name of this read.
|
|
Name() string
|
|
// Type is type of the resource being read.
|
|
Type() tokens.Type
|
|
// Provider is a reference to the provider instance to use for this read.
|
|
Provider() string
|
|
// Parent is the parent resource of the resource being read.
|
|
Parent() resource.URN
|
|
// Properties is the property bag that will be passed to Read as search parameters.
|
|
Properties() resource.PropertyMap
|
|
// Dependencies returns the list of URNs upon which this read depends.
|
|
Dependencies() []resource.URN
|
|
// Done indicates that we are done with this event.
|
|
Done(result *ReadResult)
|
|
// The names of any additional outputs that should be treated as secrets.
|
|
AdditionalSecretOutputs() []resource.PropertyKey
|
|
// The source position of the resource read
|
|
SourcePosition() string
|
|
}
|
|
|
|
type ReadResult struct {
|
|
State *resource.State
|
|
Result ResultState
|
|
}
|