Documentation ¶
Index ¶
- Constants
- Variables
- func AddRawValue(r gjson.Result, key string, v interface{}) gjson.Result
- func BuildResources(projects []*Project, projectPtrToUsageMap map[*Project]UsageMap)
- func CalculateCosts(project *Project)
- func MultiplyQuantities(resource *Resource, multiplier decimal.Decimal)
- func ParseAttributes(i interface{}) map[string]gjson.Result
- func SortResources(project *Project)
- type ActualCosts
- type AttributeFilter
- type BlankCoreResource
- type CloudResourceIDFunc
- type CoreResource
- type CoreResourceFunc
- type CoreResourceWithUsageParams
- type CostComponent
- func (c *CostComponent) CalculateCosts()
- func (c *CostComponent) CustomPrice() *decimal.Decimal
- func (c *CostComponent) Price() decimal.Decimal
- func (c *CostComponent) PriceHash() string
- func (c *CostComponent) SetCustomPrice(price *decimal.Decimal)
- func (c *CostComponent) SetPrice(price decimal.Decimal)
- func (c *CostComponent) SetPriceHash(priceHash string)
- func (c *CostComponent) UnitMultiplierHourlyQuantity() *decimal.Decimal
- func (c *CostComponent) UnitMultiplierMonthlyQuantity() *decimal.Decimal
- func (c *CostComponent) UnitMultiplierPrice() decimal.Decimal
- type EstimateFunc
- type PartialResource
- type Policies
- type Policy
- type PriceFilter
- type ProductFilter
- type Project
- func (p *Project) AddProviderMetadata(metadatas []ProviderMetadata)
- func (p *Project) AllPartialResources() []*PartialResource
- func (p *Project) AllResources() []*Resource
- func (p *Project) BuildResources(usageMap UsageMap)
- func (p *Project) CalculateDiff()
- func (p *Project) NameWithWorkspace() string
- type ProjectDiag
- type ProjectMetadata
- func (m *ProjectMetadata) AddError(err error)
- func (m *ProjectMetadata) AddErrorWithCode(err error, code int)
- func (m *ProjectMetadata) GenerateProjectName(remote vcs.Remote, dashboardEnabled bool) string
- func (m *ProjectMetadata) HasErrors() bool
- func (m *ProjectMetadata) IsRunQuotaExceeded() (string, bool)
- func (m *ProjectMetadata) WorkspaceLabel() string
- type Projects
- type Provider
- type ProviderMetadata
- type ReferenceIDFunc
- type RegistryItem
- type Remediater
- type Resource
- type ResourceData
- func (d *ResourceData) AddReference(k string, reference *ResourceData, reverseRefAttrs []string)
- func (d *ResourceData) Get(key string) gjson.Result
- func (d *ResourceData) GetBoolOrDefault(key string, def bool) bool
- func (d *ResourceData) GetFloat64OrDefault(key string, def float64) float64
- func (d *ResourceData) GetInt64OrDefault(key string, def int64) int64
- func (d *ResourceData) GetStringOrDefault(key, def string) string
- func (d *ResourceData) IsEmpty(key string) bool
- func (d *ResourceData) References(keys ...string) []*ResourceData
- func (d *ResourceData) Set(key string, value interface{})
- type ResourceFunc
- type UsageData
- func (u *UsageData) CalcEstimationSummary() map[string]bool
- func (u *UsageData) Copy() *UsageData
- func (u *UsageData) Get(key string) gjson.Result
- func (u *UsageData) GetFloat(key string) *float64
- func (u *UsageData) GetInt(key string) *int64
- func (u *UsageData) GetString(key string) *string
- func (u *UsageData) GetStringArray(key string) *[]string
- func (u *UsageData) IsEmpty(key string) bool
- func (u *UsageData) Merge(other *UsageData) *UsageData
- type UsageItem
- type UsageMap
- type UsageParam
- type UsageVariableType
Constants ¶
const ( DiagJSONParsingFailure = iota + 1 DiagModuleEvaluationFailure DiagTerragruntEvaluationFailure DiagTerragruntModuleEvaluationFailure DiagPrivateModuleDownloadFailure DiagPrivateRegistryModuleDownloadFailure DiagRunQuotaExceeded )
Variables ¶
var ( HourToMonthUnitMultiplier = decimal.NewFromInt(730) MonthToHourUnitMultiplier = decimal.NewFromInt(1).Div(HourToMonthUnitMultiplier) DaysInMonth = HourToMonthUnitMultiplier.DivRound(decimal.NewFromInt(24), 24) DayToMonthUnitMultiplier = DaysInMonth.DivRound(HourToMonthUnitMultiplier, 24) )
Functions ¶
func BuildResources ¶ added in v0.10.14
func CalculateCosts ¶
func CalculateCosts(project *Project)
func MultiplyQuantities ¶ added in v0.7.4
func ParseAttributes ¶ added in v0.7.15
func SortResources ¶
func SortResources(project *Project)
Types ¶
type ActualCosts ¶ added in v0.10.12
type AttributeFilter ¶
type BlankCoreResource ¶ added in v0.10.18
BlankCoreResource is a helper struct for NoPrice and Skipped resources that are evaluated as part of the Policy API. This implements the CoreResource interface and returns a skipped resource that doesn't affect the CLI output.
func (BlankCoreResource) BuildResource ¶ added in v0.10.18
func (b BlankCoreResource) BuildResource() *Resource
func (BlankCoreResource) CoreType ¶ added in v0.10.18
func (b BlankCoreResource) CoreType() string
func (BlankCoreResource) PopulateUsage ¶ added in v0.10.18
func (b BlankCoreResource) PopulateUsage(u *UsageData)
func (BlankCoreResource) UsageSchema ¶ added in v0.10.18
func (b BlankCoreResource) UsageSchema() []*UsageItem
type CloudResourceIDFunc ¶ added in v0.10.13
type CloudResourceIDFunc func(d *ResourceData) []string
CloudResourceIDFunc is used to calculate the cloud resource ids (AWS ARN, Google HREF, etc...) associated with the resource
type CoreResource ¶ added in v0.10.12
type CoreResource interface { CoreType() string UsageSchema() []*UsageItem PopulateUsage(u *UsageData) BuildResource() *Resource }
CoreResource is the new/preferred way to represent provider-agnostic resources that support advanced features such as Infracost Cloud usage estimates and actual costs.
type CoreResourceFunc ¶ added in v0.10.12
type CoreResourceFunc func(*ResourceData) CoreResource
type CoreResourceWithUsageParams ¶ added in v0.10.13
type CoreResourceWithUsageParams interface { CoreResource UsageEstimationParams() []UsageParam }
CoreResourceWithUsageParams is a CoreResource that sends additional parameters (e.g. Lambda memory size) to the Usage API when estimating usage.
type CostComponent ¶
type CostComponent struct { Name string Unit string UnitMultiplier decimal.Decimal // UnitRounding specifies the number of decimal places that the output unit should be rounded to. // This should be set to 0 if using MonthToHourUnitMultiplier otherwise the unit will show with // redundant .000 decimal places. UnitRounding *int32 IgnoreIfMissingPrice bool ProductFilter *ProductFilter PriceFilter *PriceFilter HourlyQuantity *decimal.Decimal MonthlyQuantity *decimal.Decimal MonthlyDiscountPerc float64 HourlyCost *decimal.Decimal MonthlyCost *decimal.Decimal // contains filtered or unexported fields }
func (*CostComponent) CalculateCosts ¶
func (c *CostComponent) CalculateCosts()
func (*CostComponent) CustomPrice ¶ added in v0.9.22
func (c *CostComponent) CustomPrice() *decimal.Decimal
func (*CostComponent) Price ¶
func (c *CostComponent) Price() decimal.Decimal
func (*CostComponent) PriceHash ¶
func (c *CostComponent) PriceHash() string
func (*CostComponent) SetCustomPrice ¶ added in v0.9.22
func (c *CostComponent) SetCustomPrice(price *decimal.Decimal)
func (*CostComponent) SetPrice ¶
func (c *CostComponent) SetPrice(price decimal.Decimal)
func (*CostComponent) SetPriceHash ¶
func (c *CostComponent) SetPriceHash(priceHash string)
func (*CostComponent) UnitMultiplierHourlyQuantity ¶ added in v0.7.0
func (c *CostComponent) UnitMultiplierHourlyQuantity() *decimal.Decimal
func (*CostComponent) UnitMultiplierMonthlyQuantity ¶ added in v0.7.0
func (c *CostComponent) UnitMultiplierMonthlyQuantity() *decimal.Decimal
func (*CostComponent) UnitMultiplierPrice ¶ added in v0.7.0
func (c *CostComponent) UnitMultiplierPrice() decimal.Decimal
type EstimateFunc ¶ added in v0.9.8
EstimateFunc queries cloud providers to gather past usage information, then projects future usage based on the results.
type PartialResource ¶ added in v0.10.12
type PartialResource struct { Type string Address string Tags *map[string]string UsageData *UsageData Metadata map[string]gjson.Result // CoreResource is the new/preferred struct for providing an intermediate-object // that contains all provider-derived information, but has not yet been built into // a Resource. CoreResource CoreResource // Resource field is provided for backward compatibility with provider resource builders // that have not yet been converted to build CoreResource's Resource *Resource // CloudResourceIDs are collected during parsing in case they need to be uploaded to the // Cloud Usage API to be used in the usage estimate calculations. CloudResourceIDs []string }
PartialResource is used to collect all information required to construct a resource that is generated by provider parser and pass it back up to top level functions that can supply additional provider-agnostic information (such as Infracost Cloud usage estimates) before the resource is built.
func NewPartialResource ¶ added in v0.10.33
func NewPartialResource(d *ResourceData, r *Resource, cr CoreResource, cloudResourceIds []string) *PartialResource
type Policy ¶ added in v0.10.14
type Policy struct { ID string `json:"id"` Title string `json:"title"` Description string `json:"description"` ResourceType string `json:"resource_type"` ResourceAttributes json.RawMessage `json:"resource_attributes"` Address string `json:"address"` Suggested string `json:"suggested"` NoCost bool `json:"no_cost"` Cost *decimal.Decimal `json:"cost"` }
type PriceFilter ¶
type PriceFilter struct { PurchaseOption *string `json:"purchaseOption,omitempty"` Unit *string `json:"unit,omitempty"` Description *string `json:"description,omitempty"` DescriptionRegex *string `json:"description_regex,omitempty"` StartUsageAmount *string `json:"startUsageAmount,omitempty"` EndUsageAmount *string `json:"endUsageAmount,omitempty"` TermLength *string `json:"termLength,omitempty"` TermPurchaseOption *string `json:"termPurchaseOption,omitempty"` TermOfferingClass *string `json:"termOfferingClass,omitempty"` }
type ProductFilter ¶
type ProductFilter struct { VendorName *string `json:"vendorName,omitempty"` Service *string `json:"service,omitempty"` ProductFamily *string `json:"productFamily,omitempty"` Region *string `json:"region,omitempty"` Sku *string `json:"sku,omitempty"` AttributeFilters []*AttributeFilter `json:"attributeFilters,omitempty"` }
type Project ¶ added in v0.7.19
type Project struct { Name string Metadata *ProjectMetadata PartialPastResources []*PartialResource PartialResources []*PartialResource PastResources []*Resource Resources []*Resource Diff []*Resource HasDiff bool }
Project contains the existing, planned state of resources and the diff between them.
func NewProject ¶ added in v0.7.19
func NewProject(name string, metadata *ProjectMetadata) *Project
func (*Project) AddProviderMetadata ¶ added in v0.10.25
func (p *Project) AddProviderMetadata(metadatas []ProviderMetadata)
func (*Project) AllPartialResources ¶ added in v0.10.13
func (p *Project) AllPartialResources() []*PartialResource
AllPartialResources returns a pointer list of the current and past partial resources
func (*Project) AllResources ¶ added in v0.7.19
AllResources returns a pointer list of all resources of the state.
func (*Project) BuildResources ¶ added in v0.10.17
BuildResources builds the resources from the partial resources and sets the PastResources and Resources fields.
func (*Project) CalculateDiff ¶ added in v0.7.19
func (p *Project) CalculateDiff()
CalculateDiff calculates the diff of past and current resources
func (*Project) NameWithWorkspace ¶ added in v0.10.13
NameWithWorkspace returns the proect Name appended with the paranenthized workspace name from Metadata if one exists.
type ProjectDiag ¶ added in v0.10.17
type ProjectDiag struct { Code int `json:"code"` Message string `json:"message"` Data interface{} `json:"data"` }
ProjectDiag holds information about all diagnostics associated with a project. This can be both critical or warnings.
func (*ProjectDiag) Error ¶ added in v0.10.20
func (p *ProjectDiag) Error() string
type ProjectMetadata ¶ added in v0.9.0
type ProjectMetadata struct { Path string `json:"path"` Type string `json:"type"` ConfigSha string `json:"configSha,omitempty"` PolicySha string `json:"policySha,omitempty"` PastPolicySha string `json:"pastPolicySha,omitempty"` TerraformModulePath string `json:"terraformModulePath,omitempty"` TerraformWorkspace string `json:"terraformWorkspace,omitempty"` VCSSubPath string `json:"vcsSubPath,omitempty"` VCSCodeChanged *bool `json:"vcsCodeChanged,omitempty"` Errors []ProjectDiag `json:"errors,omitempty"` Warnings []ProjectDiag `json:"warnings,omitempty"` Policies Policies `json:"policies,omitempty"` Providers []ProviderMetadata `json:"providers,omitempty"` RemoteModuleCalls []string `json:"remoteModuleCalls,omitempty"` }
func (*ProjectMetadata) AddError ¶ added in v0.10.17
func (m *ProjectMetadata) AddError(err error)
AddError pushes the provided error onto the metadata list. It does a naive conversion to ProjectDiag if the error provided is not already a diagnostic.
func (*ProjectMetadata) AddErrorWithCode ¶ added in v0.10.20
func (m *ProjectMetadata) AddErrorWithCode(err error, code int)
AddErrorWithCode is the same as AddError except adds a code to the fallback diagnostic.
func (*ProjectMetadata) GenerateProjectName ¶ added in v0.10.10
func (m *ProjectMetadata) GenerateProjectName(remote vcs.Remote, dashboardEnabled bool) string
func (*ProjectMetadata) HasErrors ¶ added in v0.10.17
func (m *ProjectMetadata) HasErrors() bool
func (*ProjectMetadata) IsRunQuotaExceeded ¶ added in v0.10.31
func (m *ProjectMetadata) IsRunQuotaExceeded() (string, bool)
IsRunQuotaExceeded checks if any of the project diags are of type "run quota exceeded". If found it returns the associated message with this diag. This should be used when in any output that notifies the user.
func (*ProjectMetadata) WorkspaceLabel ¶ added in v0.10.4
func (m *ProjectMetadata) WorkspaceLabel() string
type Projects ¶ added in v0.9.23
type Projects []*Project
Projects is a slice of Project that is ordered alphabetically by project name.
type ProviderMetadata ¶ added in v0.10.25
type ReferenceIDFunc ¶ added in v0.9.19
type ReferenceIDFunc func(d *ResourceData) []string
ReferenceIDFunc is used to let references be built using non-standard IDs (anything other than d.Get("id").string)
type RegistryItem ¶
type RegistryItem struct { Name string Notes []string RFunc ResourceFunc CoreRFunc CoreResourceFunc ReferenceAttributes []string CustomRefIDFunc ReferenceIDFunc DefaultRefIDFunc ReferenceIDFunc CloudResourceIDFunc CloudResourceIDFunc NoPrice bool }
type Remediater ¶ added in v0.9.8
type Remediater interface { // Describe provides an English description of the remediation action X that // would fit into a sentence "May we X?" (e.g. "enable bucket metrics"). // The description can be used to prompt the user before taking action. Describe() string // Remediate attempts to fix a problem in the cloud that prevents estimation, // e.g. by enabling metrics collection on certain resources. Remediate() error }
Remediater allows correction of cloud configuration issues so that future runs of Infracost will provide more accurate results.
type Resource ¶
type Resource struct { Name string CostComponents []*CostComponent ActualCosts []*ActualCosts SubResources []*Resource HourlyCost *decimal.Decimal MonthlyCost *decimal.Decimal IsSkipped bool NoPrice bool SkipMessage string ResourceType string Tags *map[string]string UsageSchema []*UsageItem EstimateUsage EstimateFunc EstimationSummary map[string]bool Metadata map[string]gjson.Result }
func AllProjectResources ¶ added in v0.7.19
AllProjectResources returns the resources for all projects
func BuildResource ¶ added in v0.10.12
func BuildResource(partial *PartialResource, fetchedUsage *UsageData) *Resource
BuildResource create a new Resource from the CoreResource, or (for backward compatibility) returns a previously built Resource
func CalculateDiff ¶ added in v0.9.23
CalculateDiff calculates the diff of past and current resources
func (*Resource) CalculateCosts ¶
func (r *Resource) CalculateCosts()
func (*Resource) FlattenedSubResources ¶
func (*Resource) RemoveCostComponent ¶
func (r *Resource) RemoveCostComponent(costComponent *CostComponent)
type ResourceData ¶
type ResourceData struct { Type string ProviderName string Address string Tags *map[string]string RawValues gjson.Result ReferencesMap map[string][]*ResourceData CFResource cloudformation.Resource UsageData *UsageData Metadata map[string]gjson.Result }
func NewCFResourceData ¶ added in v0.9.2
func NewCFResourceData(resourceType string, providerName string, address string, tags *map[string]string, cfResource cloudformation.Resource) *ResourceData
func NewResourceData ¶
func (*ResourceData) AddReference ¶
func (d *ResourceData) AddReference(k string, reference *ResourceData, reverseRefAttrs []string)
func (*ResourceData) GetBoolOrDefault ¶ added in v0.9.19
func (d *ResourceData) GetBoolOrDefault(key string, def bool) bool
func (*ResourceData) GetFloat64OrDefault ¶ added in v0.9.21
func (d *ResourceData) GetFloat64OrDefault(key string, def float64) float64
GetFloat64OrDefault returns the value of key within ResourceData as a float64. If the retrieved value is not set GetFloat64OrDefault will return def.
func (*ResourceData) GetInt64OrDefault ¶ added in v0.9.19
func (d *ResourceData) GetInt64OrDefault(key string, def int64) int64
GetInt64OrDefault returns the value of key within ResourceData as an int64. If the retrieved value is not set GetInt64OrDefault will return def.
func (*ResourceData) GetStringOrDefault ¶ added in v0.9.19
func (d *ResourceData) GetStringOrDefault(key, def string) string
GetStringOrDefault returns the value of key within ResourceData as a string. If the retrieved value is not set GetStringOrDefault will return def.
func (*ResourceData) IsEmpty ¶ added in v0.9.11
func (d *ResourceData) IsEmpty(key string) bool
Return true if the key doesn't exist, is null, or is an empty string. Needed because gjson.Exists returns true as long as a key exists, even if it's empty or null.
func (*ResourceData) References ¶
func (d *ResourceData) References(keys ...string) []*ResourceData
func (*ResourceData) Set ¶
func (d *ResourceData) Set(key string, value interface{})
type ResourceFunc ¶
type ResourceFunc func(*ResourceData, *UsageData) *Resource
type UsageData ¶ added in v0.7.12
func NewUsageData ¶ added in v0.7.12
func (*UsageData) CalcEstimationSummary ¶ added in v0.9.8
CalcEstimationSummary returns a map where a value of true means the attribute key has an actual estimate, false means it is using the defaults
func (*UsageData) GetStringArray ¶ added in v0.9.7
type UsageItem ¶ added in v0.9.11
type UsageItem struct { Key string DefaultValue interface{} Value interface{} ValueType UsageVariableType Description string }
type UsageMap ¶ added in v0.10.18
type UsageMap struct {
// contains filtered or unexported fields
}
UsageMap is a map of address to UsageData built from a usage file. UsageMap is a standalone type so that we can do more involved matching functionality.
func NewUsageMap ¶ added in v0.7.15
NewUsageMap initialises a Usage map with the provided usage key data. It builds a set of wildcard keys if any are found and sorts them ready for searching by Attribute name at a later point.
func NewUsageMapFromInterface ¶ added in v0.10.18
NewUsageMapFromInterface returns an initialised UsageMap from interface map.
func (UsageMap) Get ¶ added in v0.10.18
Get returns UsageData for a given resource address, this can be a combined/merged UsageData from multiple keys. Usage data is merged adhering to the following hierarchy:
- Resource type defaults - e.g. aws_lambda:
- Wildcard specified data - e.g. aws_lambda.my_lambda[*]
- Exact resource data - e.g. aws_lambda.my_lambda["foo"]
Duplicate keys specified between levels are always overwritten by keys specified at a lower level, e.g:
aws_lambda.my_lambda[*]: monthly_requests: 700000000 request_duration_ms: 750 aws_lambda.my_lambda["foo"]: request_duration_ms: 100 << this overwrites the 750 value given in the wildcard usage
If no usage key is found, Get will return nil.
type UsageParam ¶ added in v0.10.13
type UsageVariableType ¶ added in v0.9.2
type UsageVariableType int
const ( Int64 UsageVariableType = iota String Float64 StringArray SubResourceUsage KeyValueMap )