driftctl/docs/README.md

913 B

Developer guide

This directory contains some documentation about the driftctl codebase, aimed at readers who are interested in making code contributions.

Core concepts

driftctl uses Terraform providers besides cloud providers SDK to retrieve data.

Resource listing is done using cloud providers SDK. Resource details retrieval is done by calling terraform providers with gRPC.

Terminology

  • Scanner is used to scan multiple cloud providers and return a set of resources, it calls all declared Supplier
  • Remote is a representation of a cloud provider
  • Resource is an abstract representation of a cloud provider resource (e.g. S3 bucket, EC2 instance, etc ...)
  • ResourceSupplier is used to list resources from a given type on a given remote and return a resource list, it should exist only one ResourceSupplier per resource