mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-04 13:17:43 -06:00
179b32d426
By adding this method you now only have to pass a `*disco.Disco` object around in order to do discovery and use any configured credentials for the discovered hosts. Of course you can also still pass around both a `*disco.Disco` and a `auth.CredentialsSource` object if there is a need or a reason for that!
39 lines
1.2 KiB
Go
39 lines
1.2 KiB
Go
package configload
|
|
|
|
import (
|
|
"github.com/hashicorp/terraform/registry"
|
|
"github.com/hashicorp/terraform/svchost/disco"
|
|
"github.com/spf13/afero"
|
|
)
|
|
|
|
type moduleMgr struct {
|
|
FS afero.Afero
|
|
|
|
// CanInstall is true for a module manager that can support installation.
|
|
//
|
|
// This must be set only if FS is an afero.OsFs, because the installer
|
|
// (which uses go-getter) is not aware of the virtual filesystem
|
|
// abstraction and will always write into the "real" filesystem.
|
|
CanInstall bool
|
|
|
|
// Dir is the path where descendent modules are (or will be) installed.
|
|
Dir string
|
|
|
|
// Services is a service discovery client that will be used to find
|
|
// remote module registry endpoints. This object may be pre-loaded with
|
|
// cached discovery information.
|
|
Services *disco.Disco
|
|
|
|
// Registry is a client for the module registry protocol, which is used
|
|
// when a module is requested from a registry source.
|
|
Registry *registry.Client
|
|
|
|
// manifest tracks the currently-installed modules for this manager.
|
|
//
|
|
// The loader may read this. Only the installer may write to it, and
|
|
// after a set of updates are completed the installer must call
|
|
// writeModuleManifestSnapshot to persist a snapshot of the manifest
|
|
// to disk for use on subsequent runs.
|
|
manifest moduleManifest
|
|
}
|