2023-05-09 08:21:14 +00:00
|
|
|
// Copyright 2016-2023, Pulumi Corporation.
|
2019-04-17 20:48:38 +00:00
|
|
|
//
|
|
|
|
// 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.
|
2021-01-11 18:07:59 +00:00
|
|
|
|
|
|
|
// Package secrets defines the interface common to all secret managers.
|
2019-04-17 20:48:38 +00:00
|
|
|
package secrets
|
|
|
|
|
|
|
|
import (
|
2023-05-09 08:21:14 +00:00
|
|
|
"bytes"
|
2019-09-18 22:52:31 +00:00
|
|
|
"encoding/json"
|
|
|
|
|
2021-03-17 13:20:05 +00:00
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource/config"
|
2019-04-17 20:48:38 +00:00
|
|
|
)
|
|
|
|
|
2019-08-01 17:33:52 +00:00
|
|
|
// Manager provides the interface for providing stack encryption.
|
2019-04-17 20:48:38 +00:00
|
|
|
type Manager interface {
|
2023-05-09 08:21:14 +00:00
|
|
|
// Type returns a string that reflects the type of this provider. This is serialized along with the state of
|
2019-04-17 20:48:38 +00:00
|
|
|
// the manager into the deployment such that we can re-construct the correct manager when deserializing a
|
|
|
|
// deployment into a snapshot.
|
|
|
|
Type() string
|
2023-05-09 08:21:14 +00:00
|
|
|
// An opaque JSON blob, which can be used later to reconstruct the provider when deserializing the
|
|
|
|
// deployment into a snapshot.
|
|
|
|
State() json.RawMessage
|
2019-04-17 20:48:38 +00:00
|
|
|
// Encrypter returns a `config.Encrypter` that can be used to encrypt values when serializing a snapshot into a
|
|
|
|
// deployment, or an error if one can not be constructed.
|
|
|
|
Encrypter() (config.Encrypter, error)
|
|
|
|
// Decrypter returns a `config.Decrypter` that can be used to decrypt values when deserializing a snapshot from a
|
|
|
|
// deployment, or an error if one can not be constructed.
|
|
|
|
Decrypter() (config.Decrypter, error)
|
|
|
|
}
|
2019-09-18 22:52:31 +00:00
|
|
|
|
|
|
|
// AreCompatible returns true if the two Managers are of the same type and have the same state.
|
|
|
|
func AreCompatible(a, b Manager) bool {
|
|
|
|
if a == nil || b == nil {
|
|
|
|
return a == nil && b == nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if a.Type() != b.Type() {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2023-05-09 08:21:14 +00:00
|
|
|
as := a.State()
|
|
|
|
bs := b.State()
|
|
|
|
return bytes.Equal(as, bs)
|
2019-09-18 22:52:31 +00:00
|
|
|
}
|