mirror of
https://github.com/kreuzwerker/terraform-provider-docker.git
synced 2025-12-18 23:06:10 -05:00
* chore: Upgrade golangci-lint to next major version * chore: Add //nolint to new tests --------- Co-authored-by: Martin Wentzel <junker@monoceres.uberspace.de>
130 lines
3.2 KiB
Go
130 lines
3.2 KiB
Go
package provider
|
|
|
|
import (
|
|
"bufio"
|
|
"context"
|
|
"github.com/docker/docker/api/types"
|
|
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"
|
|
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
|
|
)
|
|
|
|
func dataSourceDockerLogs() *schema.Resource {
|
|
return &schema.Resource{
|
|
Description: "`docker_logs` provides logs from specific container",
|
|
|
|
ReadContext: dataSourceDockerLogsRead,
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
"name": {
|
|
Type: schema.TypeString,
|
|
Description: "The name of the Docker Container",
|
|
Required: true,
|
|
},
|
|
"logs_list_string": {
|
|
Type: schema.TypeList,
|
|
Elem: &schema.Schema{Type: schema.TypeString},
|
|
Computed: true,
|
|
Description: "List of container logs, each element is a line.",
|
|
},
|
|
"logs_list_string_enabled": {
|
|
Type: schema.TypeBool,
|
|
Default: true,
|
|
Optional: true,
|
|
Description: "If true populate computed value `logs_list_string`",
|
|
},
|
|
"discard_headers": {
|
|
Type: schema.TypeBool,
|
|
Default: true,
|
|
Optional: true,
|
|
Description: "Discard headers that docker appends to each log entry",
|
|
},
|
|
"show_stdout": {
|
|
Type: schema.TypeBool,
|
|
Default: true,
|
|
Optional: true,
|
|
},
|
|
"show_stderr": {
|
|
Type: schema.TypeBool,
|
|
Default: true,
|
|
Optional: true,
|
|
},
|
|
"since": {
|
|
Type: schema.TypeString,
|
|
Default: "",
|
|
Optional: true,
|
|
},
|
|
"until": {
|
|
Type: schema.TypeString,
|
|
Default: "",
|
|
Optional: true,
|
|
},
|
|
"timestamps": {
|
|
Type: schema.TypeBool,
|
|
Default: false,
|
|
Optional: true,
|
|
},
|
|
"follow": {
|
|
Type: schema.TypeBool,
|
|
Default: false,
|
|
Optional: true,
|
|
},
|
|
"tail": {
|
|
Type: schema.TypeString,
|
|
Default: "",
|
|
Optional: true,
|
|
},
|
|
"details": {
|
|
Type: schema.TypeBool,
|
|
Default: false,
|
|
Optional: true,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func dataSourceDockerLogsRead(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
|
|
client := meta.(*ProviderConfig).DockerClient
|
|
container := d.Get("name").(string)
|
|
d.SetId(container)
|
|
|
|
// call client for logs
|
|
readCloser, err := client.ContainerLogs(ctx, container, types.ContainerLogsOptions{
|
|
ShowStdout: d.Get("show_stdout").(bool),
|
|
ShowStderr: d.Get("show_stderr").(bool),
|
|
Since: d.Get("since").(string),
|
|
Until: d.Get("until").(string),
|
|
Timestamps: d.Get("timestamps").(bool),
|
|
Follow: d.Get("follow").(bool),
|
|
Tail: d.Get("tail").(string),
|
|
Details: d.Get("details").(bool),
|
|
})
|
|
if err != nil {
|
|
return diag.Errorf("dataSourceDockerLogsRead: error while asking for logs %s", err)
|
|
}
|
|
defer readCloser.Close() //nolint:errcheck
|
|
|
|
// see https://github.com/moby/moby/issues/7375#issuecomment-51462963
|
|
discard := d.Get("discard_headers").(bool)
|
|
|
|
// read string lines
|
|
if d.Get("logs_list_string_enabled").(bool) {
|
|
lines := make([]string, 0)
|
|
scanner := bufio.NewScanner(readCloser)
|
|
|
|
// scan each line
|
|
for scanner.Scan() {
|
|
line := scanner.Text()
|
|
if discard {
|
|
line = line[8:]
|
|
}
|
|
lines = append(lines, line)
|
|
}
|
|
|
|
// set string lines
|
|
if err := d.Set("logs_list_string", lines); err != nil {
|
|
return diag.FromErr(err)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|