Skip to content

Commit

Permalink
docs: Describe Template methods and fields in comments
Browse files Browse the repository at this point in the history
Also fix spelling of Id() to ID()
  • Loading branch information
UnseenWizzard committed Oct 2, 2023
1 parent e640e31 commit 138f326
Show file tree
Hide file tree
Showing 11 changed files with 37 additions and 21 deletions.
2 changes: 1 addition & 1 deletion pkg/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -149,7 +149,7 @@ func (c *Config) Render(properties map[string]interface{}) (string, error) {
return "", nil
}

templatePath := c.Template.Id()
var templatePath string // include path in errors if we know it
if t, ok := c.Template.(*template.FileBasedTemplate); ok {
templatePath = t.FilePath()
}
Expand Down
8 changes: 6 additions & 2 deletions pkg/config/template/filebased.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,11 +31,13 @@ var (
// FileBasedTemplate is a JSON Template stored in a file - when it's Template.Content is accessed, that file is read.
// This is the usual type of Template monaco uses.
type FileBasedTemplate struct {
fs afero.Fs
// fs is the file system the to read the template file from
fs afero.Fs
// path of the template file
path string
}

func (t *FileBasedTemplate) Id() string {
func (t *FileBasedTemplate) ID() string {
return t.path
}

Expand Down Expand Up @@ -63,6 +65,8 @@ func (t *FileBasedTemplate) UpdateContent(newContent string) error {
return nil
}

// NewFileTemplate creates a FileBasedTemplate for a given afero.Fs and filepath.
// If the file can not be accessed an error will be returned.
func NewFileTemplate(fs afero.Fs, path string) (Template, error) {
sanitizedPath := filepath.Clean(strings.ReplaceAll(path, `\`, `/`))

Expand Down
2 changes: 1 addition & 1 deletion pkg/config/template/filebased_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ func TestLoadTemplate(t *testing.T) {

got, gotErr := template.NewFileTemplate(testFs, testFilepath)
assert.NilError(t, gotErr)
assert.Equal(t, got.Id(), testFilepath)
assert.Equal(t, got.ID(), testFilepath)
assert.Equal(t, got.(*template.FileBasedTemplate).FilePath(), testFilepath)
gotContent, err := got.Content()
assert.NilError(t, err)
Expand Down
16 changes: 14 additions & 2 deletions pkg/config/template/inmemory.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,18 @@ var (
_ Template = (*InMemoryTemplate)(nil)
)

// InMemoryTemplate is a JSON Template created in-memory. This is generally used by downloads and conversions, where
// a Template is created on the fly. Deployments generally use FileBasedTemplate instead.
// An InMemoryTemplate may define a dedicated path to write it to when persisting - converted Template are create with a
// path, download ones are not.
type InMemoryTemplate struct {
id string
content string
path *string
// optional path we'd like this Template to be written to if it's persisted
path *string
}

func (t *InMemoryTemplate) Id() string {
func (t *InMemoryTemplate) ID() string {
return t.id
}

Expand All @@ -39,17 +44,24 @@ func (t *InMemoryTemplate) UpdateContent(newContent string) error {
return nil
}

// FilePath returns the optional path this Template should be written to if it's persisted. If an InMemoryTemplate has
// not defined a path nil will be returned and the file may be persisted anywhere. Generally a converted v1 Template will
// have a defined FilePath, while a downloaded template does not.
func (t *InMemoryTemplate) FilePath() *string {
return t.path
}

// NewInMemoryTemplate creates a new InMemoryTemplate without a dedicated path it should be written to if persisted.
// To create an InMemoryTemplate with a fixed target path, use NewInMemoryTemplateWithPath.
func NewInMemoryTemplate(id, content string) Template {
return &InMemoryTemplate{
id: id,
content: content,
}
}

// NewInMemoryTemplateWithPath creates a new InMemoryTemplate with a dedicated path it should be written to if persisted.
// To create a simple InMemoryTemplate without filepath, use NewInMemoryTemplate.
func NewInMemoryTemplateWithPath(filepath, content string) Template {
return &InMemoryTemplate{
path: &filepath,
Expand Down
8 changes: 4 additions & 4 deletions pkg/config/template/renderer.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,20 +25,20 @@ import (
func Render(template Template, properties map[string]interface{}) (string, error) {
content, err := template.Content()
if err != nil {
return "", fmt.Errorf("failure trying to render template %s: %w", template.Id(), err)
return "", fmt.Errorf("failure trying to render template %s: %w", template.ID(), err)
}

parsedTemplate, err := ParseTemplate(template.Id(), content)
parsedTemplate, err := ParseTemplate(template.ID(), content)

if err != nil {
return "", fmt.Errorf("failure trying to render template %s: %w", template.Id(), err)
return "", fmt.Errorf("failure trying to render template %s: %w", template.ID(), err)
}

result := bytes.Buffer{}

err = parsedTemplate.Execute(&result, properties)
if err != nil {
return "", fmt.Errorf("failure trying to render template %s: %w", template.Id(), err)
return "", fmt.Errorf("failure trying to render template %s: %w", template.ID(), err)
}

return result.String(), nil
Expand Down
8 changes: 4 additions & 4 deletions pkg/config/template/template.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,12 @@ package template
// The main implementation is FileBasedTemplate, which loads its Content from a file on disk. An InMemoryTemplate exists
// as well and is used in cases where Template data is not related to a file - e.g. during download or convert.
type Template interface {
// ID of the template
Id() string
// ID is a unique identifier for this template. It should be usable in user-facing messages.
ID() string

// Content returns the string content of the template, returns error if content is not accessible
// Content returns the string content of the template, returns error if content is not accessible.
Content() (string, error)

// UpdateContent sets the content of the template to the new provided one, returns error if update failed
// UpdateContent sets the content of the template to the new provided one, returns error if update failed.
UpdateContent(newContent string) error
}
2 changes: 1 addition & 1 deletion pkg/delete/delete_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -546,7 +546,7 @@ func TestSplitConfigsForDeletion(t *testing.T) {
},
},
{
name: "Id-fallback",
name: "ID-fallback",
args: args{
entries: []pointer.DeletePointer{{Identifier: "d1"}, {Identifier: "d2-id"}},
values: []dtclient.Value{{Name: "d1", Id: "id1"}, {Name: "d2", Id: "d2-id"}, {Name: "d3", Id: "id3"}},
Expand Down
2 changes: 1 addition & 1 deletion pkg/download/classic/downloader.go
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ func (d *Downloader) createConfigForDownloadedJson(mappedJson map[string]interfa

coord := coordinate.Coordinate{
Project: projectId,
ConfigId: templ.Id(),
ConfigId: templ.ID(),
Type: theApi.ID,
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ func findAndReplaceIDs(apiName string, configToBeUpdated config.Config, c depend
continue // skip self referencing configs
}

log.Debug("\treference: '%v/%v' referencing '%v' in coordinate '%v' ", apiName, configToBeUpdated.Template.Id(), key, conf.Coordinate)
log.Debug("\treference: '%v/%v' referencing '%v' in coordinate '%v' ", apiName, configToBeUpdated.Template.ID(), key, conf.Coordinate)

parameterName := CreateParameterName(conf.Coordinate.Type, conf.Coordinate.ConfigId)
coord := conf.Coordinate
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ func basicFindAndReplaceIDs(apiName string, configToBeUpdated config.Config, con

for key, conf := range configs {
if shouldReplaceReference(configToBeUpdated, conf, content, key) {
log.Debug("\treference: '%v/%v' referencing '%v' in coordinate '%v' ", apiName, configToBeUpdated.Template.Id(), key, conf.Coordinate)
log.Debug("\treference: '%v/%v' referencing '%v' in coordinate '%v' ", apiName, configToBeUpdated.Template.ID(), key, conf.Coordinate)

parameterName := CreateParameterName(conf.Coordinate.Type, conf.Coordinate.ConfigId)
coord := conf.Coordinate
Expand All @@ -80,5 +80,5 @@ func shouldReplaceReference(configToBeUpdated config.Config, configToUpdateFrom
return false //dashboards can not actually reference each other, but often contain a link to another inside a markdown tile
}

return configToUpdateFrom.Template.Id() != configToBeUpdated.Template.Id() && strings.Contains(contentToBeUpdated, keyToReplace)
return configToUpdateFrom.Template.ID() != configToBeUpdated.Template.ID() && strings.Contains(contentToBeUpdated, keyToReplace)
}
4 changes: 2 additions & 2 deletions pkg/persistence/config/writer/config_writer.go
Original file line number Diff line number Diff line change
Expand Up @@ -614,13 +614,13 @@ func extractTemplate(context *detailedSerializerContext, cfg config.Config) (str
}
name = n
} else {
name = sanitize(t.Id()) + ".json"
name = sanitize(t.ID()) + ".json"
path = filepath.Join(context.configFolder, name)
}
case *template.FileBasedTemplate:
path = t.FilePath()
if path == "" {
return "", configTemplate{}, newDetailedConfigWriterError(context.serializerContext, fmt.Errorf("file-based template %q is missing file path - can not write to file", t.Id()))
return "", configTemplate{}, newDetailedConfigWriterError(context.serializerContext, fmt.Errorf("file-based template %q is missing file path - can not write to file", t.ID()))
}
n, err := filepath.Rel(context.configFolder, filepath.Clean(path))
if err != nil {
Expand Down

0 comments on commit 138f326

Please sign in to comment.