2018-05-22 19:43:36 +00:00
|
|
|
// 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.
|
2018-01-25 02:22:41 +00:00
|
|
|
|
|
|
|
package backend
|
|
|
|
|
|
|
|
import (
|
2023-09-18 11:01:28 +00:00
|
|
|
"github.com/pulumi/pulumi/pkg/v3/display"
|
2021-03-17 13:20:05 +00:00
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/apitype"
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource/config"
|
2018-01-25 02:22:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// UpdateMetadata describes optional metadata about an update.
|
|
|
|
type UpdateMetadata struct {
|
|
|
|
// Message is an optional message associated with the update.
|
|
|
|
Message string `json:"message"`
|
|
|
|
// Environment contains optional data from the deploying environment. e.g. the current
|
|
|
|
// source code control commit information.
|
|
|
|
Environment map[string]string `json:"environment"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateResult is an enum for the result of the update.
|
|
|
|
type UpdateResult string
|
|
|
|
|
|
|
|
const (
|
|
|
|
// InProgressResult is for updates that have not yet completed.
|
2018-11-29 20:54:05 +00:00
|
|
|
InProgressResult UpdateResult = "in-progress"
|
2018-01-25 02:22:41 +00:00
|
|
|
// SucceededResult is for updates that completed successfully.
|
|
|
|
SucceededResult UpdateResult = "succeeded"
|
|
|
|
// FailedResult is for updates that have failed.
|
2018-11-29 20:54:05 +00:00
|
|
|
FailedResult UpdateResult = "failed"
|
2018-01-25 02:22:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Keys we use for values put into UpdateInfo.Environment.
|
|
|
|
const (
|
|
|
|
// GitHead is the commit hash of HEAD.
|
|
|
|
GitHead = "git.head"
|
2018-10-08 18:13:21 +00:00
|
|
|
// GitHeadName is the name of the HEAD ref. e.g. "refs/heads/master" or "refs/tags/v1.0.0".
|
|
|
|
GitHeadName = "git.headName"
|
2019-03-19 18:35:17 +00:00
|
|
|
// GitDirty ("true", "false") indicates if there are any unstaged or modified files in the local repo.
|
2018-01-25 02:22:41 +00:00
|
|
|
GitDirty = "git.dirty"
|
|
|
|
|
2018-05-08 16:58:33 +00:00
|
|
|
// GitCommitter is the name of the person who committed the commit at HEAD.
|
|
|
|
GitCommitter = "git.committer"
|
|
|
|
// GitCommitterEmail is the Email address associated with the committer.
|
|
|
|
GitCommitterEmail = "git.committer.email"
|
|
|
|
// GitAuthor is the name of the person who authored the commit at HEAD.
|
|
|
|
GitAuthor = "git.author"
|
|
|
|
// GitAuthorEmail is the email address associated with the commit's author.
|
|
|
|
GitAuthorEmail = "git.author.email"
|
|
|
|
|
2018-10-23 21:53:52 +00:00
|
|
|
// VCSRepoOwner is the user who owns the local repo, if the origin remote is a cloud host.
|
|
|
|
VCSRepoOwner = "vcs.owner"
|
|
|
|
// VCSRepoName is the name of the repo, if the local git repo's remote origin is a cloud host.
|
|
|
|
VCSRepoName = "vcs.repo"
|
2023-03-03 16:36:39 +00:00
|
|
|
// VCSRepoKind is the cloud host where the repo is hosted.
|
2018-10-23 21:53:52 +00:00
|
|
|
VCSRepoKind = "vcs.kind"
|
2023-06-29 18:41:19 +00:00
|
|
|
// VCSRepoRoot is the root directory of the project in the repo.
|
|
|
|
VCSRepoRoot = "vcs.root"
|
2018-10-23 21:53:52 +00:00
|
|
|
|
2018-08-01 04:38:07 +00:00
|
|
|
// CISystem is the name of the CI system running the pulumi operation.
|
|
|
|
CISystem = "ci.system"
|
2018-08-08 21:12:47 +00:00
|
|
|
// CIBuildID is an opaque ID of the build in the CI system.
|
|
|
|
CIBuildID = "ci.build.id"
|
2020-01-17 18:47:49 +00:00
|
|
|
// CIBuildNumber is a sequentially incrementing number specific for a project/repo.
|
|
|
|
// This value is only set for CI systems that have separate Build ID and a Build Number.
|
|
|
|
// If this value is blank, use `CIBuildID` always.
|
|
|
|
CIBuildNumer = "ci.build.number"
|
2018-08-08 21:12:47 +00:00
|
|
|
// CIBuildType is the type of build of the CI system, e.g. "push", "pull_request", "test_only".
|
|
|
|
CIBuildType = "ci.build.type"
|
|
|
|
// CIBuildURL is a URL to get more information about the particular CI build.
|
|
|
|
CIBuildURL = "ci.build.url"
|
2018-08-01 04:38:07 +00:00
|
|
|
|
|
|
|
// CIPRHeadSHA is the SHA of the HEAD commit of a pull request running on CI. This is needed since the CI
|
|
|
|
// server will run at a different, merge commit. (headSHA merged into the target branch.)
|
|
|
|
CIPRHeadSHA = "ci.pr.headSHA"
|
2019-05-07 18:49:13 +00:00
|
|
|
// CIPRNumber is the PR number, for which the current CI job may be executing.
|
|
|
|
// Combining this information with the `VCSRepoKind` will give us the PR URL.
|
|
|
|
CIPRNumber = "ci.pr.number"
|
2020-08-31 16:07:59 +00:00
|
|
|
|
|
|
|
// ExecutionKind indicates how the update was executed. One of "cli", "auto.local", or "auto.inline".
|
|
|
|
ExecutionKind = "exec.kind"
|
2021-04-30 14:26:23 +00:00
|
|
|
// ExecutionAgent indicates the user agent of the updater for automated scenarios (GHA, Kubernetes Operator).
|
|
|
|
ExecutionAgent = "exec.agent"
|
2022-10-12 16:42:39 +00:00
|
|
|
|
|
|
|
// UpdatePlan ("true", "false") indicates if an explicit update plan was used for the update (either
|
|
|
|
// saving one, or constraining to one).
|
|
|
|
UpdatePlan = "updatePlan"
|
2023-11-21 10:44:45 +00:00
|
|
|
|
|
|
|
// StackEnvironments indicates the list of ESC environments imported by the stack being updated.
|
|
|
|
StackEnvironments = "stack.environments"
|
2018-01-25 02:22:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// UpdateInfo describes a previous update.
|
|
|
|
type UpdateInfo struct {
|
|
|
|
// Information known before an update is started.
|
2018-08-30 00:06:48 +00:00
|
|
|
Kind apitype.UpdateKind `json:"kind"`
|
|
|
|
StartTime int64 `json:"startTime"`
|
2018-03-08 21:56:59 +00:00
|
|
|
|
2018-01-25 02:22:41 +00:00
|
|
|
// Message is an optional message associated with the update.
|
|
|
|
Message string `json:"message"`
|
2018-03-08 21:56:59 +00:00
|
|
|
|
2018-01-25 02:22:41 +00:00
|
|
|
// Environment contains optional data from the deploying environment. e.g. the current
|
|
|
|
// source code control commit information.
|
|
|
|
Environment map[string]string `json:"environment"`
|
|
|
|
|
|
|
|
// Config used for the update.
|
|
|
|
Config config.Map `json:"config"`
|
|
|
|
|
|
|
|
// Information obtained from an update completing.
|
2022-06-27 14:08:06 +00:00
|
|
|
Version int `json:"version"`
|
|
|
|
Result UpdateResult `json:"result"`
|
|
|
|
EndTime int64 `json:"endTime"`
|
|
|
|
ResourceChanges display.ResourceChanges `json:"resourceChanges,omitempty"`
|
2018-01-25 02:22:41 +00:00
|
|
|
}
|