Files
terraform-docs/format/json.go
Khosrow Moossavi 465dd14cff Make terraform.Module available in content
Add one extra special variable the `content`:

- `{{ .Module }}`

As opposed to the other variables, which are generated sections based on
a selected formatter, the `{{ .Module }}` variable is just a `struct`
representing a Terraform module.

It can be used to build highly complex and highly customized content:

```yaml
content: |-
  ## Resources

  {{ range .Module.Resources }}
  - {{ .GetMode }}.{{ .Spec }} ({{ .Position.Filename }}#{{ .Position.Line }})
  {{- end }}
```

Signed-off-by: Khosrow Moossavi <khos2ow@gmail.com>
2021-10-04 20:01:44 -04:00

60 lines
1.2 KiB
Go

/*
Copyright 2021 The terraform-docs Authors.
Licensed under the MIT license (the "License"); you may not
use this file except in compliance with the License.
You may obtain a copy of the License at the LICENSE file in
the root directory of this source tree.
*/
package format
import (
"bytes"
jsonsdk "encoding/json"
"strings"
"github.com/terraform-docs/terraform-docs/print"
"github.com/terraform-docs/terraform-docs/terraform"
)
// json represents JSON format.
type json struct {
*generator
config *print.Config
}
// NewJSON returns new instance of JSON.
func NewJSON(config *print.Config) Type {
return &json{
generator: newGenerator(config, false),
config: config,
}
}
// Generate a Terraform module as json.
func (j *json) Generate(module *terraform.Module) error {
copy := copySections(j.config, module)
buffer := new(bytes.Buffer)
encoder := jsonsdk.NewEncoder(buffer)
encoder.SetIndent("", " ")
encoder.SetEscapeHTML(j.config.Settings.Escape)
if err := encoder.Encode(copy); err != nil {
return err
}
j.generator.funcs(withContent(strings.TrimSuffix(buffer.String(), "\n")))
return nil
}
func init() {
register(map[string]initializerFn{
"json": NewJSON,
})
}